annotate dmd/TypeClass.d @ 64:4290d870944a

More fixes
author korDen
date Mon, 23 Aug 2010 20:29:15 +0400
parents 51605de93870
children 2e2a5c3f943a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1 module dmd.TypeClass;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
2
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
3 import dmd.Type;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
4 import dmd.ClassDeclaration;
64
4290d870944a More fixes
korDen
parents: 56
diff changeset
5 import dmd.TypeInstance;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
6 import dmd.Loc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
7 import dmd.Dsymbol;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
8 import dmd.Scope;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
9 import dmd.OutBuffer;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
10 import dmd.HdrGenState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
11 import dmd.Expression;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
12 import dmd.Identifier;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
13 import dmd.MATCH;
64
4290d870944a More fixes
korDen
parents: 56
diff changeset
14 import dmd.DYNCAST;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
15 import dmd.CppMangleState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
16 import dmd.ArrayTypes;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
17 import dmd.TypeInfoDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
18 import dmd.TY;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
19 import dmd.MOD;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
20 import dmd.Global;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
21 import dmd.TypePointer;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
22 import dmd.Declaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
23 import dmd.VarDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
24 import dmd.TOK;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
25 import dmd.DotExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
26 import dmd.Id;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
27 import dmd.ScopeExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
28 import dmd.DotVarExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
29 import dmd.VarExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
30 import dmd.PtrExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
31 import dmd.AddExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
32 import dmd.IntegerExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
33 import dmd.DotIdExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
34 import dmd.EnumMember;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
35 import dmd.TemplateMixin;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
36 import dmd.TemplateDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
37 import dmd.TemplateInstance;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
38 import dmd.OverloadSet;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
39 import dmd.DotTypeExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
40 import dmd.TupleExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
41 import dmd.ClassInfoDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
42 import dmd.TypeInfoInterfaceDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
43 import dmd.TypeInfoClassDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
44 import dmd.Util;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
45 import dmd.NullExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
46 import dmd.TypeExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
47 import dmd.DotTemplateExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
48 import dmd.ErrorExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
49 import dmd.ThisExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
50 import dmd.CommaExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
51
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
52 import dmd.expression.Util;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
53 import dmd.backend.Symbol;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
54 import dmd.backend.TYPE;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
55 import dmd.backend.Util;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
56 import dmd.backend.SC;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
57 import dmd.backend.STR;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
58 import dmd.backend.TYM;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
59 import dmd.backend.LIST;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
60 import dmd.backend.Classsym;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
61
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
62 import std.string : toStringz;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
63
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
64 class TypeClass : Type
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
65 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
66 ClassDeclaration sym;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
67
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
68 this(ClassDeclaration sym)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
69 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
70 super(TY.Tclass);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
71 this.sym = sym;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
72 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
73
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
74 version (DumbClone) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
75 } else {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
76 Type clone()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
77 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
78 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
79 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
80 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
81 ulong size(Loc loc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
82 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
83 return PTRSIZE;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
84 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
85
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
86 string toChars()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
87 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
88 if (mod)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
89 return Type.toChars();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
90 return sym.toPrettyChars();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
91 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
92
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
93 Type syntaxCopy()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
94 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
95 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
96 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
97
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
98 Type semantic(Loc loc, Scope sc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
99 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
100 //printf("TypeClass.semantic(%s)\n", sym.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
101 if (deco)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
102 return this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
103 //printf("\t%s\n", merge().deco);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
104 return merge();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
105 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
106
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
107 Dsymbol toDsymbol(Scope sc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
108 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
109 return sym;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
110 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
111
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
112 void toDecoBuffer(OutBuffer buf, int flag)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
113 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
114 string name = sym.mangle();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
115 //printf("TypeClass.toDecoBuffer('%s' flag=%d mod=%x) = '%s'\n", toChars(), flag, mod, name);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
116 Type.toDecoBuffer(buf, flag);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
117 buf.printf("%s", name);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
118 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
119
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
120 void toCBuffer2(OutBuffer buf, HdrGenState* hgs, MOD mod)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
121 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
122 if (mod != this.mod)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
123 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
124 toCBuffer3(buf, hgs, mod);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
125 return;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
126 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
127 buf.writestring(sym.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
128 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
129
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
130 Expression dotExp(Scope sc, Expression e, Identifier ident)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
131 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
132 uint offset;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
133
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
134 Expression b;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
135 VarDeclaration v;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
136 Dsymbol s;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
137
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
138 version (LOGDOTEXP) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
139 printf("TypeClass.dotExp(e='%s', ident='%s')\n", e.toChars(), ident.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
140 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
141
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
142 if (e.op == TOK.TOKdotexp)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
143 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
144 DotExp de = cast(DotExp)e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
145
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
146 if (de.e1.op == TOK.TOKimport)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
147 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
148 ScopeExp se = cast(ScopeExp)de.e1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
149
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
150 s = se.sds.search(e.loc, ident, 0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
151 e = de.e1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
152 goto L1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
153 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
154 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
155
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
156 if (ident is Id.tupleof_)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
157 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
158 /* Create a TupleExp
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
159 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
160 e = e.semantic(sc); // do this before turning on noaccesscheck
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
161 Expressions exps = new Expressions;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
162 exps.reserve(sym.fields.dim);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
163 for (size_t i = 0; i < sym.fields.dim; i++)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
164 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
165 VarDeclaration v2 = cast(VarDeclaration)sym.fields.data[i];
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
166 Expression fe = new DotVarExp(e.loc, e, v2);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
167 exps.push(cast(void*)fe);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
168 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
169 e = new TupleExp(e.loc, exps);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
170 sc = sc.push();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
171 sc.noaccesscheck = 1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
172 e = e.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
173 sc.pop();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
174 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
175 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
176
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
177 s = sym.search(e.loc, ident, 0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
178 L1:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
179 if (!s)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
180 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
181 // See if it's a base class
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
182 ClassDeclaration cbase;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
183 for (cbase = sym.baseClass; cbase; cbase = cbase.baseClass)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
184 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
185 if (cbase.ident.equals(ident))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
186 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
187 e = new DotTypeExp(Loc(0), e, cbase);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
188 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
189 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
190 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
191
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
192 if (ident is Id.classinfo_)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
193 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
194 assert(ClassDeclaration.classinfo);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
195 Type t = ClassDeclaration.classinfo.type;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
196 if (e.op == TOK.TOKtype || e.op == TOK.TOKdottype)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
197 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
198 /* For type.classinfo, we know the classinfo
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
199 * at compile time.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
200 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
201 if (!sym.vclassinfo)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
202 sym.vclassinfo = new ClassInfoDeclaration(sym);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
203
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
204 e = new VarExp(e.loc, sym.vclassinfo);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
205 e = e.addressOf(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
206 e.type = t; // do this so we don't get redundant dereference
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
207 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
208 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
209 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
210 /* For class objects, the classinfo reference is the first
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
211 * entry in the vtbl[]
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
212 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
213 e = new PtrExp(e.loc, e);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
214 e.type = t.pointerTo();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
215 if (sym.isInterfaceDeclaration())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
216 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
217 if (sym.isCPPinterface())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
218 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
219 /* C++ interface vtbl[]s are different in that the
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
220 * first entry is always pointer to the first virtual
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
221 * function, not classinfo.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
222 * We can't get a .classinfo for it.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
223 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
224 error(e.loc, "no .classinfo for C++ interface objects");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
225 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
226 /* For an interface, the first entry in the vtbl[]
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
227 * is actually a pointer to an instance of struct Interface.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
228 * The first member of Interface is the .classinfo,
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
229 * so add an extra pointer indirection.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
230 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
231 e.type = e.type.pointerTo();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
232 e = new PtrExp(e.loc, e);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
233 e.type = t.pointerTo();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
234 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
235 e = new PtrExp(e.loc, e, t);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
236 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
237 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
238 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
239
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
240 if (ident is Id.__vptr)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
241 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
242 /* The pointer to the vtbl[]
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
243 * *cast(invariant(void*)**)e
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
244 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
245 e = e.castTo(sc, tvoidptr.invariantOf().pointerTo().pointerTo());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
246 e = new PtrExp(e.loc, e);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
247 e = e.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
248 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
249 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
250
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
251 if (ident is Id.__monitor)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
252 { /* The handle to the monitor (call it a void*)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
253 * *(cast(void**)e + 1)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
254 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
255 e = e.castTo(sc, tvoidptr.pointerTo());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
256 e = new AddExp(e.loc, e, new IntegerExp(1));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
257 e = new PtrExp(e.loc, e);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
258 e = e.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
259 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
260 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
261
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
262 if (ident is Id.typeinfo_)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
263 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
264 if (!global.params.useDeprecated)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
265 error(e.loc, ".typeinfo deprecated, use typeid(type)");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
266
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
267 return getTypeInfo(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
268 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
269 if (ident is Id.outer && sym.vthis)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
270 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
271 s = sym.vthis;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
272 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
273 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
274 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
275 if (ident !is Id.__sizeof &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
276 ident !is Id.alignof_ &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
277 ident !is Id.init_ &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
278 ident !is Id.mangleof_ &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
279 ident !is Id.stringof_ &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
280 ident !is Id.offsetof)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
281 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
282 /* See if we should forward to the alias this.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
283 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
284 if (sym.aliasthis)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
285 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
286 /* Rewrite e.ident as:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
287 * e.aliasthis.ident
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
288 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
289 e = new DotIdExp(e.loc, e, sym.aliasthis.ident);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
290 e = new DotIdExp(e.loc, e, ident);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
291 return e.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
292 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
293
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
294 /* Look for overloaded opDot() to see if we should forward request
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
295 * to it.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
296 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
297 Dsymbol fd = search_function(sym, Id.opDot);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
298 if (fd)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
299 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
300 /* Rewrite e.ident as:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
301 * e.opId().ident
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
302 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
303 e = build_overload(e.loc, sc, e, null, fd.ident);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
304 e = new DotIdExp(e.loc, e, ident);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
305 return e.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
306 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
307 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
308
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
309 return Type.dotExp(sc, e, ident);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
310 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
311 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
312
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
313 if (!s.isFuncDeclaration()) // because of overloading
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
314 s.checkDeprecated(e.loc, sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
315
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
316 s = s.toAlias();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
317 v = s.isVarDeclaration();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
318
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
319 if (v && !v.isDataseg())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
320 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
321 Expression ei = v.getConstInitializer();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
322
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
323 if (ei)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
324 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
325 e = ei.copy(); // need to copy it if it's a StringExp
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
326 e = e.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
327 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
328 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
329 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
330
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
331 if (s.getType())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
332 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
333 // if (e.op == TOKtype)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
334 return new TypeExp(e.loc, s.getType());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
335 // return new DotTypeExp(e.loc, e, s);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
336 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
337
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
338 EnumMember em = s.isEnumMember();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
339 if (em)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
340 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
341 assert(em.value);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
342 return em.value.copy();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
343 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
344
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
345 TemplateMixin tm = s.isTemplateMixin();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
346 if (tm)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
347 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
348 Expression de = new DotExp(e.loc, e, new ScopeExp(e.loc, tm));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
349 de.type = e.type;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
350 return de;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
351 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
352
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
353 TemplateDeclaration td = s.isTemplateDeclaration();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
354 if (td)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
355 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
356 e = new DotTemplateExp(e.loc, e, td);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
357 e.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
358 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
359 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
360
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
361 TemplateInstance ti = s.isTemplateInstance();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
362 if (ti)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
363 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
364 if (!ti.semanticRun)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
365 ti.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
366 s = ti.inst.toAlias();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
367 if (!s.isTemplateInstance())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
368 goto L1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
369 Expression de = new DotExp(e.loc, e, new ScopeExp(e.loc, ti));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
370 de.type = e.type;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
371 return de;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
372 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
373
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
374 OverloadSet o = s.isOverloadSet();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
375 if (o)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
376 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
377 /* We really should allow this
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
378 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
379 error(e.loc, "overload set for %s.%s not allowed in struct declaration", e.toChars(), ident.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
380 return new ErrorExp();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
381 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
382
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
383 Declaration d = s.isDeclaration();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
384 if (!d)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
385 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
386 e.error("%s.%s is not a declaration", e.toChars(), ident.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
387 return new ErrorExp();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
388 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
389
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
390 if (e.op == TOK.TOKtype)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
391 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
392 /* It's:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
393 * Class.d
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
394 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
395 if (d.isTupleDeclaration())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
396 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
397 e = new TupleExp(e.loc, d.isTupleDeclaration());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
398 e = e.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
399 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
400 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
401 else if (d.needThis() && (hasThis(sc) || !d.isFuncDeclaration()))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
402 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
403 if (sc.func)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
404 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
405 ClassDeclaration thiscd;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
406 thiscd = sc.func.toParent().isClassDeclaration();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
407
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
408 if (thiscd)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
409 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
410 ClassDeclaration cd = e.type.isClassHandle();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
411
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
412 if (cd is thiscd)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
413 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
414 e = new ThisExp(e.loc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
415 e = new DotTypeExp(e.loc, e, cd);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
416 DotVarExp de = new DotVarExp(e.loc, e, d);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
417 e = de.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
418 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
419 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
420 else if ((!cd || !cd.isBaseOf(thiscd, null)) && !d.isFuncDeclaration())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
421 e.error("'this' is required, but %s is not a base class of %s", e.type.toChars(), thiscd.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
422 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
423 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
424
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
425 /* Rewrite as:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
426 * this.d
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
427 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
428 DotVarExp de = new DotVarExp(e.loc, new ThisExp(e.loc), d);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
429 e = de.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
430 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
431 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
432 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
433 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
434 VarExp ve = new VarExp(e.loc, d, 1);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
435 return ve;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
436 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
437 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
438
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
439 if (d.isDataseg())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
440 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
441 // (e, d)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
442 accessCheck(e.loc, sc, e, d);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
443 VarExp ve = new VarExp(e.loc, d);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
444 e = new CommaExp(e.loc, e, ve);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
445 e.type = d.type;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
446 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
447 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
448
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
449 if (d.parent && d.toParent().isModule())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
450 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
451 // (e, d)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
452 VarExp ve = new VarExp(e.loc, d, 1);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
453 e = new CommaExp(e.loc, e, ve);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
454 e.type = d.type;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
455 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
456 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
457
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
458 DotVarExp de = new DotVarExp(e.loc, e, d);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
459 return de.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
460 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
461
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
462 ClassDeclaration isClassHandle()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
463 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
464 return sym;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
465 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
466
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
467 bool isBaseOf(Type t, int* poffset)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
468 {
56
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
469 if (t.ty == Tclass)
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
470 {
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
471 ClassDeclaration cd;
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
472
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
473 cd = (cast(TypeClass)t).sym;
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
474 if (sym.isBaseOf(cd, poffset))
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
475 return true;
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
476 }
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
477
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
478 return false;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
479 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
480
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
481 MATCH implicitConvTo(Type to)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
482 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
483 //printf("TypeClass.implicitConvTo(to = '%s') %s\n", to.toChars(), toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
484 MATCH m = constConv(to);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
485 if (m != MATCH.MATCHnomatch)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
486 return m;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
487
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
488 ClassDeclaration cdto = to.isClassHandle();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
489 if (cdto && cdto.isBaseOf(sym, null))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
490 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
491 //printf("'to' is base\n");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
492 return MATCH.MATCHconvert;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
493 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
494
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
495 if (global.params.Dversion == 1)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
496 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
497 // Allow conversion to (void *)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
498 if (to.ty == TY.Tpointer && (cast(TypePointer)to).next.ty == TY.Tvoid)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
499 return MATCH.MATCHconvert;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
500 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
501
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
502 m = MATCH.MATCHnomatch;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
503 if (sym.aliasthis)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
504 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
505 Declaration d = sym.aliasthis.isDeclaration();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
506 if (d)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
507 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
508 assert(d.type);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
509 Type t = d.type.addMod(mod);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
510 m = t.implicitConvTo(to);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
511 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
512 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
513
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
514 return m;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
515 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
516
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
517 Expression defaultInit(Loc loc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
518 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
519 version (LOGDEFAULTINIT) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
520 printf("TypeClass::defaultInit() '%s'\n", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
521 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
522 Expression e = new NullExp(loc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
523 e.type = this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
524 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
525 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
526
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
527 bool isZeroInit(Loc loc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
528 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
529 return true;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
530 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
531
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
532 MATCH deduceType(Scope sc, Type tparam, TemplateParameters parameters, Objects dedtypes)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
533 {
64
4290d870944a More fixes
korDen
parents: 56
diff changeset
534 //printf("TypeClass.deduceType(this = %s)\n", toChars());
4290d870944a More fixes
korDen
parents: 56
diff changeset
535
4290d870944a More fixes
korDen
parents: 56
diff changeset
536 /* If this class is a template class, and we're matching
4290d870944a More fixes
korDen
parents: 56
diff changeset
537 * it against a template instance, convert the class type
4290d870944a More fixes
korDen
parents: 56
diff changeset
538 * to a template instance, too, and try again.
4290d870944a More fixes
korDen
parents: 56
diff changeset
539 */
4290d870944a More fixes
korDen
parents: 56
diff changeset
540 TemplateInstance ti = sym.parent.isTemplateInstance();
4290d870944a More fixes
korDen
parents: 56
diff changeset
541
4290d870944a More fixes
korDen
parents: 56
diff changeset
542 if (tparam && tparam.ty == Tinstance)
4290d870944a More fixes
korDen
parents: 56
diff changeset
543 {
4290d870944a More fixes
korDen
parents: 56
diff changeset
544 if (ti && ti.toAlias() == sym)
4290d870944a More fixes
korDen
parents: 56
diff changeset
545 {
4290d870944a More fixes
korDen
parents: 56
diff changeset
546 TypeInstance t = new TypeInstance(Loc(0), ti);
4290d870944a More fixes
korDen
parents: 56
diff changeset
547 return t.deduceType(sc, tparam, parameters, dedtypes);
4290d870944a More fixes
korDen
parents: 56
diff changeset
548 }
4290d870944a More fixes
korDen
parents: 56
diff changeset
549
4290d870944a More fixes
korDen
parents: 56
diff changeset
550 /* Match things like:
4290d870944a More fixes
korDen
parents: 56
diff changeset
551 * S!(T).foo
4290d870944a More fixes
korDen
parents: 56
diff changeset
552 */
4290d870944a More fixes
korDen
parents: 56
diff changeset
553 TypeInstance tpi = cast(TypeInstance)tparam;
4290d870944a More fixes
korDen
parents: 56
diff changeset
554 if (tpi.idents.dim)
4290d870944a More fixes
korDen
parents: 56
diff changeset
555 { Identifier id = cast(Identifier)tpi.idents.data[tpi.idents.dim - 1];
4290d870944a More fixes
korDen
parents: 56
diff changeset
556 if (id.dyncast() == DYNCAST.DYNCAST_IDENTIFIER && sym.ident.equals(id))
4290d870944a More fixes
korDen
parents: 56
diff changeset
557 {
4290d870944a More fixes
korDen
parents: 56
diff changeset
558 Type tparent = sym.parent.getType();
4290d870944a More fixes
korDen
parents: 56
diff changeset
559 if (tparent)
4290d870944a More fixes
korDen
parents: 56
diff changeset
560 {
4290d870944a More fixes
korDen
parents: 56
diff changeset
561 /* Slice off the .foo in S!(T).foo
4290d870944a More fixes
korDen
parents: 56
diff changeset
562 */
4290d870944a More fixes
korDen
parents: 56
diff changeset
563 tpi.idents.dim--;
4290d870944a More fixes
korDen
parents: 56
diff changeset
564 MATCH m = tparent.deduceType(sc, tpi, parameters, dedtypes);
4290d870944a More fixes
korDen
parents: 56
diff changeset
565 tpi.idents.dim++;
4290d870944a More fixes
korDen
parents: 56
diff changeset
566 return m;
4290d870944a More fixes
korDen
parents: 56
diff changeset
567 }
4290d870944a More fixes
korDen
parents: 56
diff changeset
568 }
4290d870944a More fixes
korDen
parents: 56
diff changeset
569 }
4290d870944a More fixes
korDen
parents: 56
diff changeset
570 }
4290d870944a More fixes
korDen
parents: 56
diff changeset
571
4290d870944a More fixes
korDen
parents: 56
diff changeset
572 // Extra check
4290d870944a More fixes
korDen
parents: 56
diff changeset
573 if (tparam && tparam.ty == Tclass)
4290d870944a More fixes
korDen
parents: 56
diff changeset
574 {
4290d870944a More fixes
korDen
parents: 56
diff changeset
575 TypeClass tp = cast(TypeClass)tparam;
4290d870944a More fixes
korDen
parents: 56
diff changeset
576
4290d870944a More fixes
korDen
parents: 56
diff changeset
577 //printf("\t%d\n", (MATCH) implicitConvTo(tp));
4290d870944a More fixes
korDen
parents: 56
diff changeset
578 return implicitConvTo(tp);
4290d870944a More fixes
korDen
parents: 56
diff changeset
579 }
4290d870944a More fixes
korDen
parents: 56
diff changeset
580 return Type.deduceType(sc, tparam, parameters, dedtypes);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
581 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
582
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
583 bool isauto()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
584 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
585 return sym.isauto;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
586 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
587
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
588 bool checkBoolean()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
589 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
590 return true;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
591 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
592
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
593 TypeInfoDeclaration getTypeInfoDeclaration()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
594 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
595 if (sym.isInterfaceDeclaration())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
596 return new TypeInfoInterfaceDeclaration(this);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
597 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
598 return new TypeInfoClassDeclaration(this);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
599 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
600
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
601 bool hasPointers()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
602 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
603 return true;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
604 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
605
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
606 bool builtinTypeInfo()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
607 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
608 /* This is statically put out with the ClassInfo, so
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
609 * claim it is built in so it isn't regenerated by each module.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
610 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
611 version (DMDV2) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
612 return mod ? false : true;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
613 } else {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
614 return true;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
615 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
616 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
617
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
618 version (DMDV2) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
619 Type toHeadMutable()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
620 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
621 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
622 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
623
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
624 MATCH constConv(Type to)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
625 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
626 if (equals(to))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
627 return MATCH.MATCHexact;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
628
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
629 if (ty == to.ty && sym == (cast(TypeClass)to).sym && to.mod == MOD.MODconst)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
630 return MATCH.MATCHconst;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
631
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
632 return MATCH.MATCHnomatch;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
633 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
634
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
635 version (CPP_MANGLE) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
636 void toCppMangle(OutBuffer buf, CppMangleState* cms)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
637 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
638 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
639 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
640 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
641 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
642
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
643 type* toCtype()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
644 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
645 type* t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
646 Symbol* s;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
647
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
648 //printf("TypeClass.toCtype() %s\n", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
649 if (ctype)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
650 return ctype;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
651
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
652 /* Need this symbol to do C++ name mangling
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
653 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
654 string name = sym.isCPPinterface() ? sym.ident.toChars() : sym.toPrettyChars();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
655 s = symbol_calloc(toStringz(name));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
656 s.Sclass = SC.SCstruct;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
657 s.Sstruct = struct_calloc();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
658 s.Sstruct.Sflags |= STR.STRclass;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
659 s.Sstruct.Salignsize = sym.alignsize;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
660 s.Sstruct.Sstructalign = cast(ubyte)sym.structalign;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
661 s.Sstruct.Sstructsize = sym.structsize;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
662
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
663 t = type_alloc(TYM.TYstruct);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
664 t.Ttag = cast(Classsym*)s; // structure tag name
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
665 t.Tcount++;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
666 s.Stype = t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
667 slist_add(s);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
668
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
669 t = type_allocn(TYM.TYnptr, t);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
670
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
671 t.Tcount++;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
672 ctype = t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
673
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
674 /* Add in fields of the class
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
675 * (after setting ctype to avoid infinite recursion)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
676 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
677 if (global.params.symdebug)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
678 for (int i = 0; i < sym.fields.dim; i++)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
679 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
680 VarDeclaration v = cast(VarDeclaration)sym.fields.data[i];
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
681
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
682 Symbol* s2 = symbol_name(toStringz(v.ident.toChars()), SC.SCmember, v.type.toCtype());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
683 s2.Smemoff = v.offset;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
684 list_append(&s.Sstruct.Sfldlst, s2);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
685 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
686
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
687 return t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
688 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
689
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
690 Symbol* toSymbol()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
691 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
692 return sym.toSymbol();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
693 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
694 }