[cfe-commits] r74935 - in /cfe/trunk: lib/Sema/SemaExpr.cpp test/SemaObjC/property-expression-error.m
Fariborz Jahanian
fjahanian at apple.com
Tue Jul 7 11:51:24 PDT 2009
Author: fjahanian
Date: Tue Jul 7 13:50:52 2009
New Revision: 74935
URL: http://llvm.org/viewvc/llvm-project?rev=74935&view=rev
Log:
Diagnose, and not crash, when taking address of property expression.
Added:
cfe/trunk/test/SemaObjC/property-expression-error.m
Modified:
cfe/trunk/lib/Sema/SemaExpr.cpp
Modified: cfe/trunk/lib/Sema/SemaExpr.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaExpr.cpp?rev=74935&r1=74934&r2=74935&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaExpr.cpp (original)
+++ cfe/trunk/lib/Sema/SemaExpr.cpp Tue Jul 7 13:50:52 2009
@@ -4678,6 +4678,11 @@
Diag(OpLoc, diag::err_typecheck_address_of)
<< "vector element" << op->getSourceRange();
return QualType();
+ } else if (isa<ObjCPropertyRefExpr>(op)) {
+ // cannot take address of a property expression.
+ Diag(OpLoc, diag::err_typecheck_address_of)
+ << "property expression" << op->getSourceRange();
+ return QualType();
} else if (dcl) { // C99 6.5.3.2p1
// We have an lvalue with a decl. Make sure the decl is not declared
// with the register storage-class specifier.
Added: cfe/trunk/test/SemaObjC/property-expression-error.m
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaObjC/property-expression-error.m?rev=74935&view=auto
==============================================================================
--- cfe/trunk/test/SemaObjC/property-expression-error.m (added)
+++ cfe/trunk/test/SemaObjC/property-expression-error.m Tue Jul 7 13:50:52 2009
@@ -0,0 +1,18 @@
+// RUN: clang-cc -fsyntax-only -verify %s
+
+ at interface AddressMyProperties
+{
+ unsigned index;
+}
+ at property unsigned index;
+ at end
+
+ at implementation AddressMyProperties
+ at synthesize index;
+ at end
+
+int main() {
+ AddressMyProperties *object;
+ &object.index; // expected-error {{address of property expression requested}}
+ return 0;
+}
More information about the cfe-commits
mailing list