From: Bruno Haible Date: Sat, 27 Dec 2003 15:29:47 +0000 (+0000) Subject: A paranoia check, merged from gnulib. X-Git-Tag: v0.14~107 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=eff992442ecc9f56268fd2b4a42a3b6547932400;p=thirdparty%2Fgettext.git A paranoia check, merged from gnulib. --- diff --git a/gettext-runtime/libasprintf/ChangeLog b/gettext-runtime/libasprintf/ChangeLog index b14eb194d..78c7b596c 100644 --- a/gettext-runtime/libasprintf/ChangeLog +++ b/gettext-runtime/libasprintf/ChangeLog @@ -1,3 +1,9 @@ +2003-10-30 Paul Eggert + Bruno Haible + + * vasprintf.c: Include , . + (vasprintf): Fail if the resulting length doesn't fit in an 'int'. + 2003-12-12 Bruno Haible Assume automake-1.8. diff --git a/gettext-runtime/libasprintf/vasprintf.c b/gettext-runtime/libasprintf/vasprintf.c index 925d2fb81..d20f8ca63 100644 --- a/gettext-runtime/libasprintf/vasprintf.c +++ b/gettext-runtime/libasprintf/vasprintf.c @@ -23,6 +23,9 @@ /* Specification. */ #include "vasprintf.h" +#include +#include + #include "vasnprintf.h" int @@ -32,6 +35,14 @@ vasprintf (char **resultp, const char *format, va_list args) char *result = vasnprintf (NULL, &length, format, args); if (result == NULL) return -1; + if (length > INT_MAX) + { + /* We could produce such a big string, but can't return its length + as an 'int'. */ + free (result); + return -1; + } + *resultp = result; /* Return the number of resulting bytes, excluding the trailing NUL. */ return length;