* [PATCH] git show <tag>: show the tagger
@ 2007-12-18 18:01 Johannes Schindelin
2007-12-18 20:10 ` Junio C Hamano
2007-12-19 9:11 ` Andreas Ericsson
0 siblings, 2 replies; 4+ messages in thread
From: Johannes Schindelin @ 2007-12-18 18:01 UTC (permalink / raw)
To: git, gitster
For commit objects, the Author is shown, so do the equivalent for
tag objects, too.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
---
I know, it's feature freeze period. But this is arguably a
usability bug.
Well, it's not _that_ serious, so it could wait for 2.0.0, too ;-)
builtin-log.c | 39 ++++++++++++++++++++++++++++++++-------
1 files changed, 32 insertions(+), 7 deletions(-)
diff --git a/builtin-log.c b/builtin-log.c
index cc3cc90..c2ad863 100644
--- a/builtin-log.c
+++ b/builtin-log.c
@@ -244,7 +244,29 @@ int cmd_whatchanged(int argc, const char **argv, const char *prefix)
return cmd_log_walk(&rev);
}
-static int show_object(const unsigned char *sha1, int suppress_header)
+static void show_tagger(char *buf, int len, struct rev_info *rev)
+{
+ char *email_end, *p;
+ unsigned long date;
+ int tz;
+
+ email_end = memchr(buf, '>', len);
+ if (!email_end)
+ return;
+ p = ++email_end;
+ while (isspace(*p))
+ p++;
+ date = strtoul(p, &p, 10);
+ while (isspace(*p))
+ p++;
+ tz = (int)strtol(p, NULL, 10);
+ printf("Tagger: %.*s\nDate: %s\n",
+ email_end - buf, buf,
+ show_date(date, tz, rev->date_mode));
+}
+
+static int show_object(const unsigned char *sha1, int show_tag_object,
+ struct rev_info *rev)
{
unsigned long size;
enum object_type type;
@@ -254,11 +276,14 @@ static int show_object(const unsigned char *sha1, int suppress_header)
if (!buf)
return error("Could not read object %s", sha1_to_hex(sha1));
- if (suppress_header)
- while (offset < size && buf[offset++] != '\n') {
- int new_offset = offset;
+ if (show_tag_object)
+ while (offset < size && buf[offset] != '\n') {
+ int new_offset = offset + 1;
while (new_offset < size && buf[new_offset++] != '\n')
; /* do nothing */
+ if (!prefixcmp(buf + offset, "tagger "))
+ show_tagger(buf + offset + 7,
+ new_offset - offset - 7, rev);
offset = new_offset;
}
@@ -299,16 +324,16 @@ int cmd_show(int argc, const char **argv, const char *prefix)
const char *name = objects[i].name;
switch (o->type) {
case OBJ_BLOB:
- ret = show_object(o->sha1, 0);
+ ret = show_object(o->sha1, 0, NULL);
break;
case OBJ_TAG: {
struct tag *t = (struct tag *)o;
- printf("%stag %s%s\n\n",
+ printf("%stag %s%s\n",
diff_get_color_opt(&rev.diffopt, DIFF_COMMIT),
t->tag,
diff_get_color_opt(&rev.diffopt, DIFF_RESET));
- ret = show_object(o->sha1, 1);
+ ret = show_object(o->sha1, 1, &rev);
objects[i].item = (struct object *)t->tagged;
i--;
break;
--
1.5.4.rc0.70.g30f7
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH] git show <tag>: show the tagger
2007-12-18 18:01 [PATCH] git show <tag>: show the tagger Johannes Schindelin
@ 2007-12-18 20:10 ` Junio C Hamano
2007-12-18 21:33 ` Jakub Narebski
2007-12-19 9:11 ` Andreas Ericsson
1 sibling, 1 reply; 4+ messages in thread
From: Junio C Hamano @ 2007-12-18 20:10 UTC (permalink / raw)
To: Johannes Schindelin; +Cc: git
Johannes Schindelin <Johannes.Schindelin@gmx.de> writes:
> For commit objects, the Author is shown, so do the equivalent for
> tag objects, too.
>
> Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
> ---
>
> I know, it's feature freeze period. But this is arguably a
> usability bug.
I'll wait for people to argue this fixes a usability bug, then.
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH] git show <tag>: show the tagger
2007-12-18 20:10 ` Junio C Hamano
@ 2007-12-18 21:33 ` Jakub Narebski
0 siblings, 0 replies; 4+ messages in thread
From: Jakub Narebski @ 2007-12-18 21:33 UTC (permalink / raw)
To: Junio C Hamano; +Cc: Johannes Schindelin, git
Junio C Hamano <gitster@pobox.com> writes:
> Johannes Schindelin <Johannes.Schindelin@gmx.de> writes:
>
> > For commit objects, the Author is shown, so do the equivalent for
> > tag objects, too.
> >
> > Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
> > ---
> >
> > I know, it's feature freeze period. But this is arguably a
> > usability bug.
>
> I'll wait for people to argue this fixes a usability bug, then.
IMHO the fact that currently "git show <tag>" _doesn't_ show
author and date of tag is a (usability) bug.
Fortunately "git cat-file -p <tag>" (or "git cat <tag>" with my
current alias) works, and dos show date in human-readable form.
--
Jakub Narebski
Poland
ShadeHawk on #git
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH] git show <tag>: show the tagger
2007-12-18 18:01 [PATCH] git show <tag>: show the tagger Johannes Schindelin
2007-12-18 20:10 ` Junio C Hamano
@ 2007-12-19 9:11 ` Andreas Ericsson
1 sibling, 0 replies; 4+ messages in thread
From: Andreas Ericsson @ 2007-12-19 9:11 UTC (permalink / raw)
To: Johannes Schindelin; +Cc: git, gitster
Johannes Schindelin wrote:
> For commit objects, the Author is shown, so do the equivalent for
> tag objects, too.
>
That's funny. I tried to apply this onto my "patches" branch and got
conflicts. I have a near-identical one there that I forgot about
~6 months back, so
Acked-by: Andreas Ericsson <ae@op5.se>
--
Andreas Ericsson andreas.ericsson@op5.se
OP5 AB www.op5.se
Tel: +46 8-230225 Fax: +46 8-230231
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2007-12-19 9:11 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-12-18 18:01 [PATCH] git show <tag>: show the tagger Johannes Schindelin
2007-12-18 20:10 ` Junio C Hamano
2007-12-18 21:33 ` Jakub Narebski
2007-12-19 9:11 ` Andreas Ericsson
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).