From: Junio C Hamano Date: Sun, 1 May 2011 23:25:04 +0000 (-0700) Subject: Merge branch 'rs/strbuf-setlen-assert' X-Git-Tag: v1.7.6-rc0~129 X-Git-Url: https://git.lorimer.id.au/gitweb.git/diff_plain/5ae6f5ca2f70bd7d5ca88c20f2be62bf3844af73?hp=638e90c235df8af6f560cf672e5038b1f2646ac6 Merge branch 'rs/strbuf-setlen-assert' * rs/strbuf-setlen-assert: strbuf: clarify assertion in strbuf_setlen() --- diff --git a/strbuf.h b/strbuf.h index 07060ce893..9e6d9fa53f 100644 --- a/strbuf.h +++ b/strbuf.h @@ -3,8 +3,6 @@ /* See Documentation/technical/api-strbuf.txt */ -#include - extern char strbuf_slopbuf[]; struct strbuf { size_t alloc; @@ -33,9 +31,8 @@ static inline size_t strbuf_avail(const struct strbuf *sb) { extern void strbuf_grow(struct strbuf *, size_t); static inline void strbuf_setlen(struct strbuf *sb, size_t len) { - if (!sb->alloc) - strbuf_grow(sb, 0); - assert(len < sb->alloc); + if (len > (sb->alloc ? sb->alloc - 1 : 0)) + die("BUG: strbuf_setlen() beyond buffer"); sb->len = len; sb->buf[len] = '\0'; }