aboutsummaryrefslogtreecommitdiff
path: root/lib/Sema/SemaStmt.cpp
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
commit1fe379f0fa6fbc0a6057e8966253aea2957ca953 (patch)
tree45f79d75fd93db228f466cf4cfa49c2352b94aad /lib/Sema/SemaStmt.cpp
parentd1d66bcd6914ff82abdfa88dd25bb0b74cde3b99 (diff)
Objective-C foreach selector elements must be lvalues.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@55316 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaStmt.cpp')
-rw-r--r--lib/Sema/SemaStmt.cpp13
1 files changed, 10 insertions, 3 deletions
diff --git a/lib/Sema/SemaStmt.cpp b/lib/Sema/SemaStmt.cpp
index 619eb772c3..629ab3465d 100644
--- a/lib/Sema/SemaStmt.cpp
+++ b/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);