summaryrefslogtreecommitdiffstats
path: root/scripts/devtool
diff options
context:
space:
mode:
authorPaul Eggleton <paul.eggleton@linux.intel.com>2016-02-19 22:38:53 +1300
committerRichard Purdie <richard.purdie@linuxfoundation.org>2016-02-21 09:32:42 +0000
commit32ef52389833a8b8dfb63444ace6561bb0ac741c (patch)
tree59f597df4ce685609706c7db90ee0eb654b044a5 /scripts/devtool
parent9f7df76eb49eac1ec7627061a8219e5d0b052034 (diff)
downloadpoky-32ef52389833a8b8dfb63444ace6561bb0ac741c.tar.gz
devtool: categorise and order subcommands in help output
The listing of subcommands in the --help output for devtool was starting to get difficult to follow, with commands appearing in no particular order (due to some being in separate modules and the order of those modules being parsed). Logically grouping the subcommands as well as being able to exercise some control over the order of the subcommands and groups would help, if we do so without losing the dynamic nature of the list (i.e. that it comes from the plugins). Argparse provides no built-in way to handle this and really, really makes it a pain to add, but with some subclassing and hacking it's now possible, and can be extended by any plugin as desired. To put a subcommand into a group, all you need to do is specify a group= parameter in the call to subparsers.add_parser(). you can also specify an order= parameter to make the subcommand sort higher or lower in the list (higher order numbers appear first, so use negative numbers to force items to the end if that's what you want). To add a new group, use subparsers.add_subparser_group(), supplying the name, description and optionally an order number for the group itself (again, higher numbers appear first). (From OE-Core rev: e1b9d31e6ea3c254ecfe940fe795af44761e0e69) Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'scripts/devtool')
-rwxr-xr-xscripts/devtool10
1 files changed, 9 insertions, 1 deletions
diff --git a/scripts/devtool b/scripts/devtool
index 23e9b50074..06e91b7591 100755
--- a/scripts/devtool
+++ b/scripts/devtool
@@ -275,10 +275,18 @@ def main():
275 275
276 subparsers = parser.add_subparsers(dest="subparser_name", title='subcommands', metavar='<subcommand>') 276 subparsers = parser.add_subparsers(dest="subparser_name", title='subcommands', metavar='<subcommand>')
277 277
278 subparsers.add_subparser_group('sdk', 'SDK maintenance', -2)
279 subparsers.add_subparser_group('advanced', 'Advanced', -1)
280 subparsers.add_subparser_group('starting', 'Beginning work on a recipe', 100)
281 subparsers.add_subparser_group('info', 'Getting information')
282 subparsers.add_subparser_group('working', 'Working on a recipe in the workspace')
283 subparsers.add_subparser_group('testbuild', 'Testing changes on target')
284
278 if not context.fixed_setup: 285 if not context.fixed_setup:
279 parser_create_workspace = subparsers.add_parser('create-workspace', 286 parser_create_workspace = subparsers.add_parser('create-workspace',
280 help='Set up workspace in an alternative location', 287 help='Set up workspace in an alternative location',
281 description='Sets up a new workspace. NOTE: other devtool subcommands will create a workspace automatically as needed, so you only need to use %(prog)s if you want to specify where the workspace should be located.') 288 description='Sets up a new workspace. NOTE: other devtool subcommands will create a workspace automatically as needed, so you only need to use %(prog)s if you want to specify where the workspace should be located.',
289 group='advanced')
282 parser_create_workspace.add_argument('layerpath', nargs='?', help='Path in which the workspace layer should be created') 290 parser_create_workspace.add_argument('layerpath', nargs='?', help='Path in which the workspace layer should be created')
283 parser_create_workspace.add_argument('--create-only', action="store_true", help='Only create the workspace layer, do not alter configuration') 291 parser_create_workspace.add_argument('--create-only', action="store_true", help='Only create the workspace layer, do not alter configuration')
284 parser_create_workspace.set_defaults(func=create_workspace, no_workspace=True) 292 parser_create_workspace.set_defaults(func=create_workspace, no_workspace=True)