From: Juanma Barranquero Date: Wed, 22 Sep 2010 17:31:21 +0000 (+0200) Subject: src/w32.c (get_emacs_configuration_options): Fix buffer overrun. X-Git-Tag: emacs-pretest-24.0.90~104^2~275^2~438^2~47^2~42^2~98 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=38c54d9dabb8e699b9e42854517e6493fbefa191;p=emacs.git src/w32.c (get_emacs_configuration_options): Fix buffer overrun. --- diff --git a/src/ChangeLog b/src/ChangeLog index 6bb13eaa088..4d8add512a4 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,8 @@ +2010-09-22 Juanma Barranquero + Eli Zaretskii + + * w32.c (get_emacs_configuration_options): Fix buffer overrun. + 2010-09-22 Eli Zaretskii * minibuf.c (Fminibuffer_contents) diff --git a/src/w32.c b/src/w32.c index e9d67870078..745642e946b 100644 --- a/src/w32.c +++ b/src/w32.c @@ -1925,7 +1925,25 @@ get_emacs_configuration (void) char * get_emacs_configuration_options (void) { - static char options_buffer[256]; + static char *options_buffer; + char cv[32]; /* Enough for COMPILER_VERSION. */ + char *options[] = { + cv, /* To be filled later. */ +#ifdef EMACSDEBUG + " --no-opt", +#endif + /* configure.bat already sets USER_CFLAGS and USER_LDFLAGS + with a starting space to save work here. */ +#ifdef USER_CFLAGS + " --cflags", USER_CFLAGS, +#endif +#ifdef USER_LDFLAGS + " --ldflags", USER_LDFLAGS, +#endif + NULL + }; + size_t size = 0; + int i; /* Work out the effective configure options for this build. */ #ifdef _MSC_VER @@ -1938,18 +1956,17 @@ get_emacs_configuration_options (void) #endif #endif - sprintf (options_buffer, COMPILER_VERSION); -#ifdef EMACSDEBUG - strcat (options_buffer, " --no-opt"); -#endif -#ifdef USER_CFLAGS - strcat (options_buffer, " --cflags"); - strcat (options_buffer, USER_CFLAGS); -#endif -#ifdef USER_LDFLAGS - strcat (options_buffer, " --ldflags"); - strcat (options_buffer, USER_LDFLAGS); -#endif + if (_snprintf (cv, sizeof (cv), COMPILER_VERSION) < 0) + return "Error: not enough space for compiler version"; + + for (i = 0; options[i]; i++) + size += strlen (options[i]); + + options_buffer = xmalloc (size + 1); + + for (i = 0; options[i]; i++) + strcat (options_buffer, options[i]); + return options_buffer; }