summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 55e7c0a)
raw | patch | inline | side by side (parent: 55e7c0a)
author | Sebastian Schuberth <sschuberth@gmail.com> | |
Mon, 7 Nov 2011 17:33:34 +0000 (18:33 +0100) | ||
committer | Junio C Hamano <gitster@pobox.com> | |
Tue, 8 Nov 2011 00:42:57 +0000 (16:42 -0800) |
2564aa4 started to initialize buf.alloc, but that should actually be one
more byte than the string length due to the trailing \0. Also, do not
modify buf.alloc out of the strbuf code. Use the existing strbuf_attach
instead.
Signed-off-by: Sebastian Schuberth <sschuberth@gmail.com>
Reviewed-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
more byte than the string length due to the trailing \0. Also, do not
modify buf.alloc out of the strbuf code. Use the existing strbuf_attach
instead.
Signed-off-by: Sebastian Schuberth <sschuberth@gmail.com>
Reviewed-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/blame.c | patch | blob | history |
diff --git a/builtin/blame.c b/builtin/blame.c
index e39d9865e2d3f8db10ef2f43b9a2d07ad0b61df9..0aac73665b79df94cf6269f3520fa147b33b6b9b 100644 (file)
--- a/builtin/blame.c
+++ b/builtin/blame.c
if (!contents_from || strcmp("-", contents_from)) {
struct stat st;
const char *read_from;
+ char *buf_ptr;
unsigned long buf_len;
if (contents_from) {
switch (st.st_mode & S_IFMT) {
case S_IFREG:
if (DIFF_OPT_TST(opt, ALLOW_TEXTCONV) &&
- textconv_object(read_from, mode, null_sha1, &buf.buf, &buf_len)) {
- buf.alloc = buf_len;
- buf.len = buf_len;
- }
+ textconv_object(read_from, mode, null_sha1, &buf_ptr, &buf_len))
+ strbuf_attach(&buf, buf_ptr, buf_len, buf_len + 1);
else if (strbuf_read_file(&buf, read_from, st.st_size) != st.st_size)
die_errno("cannot open or read '%s'", read_from);
break;