more header fixes, minor warning fix
authorRich Felker <dalias@aerifal.cx>
Tue, 15 Feb 2011 00:33:11 +0000 (19:33 -0500)
committerRich Felker <dalias@aerifal.cx>
Tue, 15 Feb 2011 00:33:11 +0000 (19:33 -0500)
include/wchar.h
include/wctype.h
src/ctype/wcwidth.c
src/stdlib/strtoimax.c
src/stdlib/wcstoimax.c
src/stdlib/wcstoumax.c

index 3f325bff27bcf02ba745c1cf97d1ae70882a58b8..53d619b3f963fcec3d4ff36a6a9c70d9c94ecaf3 100644 (file)
@@ -10,12 +10,19 @@ extern "C" {
 #define __NEED_size_t
 #define __NEED_wchar_t
 #define __NEED_wint_t
+
+#if defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE)
 #define __NEED_wctype_t
+#endif
 
 #include <bits/alltypes.h>
 
 #undef NULL
+#ifdef __cplusplus
+#define NULL 0
+#else
 #define NULL ((void*)0)
+#endif
 
 #undef WCHAR_MIN
 #undef WCHAR_MAX
@@ -74,9 +81,6 @@ size_t mbrlen (const char *, size_t, mbstate_t *);
 size_t mbsrtowcs (wchar_t *, const char **, size_t, mbstate_t *);
 size_t wcsrtombs (char *, const wchar_t **, size_t, mbstate_t *);
 
-int wcwidth (wchar_t);
-int wcswidth (const wchar_t *, size_t);
-
 float wcstof (const wchar_t *, wchar_t **);
 double wcstod (const wchar_t *, wchar_t **);
 long double wcstold (const wchar_t *, wchar_t **);
@@ -126,6 +130,9 @@ size_t wcsftime (wchar_t *, size_t, const wchar_t *, const struct tm *);
 
 #undef iswdigit
 
+#if defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE)
+int wcwidth (wchar_t);
+int wcswidth (const wchar_t *, size_t);
 int       iswalnum(wint_t);
 int       iswalpha(wint_t);
 int       iswblank(wint_t);
@@ -142,8 +149,9 @@ int       iswctype(wint_t, wctype_t);
 wint_t    towlower(wint_t);
 wint_t    towupper(wint_t);
 wctype_t  wctype(const char *);
-
+#undef iswdigit
 #define iswdigit(a) ((unsigned)(a)-'0' < 10)
+#endif
 
 #ifdef __cplusplus
 }
index 8b6c9d9da9f085b2c693d8194d1684253a97d761..af9be06909a490b168bf798f0b1fb696f6ebe0e3 100644 (file)
@@ -35,6 +35,7 @@ wint_t    towupper(wint_t);
 wctrans_t wctrans(const char *);
 wctype_t  wctype(const char *);
 
+#undef iswdigit
 #define iswdigit(a) ((unsigned)((a)-L'0') < 10)
 
 #ifdef __cplusplus
index ebc560a53bf348052dc25e7b56b4270c5c072c68..eaafd7cb6615235fd1f83cc497e4039a08b23a6c 100644 (file)
@@ -1,5 +1,6 @@
 #include <inttypes.h>
 #include <wchar.h>
+#include <wctype.h>
 
 #define R(a,b,w) { (b), (w)/2, (b)-(a) }
 
index 1969109172b9c3af5e90000cb39a02af0ea1debb..aeb0397f9ef944c0a0204da44f2853e7104567a3 100644 (file)
@@ -4,7 +4,7 @@
 
 intmax_t strtoimax(const char *s1, char **p, int base)
 {
-       const unsigned char *s = s1;
+       const unsigned char *s = (const void *)s1;
        int sign = 0;
        uintmax_t x;
 
@@ -15,7 +15,7 @@ intmax_t strtoimax(const char *s1, char **p, int base)
        if (*s == '-') sign = *s++;
        else if (*s == '+') s++;
 
-       x = strtoumax(s, p, base);
+       x = strtoumax((const void *)s, p, base);
        if (x > INTMAX_MAX) {
                if (!sign || -x != INTMAX_MIN)
                        errno = ERANGE;
index 861fcb547955c3d87b154027876975121ad11d68..59894f60fe00b0699801397371c5976fa3ee760b 100644 (file)
@@ -1,4 +1,5 @@
 #include <wchar.h>
+#include <wctype.h>
 #include <inttypes.h>
 #include <errno.h>
 
index a8f4680f223fc1cad7a0e2760a9b6f10c975d868..456ddedddfb805bb841bfa9220fc4a9b1f93f4bd 100644 (file)
@@ -1,4 +1,5 @@
 #include <wchar.h>
+#include <wctype.h>
 #include <stdlib.h>
 #include <inttypes.h>
 #include <errno.h>