builtin/notes: fix premature failure when trying to add the empty blob
authorJohan Herland <johan@herland.net>
Sun, 9 Nov 2014 12:30:47 +0000 (13:30 +0100)
committerJunio C Hamano <gitster@pobox.com>
Mon, 10 Nov 2014 20:08:20 +0000 (12:08 -0800)
This fixes a small buglet when trying to explicitly add the empty blob
as a note object using the -c or -C option to git notes add/append.
Instead of failing with a nonsensical error message indicating that the
empty blob does not exist, we should rather behave as if an empty notes
message was given (e.g. using -m "" or -F /dev/null).

The next patch contains a test that verifies the fixed behavior.

Found-by: Eric Sunshine <sunshine@sunshineco.com>
Signed-off-by: Johan Herland <johan@herland.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/notes.c
index 68b6cd8cc1ded390df592e1c6536d70bf1ffc8a0..9ee681688871fd1f3d9628ed7f8cda9b96d77d80 100644 (file)
@@ -266,7 +266,7 @@ static int parse_reuse_arg(const struct option *opt, const char *arg, int unset)
 
        if (get_sha1(arg, object))
                die(_("Failed to resolve '%s' as a valid ref."), arg);
-       if (!(buf = read_sha1_file(object, &type, &len)) || !len) {
+       if (!(buf = read_sha1_file(object, &type, &len))) {
                free(buf);
                die(_("Failed to read object '%s'."), arg);
        }