X-Git-Url: https://projects.mako.cc/source/mw/blobdiff_plain/fb328c2757462c9a7ea8ee85075b5c1b68e5d396..3ec21f92ccc70c2283d15506dc0384e5442deee2:/src/mw/cli.py diff --git a/src/mw/cli.py b/src/mw/cli.py index 7f5b4bc..d5dd6dc 100644 --- a/src/mw/cli.py +++ b/src/mw/cli.py @@ -21,11 +21,13 @@ import inspect import mw.clicommands import os import sys +from pprint import pprint class CLI(object): def __init__(self): self.me = os.path.basename(sys.argv[0]) self.commands = {} + self.shortcuts = {} for name in mw.clicommands.__dict__: if name == 'CommandBase': continue @@ -34,20 +36,30 @@ class CLI(object): issubclass(clazz, mw.clicommands.CommandBase): cmd = clazz() self.commands[cmd.name] = cmd + self.shortcuts[cmd.name] = cmd.shortcuts + self.all_commands = {} + self.all_commands.update(self.commands) + for command in self.shortcuts: + for shortcut in self.shortcuts[command]: + self.all_commands[shortcut] = self.commands[command] def usage(self): print 'usage: %s [subcommand]' % self.me print for name in self.commands: cmd = self.commands[name] - print("\t%-14s %-25s" % (name, cmd.description)) + if len(cmd.shortcuts) > 0: + full = name + ' (' + ' '.join(cmd.shortcuts) + ')' + else: + full = name + print("\t%-14s %-25s" % (full, cmd.description)) print sys.exit(1) def main(self): # determine what the subcommand is if len(sys.argv) > 1: - if sys.argv[1] in self.commands.keys(): + if sys.argv[1] in self.all_commands: the_command = sys.argv[1] # SWEET ACTION elif sys.argv[1] in ['--help', '-h']: self.usage() @@ -57,4 +69,4 @@ class CLI(object): if len(sys.argv) == 1: self.usage() # woo let's go - self.commands[the_command].main() + self.all_commands[the_command].main()