diff options
author | Alex Lorenz <arphaman@gmail.com> | 2017-04-05 14:07:21 +0000 |
---|---|---|
committer | Alex Lorenz <arphaman@gmail.com> | 2017-04-05 14:07:21 +0000 |
commit | 6615f2b3d673e422789287bb7ae097df00ca32a1 (patch) | |
tree | 0f4ca65d2bbbdcc7e34a960856d8658b83a7d24c /clang | |
parent | 38a2da92bccb3c8aec76d5cb70ec6750805a6bc2 (diff) | |
download | bcm5719-llvm-6615f2b3d673e422789287bb7ae097df00ca32a1.tar.gz bcm5719-llvm-6615f2b3d673e422789287bb7ae097df00ca32a1.zip |
-Wunreachable-code: 'true' and 'false' should not be treated as configuration
macros
Clang should emit -Wunreachable-code warnings in C mode for code that's
unreachable because of a 'false' or '!true' condition.
llvm-svn: 299541
Diffstat (limited to 'clang')
-rw-r--r-- | clang/lib/Analysis/ReachableCode.cpp | 8 | ||||
-rw-r--r-- | clang/test/Sema/warn-unreachable.c | 10 |
2 files changed, 17 insertions, 1 deletions
diff --git a/clang/lib/Analysis/ReachableCode.cpp b/clang/lib/Analysis/ReachableCode.cpp index a2f3203762f..8a9674484a5 100644 --- a/clang/lib/Analysis/ReachableCode.cpp +++ b/clang/lib/Analysis/ReachableCode.cpp @@ -132,15 +132,21 @@ static bool isExpandedFromConfigurationMacro(const Stmt *S, // so that we can refine it later. SourceLocation L = S->getLocStart(); if (L.isMacroID()) { + SourceManager &SM = PP.getSourceManager(); if (IgnoreYES_NO) { // The Objective-C constant 'YES' and 'NO' // are defined as macros. Do not treat them // as configuration values. - SourceManager &SM = PP.getSourceManager(); SourceLocation TopL = getTopMostMacro(L, SM); StringRef MacroName = PP.getImmediateMacroName(TopL); if (MacroName == "YES" || MacroName == "NO") return false; + } else if (!PP.getLangOpts().CPlusPlus) { + // Do not treat C 'false' and 'true' macros as configuration values. + SourceLocation TopL = getTopMostMacro(L, SM); + StringRef MacroName = PP.getImmediateMacroName(TopL); + if (MacroName == "false" || MacroName == "true") + return false; } return true; } diff --git a/clang/test/Sema/warn-unreachable.c b/clang/test/Sema/warn-unreachable.c index 34e0296a204..1f7921610b9 100644 --- a/clang/test/Sema/warn-unreachable.c +++ b/clang/test/Sema/warn-unreachable.c @@ -451,3 +451,13 @@ void unaryOpFixitCastSubExpr(int x) { // CHECK: fix-it:"{{.*}}":{[[@LINE-2]]:15-[[@LINE-2]]:15}:")" unaryOpFixitCastSubExpr(x); // expected-warning {{code will never be executed}} } + +#define false 0 +#define true 1 + +void testTrueFalseMacros() { + if (false) // expected-note {{silence by adding parentheses to mark code as explicitly dead}} + testTrueFalseMacros(); // expected-warning {{code will never be executed}} + if (!true) // expected-note {{silence by adding parentheses to mark code as explicitly dead}} + testTrueFalseMacros(); // expected-warning {{code will never be executed}} +} |