diff options
author | Chris Lattner <sabre@nondot.org> | 2012-08-31 22:39:21 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2012-08-31 22:39:21 +0000 |
commit | 6dc7e57d6aaa5ae4feaa31c91017f1622f325949 (patch) | |
tree | 0c4ed90091d71b455951ac8c783eda84c4f3b7f0 /clang/lib/Sema/SemaStmt.cpp | |
parent | 8ccd2863e9f168aa2f641a80610486a76fcab6c0 (diff) | |
download | bcm5719-llvm-6dc7e57d6aaa5ae4feaa31c91017f1622f325949.tar.gz bcm5719-llvm-6dc7e57d6aaa5ae4feaa31c91017f1622f325949.zip |
don't warn about unused values when the unused value is a statement expression expanded from a macro. This is of dubious utility in general, but is specifically a major issue for the linux kernel. This resolves PR13747.
llvm-svn: 163034
Diffstat (limited to 'clang/lib/Sema/SemaStmt.cpp')
-rw-r--r-- | clang/lib/Sema/SemaStmt.cpp | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaStmt.cpp b/clang/lib/Sema/SemaStmt.cpp index c885d484e71..76410e20aca 100644 --- a/clang/lib/Sema/SemaStmt.cpp +++ b/clang/lib/Sema/SemaStmt.cpp @@ -160,6 +160,13 @@ void Sema::DiagnoseUnusedExprResult(const Stmt *S) { !E->isUnusedResultAWarning(WarnExpr, Loc, R1, R2, Context)) return; + // If this is a GNU statement expression expanded from a macro, it is probably + // unused because it is a function-like macro that can be used as either an + // expression or statement. Don't warn, because it is almost certainly a + // false positive. + if (isa<StmtExpr>(E) && Loc.isMacroID()) + return; + // Okay, we have an unused result. Depending on what the base expression is, // we might want to make a more specific diagnostic. Check for one of these // cases now. |