llvm-project/clang/test/SemaObjC/property-error-readonly-assign.m
Daniel Dunbar 8fbe78f6fc Update tests to use %clang_cc1 instead of 'clang-cc' or 'clang -cc1'.
- This is designed to make it obvious that %clang_cc1 is a "test variable"
   which is substituted. It is '%clang_cc1' instead of '%clang -cc1' because it
   can be useful to redefine what gets run as 'clang -cc1' (for example, to set
   a default target).

llvm-svn: 91446
2009-12-15 20:14:24 +00:00

45 lines
848 B
Objective-C

// RUN: %clang_cc1 -fsyntax-only -verify %s
@interface A
-(int) x;
@property (readonly) int x;
@property int ok;
@end
@interface B
-(void) setOk:(int)arg;
-(int) x;
-(int) ok;
@end
void f0(A *a, B* b) {
a.x = 10; // expected-error {{assigning to property with 'readonly' attribute not allowed}}
a.ok = 20;
b.x = 10; // expected-error {{setter method is needed to assign to object using property assignment syntax}}
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