diff options
| author | Fariborz Jahanian <fjahanian@apple.com> | 2009-07-07 18:50:52 +0000 |
|---|---|---|
| committer | Fariborz Jahanian <fjahanian@apple.com> | 2009-07-07 18:50:52 +0000 |
| commit | 385db80cc574d9b6f50a396f6009275888b91375 (patch) | |
| tree | 17731268b329313abf72a93a490961fa81fddc5b | |
| parent | 32bc1e1a3be044f6da33724dd98f95a2e56ede59 (diff) | |
| download | bcm5719-llvm-385db80cc574d9b6f50a396f6009275888b91375.tar.gz bcm5719-llvm-385db80cc574d9b6f50a396f6009275888b91375.zip | |
Diagnose, and not crash, when taking address of property expression.
llvm-svn: 74935
| -rw-r--r-- | clang/lib/Sema/SemaExpr.cpp | 5 | ||||
| -rw-r--r-- | clang/test/SemaObjC/property-expression-error.m | 18 |
2 files changed, 23 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaExpr.cpp b/clang/lib/Sema/SemaExpr.cpp index d6e07bb6b39..97aae8b9679 100644 --- a/clang/lib/Sema/SemaExpr.cpp +++ b/clang/lib/Sema/SemaExpr.cpp @@ -4678,6 +4678,11 @@ QualType Sema::CheckAddressOfOperand(Expr *op, SourceLocation OpLoc) { 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. diff --git a/clang/test/SemaObjC/property-expression-error.m b/clang/test/SemaObjC/property-expression-error.m new file mode 100644 index 00000000000..b648ee939db --- /dev/null +++ b/clang/test/SemaObjC/property-expression-error.m @@ -0,0 +1,18 @@ +// RUN: clang-cc -fsyntax-only -verify %s + +@interface AddressMyProperties +{ + unsigned index; +} +@property unsigned index; +@end + +@implementation AddressMyProperties +@synthesize index; +@end + +int main() { + AddressMyProperties *object; + &object.index; // expected-error {{address of property expression requested}} + return 0; +} |

