fix missing uintXX_t in nameser.h
[musl] / include / wchar.h
index 3f325bf..12ddd4f 100644 (file)
@@ -10,22 +10,30 @@ extern "C" {
 #define __NEED_size_t
 #define __NEED_wchar_t
 #define __NEED_wint_t
+
+#if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
+ || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE)
+#define __NEED_locale_t
+#endif
+
+#if defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE)
 #define __NEED_wctype_t
+#endif
 
 #include <bits/alltypes.h>
 
+#include <bits/wchar.h>
+
 #undef NULL
+#ifdef __cplusplus
+#define NULL 0
+#else
 #define NULL ((void*)0)
-
-#undef WCHAR_MIN
-#undef WCHAR_MAX
-#define WCHAR_MIN (-1-0x7fffffff)
-#define WCHAR_MAX (0x7fffffff)
+#endif
 
 #undef WEOF
 #define WEOF (-1)
 
-
 typedef struct
 {
        unsigned __opaque1, __opaque2;
@@ -40,6 +48,7 @@ wchar_t *wcsncat (wchar_t *, const wchar_t *, size_t);
 int wcscmp (const wchar_t *, const wchar_t *);
 int wcsncmp (const wchar_t *, const wchar_t *, size_t);
 
+int wcscoll(const wchar_t *, const wchar_t *);
 size_t wcsxfrm (wchar_t *, const wchar_t *, size_t n);
 
 wchar_t *wcschr (const wchar_t *, wchar_t);
@@ -74,9 +83,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 **);
@@ -94,11 +100,11 @@ int fwide (FILE *, int);
 
 int wprintf (const wchar_t *, ...);
 int fwprintf (FILE *, const wchar_t *, ...);
-int swprintf (wchar_t *, const wchar_t *, ...);
+int swprintf (wchar_t *, size_t, const wchar_t *, ...);
 
 int vwprintf (const wchar_t *, va_list);
 int vfwprintf (FILE *, const wchar_t *, va_list);
-int vswprintf (wchar_t *, const wchar_t *, va_list);
+int vswprintf (wchar_t *, size_t, const wchar_t *, va_list);
 
 int wscanf (const wchar_t *, ...);
 int fwscanf (FILE *, const wchar_t *, ...);
@@ -126,6 +132,26 @@ size_t wcsftime (wchar_t *, size_t, const wchar_t *, const struct tm *);
 
 #undef iswdigit
 
+#if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
+ || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE)
+FILE *open_wmemstream(wchar_t **, size_t *);
+size_t mbsnrtowcs(wchar_t *, const char **, size_t, size_t, mbstate_t *);
+size_t wcsnrtombs(char *, const wchar_t **, size_t, size_t, mbstate_t *);
+wchar_t *wcsdup(const wchar_t *);
+size_t wcsnlen (const wchar_t *, size_t);
+wchar_t *wcpcpy (wchar_t *, const wchar_t *);
+wchar_t *wcpncpy (wchar_t *, const wchar_t *, size_t);
+int wcscasecmp(const wchar_t *, const wchar_t *);
+int wcscasecmp_l(const wchar_t *, const wchar_t *, locale_t);
+int wcsncasecmp(const wchar_t *, const wchar_t *, size_t);
+int wcsncasecmp_l(const wchar_t *, const wchar_t *, size_t, locale_t);
+int wcscoll_l(const wchar_t *, const wchar_t *, locale_t);
+size_t wcsxfrm_l(wchar_t *, const wchar_t *, size_t n, locale_t);
+#endif
+
+#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 +168,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
 }