diff options
author | dim <dim@FreeBSD.org> | 2011-05-02 19:39:53 +0000 |
---|---|---|
committer | dim <dim@FreeBSD.org> | 2011-05-02 19:39:53 +0000 |
commit | 110eaaceddcec790f7e6a5e3bf1261c9aa1e73ab (patch) | |
tree | 64a10f4c4154739d4a8191d7e1b52ce497f4ebd6 /test/Preprocessor | |
parent | a0fb00f9837bd0d2e5948f16f6a6b82a7a628f51 (diff) | |
download | FreeBSD-src-110eaaceddcec790f7e6a5e3bf1261c9aa1e73ab.zip FreeBSD-src-110eaaceddcec790f7e6a5e3bf1261c9aa1e73ab.tar.gz |
Vendor import of clang trunk r130700:
http://llvm.org/svn/llvm-project/cfe/trunk@130700
Diffstat (limited to 'test/Preprocessor')
-rw-r--r-- | test/Preprocessor/init.c | 14 | ||||
-rw-r--r-- | test/Preprocessor/pragma-pushpop-macro.c | 2 | ||||
-rw-r--r-- | test/Preprocessor/pragma_diagnostic_sections.cpp | 8 | ||||
-rw-r--r-- | test/Preprocessor/pragma_unknown.c | 2 | ||||
-rw-r--r-- | test/Preprocessor/stdint.c | 12 | ||||
-rw-r--r-- | test/Preprocessor/traditional-cpp.c | 12 |
6 files changed, 36 insertions, 14 deletions
diff --git a/test/Preprocessor/init.c b/test/Preprocessor/init.c index 98b0535..b0515b3 100644 --- a/test/Preprocessor/init.c +++ b/test/Preprocessor/init.c @@ -11,7 +11,6 @@ // // RUN: %clang_cc1 -x c++ -std=c++0x -E -dM < /dev/null | FileCheck -check-prefix CXX0X %s // -// CXX0X:#define __DEPRECATED 1 // CXX0X:#define __GNUG__ // CXX0X:#define __GXX_EXPERIMENTAL_CXX0X__ 1 // CXX0X:#define __GXX_RTTI 1 @@ -22,7 +21,6 @@ // // RUN: %clang_cc1 -x c++ -std=c++98 -E -dM < /dev/null | FileCheck -check-prefix CXX98 %s // -// CXX98:#define __DEPRECATED 1 // CXX98:#define __GNUG__ // CXX98:#define __GXX_RTTI 1 // CXX98:#define __GXX_WEAK__ 1 @@ -30,6 +28,11 @@ // CXX98:#define __private_extern__ extern // // +// RUN: %clang_cc1 -fdeprecated-macro -E -dM < /dev/null | FileCheck -check-prefix DEPRECATED %s +// +// DEPRECATED:#define __DEPRECATED 1 +// +// // RUN: %clang_cc1 -std=c99 -E -dM < /dev/null | FileCheck -check-prefix C99 %s // // C99:#define __STDC_VERSION__ 199901L @@ -62,7 +65,6 @@ // // RUN: %clang_cc1 -x c++ -std=gnu++98 -E -dM < /dev/null | FileCheck -check-prefix GXX98 %s // -// GXX98:#define __DEPRECATED 1 // GXX98:#define __GNUG__ // GXX98:#define __GXX_WEAK__ 1 // GXX98:#define __cplusplus 1 @@ -78,10 +80,6 @@ // // MSEXT-NOT:#define __STDC__ // MSEXT:#define _INTEGRAL_MAX_BITS 64 -// MSEXT:#define __int16 __INT16_TYPE__ -// MSEXT:#define __int32 __INT32_TYPE__ -// MSEXT:#define __int64 __INT64_TYPE__ -// MSEXT:#define __int8 __INT8_TYPE__ // // // RUN: %clang_cc1 -x objective-c -E -dM < /dev/null | FileCheck -check-prefix OBJC %s @@ -982,7 +980,7 @@ // SPARC:#define __SIZE_WIDTH__ 32 // SPARC:#define __UINTMAX_TYPE__ long long unsigned int // SPARC:#define __USER_LABEL_PREFIX__ _ -// SPARC:#define __VERSION__ "4.2.1 Compatible Clang Compiler" +// SPARC:#define __VERSION__ "4.2.1 Compatible // SPARC:#define __WCHAR_MAX__ 2147483647 // SPARC:#define __WCHAR_TYPE__ int // SPARC:#define __WCHAR_WIDTH__ 32 diff --git a/test/Preprocessor/pragma-pushpop-macro.c b/test/Preprocessor/pragma-pushpop-macro.c index 71b0e0e..08a6570 100644 --- a/test/Preprocessor/pragma-pushpop-macro.c +++ b/test/Preprocessor/pragma-pushpop-macro.c @@ -25,7 +25,7 @@ int pmx3 = X; #pragma pop_macro("Y") int pmy1 = Y; -// Have a stray 'push' to show we don't crash when having inbalanced +// Have a stray 'push' to show we don't crash when having imbalanced // push/pop #pragma push_macro("Y") #define Y 4 diff --git a/test/Preprocessor/pragma_diagnostic_sections.cpp b/test/Preprocessor/pragma_diagnostic_sections.cpp index 69436b0..b680fae 100644 --- a/test/Preprocessor/pragma_diagnostic_sections.cpp +++ b/test/Preprocessor/pragma_diagnostic_sections.cpp @@ -2,14 +2,14 @@ // rdar://8365684 struct S { - void m1() { int b = b==b; } // expected-warning {{always evaluates to true}} + void m1() { int b; while (b==b); } // expected-warning {{always evaluates to true}} #pragma clang diagnostic push #pragma clang diagnostic ignored "-Wtautological-compare" - void m2() { int b = b==b; } + void m2() { int b; while (b==b); } #pragma clang diagnostic pop - void m3() { int b = b==b; } // expected-warning {{always evaluates to true}} + void m3() { int b; while (b==b); } // expected-warning {{always evaluates to true}} }; //------------------------------------------------------------------------------ @@ -18,7 +18,7 @@ struct S { #pragma clang diagnostic ignored "-Wtautological-compare" template <typename T> struct TS { - void m() { T b = b==b; } + void m() { T b; while (b==b); } }; #pragma clang diagnostic pop diff --git a/test/Preprocessor/pragma_unknown.c b/test/Preprocessor/pragma_unknown.c index 0672ade..2586754 100644 --- a/test/Preprocessor/pragma_unknown.c +++ b/test/Preprocessor/pragma_unknown.c @@ -21,7 +21,7 @@ #pragma STDC CX_LIMITED_RANGE IN_BETWEEN // expected-warning {{expected 'ON' or 'OFF' or 'DEFAULT' in pragma}} #pragma STDC CX_LIMITED_RANGE // expected-warning {{expected 'ON' or 'OFF' or 'DEFAULT' in pragma}} -#pragma STDC CX_LIMITED_RANGE ON FULL POWER // expected-warning {{expected end of macro in pragma}} +#pragma STDC CX_LIMITED_RANGE ON FULL POWER // expected-warning {{expected end of directive in pragma}} #pragma STDC SO_GREAT // expected-warning {{unknown pragma in STDC namespace}} #pragma STDC // expected-warning {{unknown pragma in STDC namespace}} diff --git a/test/Preprocessor/stdint.c b/test/Preprocessor/stdint.c index b3ae843..ee8e3c2 100644 --- a/test/Preprocessor/stdint.c +++ b/test/Preprocessor/stdint.c @@ -1059,6 +1059,18 @@ // X86_64:UINTMAX_C_(0) 0UL // // +// RUN: %clang_cc1 -E -ffreestanding -triple=x86_64-pc-linux-gnu %s | FileCheck -check-prefix X86_64_LINUX %s +// +// X86_64_LINUX:WINT_MIN_ 0U +// X86_64_LINUX:WINT_MAX_ 4294967295U +// +// +// RUN: %clang_cc1 -E -ffreestanding -triple=i386-mingw32 %s | FileCheck -check-prefix I386_MINGW32 %s +// +// I386_MINGW32:WCHAR_MAX_ 65535U +// I386_MINGW32:WCHAR_MIN_ 0U +// +// // stdint.h forms several macro definitions by pasting together identifiers // to form names (eg. int32_t is formed from int ## 32 ## _t). The following // case tests that these joining operations are performed correctly even if diff --git a/test/Preprocessor/traditional-cpp.c b/test/Preprocessor/traditional-cpp.c new file mode 100644 index 0000000..5fc9ee3 --- /dev/null +++ b/test/Preprocessor/traditional-cpp.c @@ -0,0 +1,12 @@ +/* Clang supports a very limited subset of -traditional-cpp, basically we only + * intend to add support for things that people actually rely on when doing + * things like using /usr/bin/cpp to preprocess non-source files. */ + +/* + RUN: %clang_cc1 -traditional-cpp %s -E -o %t + RUN: FileCheck < %t %s +*/ + +/* CHECK: foo // bar + */ +foo // bar |