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