annotate dmd/StructDeclaration.d @ 131:206db751bd4c

dmdfe 2.037 compiles now
author Eldar Insafutdinov <e.insafutdinov@gmail.com>
date Fri, 10 Sep 2010 00:27:37 +0100
parents 60bb0fe4563e
children af1bebfd96a4
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1 module dmd.StructDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
2
114
e28b18c23469 added a module dmd.common for commonly used stuff
Trass3r
parents: 103
diff changeset
3 import dmd.common;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
4 import dmd.AggregateDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
5 import dmd.FuncDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
6 import dmd.DeclarationExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
7 import dmd.VoidInitializer;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
8 import dmd.Initializer;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
9 import dmd.ExpInitializer;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
10 import dmd.TOK;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
11 import dmd.Statement;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
12 import dmd.VarExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
13 import dmd.CompoundStatement;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
14 import dmd.AssignExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
15 import dmd.DotVarExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
16 import dmd.AddrExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
17 import dmd.CastExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
18 import dmd.PostBlitDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
19 import dmd.Lexer;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
20 import dmd.ExpStatement;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
21 import dmd.DotIdExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
22 import dmd.TypeSArray;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
23 import dmd.ThisExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
24 import dmd.ThisDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
25 import dmd.TypeFunction;
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
26 import dmd.Parameter;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
27 import dmd.Id;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
28 import dmd.TY;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
29 import dmd.LINK;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
30 import dmd.Type;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
31 import dmd.DsymbolTable;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
32 import dmd.ArrayTypes;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
33 import dmd.Loc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
34 import dmd.STC;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
35 import dmd.Identifier;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
36 import dmd.TemplateInstance;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
37 import dmd.Dsymbol;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
38 import dmd.Scope;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
39 import dmd.OutBuffer;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
40 import dmd.HdrGenState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
41 import dmd.PROT;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
42 import dmd.TypeStruct;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
43 import dmd.expression.Util;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
44 import dmd.Expression;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
45 import dmd.IdentifierExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
46 import dmd.PtrExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
47 import dmd.CallExp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
48 import dmd.ReturnStatement;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
49 import dmd.ScopeDsymbol;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
50 import dmd.Module;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
51 import dmd.VarDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
52 import dmd.InvariantDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
53 import dmd.NewDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
54 import dmd.DeleteDeclaration;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
55 import dmd.Global;
131
206db751bd4c dmdfe 2.037 compiles now
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 130
diff changeset
56 import dmd.MOD;
206db751bd4c dmdfe 2.037 compiles now
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 130
diff changeset
57 import dmd.IntegerExp;
206db751bd4c dmdfe 2.037 compiles now
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 130
diff changeset
58 import dmd.EqualExp;
206db751bd4c dmdfe 2.037 compiles now
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 130
diff changeset
59 import dmd.AndAndExp;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
60
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
61 import dmd.backend.dt_t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
62 import dmd.backend.Util;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
63 import dmd.backend.SC;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
64 import dmd.backend.DT;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
65 import dmd.backend.FL;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
66 import dmd.backend.glue;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
67
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
68 import std.stdio;
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
69
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
70 class StructDeclaration : AggregateDeclaration
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
71 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
72 bool zeroInit; // true if initialize with 0 fill
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
73
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
74 version (DMDV2) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
75 int hasIdentityAssign; // !=0 if has identity opAssign
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
76 FuncDeclaration cpctor; // generated copy-constructor, if any
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
77 FuncDeclaration eq; // bool opEquals(ref const T), if any
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
78
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
79 FuncDeclarations postblits; // Array of postblit functions
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
80 FuncDeclaration postblit; // aggregate postblit
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
81 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
82
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
83 this(Loc loc, Identifier id)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
84 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
85 super(loc, id);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
86
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
87 // For forward references
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
88 type = new TypeStruct(this);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
89
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
90 postblits = new FuncDeclarations(); ///
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
91 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
92
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 49
diff changeset
93 override Dsymbol syntaxCopy(Dsymbol s)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
94 {
49
0aa7d1437ada AttribDeclaration.oneMember
korDen
parents: 13
diff changeset
95 StructDeclaration sd;
0aa7d1437ada AttribDeclaration.oneMember
korDen
parents: 13
diff changeset
96
0aa7d1437ada AttribDeclaration.oneMember
korDen
parents: 13
diff changeset
97 if (s)
0aa7d1437ada AttribDeclaration.oneMember
korDen
parents: 13
diff changeset
98 sd = cast(StructDeclaration)s;
0aa7d1437ada AttribDeclaration.oneMember
korDen
parents: 13
diff changeset
99 else
0aa7d1437ada AttribDeclaration.oneMember
korDen
parents: 13
diff changeset
100 sd = new StructDeclaration(loc, ident);
0aa7d1437ada AttribDeclaration.oneMember
korDen
parents: 13
diff changeset
101 ScopeDsymbol.syntaxCopy(sd);
0aa7d1437ada AttribDeclaration.oneMember
korDen
parents: 13
diff changeset
102 return sd;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
103 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
104
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 49
diff changeset
105 override void semantic(Scope sc)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
106 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
107 Scope sc2;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
108
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
109 //printf("+StructDeclaration.semantic(this=%p, '%s')\n", this, toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
110
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
111 //static int count; if (++count == 20) *(char*)0=0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
112
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
113 assert(type);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
114 if (!members) // if forward reference
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
115 return;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
116
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
117 if (symtab)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
118 { if (!scope_)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
119 return; // semantic() already completed
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
120 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
121 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
122 symtab = new DsymbolTable();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
123
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
124 Scope scx = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
125 if (scope_)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
126 { sc = scope_;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
127 scx = scope_; // save so we don't make redundant copies
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
128 scope_ = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
129 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
130
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
131 parent = sc.parent;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
132 type = type.semantic(loc, sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
133 version (STRUCTTHISREF) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
134 handle = type;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
135 } else {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
136 handle = type.pointerTo();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
137 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
138 structalign = sc.structalign;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
139 protection = sc.protection;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
140 storage_class |= sc.stc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
141 if (sc.stc & STC.STCdeprecated)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
142 isdeprecated = 1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
143 assert(!isAnonymous());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
144 if (sc.stc & STC.STCabstract)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
145 error("structs, unions cannot be abstract");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
146 version (DMDV2) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
147 if (storage_class & STC.STCimmutable)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
148 type = type.invariantOf();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
149 else if (storage_class & STC.STCconst)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
150 type = type.constOf();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
151 else if (storage_class & STC.STCshared)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
152 type = type.sharedOf();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
153 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
154
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
155 if (sizeok == 0) // if not already done the addMember step
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
156 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
157 int hasfunctions = 0;
77
ad4792a1cfd6 more D-ification container accessing
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 74
diff changeset
158 foreach(Dsymbol s; members)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
159 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
160 //printf("adding member '%s' to '%s'\n", s.toChars(), this.toChars());
13
427f8aa74d28 On the road to make Phobos compilable
korDen
parents: 0
diff changeset
161 s.addMember(sc, this, true);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
162 if (s.isFuncDeclaration())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
163 hasfunctions = 1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
164 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
165
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
166 // If nested struct, add in hidden 'this' pointer to outer scope
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
167 if (hasfunctions && !(storage_class & STC.STCstatic))
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
168 { Dsymbol s = toParent2();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
169 if (s)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
170 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
171 AggregateDeclaration ad = s.isAggregateDeclaration();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
172 FuncDeclaration fd = s.isFuncDeclaration();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
173
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
174 TemplateInstance ti;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
175 if (ad && (ti = ad.parent.isTemplateInstance()) !is null && ti.isnested || fd)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
176 { isnested = true;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
177 Type t;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
178 if (ad)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
179 t = ad.handle;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
180 else if (fd)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
181 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
182 AggregateDeclaration add = fd.isMember2();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
183 if (add)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
184 t = add.handle;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
185 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
186 t = Type.tvoidptr;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
187 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
188 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
189 assert(0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
190 if (t.ty == TY.Tstruct)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
191 t = Type.tvoidptr; // t should not be a ref type
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
192 assert(!vthis);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
193 vthis = new ThisDeclaration(loc, t);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
194 //vthis.storage_class |= STC.STCref;
74
7e0d548de9e6 Switch Arrays of Dsymbols to the new templated Vector type
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 72
diff changeset
195 members.push(vthis);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
196 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
197 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
198 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
199 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
200
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
201 sizeok = 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
202 sc2 = sc.push(this);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
203 sc2.stc &= storage_class & STC.STC_TYPECTOR;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
204 sc2.parent = this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
205 if (isUnionDeclaration())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
206 sc2.inunion = 1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
207 sc2.protection = PROT.PROTpublic;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
208 sc2.explicitProtection = 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
209
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
210 int members_dim = members.dim;
77
ad4792a1cfd6 more D-ification container accessing
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 74
diff changeset
211 foreach(Dsymbol s; members)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
212 {
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
213 s.semantic(sc2);
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
214 if (isUnionDeclaration())
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
215 sc2.offset = 0;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
216 static if (false) {
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
217 if (sizeok == 2)
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
218 { //printf("forward reference\n");
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
219 break;
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
220 }
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
221 }
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
222 if (auto d = s.isDeclaration())
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
223 {
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
224 if (auto t = d.type) {
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
225 if (t.toBasetype().ty == TY.Tstruct) {
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
226 auto ad = t.toDsymbol(sc).isThis();
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
227 /*
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
228 StructDeclaration sd = cast(StructDeclaration)foo;
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
229 if (foo && !sd) {
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
230 writeln(t.classin);
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
231 writeln(foo.classinfo.name);
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
232 assert(false);
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
233 }
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
234 */
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
235 if (ad && ad.isnested)
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
236 error("inner struct %s cannot be a field", ad.toChars());
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
237 }
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
238 }
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
239 }
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
240 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
241
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
242 version(DMDV1) {
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
243 /* This doesn't work for DMDV2 because (ref S) and (S) parameter
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
244 * lists will overload the same.
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
245 */
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
246 /* The TypeInfo_Struct is expecting an opEquals and opCmp with
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
247 * a parameter that is a pointer to the struct. But if there
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
248 * isn't one, but is an opEquals or opCmp with a value, write
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
249 * another that is a shell around the value:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
250 * int opCmp(struct *p) { return opCmp(*p); }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
251 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
252
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
253 TypeFunction tfeqptr;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
254 {
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
255 auto arguments = new Parameters;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
256 auto arg = new Parameter(STC.STCin, handle, Id.p, null);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
257
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
258 arguments.push(arg);
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
259 tfeqptr = new TypeFunction(arguments, Type.tint32, 0, LINK.LINKd);
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
260 tfeqptr = cast(TypeFunction)tfeqptr.semantic(Loc(0), sc);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
261 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
262
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
263 TypeFunction tfeq;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
264 {
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
265 auto arguments = new Parameters;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
266 auto arg = new Parameter(STC.STCin, type, null, null);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
267
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
268 arguments.push(arg);
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
269 tfeq = new TypeFunction(arguments, Type.tint32, 0, LINK.LINKd);
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
270 tfeq = cast(TypeFunction)tfeq.semantic(Loc(0), sc);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
271 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
272
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
273 Identifier id = Id.eq;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
274 for (int j = 0; j < 2; j++)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
275 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
276 Dsymbol s = search_function(this, id);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
277 FuncDeclaration fdx = s ? s.isFuncDeclaration() : null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
278 if (fdx)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
279 { FuncDeclaration fd = fdx.overloadExactMatch(tfeqptr);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
280 if (!fd)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
281 { fd = fdx.overloadExactMatch(tfeq);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
282 if (fd)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
283 { // Create the thunk, fdptr
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
284 FuncDeclaration fdptr = new FuncDeclaration(loc, loc, fdx.ident, STC.STCundefined, tfeqptr);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
285 Expression e = new IdentifierExp(loc, Id.p);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
286 e = new PtrExp(loc, e);
84
be2ab491772e Expressions -> Vector!Expression
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 79
diff changeset
287 auto args = new Expressions();
be2ab491772e Expressions -> Vector!Expression
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 79
diff changeset
288 args.push(e);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
289 e = new IdentifierExp(loc, id);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
290 e = new CallExp(loc, e, args);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
291 fdptr.fbody = new ReturnStatement(loc, e);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
292 ScopeDsymbol ss = fdx.parent.isScopeDsymbol();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
293 assert(ss);
74
7e0d548de9e6 Switch Arrays of Dsymbols to the new templated Vector type
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 72
diff changeset
294 ss.members.push(fdptr);
13
427f8aa74d28 On the road to make Phobos compilable
korDen
parents: 0
diff changeset
295 fdptr.addMember(sc, ss, true);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
296 fdptr.semantic(sc2);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
297 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
298 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
299 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
300
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
301 id = Id.cmp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
302 }
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
303 }
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
304 version (DMDV2) {
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
305 /* Try to find the opEquals function. Build it if necessary.
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
306 */
131
206db751bd4c dmdfe 2.037 compiles now
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 130
diff changeset
307 TypeFunction tfeqptr;
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
308 { // bool opEquals(const T*) const;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
309 auto parameters = new Parameters;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
310 version(STRUCTTHISREF) {
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
311 // bool opEquals(ref const T) const;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
312 auto param = new Parameter(STC.STCref, type.constOf(), null, null);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
313 } else {
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
314 // bool opEquals(const T*) const;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
315 auto param = new Parameter(STC.STCin, type.pointerTo(), null, null);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
316 }
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
317
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
318 parameters.push(param);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
319 tfeqptr = new TypeFunction(parameters, Type.tbool, 0, LINK.LINKd);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
320 tfeqptr.mod = MOD.MODconst;
131
206db751bd4c dmdfe 2.037 compiles now
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 130
diff changeset
321 tfeqptr = cast(TypeFunction)(tfeqptr.semantic(Loc(0), sc2));
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
322
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
323 Dsymbol s = search_function(this, Id.eq);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
324 FuncDeclaration fdx = s ? s.isFuncDeclaration() : null;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
325 if (fdx)
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
326 {
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
327 eq = fdx.overloadExactMatch(tfeqptr);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
328 if (!eq)
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
329 fdx.error("type signature should be %s not %s", tfeqptr.toChars(), fdx.type.toChars());
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
330 }
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
331
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
332 if (!eq)
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
333 eq = buildOpEquals(sc2);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
334 }
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
335
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
336 dtor = buildDtor(sc2);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
337 postblit = buildPostBlit(sc2);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
338 cpctor = buildCpCtor(sc2);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
339 buildOpAssign(sc2);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
340 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
341
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
342 sc2.pop();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
343
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
344 if (sizeok == 2)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
345 { // semantic() failed because of forward references.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
346 // Unwind what we did, and defer it for later
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
347 fields.setDim(0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
348 structsize = 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
349 alignsize = 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
350 structalign = 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
351
87
b17640f0e4e8 Fixed a bug with a Scope.this(Scope enclosing) being called instead of Scope.clone() method (as a copy ctor replacement)
korDen
parents: 79
diff changeset
352 scope_ = scx ? scx : sc.clone();
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
353 scope_.setNoFree();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
354 scope_.module_.addDeferredSemantic(this);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
355 //printf("\tdeferring %s\n", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
356 return;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
357 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
358
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
359 // 0 sized struct's are set to 1 byte
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
360 if (structsize == 0)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
361 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
362 structsize = 1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
363 alignsize = 1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
364 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
365
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
366 // Round struct size up to next alignsize boundary.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
367 // This will ensure that arrays of structs will get their internals
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
368 // aligned properly.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
369 structsize = (structsize + alignsize - 1) & ~(alignsize - 1);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
370
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
371 sizeok = 1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
372 Module.dprogress++;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
373
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
374 //printf("-StructDeclaration.semantic(this=%p, '%s')\n", this, toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
375
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
376 // Determine if struct is all zeros or not
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
377 zeroInit = true;
85
8e69d041a99d Previous commit didn't compile. Fixed.
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 84
diff changeset
378 foreach (VarDeclaration vd; fields)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
379 {
79
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
380 if (vd && !vd.isDataseg())
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
381 {
79
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
382 if (vd.init)
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
383 {
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
384 // Should examine init to see if it is really all 0's
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
385 zeroInit = false;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
386 break;
79
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
387 }
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
388 else
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
389 {
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
390 if (!vd.type.isZeroInit(loc))
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
391 {
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
392 zeroInit = false;
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
393 break;
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
394 }
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
395 }
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
396 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
397 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
398
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
399 /* Look for special member functions.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
400 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
401 version (DMDV2) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
402 ctor = search(Loc(0), Id.ctor, 0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
403 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
404 inv = cast(InvariantDeclaration)search(Loc(0), Id.classInvariant, 0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
405 aggNew = cast(NewDeclaration)search(Loc(0), Id.classNew, 0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
406 aggDelete = cast(DeleteDeclaration)search(Loc(0), Id.classDelete, 0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
407
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
408 if (sc.func)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
409 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
410 semantic2(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
411 semantic3(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
412 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
413 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
414
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 49
diff changeset
415 override void toCBuffer(OutBuffer buf, HdrGenState* hgs)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
416 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
417 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
418 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
419
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 49
diff changeset
420 override string mangle()
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
421 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
422 //printf("StructDeclaration.mangle() '%s'\n", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
423 return Dsymbol.mangle();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
424 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
425
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 49
diff changeset
426 override string kind()
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
427 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
428 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
429 }
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
430
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
431 version(DMDV1)
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
432 {
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
433 Expression cloneMembers()
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
434 {
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
435 assert(false);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
436 }
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
437 }
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
438
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
439 version(DMDV2)
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
440 {
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
441 /*******************************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
442 * We need an opAssign for the struct if
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
443 * it has a destructor or a postblit.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
444 * We need to generate one if a user-specified one does not exist.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
445 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
446 bool needOpAssign()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
447 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
448 static if (false) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
449 printf("StructDeclaration.needOpAssign() %s\n", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
450 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
451 if (hasIdentityAssign)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
452 goto Ldontneed;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
453
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
454 if (dtor || postblit)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
455 goto Lneed;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
456
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
457 /* If any of the fields need an opAssign, then we
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
458 * need it too.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
459 */
85
8e69d041a99d Previous commit didn't compile. Fixed.
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 84
diff changeset
460 foreach (VarDeclaration v; fields)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
461 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
462 assert(v && v.storage_class & STC.STCfield);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
463 if (v.storage_class & STC.STCref)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
464 continue;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
465 Type tv = v.type.toBasetype();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
466 while (tv.ty == TY.Tsarray)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
467 { TypeSArray ta = cast(TypeSArray)tv;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
468 tv = tv.nextOf().toBasetype();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
469 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
470 if (tv.ty == TY.Tstruct)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
471 { TypeStruct ts = cast(TypeStruct)tv;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
472 StructDeclaration sd = ts.sym;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
473 if (sd.needOpAssign())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
474 goto Lneed;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
475 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
476 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
477 Ldontneed:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
478 static if (false) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
479 printf("\tdontneed\n");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
480 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
481 return false;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
482
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
483 Lneed:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
484 static if (false) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
485 printf("\tneed\n");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
486 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
487 return true;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
488 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
489
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
490 /*******************************************
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
491 * We need an opEquals for the struct if
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
492 * any fields has an opEquals.
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
493 * Generate one if a user-specified one does not exist.
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
494 */
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
495 bool needOpEquals()
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
496 {
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
497 enum X = 0;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
498 static if (X) printf("StructDeclaration::needOpEquals() %s\n", toChars());
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
499
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
500 /* If any of the fields has an opEquals, then we
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
501 * need it too.
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
502 */
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
503 foreach (s; fields)
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
504 {
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
505 VarDeclaration v = s.isVarDeclaration();
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
506 assert(v && v.storage_class & STC.STCfield);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
507 if (v.storage_class & STC.STCref)
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
508 continue;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
509 Type tv = v.type.toBasetype();
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
510 while (tv.ty == Tsarray)
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
511 { auto ta = cast(TypeSArray)tv;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
512 tv = tv.nextOf().toBasetype();
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
513 }
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
514 if (tv.ty == Tstruct)
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
515 { auto ts = cast(TypeStruct)tv;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
516 StructDeclaration sd = ts.sym;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
517 if (sd.eq)
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
518 goto Lneed;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
519 }
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
520 }
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
521 Ldontneed:
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
522 static if (X) printf("\tdontneed\n");
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
523 return false;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
524
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
525 Lneed:
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
526 static if (X) printf("\tneed\n");
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
527 return true;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
528 }
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
529
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
530 /******************************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
531 * Build opAssign for struct.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
532 * S* opAssign(S s) { ... }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
533 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
534 FuncDeclaration buildOpAssign(Scope sc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
535 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
536 if (!needOpAssign())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
537 return null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
538
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
539 //printf("StructDeclaration.buildOpAssign() %s\n", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
540
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
541 FuncDeclaration fop = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
542
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
543 auto param = new Parameter(STC.STCnodtor, type, Id.p, null);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
544 auto fparams = new Parameters;
126
1765f3ef917d ClassDeclarations, Arguments -> Vector
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 114
diff changeset
545 fparams.push(param);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
546 Type ftype = new TypeFunction(fparams, handle, false, LINK.LINKd);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
547 version (STRUCTTHISREF) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
548 (cast(TypeFunction)ftype).isref = 1;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
549 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
550
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
551 fop = new FuncDeclaration(Loc(0), Loc(0), Id.assign, STC.STCundefined, ftype);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
552
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
553 Expression e = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
554 if (postblit)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
555 { /* Swap:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
556 * tmp = *this; *this = s; tmp.dtor();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
557 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
558 //printf("\tswap copy\n");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
559 Identifier idtmp = Lexer.uniqueId("__tmp");
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
560 VarDeclaration tmp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
561 AssignExp ec = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
562 if (dtor)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
563 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
564 tmp = new VarDeclaration(Loc(0), type, idtmp, new VoidInitializer(Loc(0)));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
565 tmp.noauto = true;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
566 e = new DeclarationExp(Loc(0), tmp);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
567
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
568 Expression e2;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
569 version (STRUCTTHISREF) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
570 e2 = new ThisExp(Loc(0));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
571 } else {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
572 e2 = new PtrExp(Loc(0), new ThisExp(Loc(0)));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
573 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
574 ec = new AssignExp(Loc(0), new VarExp(Loc(0), tmp), e2);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
575 ec.op = TOK.TOKblit;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
576 e = Expression.combine(e, ec);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
577 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
578 Expression e2;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
579 version (STRUCTTHISREF) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
580 e2 = new ThisExp(Loc(0));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
581 } else {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
582 e2 = new PtrExp(Loc(0), new ThisExp(Loc(0)));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
583 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
584
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
585 ec = new AssignExp(Loc(0), e2, new IdentifierExp(Loc(0), Id.p));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
586 ec.op = TOK.TOKblit;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
587 e = Expression.combine(e, ec);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
588 if (dtor)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
589 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
590 /* Instead of running the destructor on s, run it
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
591 * on tmp. This avoids needing to copy tmp back in to s.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
592 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
593 Expression ecc = new DotVarExp(Loc(0), new VarExp(Loc(0), tmp), dtor, 0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
594 ecc = new CallExp(Loc(0), ecc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
595 e = Expression.combine(e, ecc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
596 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
597 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
598 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
599 { /* Do memberwise copy
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
600 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
601 //printf("\tmemberwise copy\n");
85
8e69d041a99d Previous commit didn't compile. Fixed.
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 84
diff changeset
602 foreach (VarDeclaration v; fields)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
603 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
604 assert(v && v.storage_class & STC.STCfield);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
605 // this.v = s.v;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
606 AssignExp ec = new AssignExp(Loc(0), new DotVarExp(Loc(0), new ThisExp(Loc(0)), v, 0), new DotVarExp(Loc(0), new IdentifierExp(Loc(0), Id.p), v, 0));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
607 ec.op = TOK.TOKblit;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
608 e = Expression.combine(e, ec);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
609 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
610 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
611 Statement s1 = new ExpStatement(Loc(0), e);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
612
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
613 /* Add:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
614 * return this;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
615 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
616 e = new ThisExp(Loc(0));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
617 Statement s2 = new ReturnStatement(Loc(0), e);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
618
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
619 fop.fbody = new CompoundStatement(Loc(0), s1, s2);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
620
74
7e0d548de9e6 Switch Arrays of Dsymbols to the new templated Vector type
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 72
diff changeset
621 members.push(fop);
13
427f8aa74d28 On the road to make Phobos compilable
korDen
parents: 0
diff changeset
622 fop.addMember(sc, this, true);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
623
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
624 sc = sc.push();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
625 sc.stc = STC.STCundefined;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
626 sc.linkage = LINK.LINKd;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
627
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
628 fop.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
629
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
630 sc.pop();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
631
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
632 //printf("-StructDeclaration.buildOpAssign() %s\n", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
633
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
634 return fop;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
635 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
636
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
637 /******************************************
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
638 * Build opEquals for struct.
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
639 * const bool opEquals(const ref S s) { ... }
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
640 */
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
641 FuncDeclaration buildOpEquals(Scope sc)
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
642 {
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
643 if (!needOpEquals())
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
644 return null;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
645 //printf("StructDeclaration::buildOpEquals() %s\n", toChars());
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
646 Loc loc = this.loc;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
647
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
648 auto parameters = new Parameters;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
649 version (STRUCTTHISREF) {
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
650 // bool opEquals(ref const T) const;
131
206db751bd4c dmdfe 2.037 compiles now
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 130
diff changeset
651 auto param = new Parameter(STC.STCref, type.constOf(), Id.p, null);
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
652 } else {
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
653 // bool opEquals(const T*) const;
131
206db751bd4c dmdfe 2.037 compiles now
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 130
diff changeset
654 auto param = new Parameter(STC.STCin, type.pointerTo(), Id.p, null);
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
655 }
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
656
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
657 parameters.push(param);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
658 auto ftype = new TypeFunction(parameters, Type.tbool, 0, LINKd);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
659 ftype.mod = MOD.MODconst;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
660 ftype = cast(TypeFunction)ftype.semantic(loc, sc);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
661
131
206db751bd4c dmdfe 2.037 compiles now
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 130
diff changeset
662 auto fop = new FuncDeclaration(loc, Loc(0), Id.eq, STC.STCundefined, ftype);
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
663
131
206db751bd4c dmdfe 2.037 compiles now
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 130
diff changeset
664 Expression e = null;
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
665 /* Do memberwise compare
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
666 */
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
667 //printf("\tmemberwise compare\n");
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
668 foreach (s; fields)
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
669 {
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
670 VarDeclaration v = s.isVarDeclaration();
131
206db751bd4c dmdfe 2.037 compiles now
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 130
diff changeset
671 assert(v && v.storage_class & STC.STCfield);
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
672 if (v.storage_class & STC.STCref)
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
673 assert(0); // what should we do with this?
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
674 // this.v == s.v;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
675 auto ec = new EqualExp(TOKequal, loc,
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
676 new DotVarExp(loc, new ThisExp(loc), v, 0),
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
677 new DotVarExp(loc, new IdentifierExp(loc, Id.p), v, 0));
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
678 if (e)
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
679 e = new AndAndExp(loc, e, ec);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
680 else
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
681 e = ec;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
682 }
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
683 if (!e)
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
684 e = new IntegerExp(loc, 1, Type.tbool);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
685 fop.fbody = new ReturnStatement(loc, e);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
686
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
687 members.push(fop);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
688 fop.addMember(sc, this, 1);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
689
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
690 sc = sc.push();
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
691 sc.stc = 0;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
692 sc.linkage = LINK.LINKd;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
693
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
694 fop.semantic(sc);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
695
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
696 sc.pop();
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
697
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
698 //printf("-StructDeclaration::buildOpEquals() %s\n", toChars());
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
699
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
700 return fop;
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
701 }
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
702
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
703 /*****************************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
704 * Create inclusive postblit for struct by aggregating
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
705 * all the postblits in postblits[] with the postblits for
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
706 * all the members.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
707 * Note the close similarity with AggregateDeclaration.buildDtor(),
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
708 * and the ordering changes (runs forward instead of backwards).
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
709 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
710
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
711 version (DMDV2) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
712 FuncDeclaration buildPostBlit(Scope sc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
713 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
714 //printf("StructDeclaration.buildPostBlit() %s\n", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
715 Expression e = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
716
85
8e69d041a99d Previous commit didn't compile. Fixed.
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 84
diff changeset
717 foreach (VarDeclaration v; fields)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
718 {
79
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
719 assert(v && v.storage_class & STC.STCfield);
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
720 if (v.storage_class & STC.STCref)
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
721 continue;
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
722 Type tv = v.type.toBasetype();
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
723 size_t dim = 1;
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
724 while (tv.ty == TY.Tsarray)
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
725 { TypeSArray ta = cast(TypeSArray)tv;
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
726 dim *= (cast(TypeSArray)tv).dim.toInteger();
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
727 tv = tv.nextOf().toBasetype();
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
728 }
79
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
729 if (tv.ty == TY.Tstruct)
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
730 { TypeStruct ts = cast(TypeStruct)tv;
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
731 StructDeclaration sd = ts.sym;
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
732 if (sd.postblit)
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
733 { Expression ex;
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
734
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
735 // this.v
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
736 ex = new ThisExp(Loc(0));
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
737 ex = new DotVarExp(Loc(0), ex, v, 0);
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
738
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
739 if (dim == 1)
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
740 { // this.v.postblit()
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
741 ex = new DotVarExp(Loc(0), ex, sd.postblit, 0);
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
742 ex = new CallExp(Loc(0), ex);
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
743 }
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
744 else
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
745 {
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
746 // Typeinfo.postblit(cast(void*)&this.v);
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
747 Expression ea = new AddrExp(Loc(0), ex);
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
748 ea = new CastExp(Loc(0), ea, Type.tvoid.pointerTo());
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
749
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
750 Expression et = v.type.getTypeInfo(sc);
103
e6090d1aea7c fixed dmd.Id + some small fixups
Trass3r
parents: 95
diff changeset
751 et = new DotIdExp(Loc(0), et, Id._postblit);
79
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
752
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
753 ex = new CallExp(Loc(0), et, ea);
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
754 }
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
755 e = Expression.combine(e, ex); // combine in forward order
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
756 }
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
757 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
758 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
759
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
760 /* Build our own "postblit" which executes e
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
761 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
762 if (e)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
763 { //printf("Building __fieldPostBlit()\n");
74
7e0d548de9e6 Switch Arrays of Dsymbols to the new templated Vector type
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 72
diff changeset
764 auto dd = new PostBlitDeclaration(Loc(0), Loc(0), Lexer.idPool("__fieldPostBlit"));
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
765 dd.fbody = new ExpStatement(Loc(0), e);
74
7e0d548de9e6 Switch Arrays of Dsymbols to the new templated Vector type
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 72
diff changeset
766 postblits.shift(dd);
7e0d548de9e6 Switch Arrays of Dsymbols to the new templated Vector type
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 72
diff changeset
767 members.push(dd);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
768 dd.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
769 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
770
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
771 switch (postblits.dim)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
772 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
773 case 0:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
774 return null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
775
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
776 case 1:
77
ad4792a1cfd6 more D-ification container accessing
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 74
diff changeset
777 return cast(FuncDeclaration)postblits[0];
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
778
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
779 default:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
780 e = null;
77
ad4792a1cfd6 more D-ification container accessing
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 74
diff changeset
781 foreach(FuncDeclaration fd; postblits)
ad4792a1cfd6 more D-ification container accessing
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 74
diff changeset
782 {
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
783 Expression ex = new ThisExp(Loc(0));
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
784 ex = new DotVarExp(Loc(0), ex, fd, 0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
785 ex = new CallExp(Loc(0), ex);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
786 e = Expression.combine(e, ex);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
787 }
74
7e0d548de9e6 Switch Arrays of Dsymbols to the new templated Vector type
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 72
diff changeset
788 auto dd = new PostBlitDeclaration(Loc(0), Loc(0), Lexer.idPool("__aggrPostBlit"));
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
789 dd.fbody = new ExpStatement(Loc(0), e);
74
7e0d548de9e6 Switch Arrays of Dsymbols to the new templated Vector type
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 72
diff changeset
790 members.push(dd);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
791 dd.semantic(sc);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
792 return dd;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
793 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
794 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
795 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
796
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
797 /*******************************************
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
798 * Build copy constructor for struct.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
799 * Copy constructors are compiler generated only, and are only
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
800 * callable from the compiler. They are not user accessible.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
801 * A copy constructor is:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
802 * void cpctpr(ref S s)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
803 * {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
804 * *this = s;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
805 * this.postBlit();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
806 * }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
807 * This is done so:
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
808 * - postBlit() never sees uninitialized data
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
809 * - memcpy can be much more efficient than memberwise copy
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
810 * - no fields are overlooked
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
811 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
812 FuncDeclaration buildCpCtor(Scope sc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
813 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
814 //printf("StructDeclaration.buildCpCtor() %s\n", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
815 FuncDeclaration fcp = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
816
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
817 /* Copy constructor is only necessary if there is a postblit function,
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
818 * otherwise the code generator will just do a bit copy.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
819 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
820 if (postblit)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
821 {
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
822 //printf("generating cpctor\n");
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
823
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
824 auto param = new Parameter(STC.STCref, type, Id.p, null);
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
825 auto fparams = new Parameters;
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
826 fparams.push(param);
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
827 Type ftype = new TypeFunction(fparams, Type.tvoid, false, LINK.LINKd);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
828
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
829 fcp = new FuncDeclaration(Loc(0), Loc(0), Id.cpctor, STC.STCundefined, ftype);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
830
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
831 // Build *this = p;
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
832 Expression e = new ThisExp(Loc(0));
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
833 version (STRUCTTHISREF) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
834 } else {
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
835 e = new PtrExp(Loc(0), e);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
836 }
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
837 AssignExp ea = new AssignExp(Loc(0), e, new IdentifierExp(Loc(0), Id.p));
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
838 ea.op = TOK.TOKblit;
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
839 Statement s = new ExpStatement(Loc(0), ea);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
840
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
841 // Build postBlit();
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
842 e = new VarExp(Loc(0), postblit, 0);
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
843 e = new CallExp(Loc(0), e);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
844
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
845 s = new CompoundStatement(Loc(0), s, new ExpStatement(Loc(0), e));
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
846 fcp.fbody = s;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
847
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
848 members.push(fcp);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
849
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
850 sc = sc.push();
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
851 sc.stc = STC.STCundefined;
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
852 sc.linkage = LINK.LINKd;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
853
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
854 fcp.semantic(sc);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
855
129
010eb8f0e18d further work on dmd test suite
korDen
parents: 126
diff changeset
856 sc.pop();
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
857 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
858
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
859 return fcp;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
860 }
130
60bb0fe4563e dmdfe 2.037 first main iteration
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 129
diff changeset
861 }
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 49
diff changeset
862 override void toDocBuffer(OutBuffer buf)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
863 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
864 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
865 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
866
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 49
diff changeset
867 override PROT getAccess(Dsymbol smember) // determine access to smember
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
868 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
869 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
870 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
871
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 49
diff changeset
872 override void toObjFile(int multiobj) // compile to .obj file
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
873 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
874 //printf("StructDeclaration.toObjFile('%s')\n", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
875
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
876 if (multiobj)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
877 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
878 obj_append(this);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
879 return;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
880 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
881
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
882 // Anonymous structs/unions only exist as part of others,
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
883 // do not output forward referenced structs's
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
884 if (!isAnonymous() && members)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
885 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
886 if (global.params.symdebug) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
887 toDebug();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
888 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
889
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
890 type.getTypeInfo(null); // generate TypeInfo
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
891
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
892 if (true)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
893 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
894 // Generate static initializer
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
895 toInitializer();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
896
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
897 static if (false) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
898 sinit.Sclass = SC.SCcomdat;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
899 } else {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
900 if (inTemplateInstance())
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
901 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
902 sinit.Sclass = SC.SCcomdat;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
903 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
904 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
905 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
906 sinit.Sclass = SC.SCglobal;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
907 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
908 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
909 sinit.Sfl = FL.FLdata;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
910
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
911 toDt(&sinit.Sdt);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
912
95
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 89
diff changeset
913 version (OMFOBJ)
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 89
diff changeset
914 {
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
915 /* For OMF, common blocks aren't pulled in from the library.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
916 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
917 /* ELF comdef's generate multiple
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
918 * definition errors for them from the gnu linker.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
919 * Need to figure out how to generate proper comdef's for ELF.
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
920 */
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
921 // See if we can convert a comdat to a comdef,
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
922 // which saves on exe file space.
95
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 89
diff changeset
923 if (0 && // causes multiple def problems with COMMON in one file and COMDAT in library
ae5b11064a9a beginning of 2.036 branch
Trass3r
parents: 89
diff changeset
924 sinit.Sclass == SCcomdat &&
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
925 sinit.Sdt &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
926 sinit.Sdt.dt == DT.DT_azeros &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
927 sinit.Sdt.DTnext == null &&
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
928 !global.params.multiobj)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
929 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
930 sinit.Sclass = SC.SCglobal;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
931 sinit.Sdt.dt = DT.DT_common;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
932 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
933 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
934
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
935 version (ELFOBJ) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
936 sinit.Sseg = Segment.CDATA;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
937 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
938 version (MACHOBJ) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
939 sinit.Sseg = Segment.DATA;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
940 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
941 outdata(sinit);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
942 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
943
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
944 // Put out the members
77
ad4792a1cfd6 more D-ification container accessing
Eldar Insafutdinov <e.insafutdinov@gmail.com>
parents: 74
diff changeset
945 foreach(Dsymbol member; members)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
946 member.toObjFile(0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
947 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
948 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
949
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
950 void toDt(dt_t** pdt)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
951 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
952 uint offset;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
953 dt_t* dt;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
954
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
955 //printf("StructDeclaration.toDt(), this='%s'\n", toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
956 offset = 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
957
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
958 // Note equivalence of this loop to class's
79
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
959 for (uint i = 0; i < fields.dim; i++)
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
960 {
79
43073c7c7769 updated to 2.035
Trass3r
parents: 77
diff changeset
961 VarDeclaration v = cast(VarDeclaration)fields[i];
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
962 //printf("\tfield '%s' voffset %d, offset = %d\n", v.toChars(), v.offset, offset);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
963 dt = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
964 int sz;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
965
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
966 if (v.storage_class & STC.STCref)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
967 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
968 sz = PTRSIZE;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
969 if (v.offset >= offset)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
970 dtnzeros(&dt, sz);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
971 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
972 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
973 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
974 sz = cast(uint)v.type.size();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
975 Initializer init = v.init;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
976 if (init)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
977 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
978 //printf("\t\thas initializer %s\n", init.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
979 ExpInitializer ei = init.isExpInitializer();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
980 Type tb = v.type.toBasetype();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
981 if (ei && tb.ty == TY.Tsarray)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
982 (cast(TypeSArray)tb).toDtElem(&dt, ei.exp);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
983 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
984 dt = init.toDt();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
985 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
986 else if (v.offset >= offset)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
987 v.type.toDt(&dt);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
988 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
989 if (dt)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
990 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
991 if (v.offset < offset)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
992 error("overlapping initialization for struct %s.%s", toChars(), v.toChars());
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
993 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
994 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
995 if (offset < v.offset)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
996 dtnzeros(pdt, v.offset - offset);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
997 dtcat(pdt, dt);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
998 offset = v.offset + sz;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
999 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1000 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1001 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1002
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1003 if (offset < structsize)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1004 dtnzeros(pdt, structsize - offset);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1005
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1006 dt_optimize(*pdt);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1007 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1008
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1009 void toDebug() // to symbolic debug info
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1010 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1011 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1012 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1013
72
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 49
diff changeset
1014 override StructDeclaration isStructDeclaration() { return this; }
2e2a5c3f943a reduced warnings by adding override to the methods
Trass3r
parents: 49
diff changeset
1015 }