summaryrefslogtreecommitdiff
path: root/libc/stdio/vfprintf.c
diff options
context:
space:
mode:
authorManuel Novoa III <mjn3@codepoet.org>2005-02-14 05:58:08 +0000
committerManuel Novoa III <mjn3@codepoet.org>2005-02-14 05:58:08 +0000
commit371ca78703d0f0a6aedb9879a3120b75d9f6e587 (patch)
tree3349b8a62ea0980c7bf51c8e9cb97e26f92b9768 /libc/stdio/vfprintf.c
parent67256bd81271093c911a516aa00a5b33a63d6cbd (diff)
When I broke up the stdio code, the "support pre C99 compilers" va_copy compat
define was no longer visible to vasprintf. I didn't catch this since I no longer use such old tools. Unfortunately, some well-meaning but misguided individual decided to just cut-and-paste the macro. :-( Try to clean up the situation by putting it into a header that can be overriden by any archs that need to. If this breaks for anyone (as I said, I no longer use such old tools and so haven't tested), let me know and I'll fix it.
Diffstat (limited to 'libc/stdio/vfprintf.c')
-rw-r--r--libc/stdio/vfprintf.c22
1 files changed, 1 insertions, 21 deletions
diff --git a/libc/stdio/vfprintf.c b/libc/stdio/vfprintf.c
index 49b4d11a3..d3214fff0 100644
--- a/libc/stdio/vfprintf.c
+++ b/libc/stdio/vfprintf.c
@@ -118,6 +118,7 @@
#endif /* __UCLIBC_HAS_WCHAR__ */
#include <bits/uClibc_uintmaxtostr.h>
+#include <bits/uClibc_va_copy.h>
/* Some older or broken gcc toolchains define LONG_LONG_MAX but not
* LLONG_MAX. Since LLONG_MAX is part of the standard, that's what
@@ -205,27 +206,6 @@
#define MAX_ARGS (MAX_ARGS_PER_SPEC + 2)
#endif
-
-/**********************************************************************/
-/* Deal with pre-C99 compilers. */
-
-#ifndef va_copy
-
-#ifdef __va_copy
-#define va_copy(A,B) __va_copy(A,B)
-#else
- /* TODO -- maybe create a bits/vacopy.h for arch specific versions
- * to ensure we get the right behavior? Either that or fall back
- * on the portable (but costly in size) method of using a va_list *.
- * That means a pointer derefs in the va_arg() invocations... */
-#warning Neither va_copy (C99/SUSv3) or __va_copy is defined. Using a simple copy instead. But you should really check that this is appropriate...
- /* the glibc manual suggests that this will usually suffice when
- __va_copy doesn't exist. */
-#define va_copy(A,B) A = B
-#endif
-
-#endif /* va_copy */
-
/**********************************************************************/
#define __PA_FLAG_INTMASK \