
Move the logic for determining the `wchar_t` type information into the driver. Rather than passing the single bit of information of `-fshort-wchar` indicate to the frontend the desired type of `wchar_t` through a new `-cc1` option of `-fwchar-type` and indicate the signedness through `-f{,no-}signed-wchar`. This replicates the current logic which was spread throughout Basic into the `RenderCharacterOptions`. Most of the changes to the tests are to ensure that the frontend uses the correct type. Add a new test set under `test/Driver/wchar_t.c` to ensure that we calculate the proper types for the various cases. llvm-svn: 315126
25 lines
866 B
C
25 lines
866 B
C
// RUN: %clang_cc1 %s -fsyntax-only -verify
|
|
// RUN: %clang_cc1 %s -fsyntax-only -fwchar-type=short -fno-signed-wchar -verify -DSHORT_WCHAR
|
|
|
|
typedef __WCHAR_TYPE__ wchar_t;
|
|
|
|
#if defined(_WIN32) || defined(_M_IX86) || defined(__CYGWIN__) \
|
|
|| defined(_M_X64) || defined(__ORBIS__) || defined(SHORT_WCHAR)
|
|
#define WCHAR_T_TYPE unsigned short
|
|
#elif defined(__arm) || defined(__aarch64__)
|
|
#define WCHAR_T_TYPE unsigned int
|
|
#elif defined(__sun)
|
|
#define WCHAR_T_TYPE long
|
|
#else /* Solaris. */
|
|
#define WCHAR_T_TYPE int
|
|
#endif
|
|
|
|
int check_wchar_size[sizeof(*L"") == sizeof(wchar_t) ? 1 : -1];
|
|
|
|
void foo() {
|
|
WCHAR_T_TYPE t1[] = L"x";
|
|
wchar_t tab[] = L"x";
|
|
WCHAR_T_TYPE t2[] = "x"; // expected-error {{initializing wide char array with non-wide string literal}}
|
|
char t3[] = L"x"; // expected-error {{initializing char array with wide string literal}}
|
|
}
|