summaryrefslogtreecommitdiffstats
path: root/clang/test/SemaObjC
diff options
context:
space:
mode:
authorFariborz Jahanian <fjahanian@apple.com>2009-09-14 16:40:48 +0000
committerFariborz Jahanian <fjahanian@apple.com>2009-09-14 16:40:48 +0000
commitcb1c19147fa8cf48d75dc9c6efa9c8ed1d4984d4 (patch)
treedecc76ea74bb14af126564536a94df64756e04be /clang/test/SemaObjC
parentd8530f35f52b9199ccb37debd3f9821a764b47df (diff)
downloadbcm5719-llvm-cb1c19147fa8cf48d75dc9c6efa9c8ed1d4984d4.tar.gz
bcm5719-llvm-cb1c19147fa8cf48d75dc9c6efa9c8ed1d4984d4.zip
Using the property dot-syntax to invoke a non-eixsting
structure-valued setter should cause a user error instead of crash. llvm-svn: 81769
Diffstat (limited to 'clang/test/SemaObjC')
-rw-r--r--clang/test/SemaObjC/property-error-readonly-assign.m23
1 files changed, 23 insertions, 0 deletions
diff --git a/clang/test/SemaObjC/property-error-readonly-assign.m b/clang/test/SemaObjC/property-error-readonly-assign.m
index edeff09dfad..d5cef78f18f 100644
--- a/clang/test/SemaObjC/property-error-readonly-assign.m
+++ b/clang/test/SemaObjC/property-error-readonly-assign.m
@@ -19,3 +19,26 @@ void f0(A *a, B* b) {
b.ok = 20;
}
+typedef struct {
+ int i1, i2;
+} NSRect;
+
+NSRect NSMakeRect();
+
+@interface NSWindow
+{
+ NSRect _frame;
+}
+- (NSRect)frame;
+@end
+
+@interface NSWindow (Category)
+-(void)methodToMakeClangCrash;
+@end
+
+@implementation NSWindow (Category)
+-(void)methodToMakeClangCrash
+{
+ self.frame = NSMakeRect(); // expected-error {{setter method is needed to assign to object using property assignment syntax}}
+}
+@end
OpenPOWER on IntegriCloud