rewrite-modern-class.mm
1.42 KB
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
// RUN: %clang_cc1 -x objective-c++ -Wno-return-type -fblocks -fms-extensions -rewrite-objc %s -o %t-rw.cpp
// RUN: %clang_cc1 -fsyntax-only -std=gnu++98 -fblocks -Wno-address-of-temporary -D"Class=void*" -D"id=void*" -D"SEL=void*" -D"__declspec(X)=" %t-rw.cpp
@protocol PROTO @end
@interface empty_root @end
@interface root_with_ivars
{
id ROOT_IVAR;
id ROOT1_IVAR;
}
@end
@interface MAXIMAL : root_with_ivars<PROTO>
{
double D_IVAR;
double D_PROPERTY;
}
- (void) V_METH;
@end
@implementation MAXIMAL
- (void) V_METH {}
@end
//=========================================
@interface empty_class @end
@implementation empty_class @end
//=========================================
@interface class_empty_root : empty_root @end
@implementation class_empty_root @end
//=========================================
@interface class_with_ivars : empty_root
{
int class_with_ivars_IVAR;
}
@end
@implementation class_with_ivars @end
//=========================================
@interface class_has_no_ivar : root_with_ivars @end
@implementation class_has_no_ivar @end
//============================class needs to be synthesized here=====================
@interface SUPER {
@public
double divar;
SUPER *p_super;
}
@end
@interface INTF @end
@implementation INTF
- (SUPER *) Meth : (SUPER *)arg {
return arg->p_super;
}
@end
@class FORM_CLASS;
@interface INTF_DECL {
}
@end
double Meth(INTF_DECL *p, FORM_CLASS *f) {
return 1.34;
}