diff options
author | DJ Delorie <dj@redhat.com> | 2001-09-04 21:33:56 +0000 |
---|---|---|
committer | DJ Delorie <dj@redhat.com> | 2001-09-04 21:33:56 +0000 |
commit | 843f21be9e7bc8a61562440f33e9f49d071dafe1 (patch) | |
tree | 06dc574d023f069060006225f669844de6bf7392 | |
parent | 5907e6285ec51809f82011f923cc675c26c956cf (diff) | |
download | gdb-843f21be9e7bc8a61562440f33e9f49d071dafe1.zip gdb-843f21be9e7bc8a61562440f33e9f49d071dafe1.tar.gz gdb-843f21be9e7bc8a61562440f33e9f49d071dafe1.tar.bz2 |
merge from gcc
-rw-r--r-- | libiberty/ChangeLog | 9 | ||||
-rw-r--r-- | libiberty/asprintf.c | 28 | ||||
-rw-r--r-- | libiberty/vasprintf.c | 25 |
3 files changed, 25 insertions, 37 deletions
diff --git a/libiberty/ChangeLog b/libiberty/ChangeLog index b4866cf..39b3295 100644 --- a/libiberty/ChangeLog +++ b/libiberty/ChangeLog @@ -1,3 +1,12 @@ +2001-09-04 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + * asprintf.c: Don't define USE_STDARG. Use VPARAMS, VA_OPEN, + VA_FIXEDARG & VA_CLOSE. + + * vasprintf.c: Check HAVE_STRING_H when including string.h. + (checkit): Delete redundant prototype. Add ATTRIBUTE_PRINTF_1. + Use VA_OPEN, VA_FIXEDARG & VA_CLOSE. Free allocated string. + 2001-08-27 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> * concat.c (concat): Use VPARAMS, VA_OPEN, VA_FIXEDARG & VA_CLOSE. diff --git a/libiberty/asprintf.c b/libiberty/asprintf.c index 5aaf320..e09af23 100644 --- a/libiberty/asprintf.c +++ b/libiberty/asprintf.c @@ -22,36 +22,20 @@ Boston, MA 02111-1307, USA. */ #include "ansidecl.h" #include "libiberty.h" -#if defined (ANSI_PROTOTYPES) || defined (ALMOST_STDC) -#define USE_STDARG -#endif - -#ifdef USE_STDARG +#ifdef ANSI_PROTOTYPES #include <stdarg.h> #else #include <varargs.h> #endif -/* VARARGS */ -#ifdef USE_STDARG -int -asprintf (char **buf, const char *fmt, ...) -#else int -asprintf (buf, fmt, va_alist) - char **buf; - const char *fmt; - va_dcl -#endif +asprintf VPARAMS ((char **buf, const char *fmt, ...)) { int status; - va_list ap; -#ifdef USE_STDARG - va_start (ap, fmt); -#else - va_start (ap); -#endif + VA_OPEN (ap, fmt); + VA_FIXEDARG (ap, char **, buf); + VA_FIXEDARG (ap, const char *, fmt); status = vasprintf (buf, fmt, ap); - va_end (ap); + VA_CLOSE (ap); return status; } diff --git a/libiberty/vasprintf.c b/libiberty/vasprintf.c index c34585d..32faa84 100644 --- a/libiberty/vasprintf.c +++ b/libiberty/vasprintf.c @@ -28,7 +28,9 @@ Boston, MA 02111-1307, USA. */ #include <varargs.h> #endif #include <stdio.h> +#ifdef HAVE_STRING_H #include <string.h> +#endif #ifdef HAVE_STDLIB_H #include <stdlib.h> #else @@ -142,29 +144,22 @@ vasprintf (result, format, args) } #ifdef TEST -static void checkit PARAMS ((const char *, ...)); - -static void -checkit VPARAMS ((const char* format, ...)) +static void ATTRIBUTE_PRINTF_1 +checkit VPARAMS ((const char *format, ...)) { - va_list args; char *result; -#ifndef ANSI_PROTOTYPES - const char *format; -#endif - - VA_START (args, format); - -#ifndef ANSI_PROTOTYPES - format = va_arg (args, const char *); -#endif - + VA_OPEN (args, format); + VA_FIXEDARG (args, const char *, format); vasprintf (&result, format, args); + VA_CLOSE (args); + if (strlen (result) < (size_t) global_total_width) printf ("PASS: "); else printf ("FAIL: "); printf ("%d %s\n", global_total_width, result); + + free (result); } extern int main PARAMS ((void)); |