72
|
1 module dmd.TypeInfoTypedefDeclaration;
|
|
2
|
|
3 import dmd.Type;
|
0
|
4 import dmd.TypeInfoDeclaration;
|
|
5 import dmd.TypedefDeclaration;
|
|
6 import dmd.TypeTypedef;
|
|
7 import dmd.TY;
|
72
|
8 import dmd.Loc;
|
0
|
9 import dmd.backend.dt_t;
|
|
10 import dmd.backend.TYM;
|
72
|
11 import dmd.backend.Util;
|
0
|
12
|
|
13 import std.string;
|
72
|
14
|
0
|
15 class TypeInfoTypedefDeclaration : TypeInfoDeclaration
|
|
16 {
|
|
17 this(Type tinfo)
|
|
18 {
|
|
19 super(tinfo, 0);
|
73
|
20 type = Type.typeinfotypedef.type;
|
0
|
21 }
|
|
22
|
72
|
23 override void toDt(dt_t** pdt)
|
0
|
24 {
|
|
25 //printf("TypeInfoTypedefDeclaration.toDt() %s\n", toChars());
|
|
26
|
|
27 dtxoff(pdt, Type.typeinfotypedef.toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfo_Typedef
|
|
28 dtdword(pdt, 0); // monitor
|
|
29
|
|
30 assert(tinfo.ty == Ttypedef);
|
|
31
|
|
32 TypeTypedef tc = cast(TypeTypedef)tinfo;
|
|
33 TypedefDeclaration sd = tc.sym;
|
|
34 //printf("basetype = %s\n", sd.basetype.toChars());
|
|
35
|
|
36 /* Put out:
|
|
37 * TypeInfo base;
|
|
38 * char[] name;
|
|
39 * void[] m_init;
|
|
40 */
|
|
41
|
|
42 sd.basetype = sd.basetype.merge();
|
|
43 sd.basetype.getTypeInfo(null); // generate vtinfo
|
|
44 assert(sd.basetype.vtinfo);
|
|
45 dtxoff(pdt, sd.basetype.vtinfo.toSymbol(), 0, TYnptr); // TypeInfo for basetype
|
|
46
|
|
47 string name = sd.toPrettyChars();
|
|
48 size_t namelen = name.length;
|
|
49 dtdword(pdt, namelen);
|
|
50 dtabytes(pdt, TYnptr, 0, namelen + 1, toStringz(name));
|
|
51
|
|
52 // void[] init;
|
|
53 if (tinfo.isZeroInit(Loc(0)) || !sd.init)
|
|
54 {
|
|
55 // 0 initializer, or the same as the base type
|
|
56 dtdword(pdt, 0); // init.length
|
|
57 dtdword(pdt, 0); // init.ptr
|
|
58 }
|
|
59 else
|
|
60 {
|
|
61 dtdword(pdt, cast(int)sd.type.size()); // init.length
|
|
62 dtxoff(pdt, sd.toInitializer(), 0, TYnptr); // init.ptr
|
|
63 }
|
|
64 }
|
|
65 }
|
|
66
|