From: Ray Donnelly Date: Sun, 2 Feb 2014 15:51:05 +0000 (-0500) Subject: * output.c: Ensure space for final nul byte in fmtbuf. X-Git-Tag: 4.1~44 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=e1863c05d82096aa2bfcddb436da1b54a41369e3;p=thirdparty%2Fmake.git * output.c: Ensure space for final nul byte in fmtbuf. Copyright-paperwork-exempt: yes --- diff --git a/output.c b/output.c index 000e2414..b2584f11 100644 --- a/output.c +++ b/output.c @@ -591,14 +591,14 @@ static struct fmtstring static char * get_buffer (size_t need) { - /* Make sure we have room. */ + /* Make sure we have room. NEED includes space for \0. */ if (need > fmtbuf.size) { fmtbuf.size += need * 2; fmtbuf.buffer = xrealloc (fmtbuf.buffer, fmtbuf.size); } - fmtbuf.buffer[need] = '\0'; + fmtbuf.buffer[need-1] = '\0'; return fmtbuf.buffer; } @@ -629,7 +629,7 @@ message (int prefix, size_t len, const char *fmt, ...) strcat (p, "\n"); - assert (fmtbuf.buffer[len] == '\0'); + assert (fmtbuf.buffer[len-1] == '\0'); outputs (0, fmtbuf.buffer); } @@ -660,7 +660,7 @@ error (const gmk_floc *flocp, size_t len, const char *fmt, ...) strcat (p, "\n"); - assert (fmtbuf.buffer[len] == '\0'); + assert (fmtbuf.buffer[len-1] == '\0'); outputs (1, fmtbuf.buffer); } @@ -692,7 +692,7 @@ fatal (const gmk_floc *flocp, size_t len, const char *fmt, ...) strcat (p, stop); - assert (fmtbuf.buffer[len] == '\0'); + assert (fmtbuf.buffer[len-1] == '\0'); outputs (1, fmtbuf.buffer); die (2);