diff options
author | Junio C Hamano <gitster@pobox.com> | 2007-11-14 14:06:09 -0800 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2007-11-14 14:06:09 -0800 |
commit | ef4de8357dff57d403073572e8b260618bd03175 (patch) | |
tree | 3cdea53d0ba735b71cefe8b5c4e0af9e34ca0988 | |
parent | 5e389c430d232e8b1a16e7357596328985111eab (diff) | |
parent | 4d8b1dc850bafdf2304a525a768fbfc7aa5361ae (diff) | |
download | git-ef4de8357dff57d403073572e8b260618bd03175.tar.gz git-ef4de8357dff57d403073572e8b260618bd03175.tar.xz |
Merge branch 'mh/retag'
* mh/retag:
Add tests for git tag
Reuse previous annotation when overwriting a tag
-rw-r--r-- | builtin-tag.c | 38 | ||||
-rwxr-xr-x | t/t7004-tag.sh | 16 |
2 files changed, 51 insertions, 3 deletions
diff --git a/builtin-tag.c b/builtin-tag.c index 4aca3dc79..cbb0f04e8 100644 --- a/builtin-tag.c +++ b/builtin-tag.c @@ -246,9 +246,37 @@ static int git_tag_config(const char *var, const char *value) return git_default_config(var, value); } +static void write_tag_body(int fd, const unsigned char *sha1) +{ + unsigned long size; + enum object_type type; + char *buf, *sp, *eob; + size_t len; + + buf = read_sha1_file(sha1, &type, &size); + if (!buf) + return; + /* skip header */ + sp = strstr(buf, "\n\n"); + + if (!sp || !size || type != OBJ_TAG) { + free(buf); + return; + } + sp += 2; /* skip the 2 LFs */ + eob = strstr(sp, "\n" PGP_SIGNATURE "\n"); + if (eob) + len = eob - sp; + else + len = buf + size - sp; + write_or_die(fd, sp, len); + + free(buf); +} + static void create_tag(const unsigned char *object, const char *tag, struct strbuf *buf, int message, int sign, - unsigned char *result) + unsigned char *prev, unsigned char *result) { enum object_type type; char header_buf[1024]; @@ -281,7 +309,11 @@ static void create_tag(const unsigned char *object, const char *tag, if (fd < 0) die("could not create file '%s': %s", path, strerror(errno)); - write_or_die(fd, tag_template, strlen(tag_template)); + + if (!is_null_sha1(prev)) + write_tag_body(fd, prev); + else + write_or_die(fd, tag_template, strlen(tag_template)); close(fd); launch_editor(path, buf); @@ -418,7 +450,7 @@ int cmd_tag(int argc, const char **argv, const char *prefix) die("tag '%s' already exists", tag); if (annotate) - create_tag(object, tag, &buf, message, sign, object); + create_tag(object, tag, &buf, message, sign, prev, object); lock = lock_any_ref_for_update(ref, prev, 0); if (!lock) diff --git a/t/t7004-tag.sh b/t/t7004-tag.sh index 0d07bc39c..096fe33b0 100755 --- a/t/t7004-tag.sh +++ b/t/t7004-tag.sh @@ -1004,4 +1004,20 @@ test_expect_failure \ 'verify signed tag fails when public key is not present' \ 'git-tag -v signed-tag' +test_expect_success \ + 'message in editor has initial comment' ' + GIT_EDITOR=cat git tag -a initial-comment > actual || true && + test $(sed -n "/^\(#\|\$\)/p" actual | wc -l) -gt 0 +' + +get_tag_header reuse $commit commit $time >expect +echo "An annotation to be reused" >> expect +test_expect_success \ + 'overwriting an annoted tag should use its previous body' ' + git tag -a -m "An annotation to be reused" reuse && + GIT_EDITOR=true git tag -f -a reuse && + get_tag_msg reuse >actual && + git diff expect actual +' + test_done |