[Headers][MSVC] Define wchar_t in stddef.h like MSVC if not using the builtin type
authorStephen Long <steplong@quicinc.com>
Thu, 12 May 2022 16:10:43 +0000 (09:10 -0700)
committerStephen Long <steplong@quicinc.com>
Thu, 12 May 2022 16:38:07 +0000 (09:38 -0700)
 MSVC expects wchar_t to be defined in stddef.h if /Zc:wchar_t- is specified

Reviewed By: efriedma

Differential Revision: https://reviews.llvm.org/D124026

clang/lib/Headers/stddef.h
clang/test/Headers/ms-no-wchar.cpp [new file with mode: 0644]

index 15acd44..a15d21b 100644 (file)
@@ -62,7 +62,7 @@ typedef __SIZE_TYPE__ rsize_t;
 #endif /* defined(__need_STDDEF_H_misc) */
 
 #if defined(__need_wchar_t)
-#ifndef __cplusplus
+#if !defined(__cplusplus) || (defined(_MSC_VER) && !_NATIVE_WCHAR_T_DEFINED)
 /* Always define wchar_t when modules are available. */
 #if !defined(_WCHAR_T) || __has_feature(modules)
 #if !__has_feature(modules)
diff --git a/clang/test/Headers/ms-no-wchar.cpp b/clang/test/Headers/ms-no-wchar.cpp
new file mode 100644 (file)
index 0000000..8fe1dbc
--- /dev/null
@@ -0,0 +1,6 @@
+// RUN: %clang_cc1 -fsyntax-only -triple x86_64-pc-windows-msvc -fms-compatibility-version=17.00 -fno-wchar %s
+// MSVC defines wchar_t instead of using the builtin if /Zc:wchar_t- is passed
+
+#include <stddef.h>
+
+wchar_t c;