diff options
author | René Scharfe <l.s.r@web.de> | 2016-07-21 18:46:44 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2016-07-22 09:22:26 -0700 |
commit | 31471ba21ee29886ab856981e52f723c913d7f40 (patch) | |
tree | 3d816df586a76c6112c81fe276c956248e9852c5 /strbuf.c | |
parent | 8109984d619467ad26c6a76d59b0a5de8a86e6d6 (diff) | |
download | git-31471ba21ee29886ab856981e52f723c913d7f40.tar.gz |
strbuf: avoid calling strbuf_grow() twice in strbuf_addbuf()rs/use-strbuf-addbuf
Implement strbuf_addbuf() as a normal function in order to avoid calling
strbuf_grow() twice, with the second callinside strbud_add() being a
no-op. This is slightly faster and also reduces the text size a bit.
Signed-off-by: Rene Scharfe <l.s.r@web.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'strbuf.c')
-rw-r--r-- | strbuf.c | 7 |
1 files changed, 7 insertions, 0 deletions
@@ -197,6 +197,13 @@ void strbuf_add(struct strbuf *sb, const void *data, size_t len) strbuf_setlen(sb, sb->len + len); } +void strbuf_addbuf(struct strbuf *sb, const struct strbuf *sb2) +{ + strbuf_grow(sb, sb2->len); + memcpy(sb->buf + sb->len, sb2->buf, sb2->len); + strbuf_setlen(sb, sb->len + sb2->len); +} + void strbuf_adddup(struct strbuf *sb, size_t pos, size_t len) { strbuf_grow(sb, len); |