Browse Source

show-branch: use a strbuf for reflog descriptions

When we show "branch@{0}", we format into a fixed-size
buffer using sprintf. This can overflow if you have long
branch names. We can fix it by using a temporary strbuf.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Jeff King 10 years ago committed by Junio C Hamano
parent
commit
78f23bdf68
  1. 6
      builtin/show-branch.c

6
builtin/show-branch.c

@ -720,7 +720,6 @@ int cmd_show_branch(int ac, const char **av, const char *prefix) @@ -720,7 +720,6 @@ int cmd_show_branch(int ac, const char **av, const char *prefix)

if (reflog) {
unsigned char sha1[20];
char nth_desc[256];
char *ref;
int base = 0;
unsigned int flags = 0;
@ -759,6 +758,7 @@ int cmd_show_branch(int ac, const char **av, const char *prefix) @@ -759,6 +758,7 @@ int cmd_show_branch(int ac, const char **av, const char *prefix)

for (i = 0; i < reflog; i++) {
char *logmsg;
char *nth_desc;
const char *msg;
unsigned long timestamp;
int tz;
@ -777,8 +777,10 @@ int cmd_show_branch(int ac, const char **av, const char *prefix) @@ -777,8 +777,10 @@ int cmd_show_branch(int ac, const char **av, const char *prefix)
show_date(timestamp, tz, 1),
msg);
free(logmsg);
sprintf(nth_desc, "%s@{%d}", *av, base+i);

nth_desc = xstrfmt("%s@{%d}", *av, base+i);
append_ref(nth_desc, sha1, 1);
free(nth_desc);
}
free(ref);
}

Loading…
Cancel
Save