summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRené Scharfe <rene.scharfe@lsrfire.ath.cx>2007-11-10 12:16:05 +0100
committerJunio C Hamano <gitster@pobox.com>2007-11-11 11:04:46 +0100
commit91db267ec849279053cf3ac3066c2f2c11db4321 (patch)
tree880d841fcc82d4c77d6fe4dfffb8ffb2139ff32a
parent--pretty=format: parse commit message only once (diff)
downloadgit-91db267ec849279053cf3ac3066c2f2c11db4321.tar.xz
git-91db267ec849279053cf3ac3066c2f2c11db4321.zip
add strbuf_adddup()
Add a new function, strbuf_adddup(), that appends a duplicate of a part of a struct strbuf to end of the latter. Signed-off-by: Rene Scharfe <rene.scharfe@lsrfire.ath.cx> Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rw-r--r--strbuf.c7
-rw-r--r--strbuf.h1
2 files changed, 8 insertions, 0 deletions
diff --git a/strbuf.c b/strbuf.c
index 536b43204e..dbd8c4bcfb 100644
--- a/strbuf.c
+++ b/strbuf.c
@@ -106,6 +106,13 @@ void strbuf_add(struct strbuf *sb, const void *data, size_t len)
strbuf_setlen(sb, sb->len + len);
}
+void strbuf_adddup(struct strbuf *sb, size_t pos, size_t len)
+{
+ strbuf_grow(sb, len);
+ memcpy(sb->buf + sb->len, sb->buf + pos, len);
+ strbuf_setlen(sb, sb->len + len);
+}
+
void strbuf_addf(struct strbuf *sb, const char *fmt, ...)
{
int len;
diff --git a/strbuf.h b/strbuf.h
index 21d8944154..13919123dc 100644
--- a/strbuf.h
+++ b/strbuf.h
@@ -101,6 +101,7 @@ static inline void strbuf_addstr(struct strbuf *sb, const char *s) {
static inline void strbuf_addbuf(struct strbuf *sb, struct strbuf *sb2) {
strbuf_add(sb, sb2->buf, sb2->len);
}
+extern void strbuf_adddup(struct strbuf *sb, size_t pos, size_t len);
typedef void (*expand_fn_t) (struct strbuf *sb, const char *placeholder, void *context);
extern void strbuf_expand(struct strbuf *sb, const char *format, const char **placeholders, expand_fn_t fn, void *context);