diff options
| author | Ted Kremenek <kremenek@apple.com> | 2010-02-23 01:19:11 +0000 |
|---|---|---|
| committer | Ted Kremenek <kremenek@apple.com> | 2010-02-23 01:19:11 +0000 |
| commit | bab459eaf46e4ea9c98ebed00d4abed8d05078d6 (patch) | |
| tree | 19f3d35cdde409d09eab2533fd0fb7db28305d39 /clang/lib | |
| parent | 5586096a5a2d016b70b30b1687e9e140da9b010d (diff) | |
| download | bcm5719-llvm-bab459eaf46e4ea9c98ebed00d4abed8d05078d6.tar.gz bcm5719-llvm-bab459eaf46e4ea9c98ebed00d4abed8d05078d6.zip | |
Simplify logic for determining values of 'ReturnsVoid' and 'HasNoReturn' flags.
No functionality change.
llvm-svn: 96847
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Sema/SemaChecking.cpp | 16 |
1 files changed, 7 insertions, 9 deletions
diff --git a/clang/lib/Sema/SemaChecking.cpp b/clang/lib/Sema/SemaChecking.cpp index 3617f546e08..97ad5b7dce1 100644 --- a/clang/lib/Sema/SemaChecking.cpp +++ b/clang/lib/Sema/SemaChecking.cpp @@ -2490,22 +2490,20 @@ void Sema::CheckFallThroughForFunctionDef(Decl *D, Stmt *Body, bool ReturnsVoid = false; bool HasNoReturn = false; + if (FunctionDecl *FD = dyn_cast<FunctionDecl>(D)) { // For function templates, class templates and member function templates // we'll do the analysis at instantiation time. if (FD->isDependentContext()) return; - if (FD->getResultType()->isVoidType()) - ReturnsVoid = true; - if (FD->hasAttr<NoReturnAttr>() || - FD->getType()->getAs<FunctionType>()->getNoReturnAttr()) - HasNoReturn = true; + ReturnsVoid = FD->getResultType()->isVoidType(); + HasNoReturn = FD->hasAttr<NoReturnAttr>() || + FD->getType()->getAs<FunctionType>()->getNoReturnAttr(); + } else if (ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(D)) { - if (MD->getResultType()->isVoidType()) - ReturnsVoid = true; - if (MD->hasAttr<NoReturnAttr>()) - HasNoReturn = true; + ReturnsVoid = MD->getResultType()->isVoidType(); + HasNoReturn = MD->hasAttr<NoReturnAttr>(); } // Short circuit for compilation speed. |

