diff options
| author | Chandler Carruth <chandlerc@gmail.com> | 2011-09-10 00:02:34 +0000 |
|---|---|---|
| committer | Chandler Carruth <chandlerc@gmail.com> | 2011-09-10 00:02:34 +0000 |
| commit | a626d645d5f6ddd1f8c5ed3b6664af17e559ee5f (patch) | |
| tree | f0c44e827249462c35738109a0a3d255d6186144 /clang/lib/Analysis | |
| parent | 1bbf030b8e927c62678d62097d8bd652809a1e2d (diff) | |
| download | bcm5719-llvm-a626d645d5f6ddd1f8c5ed3b6664af17e559ee5f.tar.gz bcm5719-llvm-a626d645d5f6ddd1f8c5ed3b6664af17e559ee5f.zip | |
Extend the Stmt AST to make it easier to look through label, default,
and case statements. Use this to make the logic in the CFG builder more
robust at finding the actual statements within a compound statement,
even when there are many layers of labels obscuring it.
Also extend the test cases for a large chunk of PR10063. Still more work
to do here though.
llvm-svn: 139437
Diffstat (limited to 'clang/lib/Analysis')
| -rw-r--r-- | clang/lib/Analysis/CFG.cpp | 8 |
1 files changed, 2 insertions, 6 deletions
diff --git a/clang/lib/Analysis/CFG.cpp b/clang/lib/Analysis/CFG.cpp index 393feffdada..d385420a567 100644 --- a/clang/lib/Analysis/CFG.cpp +++ b/clang/lib/Analysis/CFG.cpp @@ -723,9 +723,7 @@ void CFGBuilder::addLocalScopeForStmt(Stmt *S) { if (CompoundStmt *CS = dyn_cast<CompoundStmt>(S)) { for (CompoundStmt::body_iterator BI = CS->body_begin(), BE = CS->body_end() ; BI != BE; ++BI) { - Stmt *SI = *BI; - if (LabelStmt *LS = dyn_cast<LabelStmt>(SI)) - SI = LS->getSubStmt(); + Stmt *SI = (*BI)->stripLabelLikeStatements(); if (DeclStmt *DS = dyn_cast<DeclStmt>(SI)) Scope = addLocalScopeForDeclStmt(DS, Scope); } @@ -734,9 +732,7 @@ void CFGBuilder::addLocalScopeForStmt(Stmt *S) { // For any other statement scope will be implicit and as such will be // interesting only for DeclStmt. - if (LabelStmt *LS = dyn_cast<LabelStmt>(S)) - S = LS->getSubStmt(); - if (DeclStmt *DS = dyn_cast<DeclStmt>(S)) + if (DeclStmt *DS = dyn_cast<DeclStmt>(S->stripLabelLikeStatements())) addLocalScopeForDeclStmt(DS); } |

