|
|
%!s(int64=2) %!d(string=hai) anos | |
|---|---|---|
| .. | ||
| hint_modules | %!s(int64=2) %!d(string=hai) anos | |
| README.md | %!s(int64=6) %!d(string=hai) anos | |
| __init__.py | %!s(int64=6) %!d(string=hai) anos | |
| constants.py | %!s(int64=2) %!d(string=hai) anos | |
| core_ext.py | %!s(int64=2) %!d(string=hai) anos | |
| create_ext.py | %!s(int64=2) %!d(string=hai) anos | |
| debug_ext.py | %!s(int64=2) %!d(string=hai) anos | |
| dfu_ext.py | %!s(int64=3) %!d(string=hai) anos | |
| errors.py | %!s(int64=3) %!d(string=hai) anos | |
| global_options.py | %!s(int64=3) %!d(string=hai) anos | |
| hints.yml | %!s(int64=2) %!d(string=hai) anos | |
| roms.json | %!s(int64=2) %!d(string=hai) anos | |
| roms_schema.json | %!s(int64=3) %!d(string=hai) anos | |
| serial_ext.py | %!s(int64=2) %!d(string=hai) anos | |
| tools.py | %!s(int64=2) %!d(string=hai) anos | |
| uf2_ext.py | %!s(int64=2) %!d(string=hai) anos | |
Python modules (subdirectories and files) in this directory named [your_extension]_ext will be loaded as idf.py extensions.
If you want to provide extra extensions just provide ; separated list of directories with extensions in IDF_EXTRA_ACTIONS_PATH. Extensions will be loaded in alphanumeric order.
Command line arguments parsing and extension mechanism is implemented on top of Click (versions >=5.0 are supported).
They should define a function action_extensions(base_actions, project_path) where:
os.getcwd()This function have to return a dict with 3 possible keys:
{
# Additional options that will be available from id
"global_options": [{
"names": ["--option-name"],
"help": "Help for option --option-name.",
}],
# List of functions that will have access to full app context, and can mangle with arguments
"global_action_callbacks": [global_callback],
# Additional subcommands for idf.py
"actions": {
"subcommand_name": {
"callback": subcommand_callback,
"help": "Help for subcommand.",
},
},
}
Where function global_callback(ctx, global_args, tasks) accepts 3 arguments:
And subcommand_callback(subcommand_name, ctx, args) accepts 3 arguments: