Commit c0d76274 authored by Bram Schoenmakers's avatar Bram Schoenmakers

When the default subcommand is invoked, make sure that all arguments

are passed to that subcommand.

This is achieved by overriding the start position of where to take the
arguments in argv.
parent bd9e298e
...@@ -21,13 +21,16 @@ def usage(): ...@@ -21,13 +21,16 @@ def usage():
""" Prints the usage of the todo.txt CLI """ """ Prints the usage of the todo.txt CLI """
exit(1) exit(1)
def arguments(): def arguments(p_start=2):
""" """
Retrieves all values from the argument list starting from the given Retrieves all values from the argument list starting from the given
position. position.
This is a parameter, because argv has a different structure when no
subcommand was given and it fallbacks to the default subcommand.
""" """
try: try:
values = sys.argv[2:] # strip off subcommand at position 1 values = sys.argv[p_start:]
except IndexError: except IndexError:
usage() usage()
...@@ -69,16 +72,18 @@ class CLIApplication(object): ...@@ -69,16 +72,18 @@ class CLIApplication(object):
'pri': PriorityCommand, 'pri': PriorityCommand,
} }
if subcommand in subcommand_map: args = arguments()
command = subcommand_map[subcommand](arguments(), self.todolist, if not subcommand in subcommand_map:
lambda o: sys.stdout.write(o + "\n"), subcommand = Config.DEFAULT_ACTION
lambda e: sys.stderr.write(e + "\n"), args = arguments(1)
raw_input)
command = subcommand_map[subcommand](args, self.todolist,
lambda o: sys.stdout.write(o + "\n"),
lambda e: sys.stderr.write(e + "\n"),
raw_input)
if not command.execute(): if not command.execute():
exit(1) exit(1)
else:
usage()
if self.todolist.is_dirty(): if self.todolist.is_dirty():
todofile.write(str(self.todolist)) todofile.write(str(self.todolist))
......
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