From 6a25313c1122629b43b990ada70af1c209f03a54 Mon Sep 17 00:00:00 2001 From: Rich Felker Date: Wed, 4 Jun 2014 03:39:22 -0400 Subject: simplify vasprintf implementation the old implementation preallocated a buffer in order to try to avoid calling vsnprintf more than once. not only did this potentially lead to memory fragmentation from trimming with realloc; it also pulled in realloc/free, which otherwise might not be needed in a static linked program. --- src/stdio/vasprintf.c | 15 +-------------- 1 file changed, 1 insertion(+), 14 deletions(-) diff --git a/src/stdio/vasprintf.c b/src/stdio/vasprintf.c index 68b7246b..08251bc2 100644 --- a/src/stdio/vasprintf.c +++ b/src/stdio/vasprintf.c @@ -3,26 +3,13 @@ #include #include -#define GUESS 240U - int vasprintf(char **s, const char *fmt, va_list ap) { va_list ap2; - char *a; - int l=GUESS; - - if (!(a=malloc(GUESS))) return -1; - va_copy(ap2, ap); - l=vsnprintf(a, GUESS, fmt, ap2); + int l = vsnprintf(0, 0, fmt, ap2); va_end(ap2); - if (l