[vlc-commits] vasprintf: rewrite. va_copy() was missing.

Rémi Denis-Courmont git at videolan.org
Wed Oct 26 20:12:50 CEST 2011


vlc | branch: master | Rémi Denis-Courmont <remi at remlab.net> | Wed Oct 26 21:11:12 2011 +0300| [05a7af68c439d4b4f00cade40d366b6bcd71178f] | committer: Rémi Denis-Courmont

vasprintf: rewrite. va_copy() was missing.

> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=05a7af68c439d4b4f00cade40d366b6bcd71178f
---

 compat/vasprintf.c |   33 +++++++++++++++++++++++++++------
 1 files changed, 27 insertions(+), 6 deletions(-)

diff --git a/compat/vasprintf.c b/compat/vasprintf.c
index 17b6d67..dfd0297 100644
--- a/compat/vasprintf.c
+++ b/compat/vasprintf.c
@@ -25,13 +25,34 @@
 #include <stdio.h>
 #include <stdlib.h>
 #include <stdarg.h>
+#include <assert.h>
 
 int vasprintf (char **strp, const char *fmt, va_list ap)
 {
-    ssize_t len = vsnprintf (NULL, 0, fmt, ap) + 1;
-    char *res = malloc (len);
-    if (res == NULL)
-        return -1;
-    *strp = res;
-    return vsnprintf (res, len, fmt, ap);
+    va_list args;
+    int len;
+
+    va_copy (args, ap);
+    len = vsnprintf (NULL, 0, fmt, args);
+    va_end (args);
+
+    char *str = malloc (len + 1);
+    if (str != NULL)
+    {
+        int len2;
+
+        va_copy (args, ap);
+        len2 = vsprintf (str, fmt, args);
+        assert (len2 == len);
+        va_end (args);
+    }
+    else
+    {
+        len = -1;
+#ifndef NDEBUG
+        str = (void *)(intptr_t)0x41414141; /* poison */
+#endif
+    }
+    *strp = str;
+    return len;
 }



More information about the vlc-commits mailing list