annotate dmd/Expression.d @ 2:7427ded8caf7

Removed unreferenced modules First step at fixing GC issues - now calling GC.malloc instead of malloc (ditto calloc and realloc), get rid of free
author korDen
date Sun, 25 Oct 2009 03:20:59 +0300
parents 10317f0c89a5
children d706d958e4e8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1 module dmd.Expression;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
2
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
3 import dmd.Loc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
4 import dmd.TOK;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
5 import dmd.Type;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
6 import dmd.WANT;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
7 import dmd.Scope;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
8 import dmd.ArrayTypes;
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.MATCH;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
12 import dmd.IntRange;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
13 import dmd.Dsymbol;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
14 import dmd.FuncDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
15 import dmd.InterState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
16 import dmd.InlineCostState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
17 import dmd.InlineDoState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
18 import dmd.InlineScanState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
19 import dmd.Identifier;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
20 import dmd.IRState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
21 import dmd.DotIdExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
22 import dmd.TypeExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
23 import dmd.DYNCAST;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
24 import dmd.TY;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
25 import dmd.CallExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
26 import dmd.VarExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
27 import dmd.STC;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
28 import dmd.TemplateInstance;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
29 import dmd.CommaExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
30 import dmd.NullExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
31 import dmd.AddrExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
32 import dmd.ErrorExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
33 import dmd.TypeStruct;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
34 import dmd.CastExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
35 import dmd.Global;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
36 import dmd.Token;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
37 import dmd.TypeClass;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
38 import dmd.PtrExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
39 import dmd.TypeSArray;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
40 import dmd.TypeReference;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
41 import dmd.Util;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
42 import dmd.Complex;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
43
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
44 import dmd.backend.elem;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
45 import dmd.backend.dt_t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
46
2
7427ded8caf7 Removed unreferenced modules
korDen
parents: 0
diff changeset
47 import dmd.Memory;
7427ded8caf7 Removed unreferenced modules
korDen
parents: 0
diff changeset
48
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
49 import std.stdio : writef;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
50 import core.stdc.stdlib : malloc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
51
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
52 import std.conv;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
53
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
54 /* Things like:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
55 * int.size
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
56 * foo.size
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
57 * (foo).size
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
58 * cast(foo).size
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
59 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
60
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
61 Expression typeDotIdExp(Loc loc, Type type, Identifier ident)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
62 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
63 return new DotIdExp(loc, new TypeExp(loc, type), ident);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
64 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
65
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
66 /*****************************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
67 * Determine if 'this' is available.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
68 * If it is, return the FuncDeclaration that has it.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
69 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
70
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
71 FuncDeclaration hasThis(Scope sc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
72 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
73 FuncDeclaration fd;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
74 FuncDeclaration fdthis;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
75
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
76 //printf("hasThis()\n");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
77 fdthis = sc.parent.isFuncDeclaration();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
78 //printf("fdthis = %p, '%s'\n", fdthis, fdthis ? fdthis.toChars() : "");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
79
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
80 // Go upwards until we find the enclosing member function
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
81 fd = fdthis;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
82 while (1)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
83 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
84 if (!fd)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
85 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
86 goto Lno;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
87 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
88 if (!fd.isNested())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
89 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
90
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
91 Dsymbol parent = fd.parent;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
92 while (parent)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
93 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
94 TemplateInstance ti = parent.isTemplateInstance();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
95 if (ti)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
96 parent = ti.parent;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
97 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
98 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
99 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
100
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
101 fd = fd.parent.isFuncDeclaration();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
102 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
103
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
104 if (!fd.isThis())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
105 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
106 //printf("test '%s'\n", fd.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
107 goto Lno;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
108 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
109
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
110 assert(fd.vthis);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
111 return fd;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
112
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
113 Lno:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
114 return null; // don't have 'this' available
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
115 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
116
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
117 /***************************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
118 * Pull out any properties.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
119 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
120
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
121 Expression resolveProperties(Scope sc, Expression e)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
122 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
123 //printf("resolveProperties(%s)\n", e.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
124 if (e.type)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
125 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
126 Type t = e.type.toBasetype();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
127
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
128 if (t.ty == TY.Tfunction || e.op == TOK.TOKoverloadset)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
129 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
130 e = new CallExp(e.loc, e);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
131 e = e.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
132 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
133
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
134 /* Look for e being a lazy parameter; rewrite as delegate call
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
135 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
136 else if (e.op == TOK.TOKvar)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
137 { VarExp ve = cast(VarExp)e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
138
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
139 if (ve.var.storage_class & STC.STClazy)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
140 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
141 e = new CallExp(e.loc, e);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
142 e = e.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
143 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
144 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
145
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
146 else if (e.op == TOK.TOKdotexp)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
147 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
148 e.error("expression has no value");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
149 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
150 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
151 else if (e.op == TOK.TOKdottd)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
152 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
153 e = new CallExp(e.loc, e);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
154 e = e.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
155 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
156
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
157 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
158 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
159
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
160 class Expression
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
161 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
162 Loc loc; // file location
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
163 TOK op; // handy to minimize use of dynamic_cast
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
164 Type type; // !=null means that semantic() has been run
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
165 int size; // # of bytes in Expression so we can copy() it
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
166
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
167 this(Loc loc, TOK op, int size)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
168 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
169 this.loc = loc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
170 //writef("Expression.Expression(op = %d %s) this = %p\n", op, to!(string)(op), this);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
171 this.op = op;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
172 this.size = size;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
173 type = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
174 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
175
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
176 int equals(Object o)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
177 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
178 return this is o;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
179 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
180
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
181 /*********************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
182 * Does *not* do a deep copy.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
183 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
184 Expression copy() /// bad bad bad
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
185 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
186 Expression e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
187 if (!size)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
188 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
189 debug {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
190 writef("No expression copy for: %s\n", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
191 writef("op = %d\n", op);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
192 dump(0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
193 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
194 assert(0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
195 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
196 auto size = this.classinfo.init.length;
2
7427ded8caf7 Removed unreferenced modules
korDen
parents: 0
diff changeset
197 auto ptr = GC.malloc(size);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
198 memcpy(ptr, cast(void*)this, size);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
199
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
200 return cast(Expression)ptr;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
201 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
202
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
203 Expression syntaxCopy()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
204 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
205 //printf("Expression::syntaxCopy()\n");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
206 //dump(0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
207 return copy();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
208 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
209
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
210 Expression semantic(Scope sc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
211 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
212 version (LOGSEMANTIC) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
213 printf("Expression.semantic() %s\n", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
214 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
215 if (type)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
216 type = type.semantic(loc, sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
217 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
218 type = Type.tvoid;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
219 return this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
220 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
221
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
222 Expression trySemantic(Scope sc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
223 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
224 uint errors = global.errors;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
225 global.gag++;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
226 Expression e = semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
227 global.gag--;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
228 if (errors != global.errors)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
229 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
230 global.errors = errors;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
231 e = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
232 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
233 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
234 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
235
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
236 DYNCAST dyncast() { return DYNCAST.DYNCAST_EXPRESSION; } // kludge for template.isExpression()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
237
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
238 void print()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
239 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
240 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
241 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
242
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
243 string toChars()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
244 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
245 scope OutBuffer buf = new OutBuffer();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
246 HdrGenState hgs;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
247
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
248 toCBuffer(buf, &hgs);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
249 return buf.toChars();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
250 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
251
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
252 void dump(int indent)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
253 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
254 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
255 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
256
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
257 void error(T...)(string format, T t)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
258 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
259 .error(loc, format, t);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
260 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
261
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
262 void warning(T...)(string formar, T t)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
263 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
264 .warning(loc, format, t);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
265 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
266
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
267 void rvalue()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
268 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
269 if (type && type.toBasetype().ty == TY.Tvoid)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
270 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
271 error("expression %s is void and has no value", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
272 static if (false) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
273 dump(0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
274 halt();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
275 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
276 type = Type.terror;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
277 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
278 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
279
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
280 static Expression combine(Expression e1, Expression e2)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
281 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
282 if (e1)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
283 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
284 if (e2)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
285 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
286 e1 = new CommaExp(e1.loc, e1, e2);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
287 e1.type = e2.type;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
288 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
289 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
290 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
291 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
292 e1 = e2;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
293 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
294
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
295 return e1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
296 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
297
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
298 static Expressions arraySyntaxCopy(Expressions exps)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
299 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
300 Expressions a = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
301
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
302 if (exps)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
303 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
304 a = new Expressions();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
305 a.setDim(exps.dim);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
306 for (int i = 0; i < a.dim; i++)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
307 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
308 Expression e = cast(Expression)exps.data[i];
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
309
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
310 e = e.syntaxCopy();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
311 a.data[i] = cast(void*)e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
312 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
313 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
314 return a;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
315 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
316
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
317 ulong toInteger()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
318 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
319 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
320 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
321
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
322 ulong toUInteger()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
323 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
324 //printf("Expression %s\n", Token.toChars(op));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
325 return cast(ulong)toInteger();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
326 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
327
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
328 real toReal()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
329 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
330 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
331 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
332
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
333 real toImaginary()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
334 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
335 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
336 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
337
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
338 Complex!(real) toComplex()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
339 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
340 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
341 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
342
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
343 void toCBuffer(OutBuffer buf, HdrGenState* hgs)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
344 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
345 buf.writestring(Token.toChars(op));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
346 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
347
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
348 void toMangleBuffer(OutBuffer buf)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
349 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
350 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
351 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
352
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
353 int isLvalue()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
354 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
355 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
356 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
357
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
358 Expression toLvalue(Scope sc, Expression e)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
359 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
360 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
361 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
362
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
363 Expression modifiableLvalue(Scope sc, Expression e)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
364 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
365 //printf("Expression::modifiableLvalue() %s, type = %s\n", toChars(), type.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
366
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
367 // See if this expression is a modifiable lvalue (i.e. not const)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
368 version (DMDV2) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
369 if (type && (!type.isMutable() || !type.isAssignable()))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
370 error("%s is not mutable", e.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
371 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
372 return toLvalue(sc, e);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
373 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
374
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
375 /**************************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
376 * Do an implicit cast.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
377 * Issue error if it can't be done.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
378 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
379 Expression implicitCastTo(Scope sc, Type t)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
380 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
381 //printf("Expression.implicitCastTo(%s of type %s) => %s\n", toChars(), type.toChars(), t.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
382
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
383 MATCH match = implicitConvTo(t);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
384 if (match)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
385 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
386 TY tyfrom = type.toBasetype().ty;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
387 TY tyto = t.toBasetype().ty;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
388
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
389 version (DMDV1) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
390 if (global.params.warnings &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
391 Type.impcnvWarn[tyfrom][tyto] &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
392 op != TOKint64)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
393 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
394 Expression e = optimize(WANT.WANTflags | WANT.WANTvalue);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
395
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
396 if (e.op == TOK.TOKint64)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
397 return e.implicitCastTo(sc, t);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
398 if (tyfrom == Tint32 && (op == TOKadd || op == TOKmin || op == TOKand || op == TOKor || op == TOKxor))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
399 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
400 /* This is really only a semi-kludge fix,
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
401 * we really should look at the operands of op
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
402 * and see if they are narrower types.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
403 * For example, b=b|b and b=b|7 and s=b+b should be allowed,
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
404 * but b=b|i should be an error.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
405 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
406 ;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
407 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
408 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
409 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
410 warning("implicit conversion of expression (%s) of type %s to %s can cause loss of data", toChars(), type.toChars(), t.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
411 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
412 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
413 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
414 version (DMDV2) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
415 if (match == MATCH.MATCHconst && t == type.constOf())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
416 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
417 Expression e = copy();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
418 e.type = t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
419 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
420 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
421 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
422 return castTo(sc, t);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
423 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
424
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
425 Expression e = optimize(WANT.WANTflags | WANT.WANTvalue);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
426 if (e != this)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
427 return e.implicitCastTo(sc, t);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
428
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
429 static if (false) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
430 printf("ty = %d\n", type.ty);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
431 print();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
432 type.print();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
433 printf("to:\n");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
434 t.print();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
435 printf("%p %p type: %s to: %s\n", type.deco, t.deco, type.deco, t.deco);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
436 //printf("%p %p %p\n", type.nextOf().arrayOf(), type, t);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
437 fflush(stdout);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
438 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
439 if (!t.deco) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
440 /* Can happen with:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
441 * enum E { One }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
442 * class A
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
443 * { static void fork(EDG dg) { dg(E.One); }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
444 * alias void delegate(E) EDG;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
445 * }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
446 * Should eventually make it work.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
447 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
448 error("forward reference to type %s", t.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
449 } else if (t.reliesOnTident()) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
450 error("forward reference to type %s", t.reliesOnTident().toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
451 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
452
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
453 error("cannot implicitly convert expression (%s) of type %s to %s", toChars(), type.toChars(), t.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
454 return castTo(sc, t);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
455 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
456
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
457 /*******************************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
458 * Return !=0 if we can implicitly convert this to type t.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
459 * Don't do the actual cast.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
460 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
461 MATCH implicitConvTo(Type t)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
462 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
463 static if (false) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
464 printf("Expression.implicitConvTo(this=%s, type=%s, t=%s)\n",
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
465 toChars(), type.toChars(), t.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
466 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
467 //static int nest; if (++nest == 10) halt();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
468 if (!type)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
469 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
470 error("%s is not an expression", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
471 type = Type.terror;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
472 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
473 Expression e = optimize(WANT.WANTvalue | WANT.WANTflags);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
474 if (e.type == t)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
475 return MATCH.MATCHexact;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
476 if (e != this)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
477 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
478 //printf("\toptimized to %s of type %s\n", e.toChars(), e.type.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
479 return e.implicitConvTo(t);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
480 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
481 MATCH match = type.implicitConvTo(t);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
482 if (match != MATCH.MATCHnomatch)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
483 return match;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
484
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
485 /* See if we can do integral narrowing conversions
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
486 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
487 if (type.isintegral() && t.isintegral() &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
488 type.isTypeBasic() && t.isTypeBasic())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
489 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
490 IntRange ir = getIntRange();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
491 if (ir.imax <= t.sizemask())
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 static if (false) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
496 Type tb = t.toBasetype();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
497 if (tb.ty == Tdelegate)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
498 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
499 TypeDelegate td = cast(TypeDelegate)tb;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
500 TypeFunction tf = cast(TypeFunction)td.nextOf();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
501
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
502 if (!tf.varargs && !(tf.arguments && tf.arguments.dim))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
503 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
504 match = type.implicitConvTo(tf.nextOf());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
505 if (match)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
506 return match;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
507 if (tf.nextOf().toBasetype().ty == Tvoid)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
508 return MATCH.MATCHconvert;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
509 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
510 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
511 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
512 return MATCH.MATCHnomatch;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
513 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
514
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
515 IntRange getIntRange()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
516 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
517 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
518 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
519
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
520 /**************************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
521 * Do an explicit cast.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
522 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
523 Expression castTo(Scope sc, Type t)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
524 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
525 //printf("Expression.castTo(this=%s, t=%s)\n", toChars(), t.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
526 static if (false) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
527 writef("Expression.castTo(this=%s, type=%s, t=%s)\n",
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
528 toChars(), type.toChars(), t.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
529 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
530 if (type is t)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
531 return this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
532 Expression e = this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
533 Type tb = t.toBasetype();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
534 Type typeb = type.toBasetype();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
535 if (tb != typeb)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
536 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
537 // Do (type *) cast of (type [dim])
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
538 if (tb.ty == TY.Tpointer && typeb.ty == TY.Tsarray
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
539 )
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
540 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
541 //printf("Converting [dim] to *\n");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
542
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
543 if (typeb.size(loc) == 0)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
544 e = new NullExp(loc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
545 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
546 e = new AddrExp(loc, e);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
547 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
548 else {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
549 static if (false) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
550 if (tb.ty == Tdelegate && type.ty != Tdelegate)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
551 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
552 TypeDelegate td = cast(TypeDelegate)tb;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
553 TypeFunction tf = cast(TypeFunction)td.nextOf();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
554 return toDelegate(sc, tf.nextOf());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
555 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
556 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
557 if (typeb.ty == TY.Tstruct)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
558 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
559 TypeStruct ts = cast(TypeStruct)typeb;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
560 if (!(tb.ty == TY.Tstruct && ts.sym == (cast(TypeStruct)tb).sym) &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
561 ts.sym.aliasthis)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
562 { /* Forward the cast to our alias this member, rewrite to:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
563 * cast(to)e1.aliasthis
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
564 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
565 Expression e1 = new DotIdExp(loc, this, ts.sym.aliasthis.ident);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
566 Expression e2 = new CastExp(loc, e1, tb);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
567 e2 = e2.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
568 return e2;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
569 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
570 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
571 else if (typeb.ty == TY.Tclass)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
572 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
573 TypeClass ts = cast(TypeClass)typeb;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
574 if (tb.ty != TY.Tclass && ts.sym.aliasthis)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
575 { /* Forward the cast to our alias this member, rewrite to:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
576 * cast(to)e1.aliasthis
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
577 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
578 Expression e1 = new DotIdExp(loc, this, ts.sym.aliasthis.ident);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
579 Expression e2 = new CastExp(loc, e1, tb);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
580 e2 = e2.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
581 return e2;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
582 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
583 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
584 e = new CastExp(loc, e, tb);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
585 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
586 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
587 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
588 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
589 e = e.copy(); // because of COW for assignment to e.type
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
590 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
591
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
592 assert(e != this);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
593 e.type = t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
594 //printf("Returning: %s\n", e.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
595 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
596 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
597
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
598 /************************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
599 * Detect cases where pointers to the stack can 'escape' the
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
600 * lifetime of the stack frame.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
601 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
602 void checkEscape()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
603 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
604 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
605
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
606 void checkScalar()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
607 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
608 if (!type.isscalar())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
609 error("'%s' is not a scalar, it is a %s", toChars(), type.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
610
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
611 rvalue();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
612 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
613
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
614 void checkNoBool()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
615 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
616 if (type.toBasetype().ty == TY.Tbool)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
617 error("operation not allowed on bool '%s'", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
618 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
619
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
620 Expression checkIntegral()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
621 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
622 if (!type.isintegral())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
623 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
624 error("'%s' is not of integral type, it is a %s", toChars(), type.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
625 return new ErrorExp();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
626 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
627
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
628 rvalue();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
629 return this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
630 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
631
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
632 Expression checkArithmetic()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
633 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
634 if (!type.isintegral() && !type.isfloating())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
635 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
636 error("'%s' is not of arithmetic type, it is a %s", toChars(), type.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
637 return new ErrorExp();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
638 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
639
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
640 rvalue();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
641 return this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
642 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
643
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
644 void checkDeprecated(Scope sc, Dsymbol s)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
645 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
646 s.checkDeprecated(loc, sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
647 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
648
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
649 void checkPurity(Scope sc, FuncDeclaration f)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
650 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
651 static if (true) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
652 if (sc.func)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
653 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
654 FuncDeclaration outerfunc = sc.func;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
655 while (outerfunc.toParent2() && outerfunc.toParent2().isFuncDeclaration())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
656 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
657 outerfunc = outerfunc.toParent2().isFuncDeclaration();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
658 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
659 if (outerfunc.isPure() && !sc.intypeof && (!f.isNested() && !f.isPure()))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
660 error("pure function '%s' cannot call impure function '%s'\n",
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
661 sc.func.toChars(), f.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
662 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
663 } else {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
664 if (sc.func && sc.func.isPure() && !sc.intypeof && !f.isPure())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
665 error("pure function '%s' cannot call impure function '%s'\n",
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
666 sc.func.toChars(), .toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
667 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
668 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
669
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
670 /*****************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
671 * Check that expression can be tested for true or false.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
672 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
673 Expression checkToBoolean()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
674 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
675 // Default is 'yes' - do nothing
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
676
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
677 debug {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
678 if (!type)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
679 dump(0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
680 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
681
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
682 if (!type.checkBoolean())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
683 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
684 error("expression %s of type %s does not have a boolean value", toChars(), type.toChars());
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 this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
688 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
689
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
690 Expression checkToPointer()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
691 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
692 Expression e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
693 Type tb;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
694
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
695 //printf("Expression::checkToPointer()\n");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
696 e = this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
697
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
698 // If C static array, convert to pointer
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
699 tb = type.toBasetype();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
700 if (tb.ty == Tsarray)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
701 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
702 TypeSArray ts = cast(TypeSArray)tb;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
703 if (ts.size(loc) == 0)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
704 e = new NullExp(loc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
705 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
706 e = new AddrExp(loc, this);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
707 e.type = ts.next.pointerTo();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
708 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
709 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
710 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
711
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
712 Expression addressOf(Scope sc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
713 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
714 //printf("Expression::addressOf()\n");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
715 Expression e = toLvalue(sc, null);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
716 e = new AddrExp(loc, e);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
717 e.type = type.pointerTo();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
718 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
719 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
720
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
721 /******************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
722 * If this is a reference, dereference it.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
723 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
724 Expression deref()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
725 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
726 //printf("Expression::deref()\n");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
727 if (type.ty == TY.Treference)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
728 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
729 Expression e = new PtrExp(loc, this);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
730 e.type = (cast(TypeReference)type).next;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
731 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
732 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
733 return this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
734 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
735
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
736 /***********************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
737 * Do integral promotions (convertchk).
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
738 * Don't convert <array of> to <pointer to>
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
739 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
740 Expression integralPromotions(Scope sc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
741 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
742 Expression e = this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
743
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
744 //printf("integralPromotions %s %s\n", e.toChars(), e.type.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
745 switch (type.toBasetype().ty)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
746 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
747 case TY.Tvoid:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
748 error("void has no value");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
749 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
750
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
751 case TY.Tint8:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
752 case TY.Tuns8:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
753 case TY.Tint16:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
754 case TY.Tuns16:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
755 case TY.Tbit:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
756 case TY.Tbool:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
757 case TY.Tchar:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
758 case TY.Twchar:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
759 e = e.castTo(sc, Type.tint32);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
760 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
761
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
762 case TY.Tdchar:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
763 e = e.castTo(sc, Type.tuns32);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
764 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
765 default:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
766 break; ///
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
767 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
768 return e;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
769 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
770
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
771 Expression toDelegate(Scope sc, Type t)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
772 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
773 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
774 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
775
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
776 void scanForNestedRef(Scope sc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
777 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
778 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
779 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
780
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
781 Expression optimize(int result)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
782 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
783 //printf("Expression.optimize(result = x%x) %s\n", result, toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
784 return this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
785 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
786
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
787 Expression interpret(InterState istate)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
788 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
789 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
790 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
791
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
792 int isConst()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
793 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
794 //printf("Expression::isConst(): %s\n", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
795 return 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
796 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
797
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
798 /********************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
799 * Does this expression statically evaluate to a boolean TRUE or FALSE?
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
800 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
801 bool isBool(bool result)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
802 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
803 return false;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
804 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
805
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
806 int isBit()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
807 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
808 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
809 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
810
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
811 /********************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
812 * Check for expressions that have no use.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
813 * Input:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
814 * flag 0 not going to use the result, so issue error message if no
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
815 * side effects
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
816 * 1 the result of the expression is used, but still check
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
817 * for useless subexpressions
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
818 * 2 do not issue error messages, just return !=0 if expression
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
819 * has side effects
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
820 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
821 bool checkSideEffect(int flag)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
822 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
823 if (flag == 0)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
824 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
825 if (op == TOKimport)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
826 error("%s has no effect", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
827 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
828 error("%s has no effect in expression (%s)",
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
829
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
830 Token.toChars(op), toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
831 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
832
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
833 return false;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
834 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
835
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
836 bool canThrow()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
837 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
838 version (DMDV2) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
839 return false;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
840 } else {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
841 return true;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
842 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
843 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
844
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
845 int inlineCost(InlineCostState* ics)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
846 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
847 return 1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
848 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
849
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
850 Expression doInline(InlineDoState ids)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
851 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
852 //printf("Expression.doInline(%s): %s\n", Token.toChars(op), toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
853 return copy();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
854 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
855
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
856 Expression inlineScan(InlineScanState* iss)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
857 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
858 return this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
859 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
860
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
861 /***********************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
862 * Determine if operands of binary op can be reversed
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
863 * to fit operator overload.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
864 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
865
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
866 // For operator overloading
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
867 bool isCommutative()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
868 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
869 return false; // default is no reverse
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
870 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
871
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
872 /***********************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
873 * Get Identifier for operator overload.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
874 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
875 Identifier opId()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
876 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
877 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
878 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
879
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
880 /***********************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
881 * Get Identifier for reverse operator overload,
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
882 * null if not supported for this operator.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
883 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
884 Identifier opId_r()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
885 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
886 return null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
887 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
888
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
889 // For array ops
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
890 void buildArrayIdent(OutBuffer buf, Expressions arguments)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
891 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
892 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
893 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
894
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
895 Expression buildArrayLoop(Arguments fparams)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
896 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
897 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
898 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
899
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
900 // Back end
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
901 elem* toElem(IRState* irs)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
902 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
903 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
904 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
905
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
906 dt_t** toDt(dt_t** pdt)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
907 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
908 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
909 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
910 }