1 //===----------------------------------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 
9 // <cwchar>
10 
11 #include <cwchar>
12 #include <ctime>
13 #include <cstdarg>
14 #include <cstdio>
15 #include <type_traits>
16 
17 #include "test_macros.h"
18 
19 #ifndef NULL
20 #error NULL not defined
21 #endif
22 
23 #ifndef WCHAR_MAX
24 #error WCHAR_MAX not defined
25 #endif
26 
27 #ifndef WCHAR_MIN
28 #error WCHAR_MIN not defined
29 #endif
30 
31 #ifndef WEOF
32 #error WEOF not defined
33 #endif
34 
main(int,char **)35 int main(int, char**)
36 {
37     std::mbstate_t mb = {};
38     std::size_t s = 0;
39     std::tm *tm = 0;
40     std::wint_t w = 0;
41     ::FILE* fp = 0;
42     std::va_list va;
43 
44     char* ns = 0;
45     wchar_t* ws = 0;
46 
47     ((void)mb); // Prevent unused warning
48     ((void)s); // Prevent unused warning
49     ((void)tm); // Prevent unused warning
50     ((void)w); // Prevent unused warning
51     ((void)fp); // Prevent unused warning
52     ((void)va); // Prevent unused warning
53     ((void)ns); // Prevent unused warning
54     ((void)ws); // Prevent unused warning
55 
56     ASSERT_SAME_TYPE(int,                decltype(std::fwprintf(fp, L"")));
57     ASSERT_SAME_TYPE(int,                decltype(std::fwscanf(fp, L"")));
58     ASSERT_SAME_TYPE(int,                decltype(std::swprintf(ws, s, L"")));
59     ASSERT_SAME_TYPE(int,                decltype(std::swscanf(L"", L"")));
60     ASSERT_SAME_TYPE(int,                decltype(std::vfwprintf(fp, L"", va)));
61     ASSERT_SAME_TYPE(int,                decltype(std::vfwscanf(fp, L"", va)));
62     ASSERT_SAME_TYPE(int,                decltype(std::vswprintf(ws, s, L"", va)));
63     ASSERT_SAME_TYPE(int,                decltype(std::vswscanf(L"", L"", va)));
64     ASSERT_SAME_TYPE(std::wint_t,        decltype(std::fgetwc(fp)));
65     ASSERT_SAME_TYPE(wchar_t*,           decltype(std::fgetws(ws, 0, fp)));
66     ASSERT_SAME_TYPE(std::wint_t,        decltype(std::fputwc(L' ', fp)));
67     ASSERT_SAME_TYPE(int,                decltype(std::fputws(L"", fp)));
68     ASSERT_SAME_TYPE(int,                decltype(std::fwide(fp, 0)));
69     ASSERT_SAME_TYPE(std::wint_t,        decltype(std::getwc(fp)));
70     ASSERT_SAME_TYPE(std::wint_t,        decltype(std::putwc(L' ', fp)));
71     ASSERT_SAME_TYPE(std::wint_t,        decltype(std::ungetwc(L' ', fp)));
72     ASSERT_SAME_TYPE(double,             decltype(std::wcstod(L"", (wchar_t**)0)));
73     ASSERT_SAME_TYPE(float,              decltype(std::wcstof(L"", (wchar_t**)0)));
74     ASSERT_SAME_TYPE(long double,        decltype(std::wcstold(L"", (wchar_t**)0)));
75     ASSERT_SAME_TYPE(long,               decltype(std::wcstol(L"", (wchar_t**)0, 0)));
76     ASSERT_SAME_TYPE(long long,          decltype(std::wcstoll(L"", (wchar_t**)0, 0)));
77     ASSERT_SAME_TYPE(unsigned long,      decltype(std::wcstoul(L"", (wchar_t**)0, 0)));
78     ASSERT_SAME_TYPE(unsigned long long, decltype(std::wcstoull(L"", (wchar_t**)0, 0)));
79     ASSERT_SAME_TYPE(wchar_t*,           decltype(std::wcscpy(ws, L"")));
80     ASSERT_SAME_TYPE(wchar_t*,           decltype(std::wcsncpy(ws, L"", s)));
81     ASSERT_SAME_TYPE(wchar_t*,           decltype(std::wcscat(ws, L"")));
82     ASSERT_SAME_TYPE(wchar_t*,           decltype(std::wcsncat(ws, L"", s)));
83     ASSERT_SAME_TYPE(int,                decltype(std::wcscmp(L"", L"")));
84     ASSERT_SAME_TYPE(int,                decltype(std::wcscoll(L"", L"")));
85     ASSERT_SAME_TYPE(int,                decltype(std::wcsncmp(L"", L"", s)));
86     ASSERT_SAME_TYPE(std::size_t,        decltype(std::wcsxfrm(ws, L"", s)));
87     ASSERT_SAME_TYPE(wchar_t*,           decltype(std::wcschr((wchar_t*)0, L' ')));
88     ASSERT_SAME_TYPE(std::size_t,        decltype(std::wcscspn(L"", L"")));
89     ASSERT_SAME_TYPE(std::size_t,        decltype(std::wcslen(L"")));
90     ASSERT_SAME_TYPE(wchar_t*,           decltype(std::wcspbrk((wchar_t*)0, L"")));
91     ASSERT_SAME_TYPE(wchar_t*,           decltype(std::wcsrchr((wchar_t*)0, L' ')));
92     ASSERT_SAME_TYPE(std::size_t,        decltype(std::wcsspn(L"", L"")));
93     ASSERT_SAME_TYPE(wchar_t*,           decltype(std::wcsstr((wchar_t*)0, L"")));
94     ASSERT_SAME_TYPE(wchar_t*,           decltype(std::wcstok(ws, L"", (wchar_t**)0)));
95     ASSERT_SAME_TYPE(wchar_t*,           decltype(std::wmemchr((wchar_t*)0, L' ', s)));
96     ASSERT_SAME_TYPE(int,                decltype(std::wmemcmp(L"", L"", s)));
97     ASSERT_SAME_TYPE(wchar_t*,           decltype(std::wmemcpy(ws, L"", s)));
98     ASSERT_SAME_TYPE(wchar_t*,           decltype(std::wmemmove(ws, L"", s)));
99     ASSERT_SAME_TYPE(wchar_t*,           decltype(std::wmemset(ws, L' ', s)));
100     ASSERT_SAME_TYPE(std::size_t,        decltype(std::wcsftime(ws, s, L"", tm)));
101     ASSERT_SAME_TYPE(wint_t,             decltype(std::btowc(0)));
102     ASSERT_SAME_TYPE(int,                decltype(std::wctob(w)));
103     ASSERT_SAME_TYPE(int,                decltype(std::mbsinit(&mb)));
104     ASSERT_SAME_TYPE(std::size_t,        decltype(std::mbrlen("", s, &mb)));
105     ASSERT_SAME_TYPE(std::size_t,        decltype(std::mbrtowc(ws, "", s, &mb)));
106     ASSERT_SAME_TYPE(std::size_t,        decltype(std::wcrtomb(ns, L' ', &mb)));
107     ASSERT_SAME_TYPE(std::size_t,        decltype(std::mbsrtowcs(ws, (const char**)0, s, &mb)));
108     ASSERT_SAME_TYPE(std::size_t,        decltype(std::wcsrtombs(ns, (const wchar_t**)0, s, &mb)));
109 
110     // These tests fail on systems whose C library doesn't provide a correct overload
111     // set for wcschr, wcspbrk, wcsrchr, wcsstr, and wmemchr, unless the compiler is
112     // a suitably recent version of Clang.
113 #if !defined(__APPLE__) || defined(_LIBCPP_PREFERRED_OVERLOAD)
114     ASSERT_SAME_TYPE(const wchar_t*,     decltype(std::wcschr((const wchar_t*)0, L' ')));
115     ASSERT_SAME_TYPE(const wchar_t*,     decltype(std::wcspbrk((const wchar_t*)0, L"")));
116     ASSERT_SAME_TYPE(const wchar_t*,     decltype(std::wcsrchr((const wchar_t*)0, L' ')));
117     ASSERT_SAME_TYPE(const wchar_t*,     decltype(std::wcsstr((const wchar_t*)0, L"")));
118     ASSERT_SAME_TYPE(const wchar_t*,     decltype(std::wmemchr((const wchar_t*)0, L' ', s)));
119 #endif
120 
121 #ifndef _LIBCPP_HAS_NO_STDIN
122     ASSERT_SAME_TYPE(std::wint_t,        decltype(std::getwchar()));
123     ASSERT_SAME_TYPE(int,                decltype(std::vwscanf(L"", va)));
124     ASSERT_SAME_TYPE(int,                decltype(std::wscanf(L"")));
125 #endif
126 
127 #ifndef _LIBCPP_HAS_NO_STDOUT
128     ASSERT_SAME_TYPE(std::wint_t,        decltype(std::putwchar(L' ')));
129     ASSERT_SAME_TYPE(int,                decltype(std::vwprintf(L"", va)));
130     ASSERT_SAME_TYPE(int,                decltype(std::wprintf(L"")));
131 #endif
132 
133   return 0;
134 }
135