diff options
author | Jeff King <peff@peff.net> | 2014-06-30 19:01:51 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2014-06-30 22:43:32 +0200 |
commit | 6dda4e60f2c3c309de6e3fe1b86a47846a86dabf (patch) | |
tree | 1e1ba2572a16b536e1f7f65130d907b9615b9258 /strbuf.h | |
parent | index-pack: use strip_suffix to avoid magic numbers (diff) | |
download | git-6dda4e60f2c3c309de6e3fe1b86a47846a86dabf.tar.xz git-6dda4e60f2c3c309de6e3fe1b86a47846a86dabf.zip |
strbuf: implement strbuf_strip_suffix
You can almost get away with just calling "strip_suffix_mem"
on a strbuf's buf and len fields. But we also need to move
the NUL-terminator to satisfy strbuf's invariants. Let's
provide a convenience wrapper that handles this.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'strbuf.h')
-rw-r--r-- | strbuf.h | 9 |
1 files changed, 9 insertions, 0 deletions
@@ -47,6 +47,15 @@ extern void strbuf_rtrim(struct strbuf *); extern void strbuf_ltrim(struct strbuf *); extern int strbuf_cmp(const struct strbuf *, const struct strbuf *); +static inline int strbuf_strip_suffix(struct strbuf *sb, const char *suffix) +{ + if (strip_suffix_mem(sb->buf, &sb->len, suffix)) { + strbuf_setlen(sb, sb->len); + return 1; + } else + return 0; +} + /* * Split str (of length slen) at the specified terminator character. * Return a null-terminated array of pointers to strbuf objects |