summaryrefslogtreecommitdiffstats
path: root/compat_vasprintf.c
diff options
context:
space:
mode:
authorIngo Schwarze <schwarze@openbsd.org>2015-03-20 15:25:12 +0000
committerIngo Schwarze <schwarze@openbsd.org>2015-03-20 15:25:12 +0000
commite288630db51bbfcab093f985392465505099da6d (patch)
tree02b2c832450144ee29973a46f7ec98638f134447 /compat_vasprintf.c
parent12a8b42da58bc9593db136d2e84368f28052e735 (diff)
downloadmandoc-e288630db51bbfcab093f985392465505099da6d.tar.gz
Patch from Christian Neukirchen <chneukirchen at gmail dot com>:
He reports that on some platforms, it is not possible to use the same va_list twice. So use va_copy(3) for additional safety.
Diffstat (limited to 'compat_vasprintf.c')
-rw-r--r--compat_vasprintf.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/compat_vasprintf.c b/compat_vasprintf.c
index 10113aaa..bfeb96dd 100644
--- a/compat_vasprintf.c
+++ b/compat_vasprintf.c
@@ -37,10 +37,14 @@ int
vasprintf(char **ret, const char *format, va_list ap)
{
char buf[2];
+ va_list ap2;
int sz;
- if ((sz = vsnprintf(buf, sizeof(buf), format, ap)) != -1 &&
- (*ret = malloc(sz + 1)) != NULL) {
+ va_copy(ap2, ap);
+ sz = vsnprintf(buf, sizeof(buf), format, ap2);
+ va_end(ap2);
+
+ if (sz != -1 && (*ret = malloc(sz + 1)) != NULL) {
if (vsnprintf(*ret, sz + 1, format, ap) == sz)
return(sz);
free(*ret);