Mercurial > projects > ddmd
annotate dmd/TemplateValueParameter.d @ 130:60bb0fe4563e
dmdfe 2.037 first main iteration
author | Eldar Insafutdinov <e.insafutdinov@gmail.com> |
---|---|
date | Thu, 09 Sep 2010 22:51:44 +0100 |
parents | e28b18c23469 |
children | 96c0fff6897d |
rev | line source |
---|---|
0 | 1 module dmd.TemplateValueParameter; |
2 | |
114 | 3 import dmd.common; |
0 | 4 import dmd.TemplateParameter; |
5 import dmd.Scope; | |
6 import dmd.Declaration; | |
7 import dmd.ArrayTypes; | |
8 import dmd.Type; | |
9 import dmd.Expression; | |
10 import dmd.Loc; | |
11 import dmd.Identifier; | |
12 import dmd.OutBuffer; | |
13 import dmd.HdrGenState; | |
14 import dmd.MATCH; | |
7
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
15 import dmd.VarDeclaration; |
40 | 16 import dmd.Initializer; |
17 import dmd.ExpInitializer; | |
44 | 18 import dmd.DefaultInitExp; |
7
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
19 import dmd.STC; |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
20 import dmd.Util; |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
21 import dmd.TY; |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
22 import dmd.WANT; |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
23 import dmd.TOK; |
0 | 24 |
40 | 25 import dmd.Dsymbol : isExpression; |
26 | |
0 | 27 class TemplateValueParameter : TemplateParameter |
28 { | |
29 /* Syntax: | |
30 * valType ident : specValue = defaultValue | |
31 */ | |
32 | |
33 Type valType; | |
34 Expression specValue; | |
35 Expression defaultValue; | |
36 | |
37 static Expression edummy; | |
38 | |
39 this(Loc loc, Identifier ident, Type valType, Expression specValue, Expression defaultValue) | |
40 { | |
41 super(loc, ident); | |
7
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
42 |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
43 this.valType = valType; |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
44 this.specValue = specValue; |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
45 this.defaultValue = defaultValue; |
0 | 46 } |
47 | |
72 | 48 override TemplateValueParameter isTemplateValueParameter() |
0 | 49 { |
7
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
50 return this; |
0 | 51 } |
52 | |
72 | 53 override TemplateParameter syntaxCopy() |
0 | 54 { |
7
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
55 TemplateValueParameter tp = new TemplateValueParameter(loc, ident, valType, specValue, defaultValue); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
56 tp.valType = valType.syntaxCopy(); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
57 if (specValue) |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
58 tp.specValue = specValue.syntaxCopy(); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
59 if (defaultValue) |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
60 tp.defaultValue = defaultValue.syntaxCopy(); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
61 return tp; |
0 | 62 } |
63 | |
72 | 64 override void declareParameter(Scope sc) |
0 | 65 { |
7
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
66 VarDeclaration v = new VarDeclaration(loc, valType, ident, null); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
67 v.storage_class = STC.STCtemplateparameter; |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
68 if (!sc.insert(v)) |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
69 error(loc, "parameter '%s' multiply defined", ident.toChars()); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
70 sparam = v; |
0 | 71 } |
72 | |
72 | 73 override void semantic(Scope sc) |
0 | 74 { |
7
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
75 sparam.semantic(sc); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
76 valType = valType.semantic(loc, sc); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
77 if (!(valType.isintegral() || valType.isfloating() || valType.isString()) && valType.ty != TY.Tident) |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
78 error(loc, "arithmetic/string type expected for value-parameter, not %s", valType.toChars()); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
79 |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
80 if (specValue) |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
81 { |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
82 Expression e = specValue; |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
83 |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
84 e = e.semantic(sc); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
85 e = e.implicitCastTo(sc, valType); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
86 e = e.optimize(WANTvalue | WANTinterpret); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
87 if (e.op == TOKint64 || e.op == TOKfloat64 || |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
88 e.op == TOKcomplex80 || e.op == TOKnull || e.op == TOKstring) |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
89 specValue = e; |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
90 //e.toInteger(); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
91 } |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
92 |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
93 static if (false) { // defer semantic analysis to arg match |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
94 if (defaultValue) |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
95 { |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
96 Expression e = defaultValue; |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
97 |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
98 e = e.semantic(sc); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
99 e = e.implicitCastTo(sc, valType); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
100 e = e.optimize(WANTvalue | WANTinterpret); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
101 if (e.op == TOKint64) |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
102 defaultValue = e; |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
103 //e.toInteger(); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
104 } |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
105 } |
0 | 106 } |
107 | |
72 | 108 override void print(Object oarg, Object oded) |
0 | 109 { |
110 assert(false); | |
111 } | |
112 | |
72 | 113 override void toCBuffer(OutBuffer buf, HdrGenState* hgs) |
0 | 114 { |
50 | 115 valType.toCBuffer(buf, ident, hgs); |
116 if (specValue) | |
117 { | |
118 buf.writestring(" : "); | |
119 specValue.toCBuffer(buf, hgs); | |
120 } | |
121 if (defaultValue) | |
122 { | |
123 buf.writestring(" = "); | |
124 defaultValue.toCBuffer(buf, hgs); | |
125 } | |
0 | 126 } |
127 | |
72 | 128 override Object specialization() |
0 | 129 { |
39 | 130 return specValue; |
0 | 131 } |
132 | |
72 | 133 override Object defaultArg(Loc loc, Scope sc) |
0 | 134 { |
44 | 135 Expression e = defaultValue; |
136 if (e) | |
137 { | |
138 e = e.syntaxCopy(); | |
139 e = e.semantic(sc); | |
140 version (DMDV2) { | |
130
60bb0fe4563e
dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents:
114
diff
changeset
|
141 e = e.resolveLoc(loc, sc); |
44 | 142 } |
143 } | |
144 return e; | |
0 | 145 } |
146 | |
72 | 147 override bool overloadMatch(TemplateParameter tp) |
0 | 148 { |
7
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
149 TemplateValueParameter tvp = tp.isTemplateValueParameter(); |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
150 |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
151 if (tvp) |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
152 { |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
153 if (valType != tvp.valType) |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
154 return false; |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
155 |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
156 if (valType && !valType.equals(tvp.valType)) |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
157 return false; |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
158 |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
159 if (specValue != tvp.specValue) |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
160 return false; |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
161 |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
162 return true; // match |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
163 } |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
164 |
89cc05dbdae1
Implementing TemplateAliasParameter and TemplateValueParameter
dkoroskin <>
parents:
0
diff
changeset
|
165 return false; |
0 | 166 } |
167 | |
72 | 168 override MATCH matchArg(Scope sc, Objects tiargs, int i, TemplateParameters parameters, Objects dedtypes, Declaration* psparam, int flags) |
0 | 169 { |
40 | 170 //printf("TemplateValueParameter.matchArg()\n"); |
171 | |
172 Initializer init; | |
173 Declaration sparam; | |
174 MATCH m = MATCHexact; | |
175 Expression ei; | |
176 Object oarg; | |
177 | |
178 if (i < tiargs.dim) | |
113
3482c73a991b
More cleanup for arrays
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents:
94
diff
changeset
|
179 oarg = tiargs[i]; |
40 | 180 else |
181 { | |
182 // Get default argument instead | |
183 oarg = defaultArg(loc, sc); | |
184 if (!oarg) | |
185 { | |
186 assert(i < dedtypes.dim); | |
187 // It might have already been deduced | |
113
3482c73a991b
More cleanup for arrays
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents:
94
diff
changeset
|
188 oarg = dedtypes[i]; |
40 | 189 if (!oarg) |
190 goto Lnomatch; | |
191 } | |
192 } | |
193 | |
194 ei = isExpression(oarg); | |
195 Type vt; | |
196 | |
197 if (!ei && oarg) | |
198 goto Lnomatch; | |
199 | |
200 if (ei && ei.op == TOKvar) | |
201 { | |
202 // Resolve const variables that we had skipped earlier | |
203 ei = ei.optimize(WANTvalue | WANTinterpret); | |
204 } | |
205 | |
206 if (specValue) | |
207 { | |
208 if (!ei || ei == edummy) | |
209 goto Lnomatch; | |
210 | |
211 Expression e = specValue; | |
212 | |
213 e = e.semantic(sc); | |
214 e = e.implicitCastTo(sc, valType); | |
215 e = e.optimize(WANTvalue | WANTinterpret); | |
216 //e.type = e.type.toHeadMutable(); | |
217 | |
218 ei = ei.syntaxCopy(); | |
219 ei = ei.semantic(sc); | |
220 ei = ei.optimize(WANTvalue | WANTinterpret); | |
221 //ei.type = ei.type.toHeadMutable(); | |
222 //printf("\tei: %s, %s\n", ei.toChars(), ei.type.toChars()); | |
223 //printf("\te : %s, %s\n", e.toChars(), e.type.toChars()); | |
224 if (!ei.equals(e)) | |
225 goto Lnomatch; | |
226 } | |
113
3482c73a991b
More cleanup for arrays
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents:
94
diff
changeset
|
227 else if (dedtypes[i]) |
40 | 228 { // Must match already deduced value |
113
3482c73a991b
More cleanup for arrays
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents:
94
diff
changeset
|
229 auto e = cast(Expression)dedtypes[i]; |
40 | 230 |
231 if (!ei || !ei.equals(e)) | |
232 goto Lnomatch; | |
233 } | |
234 Lmatch: | |
235 //printf("\tvalType: %s, ty = %d\n", valType.toChars(), valType.ty); | |
236 vt = valType.semantic(Loc(0), sc); | |
237 //printf("ei: %s, ei.type: %s\n", ei.toChars(), ei.type.toChars()); | |
238 //printf("vt = %s\n", vt.toChars()); | |
239 if (ei.type) | |
240 { | |
241 m = cast(MATCH)ei.implicitConvTo(vt); | |
242 //printf("m: %d\n", m); | |
243 if (!m) | |
244 goto Lnomatch; | |
245 } | |
94
3a0b150c9841
Objects -> Vector!Object iteration 1
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents:
72
diff
changeset
|
246 dedtypes[i] = ei; |
40 | 247 |
248 init = new ExpInitializer(loc, ei); | |
249 sparam = new VarDeclaration(loc, vt, ident, init); | |
250 sparam.storage_class = STCmanifest; | |
251 *psparam = sparam; | |
252 return m; | |
253 | |
254 Lnomatch: | |
255 //printf("\tno match\n"); | |
256 *psparam = null; | |
257 return MATCHnomatch; | |
0 | 258 } |
259 | |
94
3a0b150c9841
Objects -> Vector!Object iteration 1
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents:
72
diff
changeset
|
260 override Object dummyArg() |
0 | 261 { |
64 | 262 Expression e; |
263 | |
264 e = specValue; | |
265 if (!e) | |
266 { | |
267 // Create a dummy value | |
268 if (!edummy) | |
269 edummy = valType.defaultInit(Loc(0)); | |
270 e = edummy; | |
271 } | |
94
3a0b150c9841
Objects -> Vector!Object iteration 1
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents:
72
diff
changeset
|
272 return e; |
0 | 273 } |
72 | 274 } |