notes: rework subcommands and parse options
commit74884b524e7e12b3419264d3180de785a9e39fa5
authorStephen Boyd <bebarino@gmail.com>
Sat, 27 Feb 2010 08:59:22 +0000 (27 00:59 -0800)
committerJunio C Hamano <gitster@pobox.com>
Sat, 13 Mar 2010 06:09:18 +0000 (12 22:09 -0800)
treef6552409c466066c148caaadedf51f6be4f94b12
parent66d681998411e8e5034080d5267a5e0f6cdc0c17
notes: rework subcommands and parse options

Running 'git notes copy -h' is not very helfpul right now. It lists
the options for all the git notes subcommands and is rather confusing.
Fix this by splitting cmd_notes() into separate functions for each
subcommand (besides append and edit since they're very similar) and
only providing a usage message for the subcommand.

This has an added benefit of reducing the code complexity while making
it safer and easier to read. The downside is we get some code bloat
from similar setup and teardown needed for notes and options parsing.
We also get a bit stricter in options parsing by only allowing
the ref option to come before the subcommand.

Acked-by: Johan Herland <johan@herland.net>
Cc: Thomas Rast <trast@student.ethz.ch>
Signed-off-by: Stephen Boyd <bebarino@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin-notes.c
t/t3301-notes.sh