summaryrefslogtreecommitdiffstats
path: root/clang/lib
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2008-08-25 18:16:36 +0000
committerAnders Carlsson <andersca@mac.com>2008-08-25 18:16:36 +0000
commit1ec2ccd8ee06f14239fdf27931aaeac8d6a3a144 (patch)
tree675605d12f0d2e1ac04df0c610b24c8607146edd /clang/lib
parentdab94255474cc49516d4afba7cfa0b9815398c7b (diff)
downloadbcm5719-llvm-1ec2ccd8ee06f14239fdf27931aaeac8d6a3a144.tar.gz
bcm5719-llvm-1ec2ccd8ee06f14239fdf27931aaeac8d6a3a144.zip
Objective-C foreach selector elements must be lvalues.
llvm-svn: 55316
Diffstat (limited to 'clang/lib')
-rw-r--r--clang/lib/Sema/SemaStmt.cpp13
1 files changed, 10 insertions, 3 deletions
diff --git a/clang/lib/Sema/SemaStmt.cpp b/clang/lib/Sema/SemaStmt.cpp
index 619eb772c34..629ab3465dd 100644
--- a/clang/lib/Sema/SemaStmt.cpp
+++ b/clang/lib/Sema/SemaStmt.cpp
@@ -562,11 +562,18 @@ Sema::ActOnObjCForCollectionStmt(SourceLocation ForLoc,
return Diag(VD->getLocation(), diag::err_non_variable_decl_in_for);
if (D->getNextDeclarator())
return Diag(D->getLocation(), diag::err_toomany_element_decls);
- } else
- FirstType = static_cast<Expr*>(first)->getType();
+ } else {
+ Expr::isLvalueResult lval = cast<Expr>(First)->isLvalue(Context);
+
+ if (lval != Expr::LV_Valid)
+ return Diag(First->getLocStart(), diag::err_selector_element_not_lvalue,
+ First->getSourceRange());
+
+ FirstType = static_cast<Expr*>(first)->getType();
+ }
if (!Context.isObjCObjectPointerType(FirstType))
Diag(ForLoc, diag::err_selector_element_type,
- FirstType.getAsString(), First->getSourceRange());
+ FirstType.getAsString(), First->getSourceRange());
}
if (Second) {
DefaultFunctionArrayConversion(Second);
OpenPOWER on IntegriCloud