llvm-capstone/clang/test/SemaObjC/property-error-readonly-assign.m
Aaron Ballman 7deaeb2a05 Use functions with prototypes when appropriate; NFC
A significant number of our tests in C accidentally use functions
without prototypes. This patch converts the function signatures to have
a prototype for the situations where the test is not specific to K&R C
declarations. e.g.,

  void func();

becomes

  void func(void);

This is the fourth batch of tests being updated (there are a significant
number of other tests left to be updated).
2022-02-07 15:29:36 -05:00

45 lines
778 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 {{assignment to readonly property}}
a.ok = 20;
b.x = 10; // expected-error {{no setter method 'setX:' for assignment to property}}
b.ok = 20;
}
typedef struct {
int i1, i2;
} NSRect;
NSRect NSMakeRect(void);
@interface NSWindow
{
NSRect _frame;
}
- (NSRect)frame;
@end
@interface NSWindow (Category)
-(void)methodToMakeClangCrash;
@end
@implementation NSWindow (Category)
-(void)methodToMakeClangCrash
{
self.frame = NSMakeRect(); // expected-error {{no setter method 'setFrame:' for assignment to property}}
}
@end