Browse Source

builtin/notes: simplify early exit code in add()

Remove the need for 'retval' and the unnecessary goto. Also reorganize
to only call free_note_data() is actually needed.

Improved-by: Junio C Hamano <gitster@pobox.com>
Signed-off-by: Johan Herland <johan@herland.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Johan Herland 10 years ago committed by Junio C Hamano
parent
commit
b0de56c6a5
  1. 35
      builtin/notes.c

35
builtin/notes.c

@ -399,7 +399,7 @@ static int append_edit(int argc, const char **argv, const char *prefix);


static int add(int argc, const char **argv, const char *prefix) static int add(int argc, const char **argv, const char *prefix)
{ {
int retval = 0, force = 0; int force = 0;
const char *object_ref; const char *object_ref;
struct notes_tree *t; struct notes_tree *t;
unsigned char object[20], new_note[20]; unsigned char object[20], new_note[20];
@ -441,23 +441,23 @@ static int add(int argc, const char **argv, const char *prefix)


if (note) { if (note) {
if (!force) { if (!force) {
if (!d.given) { free_notes(t);
/* if (d.given) {
* Redirect to "edit" subcommand.
*
* We only end up here if none of -m/-F/-c/-C
* or -f are given. The original args are
* therefore still in argv[0-1].
*/
argv[0] = "edit";
free_note_data(&d); free_note_data(&d);
free_notes(t); return error(_("Cannot add notes. "
return append_edit(argc, argv, prefix); "Found existing notes for object %s. "
"Use '-f' to overwrite existing notes"),
sha1_to_hex(object));
} }
retval = error(_("Cannot add notes. Found existing notes " /*
"for object %s. Use '-f' to overwrite " * Redirect to "edit" subcommand.
"existing notes"), sha1_to_hex(object)); *
goto out; * We only end up here if none of -m/-F/-c/-C or -f are
* given. The original args are therefore still in
* argv[0-1].
*/
argv[0] = "edit";
return append_edit(argc, argv, prefix);
} }
fprintf(stderr, _("Overwriting existing notes for object %s\n"), fprintf(stderr, _("Overwriting existing notes for object %s\n"),
sha1_to_hex(object)); sha1_to_hex(object));
@ -474,9 +474,8 @@ static int add(int argc, const char **argv, const char *prefix)
snprintf(logmsg, sizeof(logmsg), "Notes %s by 'git notes %s'", snprintf(logmsg, sizeof(logmsg), "Notes %s by 'git notes %s'",
is_null_sha1(new_note) ? "removed" : "added", "add"); is_null_sha1(new_note) ? "removed" : "added", "add");
commit_notes(t, logmsg); commit_notes(t, logmsg);
out:
free_notes(t); free_notes(t);
return retval; return 0;
} }


static int copy(int argc, const char **argv, const char *prefix) static int copy(int argc, const char **argv, const char *prefix)

Loading…
Cancel
Save