diff options
author | Serge Pavlov <sepavloff@gmail.com> | 2014-12-18 11:14:21 +0000 |
---|---|---|
committer | Serge Pavlov <sepavloff@gmail.com> | 2014-12-18 11:14:21 +0000 |
commit | 07c0f04e08c840fc8bf1bfb8d5a2775b40c6e503 (patch) | |
tree | c2501b10b465ff12299b7af533ee91e930a8169e /clang/test/Preprocessor/macro-reserved.cpp | |
parent | 794771b08bec6272a40b8f952fa6ea6d7586cf28 (diff) | |
download | bcm5719-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.cpp | 62 |
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; |