annotate dmd/StructLiteralExp.d @ 67:f708f0452e81

some of the backend/codegen stuff implemented
author korDen
date Mon, 23 Aug 2010 21:21:05 +0400
parents 4290d870944a
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.StructLiteralExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
2
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
3 import dmd.Expression;
64
4290d870944a More fixes
korDen
parents: 63
diff changeset
4 import dmd.MOD;
4290d870944a More fixes
korDen
parents: 63
diff changeset
5 import dmd.TypeStruct;
67
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
6 import dmd.TypeSArray;
63
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
7 import dmd.expression.Util;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
8 import dmd.ErrorExp;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
9 import dmd.Dsymbol;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
10 import dmd.VarDeclaration;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
11 import dmd.StructDeclaration;
67
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
12 import dmd.FuncDeclaration;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
13 import dmd.ThisDeclaration;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
14 import dmd.backend.elem;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
15 import dmd.InterState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
16 import dmd.MATCH;
56
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
17 import dmd.WANT;
63
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
18 import dmd.TY;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
19 import dmd.Type;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
20 import dmd.OutBuffer;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
21 import dmd.Loc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
22 import dmd.Scope;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
23 import dmd.InlineCostState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
24 import dmd.IRState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
25 import dmd.InlineDoState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
26 import dmd.backend.Symbol;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
27 import dmd.HdrGenState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
28 import dmd.backend.dt_t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
29 import dmd.InlineScanState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
30 import dmd.ArrayTypes;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
31 import dmd.TOK;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
32
67
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
33 import dmd.codegen.Util;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
34 import dmd.backend.Util;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
35 import dmd.backend.RTLSYM;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
36 import dmd.backend.TYM;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
37 import dmd.backend.mTY;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
38 import dmd.backend.OPER;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
39
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
40
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
41 class StructLiteralExp : Expression
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
42 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
43 StructDeclaration sd; // which aggregate this is for
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
44 Expressions elements; // parallels sd->fields[] with
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
45 // NULL entries for fields to skip
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
46
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
47 Symbol* sym; // back end symbol to initialize with literal
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
48 size_t soffset; // offset from start of s
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
49 int fillHoles; // fill alignment 'holes' with zero
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
50
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
51 this(Loc loc, StructDeclaration sd, Expressions elements)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
52 {
56
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
53 super(loc, TOKstructliteral, StructLiteralExp.sizeof);
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
54 this.sd = sd;
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
55 this.elements = elements;
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
56 this.sym = null;
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
57 this.soffset = 0;
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
58 this.fillHoles = 1;
0
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 syntaxCopy()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
62 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
63 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
64 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
65
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
66 Expression semantic(Scope sc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
67 {
63
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
68 Expression e;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
69 int nfields = sd.fields.dim - sd.isnested;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
70
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
71 version (LOGSEMANTIC) {
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
72 printf("StructLiteralExp.semantic('%s')\n", toChars());
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
73 }
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
74 if (type)
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
75 return this;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
76
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
77 // Run semantic() on each element
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
78 for (size_t i = 0; i < elements.dim; i++)
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
79 {
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
80 e = cast(Expression)elements.data[i];
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
81 if (!e)
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
82 continue;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
83 e = e.semantic(sc);
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
84 elements.data[i] = cast(void*)e;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
85 }
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
86 expandTuples(elements);
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
87 size_t offset = 0;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
88 for (size_t i = 0; i < elements.dim; i++)
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
89 {
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
90 e = cast(Expression)elements.data[i];
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
91 if (!e)
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
92 continue;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
93
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
94 if (!e.type)
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
95 error("%s has no value", e.toChars());
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
96 e = resolveProperties(sc, e);
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
97 if (i >= nfields)
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
98 {
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
99 error("more initializers than fields of %s", sd.toChars());
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
100 return new ErrorExp();
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
101 }
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
102 Dsymbol s = cast(Dsymbol)sd.fields.data[i];
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
103 VarDeclaration v = s.isVarDeclaration();
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
104 assert(v);
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
105 if (v.offset < offset)
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
106 error("overlapping initialization for %s", v.toChars());
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
107 offset = v.offset + cast(uint)v.type.size();
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
108
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
109 Type telem = v.type;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
110 while (!e.implicitConvTo(telem) && telem.toBasetype().ty == Tsarray)
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
111 {
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
112 /* Static array initialization, as in:
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
113 * T[3][5] = e;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
114 */
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
115 telem = telem.toBasetype().nextOf();
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
116 }
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
117
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
118 e = e.implicitCastTo(sc, telem);
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
119
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
120 elements.data[i] = cast(void*)e;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
121 }
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
122
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
123 /* Fill out remainder of elements[] with default initializers for fields[]
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
124 */
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
125 for (size_t i = elements.dim; i < nfields; i++)
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
126 {
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
127 Dsymbol s = cast(Dsymbol)sd.fields.data[i];
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
128 VarDeclaration v = s.isVarDeclaration();
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
129 assert(v);
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
130 assert(!v.isThisDeclaration());
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
131
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
132 if (v.offset < offset)
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
133 {
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
134 e = null;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
135 sd.hasUnions = 1;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
136 }
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
137 else
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
138 {
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
139 if (v.init)
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
140 {
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
141 e = v.init.toExpression();
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
142 if (!e)
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
143 error("cannot make expression out of initializer for %s", v.toChars());
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
144 }
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
145 else
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
146 {
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
147 e = v.type.defaultInit(Loc(0));
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
148 e.loc = loc;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
149 }
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
150 offset = v.offset + cast(uint)v.type.size();
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
151 }
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
152 elements.push(cast(void*)e);
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
153 }
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
154
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
155 type = sd.type;
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
156 return this;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
157 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
158
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
159 Expression getField(Type type, uint offset)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
160 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
161 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
162 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
163
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
164 int getFieldIndex(Type type, uint offset)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
165 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
166 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
167 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
168
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
169 elem* toElem(IRState* irs)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
170 {
67
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
171 elem* e;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
172 size_t dim;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
173
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
174 //printf("StructLiteralExp.toElem() %s\n", toChars());
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
175
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
176 // struct symbol to initialize with the literal
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
177 Symbol* stmp = sym ? sym : symbol_genauto(sd.type.toCtype());
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
178
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
179 e = null;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
180
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
181 if (fillHoles)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
182 {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
183 /* Initialize all alignment 'holes' to zero.
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
184 * Do before initializing fields, as the hole filling process
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
185 * can spill over into the fields.
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
186 */
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
187 size_t offset = 0;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
188 for (size_t i = 0; i < sd.fields.dim; i++)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
189 {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
190 Dsymbol s = cast(Dsymbol)sd.fields.data[i];
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
191 VarDeclaration v = s.isVarDeclaration();
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
192 assert(v);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
193
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
194 e = el_combine(e, fillHole(stmp, &offset, v.offset, sd.structsize));
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
195 size_t vend = v.offset + cast(uint)v.type.size();
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
196 if (offset < vend)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
197 offset = vend;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
198 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
199 e = el_combine(e, fillHole(stmp, &offset, sd.structsize, sd.structsize));
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
200 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
201
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
202 if (elements)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
203 {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
204 dim = elements.dim;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
205 assert(dim <= sd.fields.dim);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
206 for (size_t i = 0; i < dim; i++)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
207 {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
208 Expression el = cast(Expression)elements.data[i];
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
209 if (!el)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
210 continue;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
211
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
212 Dsymbol s = cast(Dsymbol)sd.fields.data[i];
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
213 VarDeclaration v = s.isVarDeclaration();
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
214 assert(v);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
215 assert(!v.isThisDeclaration());
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
216
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
217 elem* e1;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
218 if (tybasic(stmp.Stype.Tty) == TYnptr)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
219 {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
220 e1 = el_var(stmp);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
221 e1.EV.sp.Voffset = soffset;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
222 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
223 else
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
224 {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
225 e1 = el_ptr(stmp);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
226 if (soffset)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
227 e1 = el_bin(OPadd, TYnptr, e1, el_long(TYsize_t, soffset));
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
228 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
229 e1 = el_bin(OPadd, TYnptr, e1, el_long(TYsize_t, v.offset));
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
230 elem* ec = e1; // pointer to destination
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
231
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
232 elem* ep = el.toElem(irs);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
233
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
234 Type t1b = v.type.toBasetype();
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
235 Type t2b = el.type.toBasetype();
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
236 if (t1b.ty == Tsarray)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
237 {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
238 if (t2b.implicitConvTo(t1b))
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
239 {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
240 ///version (DMDV2) {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
241 // Determine if postblit is needed
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
242 int postblit = 0;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
243 if (needsPostblit(t1b))
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
244 postblit = 1;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
245
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
246 if (postblit)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
247 {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
248 /* Generate:
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
249 * _d_arrayctor(ti, From: ep, To: e1)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
250 */
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
251 Expression ti = t1b.nextOf().toBasetype().getTypeInfo(null);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
252 elem* esize = el_long(TYsize_t, (cast(TypeSArray)t1b).dim.toInteger());
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
253 e1 = el_pair(TYdarray, esize, e1);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
254 ep = el_pair(TYdarray, el_copytree(esize), array_toPtr(el.type, ep));
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
255 ep = el_params(e1, ep, ti.toElem(irs), null);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
256 int rtl = RTLSYM_ARRAYCTOR;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
257 e1 = el_bin(OPcall, type.totym(), el_var(rtlsym[rtl]), ep);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
258 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
259 else
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
260 ///}
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
261 {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
262 elem* esize = el_long(TYsize_t, t1b.size());
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
263 ep = array_toPtr(el.type, ep);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
264 e1 = el_bin(OPmemcpy, TYnptr, e1, el_param(ep, esize));
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
265 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
266 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
267 else
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
268 {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
269 elem* edim = el_long(TYsize_t, t1b.size() / t2b.size());
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
270 e1 = setArray(e1, edim, t2b, ep, irs, TOKconstruct);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
271 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
272 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
273 else
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
274 {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
275 tym_t ty = v.type.totym();
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
276 e1 = el_una(OPind, ty, e1);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
277 if (tybasic(ty) == TYstruct)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
278 e1.Enumbytes = cast(uint)v.type.size();
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
279 e1 = el_bin(OPeq, ty, e1, ep);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
280 if (tybasic(ty) == TYstruct)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
281 {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
282 e1.Eoper = OPstreq;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
283 e1.Enumbytes = cast(uint)v.type.size();
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
284 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
285 version (DMDV2) {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
286 /* Call postblit() on e1
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
287 */
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
288 StructDeclaration sd = needsPostblit(v.type);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
289 if (sd)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
290 {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
291 FuncDeclaration fd = sd.postblit;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
292 ec = el_copytree(ec);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
293 ec = callfunc(loc, irs, 1, Type.tvoid, ec, sd.type.pointerTo(), fd, fd.type, null, null);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
294 e1 = el_bin(OPcomma, ec.Ety, e1, ec);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
295 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
296 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
297 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
298 e = el_combine(e, e1);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
299 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
300 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
301
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
302 version (DMDV2) {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
303 if (sd.isnested)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
304 { // Initialize the hidden 'this' pointer
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
305 assert(sd.fields.dim);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
306 Dsymbol s = cast(Dsymbol)sd.fields.data[sd.fields.dim - 1];
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
307 ThisDeclaration v = s.isThisDeclaration();
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
308 assert(v);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
309
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
310 elem* e1;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
311 if (tybasic(stmp.Stype.Tty) == TYnptr)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
312 {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
313 e1 = el_var(stmp);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
314 e1.EV.sp.Voffset = soffset;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
315 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
316 else
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
317 {
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
318 e1 = el_ptr(stmp);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
319 if (soffset)
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
320 e1 = el_bin(OPadd, TYnptr, e1, el_long(TYsize_t, soffset));
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
321 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
322 e1 = el_bin(OPadd, TYnptr, e1, el_long(TYsize_t, v.offset));
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
323 e1 = setEthis(loc, irs, e1, sd);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
324
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
325 e = el_combine(e, e1);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
326 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
327 }
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
328
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
329 elem* ev = el_var(stmp);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
330 ev.Enumbytes = sd.structsize;
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
331 e = el_combine(e, ev);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
332 el_setLoc(e,loc);
f708f0452e81 some of the backend/codegen stuff implemented
korDen
parents: 64
diff changeset
333 return e;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
334 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
335
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
336 bool checkSideEffect(int flag)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
337 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
338 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
339 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
340
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
341 void toCBuffer(OutBuffer buf, HdrGenState* hgs)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
342 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
343 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
344 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
345
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
346 void toMangleBuffer(OutBuffer buf)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
347 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
348 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
349 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
350
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
351 void scanForNestedRef(Scope sc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
352 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
353 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
354 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
355
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
356 Expression optimize(int result)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
357 {
56
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
358 if (elements)
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
359 {
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
360 for (size_t i = 0; i < elements.dim; i++)
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
361 {
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
362 Expression e = cast(Expression)elements.data[i];
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
363 if (!e)
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
364 continue;
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
365 e = e.optimize(WANTvalue | (result & WANTinterpret));
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
366 elements.data[i] = cast(void*)e;
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
367 }
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
368 }
51605de93870 TupleExp.optimize
korDen
parents: 0
diff changeset
369 return this;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
370 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
371
63
cab4c37afb89 A bunch of implementations
korDen
parents: 56
diff changeset
372 Expression interpret(InterState istate)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
373 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
374 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
375 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
376
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
377 dt_t** toDt(dt_t** pdt)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
378 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
379 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
380 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
381
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
382 int isLvalue()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
383 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
384 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
385 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
386
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
387 Expression toLvalue(Scope sc, Expression e)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
388 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
389 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
390 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
391
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
392 bool canThrow()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
393 {
64
4290d870944a More fixes
korDen
parents: 63
diff changeset
394 return arrayExpressionCanThrow(elements);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
395 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
396
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
397 MATCH implicitConvTo(Type t)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
398 {
64
4290d870944a More fixes
korDen
parents: 63
diff changeset
399 static if (false) {
4290d870944a More fixes
korDen
parents: 63
diff changeset
400 printf("StructLiteralExp.implicitConvTo(this=%.*s, type=%.*s, t=%.*s)\n",
4290d870944a More fixes
korDen
parents: 63
diff changeset
401 toChars(), type.toChars(), t.toChars());
4290d870944a More fixes
korDen
parents: 63
diff changeset
402 }
4290d870944a More fixes
korDen
parents: 63
diff changeset
403 MATCH m = Expression.implicitConvTo(t);
4290d870944a More fixes
korDen
parents: 63
diff changeset
404 if (m != MATCHnomatch)
4290d870944a More fixes
korDen
parents: 63
diff changeset
405 return m;
4290d870944a More fixes
korDen
parents: 63
diff changeset
406 if (type.ty == t.ty && type.ty == Tstruct && (cast(TypeStruct)type).sym == (cast(TypeStruct)t).sym)
4290d870944a More fixes
korDen
parents: 63
diff changeset
407 {
4290d870944a More fixes
korDen
parents: 63
diff changeset
408 m = MATCHconst;
4290d870944a More fixes
korDen
parents: 63
diff changeset
409 for (int i = 0; i < elements.dim; i++)
4290d870944a More fixes
korDen
parents: 63
diff changeset
410 {
4290d870944a More fixes
korDen
parents: 63
diff changeset
411 Expression e = cast(Expression)elements.data[i];
4290d870944a More fixes
korDen
parents: 63
diff changeset
412 Type te = e.type;
4290d870944a More fixes
korDen
parents: 63
diff changeset
413 if (t.mod == 0)
4290d870944a More fixes
korDen
parents: 63
diff changeset
414 te = te.mutableOf();
4290d870944a More fixes
korDen
parents: 63
diff changeset
415 else
4290d870944a More fixes
korDen
parents: 63
diff changeset
416 {
4290d870944a More fixes
korDen
parents: 63
diff changeset
417 assert(t.mod == MODinvariant);
4290d870944a More fixes
korDen
parents: 63
diff changeset
418 te = te.invariantOf();
4290d870944a More fixes
korDen
parents: 63
diff changeset
419 }
4290d870944a More fixes
korDen
parents: 63
diff changeset
420 MATCH m2 = e.implicitConvTo(te);
4290d870944a More fixes
korDen
parents: 63
diff changeset
421 //printf("\t%s => %s, match = %d\n", e.toChars(), te.toChars(), m2);
4290d870944a More fixes
korDen
parents: 63
diff changeset
422 if (m2 < m)
4290d870944a More fixes
korDen
parents: 63
diff changeset
423 m = m2;
4290d870944a More fixes
korDen
parents: 63
diff changeset
424 }
4290d870944a More fixes
korDen
parents: 63
diff changeset
425 }
4290d870944a More fixes
korDen
parents: 63
diff changeset
426 return m;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
427 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
428
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
429 int inlineCost(InlineCostState* ics)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
430 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
431 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
432 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
433
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
434 Expression doInline(InlineDoState ids)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
435 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
436 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
437 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
438
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
439 Expression inlineScan(InlineScanState* iss)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
440 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
441 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
442 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
443 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
444