diff options
| -rw-r--r-- | clang/lib/Sema/SemaStmt.cpp | 5 | ||||
| -rw-r--r-- | clang/test/Sema/if-empty-body.c | 8 | 
2 files changed, 12 insertions, 1 deletions
| diff --git a/clang/lib/Sema/SemaStmt.cpp b/clang/lib/Sema/SemaStmt.cpp index 84dfa1a9999..c9a6da13fbe 100644 --- a/clang/lib/Sema/SemaStmt.cpp +++ b/clang/lib/Sema/SemaStmt.cpp @@ -272,9 +272,12 @@ Sema::ActOnIfStmt(SourceLocation IfLoc, FullExprArg CondVal, Decl *CondVar,    // this helps prevent bugs due to typos, such as    // if (condition);    //   do_stuff(); +  // +  // NOTE: Do not emit this warning if the body is expanded from a macro.    if (!elseStmt) {      if (NullStmt* stmt = dyn_cast<NullStmt>(thenStmt)) -      Diag(stmt->getSemiLoc(), diag::warn_empty_if_body); +      if (!stmt->getLocStart().isMacroID()) +        Diag(stmt->getSemiLoc(), diag::warn_empty_if_body);    }    DiagnoseUnusedExprResult(elseStmt); diff --git a/clang/test/Sema/if-empty-body.c b/clang/test/Sema/if-empty-body.c index af1e62f6b1b..b28c1cdce96 100644 --- a/clang/test/Sema/if-empty-body.c +++ b/clang/test/Sema/if-empty-body.c @@ -14,3 +14,11 @@ void f3() {    return;    // no empty body warning.  } +// Don't warn about an empty body if is expanded from a macro. +void f4(int i) { +  #define BODY ; +  if (i == i) // expected-warning{{self-comparison always evaluates to true}} +    BODY +  #undef BODY +} + | 

