blob: 837d303f317df3125edf31d8ad72573832afcf63 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
/* Basic test, auto-generated getter/setter based on named ivar */
/* { dg-do run } */
/* { dg-xfail-run-if "Needs OBJC2 ABI" { *-*-darwin* && { lp64 && { ! objc2 } } } { "-fnext-runtime" } { "" } } */
extern int printf (char *fmt,...) ;
extern void abort (void);
typedef struct objc_class *Class;
#ifdef __NEXT_RUNTIME__
extern id class_createInstance(Class, long);
#define class_create_instance(C) class_createInstance(C, 0)
#else
extern id class_create_instance(Class);
#endif
@interface Bar
{
@public
#ifdef __NEXT_RUNTIME__
Class isa;
#else
Class class_pointer;
#endif
int var;
}
+ (id) initialize;
+ (id) alloc ;
- (id) init;
@property int FooBar;
@end
@implementation Bar
+initialize { return self;}
+ (id) alloc { return class_create_instance(self);}
- (id) init {return self;}
@property (ivar = var) int FooBar ;
@end
int main(int argc, char *argv[]) {
int res;
Bar *f = [[Bar alloc] init];
/* First, establish that the property getter & setter have been synthesized
and operate correctly. */
[f setFooBar:1234];
if (f->var != 1234)
{ printf ("setFooBar did not set var correctly\n"); abort ();}
res = [f FooBar];
if (res != 1234 )
{ printf ("[f FooBar] = %d\n", res); abort ();}
/* Now check the short-cut CLASS.property syntax. */
/* Read .... */
res = f.FooBar;
if (res != 1234 )
{ printf ("f.FooBar = %d\n", res); abort ();}
/* ... and write. */
f.FooBar = 0;
/* printf ("seems OK\n", res); */
return f.FooBar;
}
|