annotate gen/typinf.c @ 57:a9d29e9f1fed trunk

[svn r61] Added support for D-style variadic functions :)
author lindquist
date Thu, 25 Oct 2007 02:39:53 +0200
parents 28e99b04a132
children 2c3cd3596187
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
1
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
2
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
3 // Copyright (c) 1999-2004 by Digital Mars
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
4 // All Rights Reserved
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
5 // written by Walter Bright
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
6 // www.digitalmars.com
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
7 // License for redistribution is by either the Artistic License
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
8 // in artistic.txt, or the GNU General Public License in gnu.txt.
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
9 // See the included readme.txt for details.
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
10
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
11 #include <cstdio>
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
12 #include <cassert>
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
13
52
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
14 #include "gen/llvm.h"
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
15
1
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
16 #include "mars.h"
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
17 #include "module.h"
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
18 #include "mtype.h"
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
19 #include "scope.h"
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
20 #include "init.h"
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
21 #include "expression.h"
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
22 #include "attrib.h"
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
23 #include "declaration.h"
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
24 #include "template.h"
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
25 #include "id.h"
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
26 #include "enum.h"
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
27 #include "import.h"
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
28 #include "aggregate.h"
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
29
52
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
30 #include "gen/irstate.h"
4
e116aa1488e6 [svn r8] changed backend includes to always use the gen/<foo>.h prefix
lindquist
parents: 1
diff changeset
31 #include "gen/logger.h"
52
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
32 #include "gen/runtime.h"
54
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
33 #include "gen/tollvm.h"
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
34 #include "gen/arrays.h"
1
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
35
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
36 /*******************************************
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
37 * Get a canonicalized form of the TypeInfo for use with the internal
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
38 * runtime library routines. Canonicalized in that static arrays are
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
39 * represented as dynamic arrays, enums are represented by their
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
40 * underlying type, etc. This reduces the number of TypeInfo's needed,
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
41 * so we can use the custom internal ones more.
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
42 */
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
43
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
44 Expression *Type::getInternalTypeInfo(Scope *sc)
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
45 { TypeInfoDeclaration *tid;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
46 Expression *e;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
47 Type *t;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
48 static TypeInfoDeclaration *internalTI[TMAX];
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
49
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
50 //printf("Type::getInternalTypeInfo() %s\n", toChars());
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
51 t = toBasetype();
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
52 switch (t->ty)
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
53 {
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
54 case Tsarray:
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
55 t = t->next->arrayOf(); // convert to corresponding dynamic array type
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
56 break;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
57
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
58 case Tclass:
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
59 if (((TypeClass *)t)->sym->isInterfaceDeclaration())
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
60 break;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
61 goto Linternal;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
62
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
63 case Tarray:
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
64 if (t->next->ty != Tclass)
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
65 break;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
66 goto Linternal;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
67
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
68 case Tfunction:
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
69 case Tdelegate:
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
70 case Tpointer:
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
71 Linternal:
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
72 tid = internalTI[t->ty];
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
73 if (!tid)
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
74 { tid = new TypeInfoDeclaration(t, 1);
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
75 internalTI[t->ty] = tid;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
76 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
77 e = new VarExp(0, tid);
52
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
78 //e = e->addressOf(sc);
1
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
79 e->type = tid->type; // do this so we don't get redundant dereference
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
80 return e;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
81
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
82 default:
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
83 break;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
84 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
85 //printf("\tcalling getTypeInfo() %s\n", t->toChars());
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
86 return t->getTypeInfo(sc);
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
87 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
88
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
89
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
90 /****************************************************
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
91 * Get the exact TypeInfo.
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
92 */
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
93
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
94 Expression *Type::getTypeInfo(Scope *sc)
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
95 {
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
96 Expression *e;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
97 Type *t;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
98
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
99 //printf("Type::getTypeInfo() %p, %s\n", this, toChars());
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
100 t = merge(); // do this since not all Type's are merge'd
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
101 if (!t->vtinfo)
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
102 { t->vtinfo = t->getTypeInfoDeclaration();
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
103 assert(t->vtinfo);
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
104
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
105 /* If this has a custom implementation in std/typeinfo, then
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
106 * do not generate a COMDAT for it.
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
107 */
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
108 if (!t->builtinTypeInfo())
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
109 { // Generate COMDAT
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
110 if (sc) // if in semantic() pass
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
111 { // Find module that will go all the way to an object file
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
112 Module *m = sc->module->importedFrom;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
113 m->members->push(t->vtinfo);
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
114 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
115 else // if in obj generation pass
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
116 {
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
117 t->vtinfo->toObjFile();
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
118 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
119 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
120 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
121 e = new VarExp(0, t->vtinfo);
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
122 //e = e->addressOf(sc);
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
123 e->type = t->vtinfo->type; // do this so we don't get redundant dereference
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
124 return e;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
125 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
126
52
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
127 enum RET TypeFunction::retStyle()
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
128 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
129 return RETstack;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
130 }
1
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
131
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
132 TypeInfoDeclaration *Type::getTypeInfoDeclaration()
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
133 {
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
134 //printf("Type::getTypeInfoDeclaration() %s\n", toChars());
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
135 return new TypeInfoDeclaration(this, 0);
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
136 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
137
52
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
138 TypeInfoDeclaration *TypeTypedef::getTypeInfoDeclaration()
1
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
139 {
52
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
140 return new TypeInfoTypedefDeclaration(this);
1
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
141 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
142
52
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
143 TypeInfoDeclaration *TypePointer::getTypeInfoDeclaration()
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
144 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
145 return new TypeInfoPointerDeclaration(this);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
146 }
1
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
147
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
148 TypeInfoDeclaration *TypeDArray::getTypeInfoDeclaration()
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
149 {
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
150 return new TypeInfoArrayDeclaration(this);
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
151 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
152
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
153 TypeInfoDeclaration *TypeSArray::getTypeInfoDeclaration()
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
154 {
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
155 return new TypeInfoStaticArrayDeclaration(this);
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
156 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
157
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
158 TypeInfoDeclaration *TypeAArray::getTypeInfoDeclaration()
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
159 {
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
160 return new TypeInfoAssociativeArrayDeclaration(this);
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
161 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
162
52
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
163 TypeInfoDeclaration *TypeStruct::getTypeInfoDeclaration()
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
164 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
165 return new TypeInfoStructDeclaration(this);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
166 }
1
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
167
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
168 TypeInfoDeclaration *TypeClass::getTypeInfoDeclaration()
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
169 {
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
170 if (sym->isInterfaceDeclaration())
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
171 return new TypeInfoInterfaceDeclaration(this);
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
172 else
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
173 return new TypeInfoClassDeclaration(this);
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
174 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
175
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
176 TypeInfoDeclaration *TypeEnum::getTypeInfoDeclaration()
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
177 {
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
178 return new TypeInfoEnumDeclaration(this);
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
179 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
180
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
181 TypeInfoDeclaration *TypeFunction::getTypeInfoDeclaration()
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
182 {
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
183 return new TypeInfoFunctionDeclaration(this);
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
184 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
185
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
186 TypeInfoDeclaration *TypeDelegate::getTypeInfoDeclaration()
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
187 {
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
188 return new TypeInfoDelegateDeclaration(this);
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
189 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
190
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
191 TypeInfoDeclaration *TypeTuple::getTypeInfoDeclaration()
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
192 {
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
193 return new TypeInfoTupleDeclaration(this);
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
194 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
195
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
196
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
197 /* ========================================================================= */
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
198
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
199 /* These decide if there's an instance for them already in std.typeinfo,
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
200 * because then the compiler doesn't need to build one.
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
201 */
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
202
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
203 int Type::builtinTypeInfo()
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
204 {
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
205 return 0;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
206 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
207
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
208 int TypeBasic::builtinTypeInfo()
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
209 {
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
210 return 1;
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
211 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
212
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
213 int TypeDArray::builtinTypeInfo()
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
214 {
52
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
215 return next->isTypeBasic() != NULL;
1
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
216 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
217
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
218 /* ========================================================================= */
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
219
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
220 /***************************************
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
221 * Create a static array of TypeInfo references
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
222 * corresponding to an array of Expression's.
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
223 * Used to supply hidden _arguments[] value for variadic D functions.
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
224 */
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
225
57
a9d29e9f1fed [svn r61] Added support for D-style variadic functions :)
lindquist
parents: 54
diff changeset
226 Expression *createTypeInfoArray(Scope *sc, Expression *exps[], int dim)
1
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
227 {
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
228 assert(0);
57
a9d29e9f1fed [svn r61] Added support for D-style variadic functions :)
lindquist
parents: 54
diff changeset
229 return NULL;
1
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
230 }
c53b6e3fe49a [svn r5] Initial commit. Most things are very rough.
lindquist
parents:
diff changeset
231
52
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
232 /* ========================================================================= */
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
233
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
234 //////////////////////////////////////////////////////////////////////////////
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
235 // MAGIC PLACE
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
236 //////////////////////////////////////////////////////////////////////////////
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
237
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
238 void TypeInfoDeclaration::toObjFile()
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
239 {
57
a9d29e9f1fed [svn r61] Added support for D-style variadic functions :)
lindquist
parents: 54
diff changeset
240 if (llvmTouched) return;
a9d29e9f1fed [svn r61] Added support for D-style variadic functions :)
lindquist
parents: 54
diff changeset
241 else llvmTouched = true;
a9d29e9f1fed [svn r61] Added support for D-style variadic functions :)
lindquist
parents: 54
diff changeset
242
52
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
243 Logger::println("TypeInfoDeclaration::toObjFile()");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
244 LOG_SCOPE;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
245 Logger::println("type = '%s'", tinfo->toChars());
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
246
54
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
247 Logger::println("typeinfo mangle: %s", mangle());
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
248
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
249 if (tinfo->builtinTypeInfo()) {
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
250 // this is a declaration of a builtin __initZ var
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
251 llvmValue = LLVM_D_GetRuntimeGlobal(gIR->module, mangle());
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
252 assert(llvmValue);
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
253 Logger::cout() << "Got typeinfo var:" << '\n' << *llvmValue << '\n';
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
254 }
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
255 else {
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
256 toDt(NULL);
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
257 // this is a specialized typeinfo
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
258 //std::vector<const llvm::Type*> stypes;
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
259 //stypes.push_back(
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
260 }
52
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
261 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
262
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
263 /* ========================================================================= */
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
264
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
265 void TypeInfoDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
266 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
267 assert(0 && "TypeInfoDeclaration");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
268 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
269
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
270 void TypeInfoTypedefDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
271 {
54
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
272 Logger::println("TypeInfoTypedefDeclaration::toDt() %s", toChars());
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
273 LOG_SCOPE;
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
274
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
275 ClassDeclaration* base = Type::typeinfotypedef;
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
276 base->toObjFile();
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
277
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
278 llvm::Constant* initZ = base->llvmInitZ;
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
279 assert(initZ);
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
280 const llvm::StructType* stype = llvm::cast<llvm::StructType>(initZ->getType());
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
281
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
282 std::vector<llvm::Constant*> sinits;
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
283 sinits.push_back(initZ->getOperand(0));
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
284
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
285 assert(tinfo->ty == Ttypedef);
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
286 TypeTypedef *tc = (TypeTypedef *)tinfo;
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
287 TypedefDeclaration *sd = tc->sym;
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
288
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
289 // TypeInfo base
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
290 //const llvm::PointerType* basept = llvm::cast<llvm::PointerType>(initZ->getOperand(1)->getType());
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
291 //sinits.push_back(llvm::ConstantPointerNull::get(basept));
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
292 Logger::println("generating base typeinfo");
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
293 //sd->basetype = sd->basetype->merge();
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
294 sd->basetype->getTypeInfo(NULL); // generate vtinfo
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
295 assert(sd->basetype->vtinfo);
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
296 if (!sd->basetype->vtinfo->llvmValue)
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
297 sd->basetype->vtinfo->toObjFile();
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
298 assert(llvm::isa<llvm::Constant>(sd->basetype->vtinfo->llvmValue));
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
299 llvm::Constant* castbase = llvm::cast<llvm::Constant>(sd->basetype->vtinfo->llvmValue);
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
300 castbase = llvm::ConstantExpr::getBitCast(castbase, initZ->getOperand(1)->getType());
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
301 sinits.push_back(castbase);
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
302
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
303 // char[] name
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
304 char *name = sd->toPrettyChars();
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
305 sinits.push_back(LLVM_DtoConstString(name));
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
306 assert(sinits.back()->getType() == initZ->getOperand(2)->getType());
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
307
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
308 // void[] init
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
309 //const llvm::PointerType* initpt = llvm::PointerType::get(llvm::Type::Int8Ty);
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
310 //sinits.push_back(LLVM_DtoConstantSlice(LLVM_DtoConstSize_t(0), llvm::ConstantPointerNull::get(initpt)));
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
311 sinits.push_back(initZ->getOperand(3));
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
312
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
313 // create the symbol
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
314 llvm::Constant* tiInit = llvm::ConstantStruct::get(stype, sinits);
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
315 llvm::GlobalVariable* gvar = new llvm::GlobalVariable(stype,true,llvm::GlobalValue::InternalLinkage,tiInit,toChars(),gIR->module);
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
316
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
317 llvmValue = gvar;
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
318
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
319 /*
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
320 dtxoff(pdt, Type::typeinfotypedef->toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfo_Typedef
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
321 dtdword(pdt, 0); // monitor
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
322
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
323 assert(tinfo->ty == Ttypedef);
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
324
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
325 TypeTypedef *tc = (TypeTypedef *)tinfo;
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
326 TypedefDeclaration *sd = tc->sym;
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
327 //printf("basetype = %s\n", sd->basetype->toChars());
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
328
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
329 // Put out:
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
330 // TypeInfo base;
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
331 // char[] name;
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
332 // void[] m_init;
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
333
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
334 sd->basetype = sd->basetype->merge();
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
335 sd->basetype->getTypeInfo(NULL); // generate vtinfo
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
336 assert(sd->basetype->vtinfo);
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
337 dtxoff(pdt, sd->basetype->vtinfo->toSymbol(), 0, TYnptr); // TypeInfo for basetype
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
338
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
339 char *name = sd->toPrettyChars();
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
340 size_t namelen = strlen(name);
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
341 dtdword(pdt, namelen);
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
342 dtabytes(pdt, TYnptr, 0, namelen + 1, name);
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
343
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
344 // void[] init;
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
345 if (tinfo->isZeroInit() || !sd->init)
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
346 { // 0 initializer, or the same as the base type
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
347 dtdword(pdt, 0); // init.length
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
348 dtdword(pdt, 0); // init.ptr
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
349 }
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
350 else
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
351 {
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
352 dtdword(pdt, sd->type->size()); // init.length
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
353 dtxoff(pdt, sd->toInitializer(), 0, TYnptr); // init.ptr
28e99b04a132 [svn r58] Fixed cond expression resulting in a non-basic type.
lindquist
parents: 52
diff changeset
354 */
52
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
355 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
356
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
357 void TypeInfoEnumDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
358 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
359 assert(0 && "TypeInfoEnumDeclaration");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
360 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
361
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
362 void TypeInfoPointerDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
363 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
364 assert(0 && "TypeInfoPointerDeclaration");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
365 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
366
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
367 void TypeInfoArrayDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
368 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
369 assert(0 && "TypeInfoArrayDeclaration");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
370 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
371
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
372 void TypeInfoStaticArrayDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
373 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
374 assert(0 && "TypeInfoStaticArrayDeclaration");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
375 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
376
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
377 void TypeInfoAssociativeArrayDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
378 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
379 assert(0 && "TypeInfoAssociativeArrayDeclaration");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
380 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
381
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
382 void TypeInfoFunctionDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
383 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
384 assert(0 && "TypeInfoFunctionDeclaration");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
385 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
386
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
387 void TypeInfoDelegateDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
388 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
389 assert(0 && "TypeInfoDelegateDeclaration");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
390 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
391
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
392 void TypeInfoStructDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
393 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
394 assert(0 && "TypeInfoStructDeclaration");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
395 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
396
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
397 void TypeInfoClassDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
398 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
399 assert(0 && "TypeInfoClassDeclaration");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
400 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
401
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
402 void TypeInfoInterfaceDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
403 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
404 assert(0 && "TypeInfoInterfaceDeclaration");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
405 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
406
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
407 void TypeInfoTupleDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
408 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
409 assert(0 && "TypeInfoTupleDeclaration");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
410 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
411
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
412 // original dmdfe toDt code for reference
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
413
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
414 #if 0
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
415
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
416 void TypeInfoDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
417 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
418 //printf("TypeInfoDeclaration::toDt() %s\n", toChars());
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
419 dtxoff(pdt, Type::typeinfo->toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfo
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
420 dtdword(pdt, 0); // monitor
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
421 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
422
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
423 void TypeInfoTypedefDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
424 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
425 //printf("TypeInfoTypedefDeclaration::toDt() %s\n", toChars());
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
426
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
427 dtxoff(pdt, Type::typeinfotypedef->toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfo_Typedef
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
428 dtdword(pdt, 0); // monitor
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
429
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
430 assert(tinfo->ty == Ttypedef);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
431
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
432 TypeTypedef *tc = (TypeTypedef *)tinfo;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
433 TypedefDeclaration *sd = tc->sym;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
434 //printf("basetype = %s\n", sd->basetype->toChars());
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
435
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
436 /* Put out:
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
437 * TypeInfo base;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
438 * char[] name;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
439 * void[] m_init;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
440 */
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
441
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
442 sd->basetype = sd->basetype->merge();
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
443 sd->basetype->getTypeInfo(NULL); // generate vtinfo
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
444 assert(sd->basetype->vtinfo);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
445 dtxoff(pdt, sd->basetype->vtinfo->toSymbol(), 0, TYnptr); // TypeInfo for basetype
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
446
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
447 char *name = sd->toPrettyChars();
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
448 size_t namelen = strlen(name);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
449 dtdword(pdt, namelen);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
450 dtabytes(pdt, TYnptr, 0, namelen + 1, name);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
451
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
452 // void[] init;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
453 if (tinfo->isZeroInit() || !sd->init)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
454 { // 0 initializer, or the same as the base type
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
455 dtdword(pdt, 0); // init.length
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
456 dtdword(pdt, 0); // init.ptr
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
457 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
458 else
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
459 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
460 dtdword(pdt, sd->type->size()); // init.length
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
461 dtxoff(pdt, sd->toInitializer(), 0, TYnptr); // init.ptr
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
462 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
463 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
464
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
465 void TypeInfoEnumDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
466 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
467 //printf("TypeInfoEnumDeclaration::toDt()\n");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
468 dtxoff(pdt, Type::typeinfoenum->toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfo_Enum
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
469 dtdword(pdt, 0); // monitor
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
470
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
471 assert(tinfo->ty == Tenum);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
472
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
473 TypeEnum *tc = (TypeEnum *)tinfo;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
474 EnumDeclaration *sd = tc->sym;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
475
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
476 /* Put out:
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
477 * TypeInfo base;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
478 * char[] name;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
479 * void[] m_init;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
480 */
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
481
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
482 sd->memtype->getTypeInfo(NULL);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
483 dtxoff(pdt, sd->memtype->vtinfo->toSymbol(), 0, TYnptr); // TypeInfo for enum members
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
484
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
485 char *name = sd->toPrettyChars();
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
486 size_t namelen = strlen(name);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
487 dtdword(pdt, namelen);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
488 dtabytes(pdt, TYnptr, 0, namelen + 1, name);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
489
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
490 // void[] init;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
491 if (tinfo->isZeroInit() || !sd->defaultval)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
492 { // 0 initializer, or the same as the base type
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
493 dtdword(pdt, 0); // init.length
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
494 dtdword(pdt, 0); // init.ptr
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
495 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
496 else
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
497 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
498 dtdword(pdt, sd->type->size()); // init.length
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
499 dtxoff(pdt, sd->toInitializer(), 0, TYnptr); // init.ptr
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
500 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
501 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
502
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
503 void TypeInfoPointerDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
504 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
505 //printf("TypeInfoPointerDeclaration::toDt()\n");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
506 dtxoff(pdt, Type::typeinfopointer->toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfo_Pointer
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
507 dtdword(pdt, 0); // monitor
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
508
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
509 assert(tinfo->ty == Tpointer);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
510
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
511 TypePointer *tc = (TypePointer *)tinfo;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
512
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
513 tc->next->getTypeInfo(NULL);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
514 dtxoff(pdt, tc->next->vtinfo->toSymbol(), 0, TYnptr); // TypeInfo for type being pointed to
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
515 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
516
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
517 void TypeInfoArrayDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
518 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
519 //printf("TypeInfoArrayDeclaration::toDt()\n");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
520 dtxoff(pdt, Type::typeinfoarray->toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfo_Array
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
521 dtdword(pdt, 0); // monitor
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
522
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
523 assert(tinfo->ty == Tarray);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
524
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
525 TypeDArray *tc = (TypeDArray *)tinfo;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
526
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
527 tc->next->getTypeInfo(NULL);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
528 dtxoff(pdt, tc->next->vtinfo->toSymbol(), 0, TYnptr); // TypeInfo for array of type
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
529 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
530
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
531 void TypeInfoStaticArrayDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
532 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
533 //printf("TypeInfoStaticArrayDeclaration::toDt()\n");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
534 dtxoff(pdt, Type::typeinfostaticarray->toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfo_StaticArray
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
535 dtdword(pdt, 0); // monitor
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
536
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
537 assert(tinfo->ty == Tsarray);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
538
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
539 TypeSArray *tc = (TypeSArray *)tinfo;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
540
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
541 tc->next->getTypeInfo(NULL);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
542 dtxoff(pdt, tc->next->vtinfo->toSymbol(), 0, TYnptr); // TypeInfo for array of type
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
543
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
544 dtdword(pdt, tc->dim->toInteger()); // length
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
545 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
546
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
547 void TypeInfoAssociativeArrayDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
548 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
549 //printf("TypeInfoAssociativeArrayDeclaration::toDt()\n");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
550 dtxoff(pdt, Type::typeinfoassociativearray->toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfo_AssociativeArray
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
551 dtdword(pdt, 0); // monitor
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
552
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
553 assert(tinfo->ty == Taarray);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
554
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
555 TypeAArray *tc = (TypeAArray *)tinfo;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
556
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
557 tc->next->getTypeInfo(NULL);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
558 dtxoff(pdt, tc->next->vtinfo->toSymbol(), 0, TYnptr); // TypeInfo for array of type
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
559
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
560 tc->index->getTypeInfo(NULL);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
561 dtxoff(pdt, tc->index->vtinfo->toSymbol(), 0, TYnptr); // TypeInfo for array of type
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
562 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
563
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
564 void TypeInfoFunctionDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
565 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
566 //printf("TypeInfoFunctionDeclaration::toDt()\n");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
567 dtxoff(pdt, Type::typeinfofunction->toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfo_Function
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
568 dtdword(pdt, 0); // monitor
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
569
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
570 assert(tinfo->ty == Tfunction);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
571
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
572 TypeFunction *tc = (TypeFunction *)tinfo;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
573
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
574 tc->next->getTypeInfo(NULL);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
575 dtxoff(pdt, tc->next->vtinfo->toSymbol(), 0, TYnptr); // TypeInfo for function return value
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
576 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
577
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
578 void TypeInfoDelegateDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
579 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
580 //printf("TypeInfoDelegateDeclaration::toDt()\n");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
581 dtxoff(pdt, Type::typeinfodelegate->toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfo_Delegate
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
582 dtdword(pdt, 0); // monitor
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
583
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
584 assert(tinfo->ty == Tdelegate);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
585
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
586 TypeDelegate *tc = (TypeDelegate *)tinfo;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
587
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
588 tc->next->next->getTypeInfo(NULL);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
589 dtxoff(pdt, tc->next->next->vtinfo->toSymbol(), 0, TYnptr); // TypeInfo for delegate return value
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
590 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
591
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
592 void TypeInfoStructDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
593 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
594 //printf("TypeInfoStructDeclaration::toDt() '%s'\n", toChars());
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
595
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
596 unsigned offset = Type::typeinfostruct->structsize;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
597
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
598 dtxoff(pdt, Type::typeinfostruct->toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfo_Struct
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
599 dtdword(pdt, 0); // monitor
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
600
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
601 assert(tinfo->ty == Tstruct);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
602
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
603 TypeStruct *tc = (TypeStruct *)tinfo;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
604 StructDeclaration *sd = tc->sym;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
605
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
606 /* Put out:
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
607 * char[] name;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
608 * void[] init;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
609 * hash_t function(void*) xtoHash;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
610 * int function(void*,void*) xopEquals;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
611 * int function(void*,void*) xopCmp;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
612 * char[] function(void*) xtoString;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
613 * uint m_flags;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
614 *
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
615 * name[]
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
616 */
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
617
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
618 char *name = sd->toPrettyChars();
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
619 size_t namelen = strlen(name);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
620 dtdword(pdt, namelen);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
621 //dtabytes(pdt, TYnptr, 0, namelen + 1, name);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
622 dtxoff(pdt, toSymbol(), offset, TYnptr);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
623 offset += namelen + 1;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
624
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
625 // void[] init;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
626 dtdword(pdt, sd->structsize); // init.length
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
627 if (sd->zeroInit)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
628 dtdword(pdt, 0); // NULL for 0 initialization
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
629 else
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
630 dtxoff(pdt, sd->toInitializer(), 0, TYnptr); // init.ptr
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
631
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
632 FuncDeclaration *fd;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
633 FuncDeclaration *fdx;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
634 TypeFunction *tf;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
635 Type *ta;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
636 Dsymbol *s;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
637
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
638 static TypeFunction *tftohash;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
639 static TypeFunction *tftostring;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
640
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
641 if (!tftohash)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
642 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
643 Scope sc;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
644
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
645 tftohash = new TypeFunction(NULL, Type::thash_t, 0, LINKd);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
646 tftohash = (TypeFunction *)tftohash->semantic(0, &sc);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
647
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
648 tftostring = new TypeFunction(NULL, Type::tchar->arrayOf(), 0, LINKd);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
649 tftostring = (TypeFunction *)tftostring->semantic(0, &sc);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
650 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
651
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
652 TypeFunction *tfeqptr;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
653 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
654 Scope sc;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
655 Arguments *arguments = new Arguments;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
656 Argument *arg = new Argument(STCin, tc->pointerTo(), NULL, NULL);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
657
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
658 arguments->push(arg);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
659 tfeqptr = new TypeFunction(arguments, Type::tint32, 0, LINKd);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
660 tfeqptr = (TypeFunction *)tfeqptr->semantic(0, &sc);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
661 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
662
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
663 #if 0
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
664 TypeFunction *tfeq;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
665 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
666 Scope sc;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
667 Array *arguments = new Array;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
668 Argument *arg = new Argument(In, tc, NULL, NULL);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
669
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
670 arguments->push(arg);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
671 tfeq = new TypeFunction(arguments, Type::tint32, 0, LINKd);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
672 tfeq = (TypeFunction *)tfeq->semantic(0, &sc);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
673 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
674 #endif
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
675
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
676 s = search_function(sd, Id::tohash);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
677 fdx = s ? s->isFuncDeclaration() : NULL;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
678 if (fdx)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
679 { fd = fdx->overloadExactMatch(tftohash);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
680 if (fd)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
681 dtxoff(pdt, fd->toSymbol(), 0, TYnptr);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
682 else
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
683 //fdx->error("must be declared as extern (D) uint toHash()");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
684 dtdword(pdt, 0);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
685 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
686 else
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
687 dtdword(pdt, 0);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
688
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
689 s = search_function(sd, Id::eq);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
690 fdx = s ? s->isFuncDeclaration() : NULL;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
691 for (int i = 0; i < 2; i++)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
692 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
693 if (fdx)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
694 { fd = fdx->overloadExactMatch(tfeqptr);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
695 if (fd)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
696 dtxoff(pdt, fd->toSymbol(), 0, TYnptr);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
697 else
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
698 //fdx->error("must be declared as extern (D) int %s(%s*)", fdx->toChars(), sd->toChars());
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
699 dtdword(pdt, 0);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
700 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
701 else
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
702 dtdword(pdt, 0);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
703
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
704 s = search_function(sd, Id::cmp);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
705 fdx = s ? s->isFuncDeclaration() : NULL;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
706 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
707
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
708 s = search_function(sd, Id::tostring);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
709 fdx = s ? s->isFuncDeclaration() : NULL;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
710 if (fdx)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
711 { fd = fdx->overloadExactMatch(tftostring);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
712 if (fd)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
713 dtxoff(pdt, fd->toSymbol(), 0, TYnptr);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
714 else
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
715 //fdx->error("must be declared as extern (D) char[] toString()");
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
716 dtdword(pdt, 0);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
717 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
718 else
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
719 dtdword(pdt, 0);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
720
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
721 // uint m_flags;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
722 dtdword(pdt, tc->hasPointers());
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
723
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
724 // name[]
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
725 dtnbytes(pdt, namelen + 1, name);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
726 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
727
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
728 void TypeInfoClassDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
729 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
730 //printf("TypeInfoClassDeclaration::toDt() %s\n", tinfo->toChars());
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
731 dtxoff(pdt, Type::typeinfoclass->toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfoClass
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
732 dtdword(pdt, 0); // monitor
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
733
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
734 assert(tinfo->ty == Tclass);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
735
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
736 TypeClass *tc = (TypeClass *)tinfo;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
737 Symbol *s;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
738
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
739 if (!tc->sym->vclassinfo)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
740 tc->sym->vclassinfo = new ClassInfoDeclaration(tc->sym);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
741 s = tc->sym->vclassinfo->toSymbol();
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
742 dtxoff(pdt, s, 0, TYnptr); // ClassInfo for tinfo
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
743 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
744
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
745 void TypeInfoInterfaceDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
746 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
747 //printf("TypeInfoInterfaceDeclaration::toDt() %s\n", tinfo->toChars());
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
748 dtxoff(pdt, Type::typeinfointerface->toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfoInterface
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
749 dtdword(pdt, 0); // monitor
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
750
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
751 assert(tinfo->ty == Tclass);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
752
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
753 TypeClass *tc = (TypeClass *)tinfo;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
754 Symbol *s;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
755
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
756 if (!tc->sym->vclassinfo)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
757 tc->sym->vclassinfo = new ClassInfoDeclaration(tc->sym);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
758 s = tc->sym->vclassinfo->toSymbol();
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
759 dtxoff(pdt, s, 0, TYnptr); // ClassInfo for tinfo
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
760 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
761
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
762 void TypeInfoTupleDeclaration::toDt(dt_t **pdt)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
763 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
764 //printf("TypeInfoTupleDeclaration::toDt() %s\n", tinfo->toChars());
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
765 dtxoff(pdt, Type::typeinfotypelist->toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfoInterface
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
766 dtdword(pdt, 0); // monitor
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
767
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
768 assert(tinfo->ty == Ttuple);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
769
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
770 TypeTuple *tu = (TypeTuple *)tinfo;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
771
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
772 size_t dim = tu->arguments->dim;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
773 dtdword(pdt, dim); // elements.length
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
774
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
775 dt_t *d = NULL;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
776 for (size_t i = 0; i < dim; i++)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
777 { Argument *arg = (Argument *)tu->arguments->data[i];
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
778 Expression *e = arg->type->getTypeInfo(NULL);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
779 e = e->optimize(WANTvalue);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
780 e->toDt(&d);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
781 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
782
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
783 Symbol *s;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
784 s = static_sym();
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
785 s->Sdt = d;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
786 outdata(s);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
787
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
788 dtxoff(pdt, s, 0, TYnptr); // elements.ptr
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
789 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
790
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
791 void TypeInfoDeclaration::toObjFile()
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
792 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
793 Symbol *s;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
794 unsigned sz;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
795 Dsymbol *parent;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
796
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
797 //printf("TypeInfoDeclaration::toObjFile(%p '%s') protection %d\n", this, toChars(), protection);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
798
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
799 s = toSymbol();
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
800 sz = type->size();
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
801
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
802 parent = this->toParent();
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
803 s->Sclass = SCcomdat;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
804 s->Sfl = FLdata;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
805
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
806 toDt(&s->Sdt);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
807
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
808 dt_optimize(s->Sdt);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
809
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
810 // See if we can convert a comdat to a comdef,
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
811 // which saves on exe file space.
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
812 if (s->Sclass == SCcomdat &&
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
813 s->Sdt->dt == DT_azeros &&
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
814 s->Sdt->DTnext == NULL)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
815 {
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
816 s->Sclass = SCglobal;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
817 s->Sdt->dt = DT_common;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
818 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
819
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
820 #if ELFOBJ // Burton
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
821 if (s->Sdt && s->Sdt->dt == DT_azeros && s->Sdt->DTnext == NULL)
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
822 s->Sseg = UDATA;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
823 else
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
824 s->Sseg = DATA;
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
825 #endif /* ELFOBJ */
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
826 outdata(s);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
827 if (isExport())
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
828 obj_export(s,0);
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
829 }
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
830
0c77619e803b [svn r56] Initial support for TypeInfo.
lindquist
parents: 4
diff changeset
831 #endif