diff options
author | René Scharfe <l.s.r@web.de> | 2014-07-19 17:35:34 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2014-07-21 10:37:02 -0700 |
commit | 5c0b13f85ab3a5326508b854768eb70c8829cda4 (patch) | |
tree | c498179a86e3e05abb664caa8d943c81ae4142f5 /builtin | |
parent | 51a60f5bfbaf1ee7c7a2d2b73eca4f042f7af8cb (diff) | |
download | git-5c0b13f85ab3a5326508b854768eb70c8829cda4.tar.gz git-5c0b13f85ab3a5326508b854768eb70c8829cda4.tar.xz |
use xmemdupz() to allocate copies of strings given by start and length
Use xmemdupz() to allocate the memory, copy the data and make sure to
NUL-terminate the result, all in one step. The resulting code is
shorter, doesn't contain the constants 1 and '\0', and avoids
duplicating function parameters.
For blame, the last copied byte (o->file.ptr[o->file.size]) is always
set to NUL by fake_working_tree_commit() or read_sha1_file(), so no
information is lost by the conversion to using xmemdupz().
Signed-off-by: Rene Scharfe <l.s.r@web.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'builtin')
-rw-r--r-- | builtin/apply.c | 4 | ||||
-rw-r--r-- | builtin/blame.c | 5 |
2 files changed, 2 insertions, 7 deletions
diff --git a/builtin/apply.c b/builtin/apply.c index 9c5724eac..622ee1674 100644 --- a/builtin/apply.c +++ b/builtin/apply.c @@ -2869,9 +2869,7 @@ static int apply_binary_fragment(struct image *img, struct patch *patch) case BINARY_LITERAL_DEFLATED: clear_image(img); img->len = fragment->size; - img->buf = xmalloc(img->len+1); - memcpy(img->buf, fragment->patch, img->len); - img->buf[img->len] = '\0'; + img->buf = xmemdupz(fragment->patch, img->len); return 0; } return -1; diff --git a/builtin/blame.c b/builtin/blame.c index ef7cb1d25..6a284ce46 100644 --- a/builtin/blame.c +++ b/builtin/blame.c @@ -2458,11 +2458,8 @@ parse_done: die("revision walk setup failed"); if (is_null_sha1(sb.final->object.sha1)) { - char *buf; o = sb.final->util; - buf = xmalloc(o->file.size + 1); - memcpy(buf, o->file.ptr, o->file.size + 1); - sb.final_buf = buf; + sb.final_buf = xmemdupz(o->file.ptr, o->file.size); sb.final_buf_size = o->file.size; } else { |