annotate dmd/TypeFunction.d @ 129:010eb8f0e18d

further work on dmd test suite
author korDen
date Sun, 05 Sep 2010 15:32:22 +0400
parents 1765f3ef917d
children 60bb0fe4563e
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1 module dmd.TypeFunction;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
2
114
e28b18c23469 added a module dmd.common for commonly used stuff
Trass3r
parents: 113
diff changeset
3 import dmd.common;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
4 import dmd.TypeNext;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
5 import dmd.TypeSArray;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
6 import dmd.TypeArray;
123
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
7 import dmd.TemplateTupleParameter;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
8 import dmd.ArrayTypes;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
9 import dmd.LINK;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
10 import dmd.StructDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
11 import dmd.TypeStruct;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
12 import dmd.Global;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
13 import dmd.STC;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
14 import dmd.MOD;
73
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
15 import dmd.PROT;
123
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
16 import dmd.TypeIdentifier;
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
17 import dmd.TemplateParameter;
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
18 import dmd.TypeInfoFunctionDeclaration;
123
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
19 import dmd.Tuple;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
20 import dmd.Type;
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.Identifier;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
24 import dmd.OutBuffer;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
25 import dmd.HdrGenState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
26 import dmd.CppMangleState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
27 import dmd.TypeInfoDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
28 import dmd.MATCH;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
29 import dmd.Argument;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
30 import dmd.Expression;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
31 import dmd.RET;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
32 import dmd.TY;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
33 import dmd.Util;
123
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
34 import dmd.TemplateInstance : isTuple;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
35
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
36 import dmd.backend.TYPE;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
37 import dmd.backend.PARAM;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
38 import dmd.backend.Util;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
39 import dmd.backend.TYM;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
40 import dmd.backend.TF;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
41 import dmd.backend.mTY;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
42
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
43 import core.stdc.stdlib;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
44 import core.stdc.string;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
45
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
46 import std.stdio;
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
47
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
48 class TypeFunction : TypeNext
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
49 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
50 // .next is the return type
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
51
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
52 Arguments parameters; // function parameters
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
53 int varargs; // 1: T t, ...) style for variable number of arguments
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
54 // 2: T t ...) style for variable number of arguments
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
55 bool isnothrow; // true: nothrow
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
56 bool ispure; // true: pure
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
57 bool isproperty; // can be called without parentheses
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
58 bool isref; // true: returns a reference
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
59 LINK linkage; // calling convention
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
60
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
61 int inuse;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
62
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
63 this(Arguments parameters, Type treturn, int varargs, LINK linkage)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
64 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
65 super(TY.Tfunction, treturn);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
66
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
67 //if (!treturn) *(char*)0=0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
68 // assert(treturn);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
69 assert(0 <= varargs && varargs <= 2);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
70 this.parameters = parameters;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
71 this.varargs = varargs;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
72 this.linkage = linkage;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
73 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
74
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 22
diff changeset
75 override Type syntaxCopy()
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
76 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
77 Type treturn = next ? next.syntaxCopy() : null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
78 Arguments params = Argument.arraySyntaxCopy(parameters);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
79 TypeFunction t = new TypeFunction(params, treturn, varargs, linkage);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
80 t.mod = mod;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
81 t.isnothrow = isnothrow;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
82 t.ispure = ispure;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
83 t.isproperty = isproperty;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
84 t.isref = isref;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
85
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
86 return t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
87 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
88
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
89 version (DumbClone) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
90 } else {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
91 final TypeFunction cloneTo(TypeFunction t)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
92 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
93 super.cloneTo(t);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
94
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
95 // these 3 should be set by ctor
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
96 assert(t.parameters is null);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
97 assert(t.varargs == varargs);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
98 assert(t.linkage == linkage);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
99
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
100 t.isnothrow = isnothrow;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
101 t.ispure = ispure;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
102 t.isproperty = isproperty;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
103 t.isref = isref;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
104 t.inuse = inuse;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
105
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
106 if (parameters)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
107 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
108 t.parameters = parameters.copy();
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
109 foreach (arg; parameters)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
110 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
111 Argument cpy = arg.clone();
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
112 t.parameters[i] = cpy;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
113 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
114 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
115
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
116 return t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
117 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
118
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
119 TypeFunction clone()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
120 {
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
121 assert(this.classinfo is TypeFunction.classinfo);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
122 return cloneTo(new TypeFunction(null, next, varargs, linkage));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
123 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
124 }
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 22
diff changeset
125 override Type semantic(Loc loc, Scope sc)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
126 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
127 if (deco) // if semantic() already run
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
128 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
129 //printf("already done\n");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
130 return this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
131 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
132 //printf("TypeFunction.semantic() this = %p\n", this);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
133 //printf("TypeFunction.semantic() %s, sc.stc = %x\n", toChars(), sc.stc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
134
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
135 /* Copy in order to not mess up original.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
136 * This can produce redundant copies if inferring return type,
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
137 * as semantic() will get called again on this.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
138 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
139
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
140 TypeFunction tf = cloneThis(this);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
141
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
142 if (sc.stc & STC.STCpure)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
143 tf.ispure = true;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
144 if (sc.stc & STC.STCnothrow)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
145 tf.isnothrow = true;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
146 if (sc.stc & STC.STCref)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
147 tf.isref = true;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
148
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
149 tf.linkage = sc.linkage;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
150 if (tf.next)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
151 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
152 tf.next = tf.next.semantic(loc,sc);
96
acd69f84627e further work
Trass3r
parents: 95
diff changeset
153 version(SARRAYVALUE) {} else
acd69f84627e further work
Trass3r
parents: 95
diff changeset
154 {
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
155 if (tf.next.toBasetype().ty == TY.Tsarray)
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
156 {
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
157 error(loc, "functions cannot return static array %s", tf.next.toChars());
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
158 tf.next = Type.terror;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
159 }
96
acd69f84627e further work
Trass3r
parents: 95
diff changeset
160 }
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
161 if (tf.next.toBasetype().ty == TY.Tfunction)
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
162 {
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
163 error(loc, "functions cannot return a function");
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
164 tf.next = Type.terror;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
165 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
166 if (tf.next.toBasetype().ty == TY.Ttuple)
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
167 {
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
168 error(loc, "functions cannot return a tuple");
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
169 tf.next = Type.terror;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
170 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
171 if (tf.next.isauto() && !(sc.flags & SCOPE.SCOPEctor))
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
172 error(loc, "functions cannot return scope %s", tf.next.toChars());
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
173 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
174
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
175 if (tf.parameters)
73
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
176 {
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
177 /* Create a scope for evaluating the default arguments for the parameters
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
178 */
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
179 Scope argsc = sc.push();
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
180 argsc.stc = STCundefined; // don't inherit storage class
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
181 argsc.protection = PROT.PROTpublic;
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
182
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
183 size_t dim = Argument.dim(tf.parameters);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
184
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
185 for (size_t i = 0; i < dim; i++)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
186 { Argument arg = Argument.getNth(tf.parameters, i);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
187
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
188 tf.inuse++;
73
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
189 arg.type = arg.type.semantic(loc, argsc);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
190 if (tf.inuse == 1) tf.inuse--;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
191
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
192 arg.type = arg.type.addStorageClass(arg.storageClass);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
193
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
194 if (arg.storageClass & (STC.STCauto | STC.STCalias | STC.STCstatic))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
195 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
196 if (!arg.type)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
197 continue;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
198 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
199
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
200 Type t = arg.type.toBasetype();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
201
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
202 if (arg.storageClass & (STC.STCout | STC.STCref | STC.STClazy))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
203 {
96
acd69f84627e further work
Trass3r
parents: 95
diff changeset
204 //if (t.ty == TY.Tsarray)
acd69f84627e further work
Trass3r
parents: 95
diff changeset
205 //error(loc, "cannot have out or ref parameter of type %s", t.toChars());
acd69f84627e further work
Trass3r
parents: 95
diff changeset
206 if (arg.storageClass & STC.STCout && arg.type.mod & (STCconst | STCimmutable))
acd69f84627e further work
Trass3r
parents: 95
diff changeset
207 error(loc, "cannot have const or immutabl out parameter of type %s", t.toChars());
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
208 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
209 if (!(arg.storageClass & STC.STClazy) && t.ty == TY.Tvoid)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
210 error(loc, "cannot have parameter of type %s", arg.type.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
211
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
212 if (arg.defaultArg)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
213 {
73
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
214 arg.defaultArg = arg.defaultArg.semantic(argsc);
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
215 arg.defaultArg = resolveProperties(argsc, arg.defaultArg);
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
216 arg.defaultArg = arg.defaultArg.implicitCastTo(argsc, arg.type);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
217 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
218
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
219 /* If arg turns out to be a tuple, the number of parameters may
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
220 * change.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
221 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
222 if (t.ty == TY.Ttuple)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
223 { dim = Argument.dim(tf.parameters);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
224 i--;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
225 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
226 }
73
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
227 argsc.pop();
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
228 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
229 if (tf.next)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
230 tf.deco = tf.merge().deco;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
231
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
232 if (tf.inuse)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
233 { error(loc, "recursive type");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
234 tf.inuse = 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
235 return terror;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
236 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
237
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
238 if (tf.varargs == 1 && tf.linkage != LINK.LINKd && Argument.dim(tf.parameters) == 0)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
239 error(loc, "variadic functions with non-D linkage must have at least one parameter");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
240
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
241 /* Don't return merge(), because arg identifiers and default args
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
242 * can be different
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
243 * even though the types match
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
244 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
245 return tf;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
246 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
247
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 22
diff changeset
248 override void toDecoBuffer(OutBuffer buf, int flag)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
249 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
250 ubyte mc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
251
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
252 //printf("TypeFunction.toDecoBuffer() this = %p %s\n", this, toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
253 //static int nest; if (++nest == 50) *(char*)0=0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
254 if (inuse)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
255 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
256 inuse = 2; // flag error to caller
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
257 return;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
258 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
259 inuse++;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
260 static if (true) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
261 if (mod & MOD.MODshared)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
262 buf.writeByte('O');
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
263 if (mod & MOD.MODconst)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
264 buf.writeByte('x');
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
265 else if (mod & MOD.MODinvariant)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
266 buf.writeByte('y');
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
267 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
268 switch (linkage)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
269 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
270 case LINK.LINKd: mc = 'F'; break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
271 case LINK.LINKc: mc = 'U'; break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
272 case LINK.LINKwindows: mc = 'W'; break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
273 case LINK.LINKpascal: mc = 'V'; break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
274 case LINK.LINKcpp: mc = 'R'; break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
275 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
276 buf.writeByte(mc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
277 if (ispure || isnothrow || isproperty || isref)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
278 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
279 if (ispure)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
280 buf.writestring("Na");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
281 if (isnothrow)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
282 buf.writestring("Nb");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
283 if (isref)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
284 buf.writestring("Nc");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
285 if (isproperty)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
286 buf.writestring("Nd");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
287 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
288 // Write argument types
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
289 Argument.argsToDecoBuffer(buf, parameters);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
290 //if (buf.data[buf.offset - 1] == '@') halt();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
291 buf.writeByte('Z' - varargs); // mark end of arg list
79
43073c7c7769 updated to 2.035
Trass3r
parents: 73
diff changeset
292 assert(next);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
293 next.toDecoBuffer(buf);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
294 inuse--;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
295 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
296
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 22
diff changeset
297 override void toCBuffer(OutBuffer buf, Identifier ident, HdrGenState* hgs)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
298 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
299 //printf("TypeFunction.toCBuffer() this = %p\n", this);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
300 string p = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
301
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
302 if (inuse)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
303 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
304 inuse = 2; // flag error to caller
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
305 return;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
306 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
307 inuse++;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
308
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
309 /* Use 'storage class' style for attributes
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
310 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
311 if (mod & MODconst)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
312 buf.writestring("const ");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
313 if (mod & MODinvariant)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
314 buf.writestring("immutable ");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
315 if (mod & MODshared)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
316 buf.writestring("shared ");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
317
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
318 if (ispure)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
319 buf.writestring("pure ");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
320 if (isnothrow)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
321 buf.writestring("nothrow ");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
322 if (isproperty)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
323 buf.writestring("@property ");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
324 if (isref)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
325 buf.writestring("ref ");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
326
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
327 if (next && (!ident || ident.toHChars2() == ident.toChars()))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
328 next.toCBuffer2(buf, hgs, MODundefined);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
329 if (hgs.ddoc != 1)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
330 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
331 switch (linkage)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
332 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
333 case LINKd: p = null; break;
73
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
334 case LINKc: p = " C"; break;
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
335 case LINKwindows: p = " Windows"; break;
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
336 case LINKpascal: p = " Pascal"; break;
ef02e2e203c2 Updating to dmd2.033
korDen
parents: 72
diff changeset
337 case LINKcpp: p = " C++"; break;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
338 default:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
339 assert(0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
340 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
341 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
342
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
343 if (!hgs.hdrgen && p)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
344 buf.writestring(p);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
345 if (ident)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
346 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
347 buf.writeByte(' ');
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
348 buf.writestring(ident.toHChars2());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
349 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
350 Argument.argsToCBuffer(buf, hgs, parameters, varargs);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
351 inuse--;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
352 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
353
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 22
diff changeset
354 override void toCBuffer2(OutBuffer buf, HdrGenState* hgs, MOD mod)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
355 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
356 //printf("TypeFunction::toCBuffer2() this = %p, ref = %d\n", this, isref);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
357 string p;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
358
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
359 if (inuse)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
360 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
361 inuse = 2; // flag error to caller
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
362 return;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
363 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
364
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
365 inuse++;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
366 if (next)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
367 next.toCBuffer2(buf, hgs, MODundefined);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
368
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
369 if (hgs.ddoc != 1)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
370 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
371 switch (linkage)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
372 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
373 case LINKd: p = null; break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
374 case LINKc: p = "C "; break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
375 case LINKwindows: p = "Windows "; break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
376 case LINKpascal: p = "Pascal "; break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
377 case LINKcpp: p = "C++ "; break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
378 default: assert(0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
379 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
380 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
381
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
382 if (!hgs.hdrgen && p)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
383 buf.writestring(p);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
384 buf.writestring(" function");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
385 Argument.argsToCBuffer(buf, hgs, parameters, varargs);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
386
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
387 /* Use postfix style for attributes
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
388 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
389 if (mod != this.mod)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
390 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
391 modToBuffer(buf);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
392 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
393
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
394 if (ispure)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
395 buf.writestring(" pure");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
396 if (isnothrow)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
397 buf.writestring(" nothrow");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
398 if (isproperty)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
399 buf.writestring(" @property");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
400 if (isref)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
401 buf.writestring(" ref");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
402
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
403 inuse--;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
404 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
405
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 22
diff changeset
406 override MATCH deduceType(Scope sc, Type tparam, TemplateParameters parameters, Objects dedtypes)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
407 {
123
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
408 //printf("TypeFunction.deduceType()\n");
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
409 //printf("\tthis = %d, ", ty); print();
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
410 //printf("\ttparam = %d, ", tparam.ty); tparam.print();
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
411
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
412 // Extra check that function characteristics must match
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
413 if (tparam && tparam.ty == Tfunction)
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
414 {
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
415 TypeFunction tp = cast(TypeFunction)tparam;
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
416 if (varargs != tp.varargs ||
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
417 linkage != tp.linkage)
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
418 return MATCHnomatch;
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
419
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
420 size_t nfargs = Argument.dim(this.parameters);
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
421 size_t nfparams = Argument.dim(tp.parameters);
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
422
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
423 /* See if tuple match
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
424 */
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
425 if (nfparams > 0 && nfargs >= nfparams - 1)
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
426 {
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
427 /* See if 'A' of the template parameter matches 'A'
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
428 * of the type of the last function parameter.
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
429 */
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
430 Argument fparam = Argument.getNth(tp.parameters, nfparams - 1);
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
431 assert(fparam);
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
432 assert(fparam.type);
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
433 if (fparam.type.ty != Tident)
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
434 goto L1;
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
435 TypeIdentifier tid = cast(TypeIdentifier)fparam.type;
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
436 if (tid.idents.dim)
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
437 goto L1;
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
438
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
439 /* Look through parameters to find tuple matching tid.ident
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
440 */
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
441 size_t tupi = 0;
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
442 for (; 1; tupi++)
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
443 {
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
444 if (tupi == parameters.dim)
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
445 goto L1;
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
446 TemplateParameter t = parameters[tupi];
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
447 TemplateTupleParameter tup = t.isTemplateTupleParameter();
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
448 if (tup && tup.ident.equals(tid.ident))
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
449 break;
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
450 }
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
451
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
452 /* The types of the function arguments [nfparams - 1 .. nfargs]
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
453 * now form the tuple argument.
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
454 */
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
455 int tuple_dim = nfargs - (nfparams - 1);
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
456
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
457 /* See if existing tuple, and whether it matches or not
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
458 */
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
459 Object o = dedtypes[tupi];
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
460 if (o)
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
461 {
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
462 // Existing deduced argument must be a tuple, and must match
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
463 Tuple t = isTuple(o);
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
464 if (!t || t.objects.dim != tuple_dim)
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
465 return MATCHnomatch;
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
466 for (size_t i = 0; i < tuple_dim; i++)
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
467 {
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
468 Argument arg = Argument.getNth(this.parameters, nfparams - 1 + i);
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
469 if (!arg.type.equals(t.objects[i]))
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
470 return MATCHnomatch;
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
471 }
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
472 }
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
473 else
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
474 { // Create new tuple
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
475 Tuple t = new Tuple();
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
476 t.objects.setDim(tuple_dim);
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
477 for (size_t i = 0; i < tuple_dim; i++)
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
478 {
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
479 Argument arg = Argument.getNth(this.parameters, nfparams - 1 + i);
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
480 t.objects[i] = arg.type;
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
481 }
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
482 dedtypes[tupi] = t;
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
483 }
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
484 nfparams--; // don't consider the last parameter for type deduction
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
485 goto L2;
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
486 }
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
487
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
488 L1:
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
489 if (nfargs != nfparams)
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
490 return MATCHnomatch;
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
491 L2:
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
492 for (size_t i = 0; i < nfparams; i++)
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
493 {
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
494 Argument a = Argument.getNth(this.parameters, i);
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
495 Argument ap = Argument.getNth(tp.parameters, i);
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
496 if (a.storageClass != ap.storageClass ||
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
497 !a.type.deduceType(sc, ap.type, parameters, dedtypes))
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
498 return MATCHnomatch;
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
499 }
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
500 }
9e39c7de8438 Make dmd test suite compile
korDen
parents: 114
diff changeset
501 return Type.deduceType(sc, tparam, parameters, dedtypes);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
502 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
503
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 22
diff changeset
504 override TypeInfoDeclaration getTypeInfoDeclaration()
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
505 {
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
506 return new TypeInfoFunctionDeclaration(this);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
507 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
508
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 22
diff changeset
509 override Type reliesOnTident()
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
510 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
511 if (parameters)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
512 {
126
1765f3ef917d ClassDeclarations, Arguments -> Vector
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 123
diff changeset
513 foreach (arg; parameters)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
514 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
515 Type t = arg.type.reliesOnTident();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
516 if (t)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
517 return t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
518 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
519 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
520 return next.reliesOnTident();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
521 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
522
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
523 version (CPP_MANGLE) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
524 void toCppMangle(OutBuffer buf, CppMangleState* cms)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
525 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
526 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
527 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
528 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
529
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
530 /***************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
531 * Examine function signature for parameter p and see if
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
532 * p can 'escape' the scope of the function.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
533 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
534 bool parameterEscapes(Argument p)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
535 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
536 /* Scope parameters do not escape.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
537 * Allow 'lazy' to imply 'scope' -
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
538 * lazy parameters can be passed along
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
539 * as lazy parameters to the next function, but that isn't
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
540 * escaping.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
541 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
542 if (p.storageClass & (STC.STCscope | STC.STClazy))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
543 return false;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
544
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
545 if (ispure)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
546 { /* With pure functions, we need only be concerned if p escapes
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
547 * via any return statement.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
548 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
549 Type tret = nextOf().toBasetype();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
550 if (!isref && !tret.hasPointers())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
551 { /* The result has no references, so p could not be escaping
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
552 * that way.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
553 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
554 return false;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
555 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
556 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
557
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
558 /* Assume it escapes in the absence of better information.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
559 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
560 return true;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
561 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
562
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
563 /********************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
564 * 'args' are being matched to function 'this'
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
565 * Determine match level.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
566 * Returns:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
567 * MATCHxxxx
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
568 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
569 MATCH callMatch(Expression ethis, Expressions args)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
570 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
571 //printf("TypeFunction.callMatch() %s\n", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
572 MATCH match = MATCH.MATCHexact; // assume exact match
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
573
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
574 if (ethis)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
575 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
576 Type t = ethis.type;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
577 if (t.toBasetype().ty == TY.Tpointer)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
578 t = t.toBasetype().nextOf(); // change struct* to struct
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
579
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
580 if (t.mod != mod)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
581 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
582 if (mod == MOD.MODconst)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
583 match = MATCH.MATCHconst;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
584 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
585 return MATCH.MATCHnomatch;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
586 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
587 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
588
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
589 size_t nparams = Argument.dim(parameters);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
590 size_t nargs = args ? args.dim : 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
591 if (nparams == nargs) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
592 ;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
593 } else if (nargs > nparams)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
594 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
595 if (varargs == 0)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
596 goto Nomatch; // too many args; no match
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
597 match = MATCH.MATCHconvert; // match ... with a "conversion" match level
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
598 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
599
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
600 for (size_t u = 0; u < nparams; u++)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
601 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
602 MATCH m;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
603 Expression arg;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
604
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
605 // BUG: what about out and ref?
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
606
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
607 Argument p = Argument.getNth(parameters, u);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
608 assert(p);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
609 if (u >= nargs)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
610 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
611 if (p.defaultArg)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
612 continue;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
613 if (varargs == 2 && u + 1 == nparams)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
614 goto L1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
615 goto Nomatch; // not enough arguments
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
616 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
617
113
3482c73a991b More cleanup for arrays
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 96
diff changeset
618 arg = cast(Expression)args[u];
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
619 assert(arg);
96
acd69f84627e further work
Trass3r
parents: 95
diff changeset
620 // writef("arg: %s, type: %s\n", arg.toChars(), arg.type.toChars());
acd69f84627e further work
Trass3r
parents: 95
diff changeset
621
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
622
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
623 // Non-lvalues do not match ref or out parameters
96
acd69f84627e further work
Trass3r
parents: 95
diff changeset
624 if (p.storageClass & (STC.STCref | STC.STCout))
acd69f84627e further work
Trass3r
parents: 95
diff changeset
625 {
acd69f84627e further work
Trass3r
parents: 95
diff changeset
626 if (!arg.isLvalue())
acd69f84627e further work
Trass3r
parents: 95
diff changeset
627 goto Nomatch;
acd69f84627e further work
Trass3r
parents: 95
diff changeset
628 }
acd69f84627e further work
Trass3r
parents: 95
diff changeset
629
acd69f84627e further work
Trass3r
parents: 95
diff changeset
630 if (p.storageClass & STCref)
acd69f84627e further work
Trass3r
parents: 95
diff changeset
631 {
acd69f84627e further work
Trass3r
parents: 95
diff changeset
632 /* Don't allow static arrays to be passed to mutable refereces
acd69f84627e further work
Trass3r
parents: 95
diff changeset
633 * to static arrays if the argument cannot be modified.
acd69f84627e further work
Trass3r
parents: 95
diff changeset
634 */
acd69f84627e further work
Trass3r
parents: 95
diff changeset
635 Type targb = arg.type.toBasetype();
acd69f84627e further work
Trass3r
parents: 95
diff changeset
636 Type tparb = p.type.toBasetype();
acd69f84627e further work
Trass3r
parents: 95
diff changeset
637 //writef("%s\n", targb.toChars());
acd69f84627e further work
Trass3r
parents: 95
diff changeset
638 //writef("%s\n", tparb.toChars());
acd69f84627e further work
Trass3r
parents: 95
diff changeset
639 if (targb.nextOf() && tparb.ty == Tsarray &&
acd69f84627e further work
Trass3r
parents: 95
diff changeset
640 targb.nextOf().mod != tparb.nextOf().mod &&
acd69f84627e further work
Trass3r
parents: 95
diff changeset
641 !tparb.nextOf().isConst())
acd69f84627e further work
Trass3r
parents: 95
diff changeset
642 goto Nomatch;
acd69f84627e further work
Trass3r
parents: 95
diff changeset
643 }
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
644
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
645 if (p.storageClass & STC.STClazy && p.type.ty == TY.Tvoid && arg.type.ty != TY.Tvoid)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
646 m = MATCH.MATCHconvert;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
647 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
648 m = arg.implicitConvTo(p.type);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
649 //printf("\tm = %d\n", m);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
650 if (m == MATCH.MATCHnomatch) // if no match
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
651 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
652 L1:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
653 if (varargs == 2 && u + 1 == nparams) // if last varargs param
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
654 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
655 Type tb = p.type.toBasetype();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
656 TypeSArray tsa;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
657 long sz;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
658
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
659 switch (tb.ty)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
660 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
661 case TY.Tsarray:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
662 tsa = cast(TypeSArray)tb;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
663 sz = tsa.dim.toInteger();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
664 if (sz != nargs - u)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
665 goto Nomatch;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
666 case TY.Tarray:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
667 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
668 TypeArray ta = cast(TypeArray)tb;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
669 for (; u < nargs; u++)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
670 {
113
3482c73a991b More cleanup for arrays
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 96
diff changeset
671 arg = cast(Expression)args[u];
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
672 assert(arg);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
673 static if (true) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
674 /* If lazy array of delegates,
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
675 * convert arg(s) to delegate(s)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
676 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
677 Type tret = p.isLazyArray();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
678 if (tret)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
679 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
680 if (ta.next.equals(arg.type))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
681 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
682 m = MATCH.MATCHexact;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
683 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
684 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
685 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
686 m = arg.implicitConvTo(tret);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
687 if (m == MATCH.MATCHnomatch)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
688 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
689 if (tret.toBasetype().ty == TY.Tvoid)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
690 m = MATCH.MATCHconvert;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
691 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
692 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
693 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
694 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
695 m = arg.implicitConvTo(ta.next);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
696 } else {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
697 m = arg.implicitConvTo(ta.next);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
698 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
699 if (m == MATCH.MATCHnomatch)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
700 goto Nomatch;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
701
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
702 if (m < match)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
703 match = m;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
704 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
705 goto Ldone;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
706 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
707
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
708 case TY.Tclass:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
709 // Should see if there's a constructor match?
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
710 // Or just leave it ambiguous?
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
711 goto Ldone;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
712
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
713 default:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
714 goto Nomatch;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
715 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
716 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
717
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
718 goto Nomatch;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
719 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
720
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
721 if (m < match)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
722 match = m; // pick worst match
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
723 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
724
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
725 Ldone:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
726 //printf("match = %d\n", match);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
727 return match;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
728
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
729 Nomatch:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
730 //printf("no match\n");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
731 return MATCH.MATCHnomatch;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
732 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
733
96
acd69f84627e further work
Trass3r
parents: 95
diff changeset
734 override type* toCtype()
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
735 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
736 if (ctype) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
737 return ctype;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
738 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
739
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
740 type* t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
741 if (true)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
742 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
743 param_t* paramtypes;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
744 tym_t tyf;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
745 type* tp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
746
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
747 paramtypes = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
748 size_t nparams = Argument.dim(parameters);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
749 for (size_t i = 0; i < nparams; i++)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
750 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
751 Argument arg = Argument.getNth(parameters, i);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
752 tp = arg.type.toCtype();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
753 if (arg.storageClass & (STC.STCout | STC.STCref))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
754 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
755 // C doesn't have reference types, so it's really a pointer
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
756 // to the parameter type
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
757 tp = type_allocn(TYM.TYref, tp);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
758 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
759 param_append_type(&paramtypes,tp);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
760 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
761 tyf = totym();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
762 t = type_alloc(tyf);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
763 t.Tflags |= TF.TFprototype;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
764 if (varargs != 1)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
765 t.Tflags |= TF.TFfixed;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
766 ctype = t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
767 t.Tnext = next.toCtype();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
768 t.Tnext.Tcount++;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
769 t.Tparamtypes = paramtypes;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
770 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
771 ctype = t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
772 return t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
773 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
774
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
775 /***************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
776 * Determine return style of function - whether in registers or
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
777 * through a hidden pointer to the caller's stack.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
778 */
96
acd69f84627e further work
Trass3r
parents: 95
diff changeset
779 RET retStyle()
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
780 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
781 //printf("TypeFunction.retStyle() %s\n", toChars());
95
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
782 version (DMDV2)
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
783 {
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
784 if (isref)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
785 return RET.RETregs; // returns a pointer
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
786 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
787
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
788 Type tn = next.toBasetype();
95
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
789 Type tns = tn;
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
790 ulong sz = tn.size();
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
791
95
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
792 version(SARRAYVALUE)
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
793 {
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
794 if (tn.ty == Tsarray)
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
795 {
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
796 do
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
797 {
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
798 tns = tns.nextOf().toBasetype();
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
799 } while (tns.ty == Tsarray);
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
800 if (tns.ty != Tstruct)
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
801 {
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
802 if (global.params.isLinux && linkage != LINKd)
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
803 {}
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
804 else
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
805 {
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
806 switch (sz)
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
807 { case 1:
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
808 case 2:
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
809 case 4:
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
810 case 8:
96
acd69f84627e further work
Trass3r
parents: 95
diff changeset
811 return RET.RETregs; // return small structs in regs
acd69f84627e further work
Trass3r
parents: 95
diff changeset
812 // (not 3 byte structs!)
95
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
813 default:
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
814 break;
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
815 }
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
816 }
96
acd69f84627e further work
Trass3r
parents: 95
diff changeset
817 return RET.RETstack;
95
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
818 }
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
819 }
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
820 }
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
821 if (tns.ty == TY.Tstruct)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
822 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
823 StructDeclaration sd = (cast(TypeStruct)tn).sym;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
824 if (global.params.isLinux && linkage != LINK.LINKd) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
825 ;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
826 }
95
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
827 ///version (DMDV2) { // TODO:
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
828 else if (sd.dtor || sd.cpctor)
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
829 {
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
830 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
831 ///}
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
832 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
833 {
95
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 79
diff changeset
834 switch (sz)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
835 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
836 case 1:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
837 case 2:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
838 case 4:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
839 case 8:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
840 return RET.RETregs; // return small structs in regs
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
841 // (not 3 byte structs!)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
842 default:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
843 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
844 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
845 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
846 return RET.RETstack;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
847 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
848 else if ((global.params.isLinux || global.params.isOSX || global.params.isFreeBSD || global.params.isSolaris) &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
849 linkage == LINK.LINKc &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
850 tn.iscomplex())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
851 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
852 if (tn.ty == TY.Tcomplex32)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
853 return RET.RETregs; // in EDX:EAX, not ST1:ST0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
854 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
855 return RET.RETstack;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
856 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
857 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
858 return RET.RETregs;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
859 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
860
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 22
diff changeset
861 override TYM totym()
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
862 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
863 TYM tyf;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
864
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
865 //printf("TypeFunction.totym(), linkage = %d\n", linkage);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
866 switch (linkage)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
867 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
868 case LINK.LINKwindows:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
869 tyf = (varargs == 1) ? TYM.TYnfunc : TYM.TYnsfunc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
870 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
871
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
872 case LINK.LINKpascal:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
873 tyf = (varargs == 1) ? TYM.TYnfunc : TYM.TYnpfunc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
874 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
875
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
876 case LINK.LINKc:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
877 tyf = TYM.TYnfunc;
22
fd4acc376c45 Implemented object file output and linking on linux.
Robert Clipsham <robert@octarineparrot.com>
parents: 0
diff changeset
878 version (POSIX) {///TARGET_LINUX || TARGET_OSX || TARGET_FREEBSD || TARGET_SOLARIS
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
879 if (retStyle() == RET.RETstack)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
880 tyf = TYM.TYhfunc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
881 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
882 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
883
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
884 case LINK.LINKd:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
885 tyf = (varargs == 1) ? TYM.TYnfunc : TYM.TYjfunc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
886 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
887
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
888 case LINK.LINKcpp:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
889 tyf = TYM.TYnfunc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
890 break;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
891
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
892 default:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
893 writef("linkage = %d\n", linkage);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
894 assert(0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
895 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
896 version (DMDV2) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
897 if (isnothrow)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
898 tyf |= mTY.mTYnothrow;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
899 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
900 return tyf;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
901 }
22
fd4acc376c45 Implemented object file output and linking on linux.
Robert Clipsham <robert@octarineparrot.com>
parents: 0
diff changeset
902 }