aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2008-10-06 20:58:11 +0000
committerTed Kremenek <kremenek@apple.com>2008-10-06 20:58:11 +0000
commitf34afeed9a0112bf31fee185b6c80556111d3834 (patch)
tree1fc83a8c90f90e48aa35dc9f036c8f1f75089ac0
parent53061c842d287b73500c47141f0059792631ed89 (diff)
When processing Objective-C foreach statements, first check to see if the statement has a DeclStmt with a single Decl. Afterwards, use DeclStmt::getSolitaryDecl() to access that Decl (thus avoiding an assertion being triggered). These changes remove an unneeded use of ScopedDecl::getNextDeclarator() and DeclStmt::getDecl().
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@57207 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/Sema/SemaStmt.cpp10
1 files changed, 6 insertions, 4 deletions
diff --git a/lib/Sema/SemaStmt.cpp b/lib/Sema/SemaStmt.cpp
index cb61ce969b..68b36ba818 100644
--- a/lib/Sema/SemaStmt.cpp
+++ b/lib/Sema/SemaStmt.cpp
@@ -589,15 +589,17 @@ Sema::ActOnObjCForCollectionStmt(SourceLocation ForLoc,
if (First) {
QualType FirstType;
if (DeclStmt *DS = dyn_cast<DeclStmt>(First)) {
- FirstType = cast<ValueDecl>(DS->getDecl())->getType();
+ if (!DS->hasSolitaryDecl())
+ return Diag((*DS->decl_begin())->getLocation(),
+ diag::err_toomany_element_decls);
+
+ ScopedDecl *D = DS->getSolitaryDecl();
+ FirstType = cast<ValueDecl>(D)->getType();
// C99 6.8.5p3: The declaration part of a 'for' statement shall only declare
// identifiers for objects having storage class 'auto' or 'register'.
- ScopedDecl *D = DS->getDecl();
VarDecl *VD = cast<VarDecl>(D);
if (VD->isBlockVarDecl() && !VD->hasLocalStorage())
return Diag(VD->getLocation(), diag::err_non_variable_decl_in_for);
- if (D->getNextDeclarator())
- return Diag(D->getLocation(), diag::err_toomany_element_decls);
} else {
Expr::isLvalueResult lval = cast<Expr>(First)->isLvalue(Context);