summaryrefslogtreecommitdiffstats
path: root/clang/test/Preprocessor/macro-reserved.cpp
diff options
context:
space:
mode:
authorSerge Pavlov <sepavloff@gmail.com>2014-12-18 11:14:21 +0000
committerSerge Pavlov <sepavloff@gmail.com>2014-12-18 11:14:21 +0000
commit07c0f04e08c840fc8bf1bfb8d5a2775b40c6e503 (patch)
treec2501b10b465ff12299b7af533ee91e930a8169e /clang/test/Preprocessor/macro-reserved.cpp
parent794771b08bec6272a40b8f952fa6ea6d7586cf28 (diff)
downloadbcm5719-llvm-07c0f04e08c840fc8bf1bfb8d5a2775b40c6e503.tar.gz
bcm5719-llvm-07c0f04e08c840fc8bf1bfb8d5a2775b40c6e503.zip
Fixed warnings on redefine keywords and reserved ids.
Repared support for warnings -Wkeyword-macro and -Wreserved-id-macro. The warning -Wkeyword-macro now is not issued in patterns that are used in configuration scripts: #define inline also for 'const', 'extern' and 'static'. If macro repalcement is identical to macro name, the warning also is not issued: #define volatile volatile And finally if macro replacement is also a keyword identical to the replaced one but decorated with leading/trailing underscores: #define inline __inline #define inline __inline__ #define inline _inline // in MSVC compatibility mode Warning -Wreserved-id-macro is off by default, it could help catching things like: #undef __cplusplus llvm-svn: 224512
Diffstat (limited to 'clang/test/Preprocessor/macro-reserved.cpp')
-rw-r--r--clang/test/Preprocessor/macro-reserved.cpp62
1 files changed, 50 insertions, 12 deletions
diff --git a/clang/test/Preprocessor/macro-reserved.cpp b/clang/test/Preprocessor/macro-reserved.cpp
index 087c27e1ab1..ba1594a0af4 100644
--- a/clang/test/Preprocessor/macro-reserved.cpp
+++ b/clang/test/Preprocessor/macro-reserved.cpp
@@ -1,25 +1,63 @@
-// RUN: %clang_cc1 -fsyntax-only %s -verify
-
-#pragma clang diagnostic warning "-Wkeyword-macro"
+// RUN: %clang_cc1 -fsyntax-only -verify -pedantic %s
#define for 0 // expected-warning {{keyword is hidden by macro definition}}
-#define final 1 // expected-warning {{keyword is hidden by macro definition}}
+#define final 1
#define __HAVE_X 0
#define _HAVE_X 0
#define X__Y
-#undef __cplusplus
+#undef for
+#undef final
+#undef __HAVE_X
#undef _HAVE_X
#undef X__Y
+#undef __cplusplus
+#define __cplusplus
+
+// whitelisted definitions
+#define while while
+#define const
+#define static
+#define extern
+#define inline
+
+#undef while
+#undef const
+#undef static
+#undef extern
+#undef inline
+
+#define inline __inline
+#undef inline
+#define inline __inline__
+#undef inline
+
+#define inline inline__ // expected-warning {{keyword is hidden by macro definition}}
+#undef inline
+#define extern __inline // expected-warning {{keyword is hidden by macro definition}}
+#undef extern
+#define extern __extern // expected-warning {{keyword is hidden by macro definition}}
+#undef extern
+#define extern __extern__ // expected-warning {{keyword is hidden by macro definition}}
+#undef extern
+
+#define inline _inline // expected-warning {{keyword is hidden by macro definition}}
+#undef inline
+#define volatile // expected-warning {{keyword is hidden by macro definition}}
+#undef volatile
+
+
+#pragma clang diagnostic warning "-Wreserved-id-macro"
+
#define switch if // expected-warning {{keyword is hidden by macro definition}}
-#define final 1 // expected-warning {{keyword is hidden by macro definition}}
-#define __HAVE_X 0
-#define _HAVE_X 0
-#define X__Y
+#define final 1
+#define __HAVE_X 0 // expected-warning {{macro name is a reserved identifier}}
+#define _HAVE_X 0 // expected-warning {{macro name is a reserved identifier}}
+#define X__Y // expected-warning {{macro name is a reserved identifier}}
-#undef __cplusplus
-#undef _HAVE_X
-#undef X__Y
+#undef __cplusplus // expected-warning {{macro name is a reserved identifier}}
+#undef _HAVE_X // expected-warning {{macro name is a reserved identifier}}
+#undef X__Y // expected-warning {{macro name is a reserved identifier}}
int x;
OpenPOWER on IntegriCloud