提交 fb75e317 编写于 作者: J Junio C Hamano

Merge branch 'cw/tag-reflog-message'

"git tag" did not leave useful message when adding a new entry to
reflog; this was left unnoticed for a long time because refs/tags/*
doesn't keep reflog by default.

* cw/tag-reflog-message:
  tag: generate useful reflog message
...@@ -302,6 +302,54 @@ static void create_tag(const unsigned char *object, const char *tag, ...@@ -302,6 +302,54 @@ static void create_tag(const unsigned char *object, const char *tag,
} }
} }
static void create_reflog_msg(const unsigned char *sha1, struct strbuf *sb)
{
enum object_type type;
struct commit *c;
char *buf;
unsigned long size;
int subject_len = 0;
const char *subject_start;
char *rla = getenv("GIT_REFLOG_ACTION");
if (rla) {
strbuf_addstr(sb, rla);
} else {
strbuf_addstr(sb, _("tag: tagging "));
strbuf_add_unique_abbrev(sb, sha1, DEFAULT_ABBREV);
}
strbuf_addstr(sb, " (");
type = sha1_object_info(sha1, NULL);
switch (type) {
default:
strbuf_addstr(sb, _("object of unknown type"));
break;
case OBJ_COMMIT:
if ((buf = read_sha1_file(sha1, &type, &size)) != NULL) {
subject_len = find_commit_subject(buf, &subject_start);
strbuf_insert(sb, sb->len, subject_start, subject_len);
} else {
strbuf_addstr(sb, _("commit object"));
}
free(buf);
if ((c = lookup_commit_reference(sha1)) != NULL)
strbuf_addf(sb, ", %s", show_date(c->date, 0, DATE_MODE(SHORT)));
break;
case OBJ_TREE:
strbuf_addstr(sb, _("tree object"));
break;
case OBJ_BLOB:
strbuf_addstr(sb, _("blob object"));
break;
case OBJ_TAG:
strbuf_addstr(sb, _("other tag object"));
break;
}
strbuf_addch(sb, ')');
}
struct msg_arg { struct msg_arg {
int given; int given;
struct strbuf buf; struct strbuf buf;
...@@ -335,6 +383,7 @@ int cmd_tag(int argc, const char **argv, const char *prefix) ...@@ -335,6 +383,7 @@ int cmd_tag(int argc, const char **argv, const char *prefix)
{ {
struct strbuf buf = STRBUF_INIT; struct strbuf buf = STRBUF_INIT;
struct strbuf ref = STRBUF_INIT; struct strbuf ref = STRBUF_INIT;
struct strbuf reflog_msg = STRBUF_INIT;
unsigned char object[20], prev[20]; unsigned char object[20], prev[20];
const char *object_ref, *tag; const char *object_ref, *tag;
struct create_tag_options opt; struct create_tag_options opt;
...@@ -496,6 +545,8 @@ int cmd_tag(int argc, const char **argv, const char *prefix) ...@@ -496,6 +545,8 @@ int cmd_tag(int argc, const char **argv, const char *prefix)
else else
die(_("Invalid cleanup mode %s"), cleanup_arg); die(_("Invalid cleanup mode %s"), cleanup_arg);
create_reflog_msg(object, &reflog_msg);
if (create_tag_object) { if (create_tag_object) {
if (force_sign_annotate && !annotate) if (force_sign_annotate && !annotate)
opt.sign = 1; opt.sign = 1;
...@@ -506,7 +557,7 @@ int cmd_tag(int argc, const char **argv, const char *prefix) ...@@ -506,7 +557,7 @@ int cmd_tag(int argc, const char **argv, const char *prefix)
if (!transaction || if (!transaction ||
ref_transaction_update(transaction, ref.buf, object, prev, ref_transaction_update(transaction, ref.buf, object, prev,
create_reflog ? REF_FORCE_CREATE_REFLOG : 0, create_reflog ? REF_FORCE_CREATE_REFLOG : 0,
NULL, &err) || reflog_msg.buf, &err) ||
ref_transaction_commit(transaction, &err)) ref_transaction_commit(transaction, &err))
die("%s", err.buf); die("%s", err.buf);
ref_transaction_free(transaction); ref_transaction_free(transaction);
...@@ -516,5 +567,6 @@ int cmd_tag(int argc, const char **argv, const char *prefix) ...@@ -516,5 +567,6 @@ int cmd_tag(int argc, const char **argv, const char *prefix)
strbuf_release(&err); strbuf_release(&err);
strbuf_release(&buf); strbuf_release(&buf);
strbuf_release(&ref); strbuf_release(&ref);
strbuf_release(&reflog_msg);
return 0; return 0;
} }
...@@ -81,9 +81,25 @@ test_expect_success 'creating a tag using default HEAD should succeed' ' ...@@ -81,9 +81,25 @@ test_expect_success 'creating a tag using default HEAD should succeed' '
' '
test_expect_success 'creating a tag with --create-reflog should create reflog' ' test_expect_success 'creating a tag with --create-reflog should create reflog' '
git log -1 \
--format="format:tag: tagging %h (%s, %cd)%n" \
--date=format:%Y-%m-%d >expected &&
test_when_finished "git tag -d tag_with_reflog" && test_when_finished "git tag -d tag_with_reflog" &&
git tag --create-reflog tag_with_reflog && git tag --create-reflog tag_with_reflog &&
git reflog exists refs/tags/tag_with_reflog git reflog exists refs/tags/tag_with_reflog &&
sed -e "s/^.* //" .git/logs/refs/tags/tag_with_reflog >actual &&
test_cmp expected actual
'
test_expect_success 'annotated tag with --create-reflog has correct message' '
git log -1 \
--format="format:tag: tagging %h (%s, %cd)%n" \
--date=format:%Y-%m-%d >expected &&
test_when_finished "git tag -d tag_with_reflog" &&
git tag -m "annotated tag" --create-reflog tag_with_reflog &&
git reflog exists refs/tags/tag_with_reflog &&
sed -e "s/^.* //" .git/logs/refs/tags/tag_with_reflog >actual &&
test_cmp expected actual
' '
test_expect_success '--create-reflog does not create reflog on failure' ' test_expect_success '--create-reflog does not create reflog on failure' '
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册