From: René Scharfe Date: Mon, 18 May 2026 20:25:01 +0000 (+0200) Subject: strbuf: use st_add3() in strbuf_grow() X-Git-Url: http://git.ipfire.org/gitweb/index.cgi?a=commitdiff_plain;h=c13d0f7bd4e696d5db3345e00f763df23347b6ad;p=thirdparty%2Fgit.git strbuf: use st_add3() in strbuf_grow() Simplify the code by calling st_add3() to do overflow checks instead of open-coding it. This changes the error message to include the offending summands, which can be helpful when tracking down the cause. Signed-off-by: René Scharfe Signed-off-by: Junio C Hamano --- diff --git a/strbuf.c b/strbuf.c index 3e04addc22..8610965d53 100644 --- a/strbuf.c +++ b/strbuf.c @@ -106,12 +106,10 @@ void strbuf_attach(struct strbuf *sb, void *buf, size_t len, size_t alloc) void strbuf_grow(struct strbuf *sb, size_t extra) { int new_buf = !sb->alloc; - if (unsigned_add_overflows(extra, 1) || - unsigned_add_overflows(sb->len, extra + 1)) - die("you want to use way too much memory"); + size_t new_len = st_add3(sb->len, extra, 1); if (new_buf) sb->buf = NULL; - ALLOC_GROW(sb->buf, sb->len + extra + 1, sb->alloc); + ALLOC_GROW(sb->buf, new_len, sb->alloc); if (new_buf) sb->buf[0] = '\0'; }