Commit 5acc784d authored by Bram Schoenmakers's avatar Bram Schoenmakers

Another attempt to handle subcommands, arguments and defaults.

parent 2d6925a0
...@@ -165,11 +165,6 @@ class CLIApplication(object): ...@@ -165,11 +165,6 @@ class CLIApplication(object):
todofile = TodoFile.TodoFile(self.path) todofile = TodoFile.TodoFile(self.path)
self.todolist = TodoList.TodoList(todofile.read()) self.todolist = TodoList.TodoList(todofile.read())
try:
subcommand = args[0]
except IndexError:
subcommand = self.config.default_command()
subcommand_map = { subcommand_map = {
'add': AddCommand, 'add': AddCommand,
'app': AppendCommand, 'app': AppendCommand,
...@@ -194,10 +189,26 @@ class CLIApplication(object): ...@@ -194,10 +189,26 @@ class CLIApplication(object):
'tag': TagCommand, 'tag': TagCommand,
} }
if not subcommand in subcommand_map: try:
subcommand = args[0]
if subcommand in subcommand_map:
subcommand = subcommand_map[subcommand]
if len(args) > 1:
args = args[1:]
else:
subcommand = self.config.default_command()
if subcommand in subcommand_map:
subcommand = subcommand_map[subcommand]
# leave args unchanged
else:
usage()
except IndexError:
subcommand = self.config.default_command() subcommand = self.config.default_command()
else: if subcommand in subcommand_map:
args.pop(0) subcommand = subcommand_map[subcommand]
else:
usage()
if self.execute(subcommand_map[subcommand], args) == False: if self.execute(subcommand_map[subcommand], args) == False:
exit(1) exit(1)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment