72
|
1 module dmd.TypeInfoEnumDeclaration;
|
0
|
2
|
72
|
3 import dmd.TY;
|
0
|
4 import dmd.Type;
|
|
5 import dmd.Loc;
|
|
6 import dmd.TypeEnum;
|
72
|
7 import dmd.EnumDeclaration;
|
|
8 import dmd.TypeInfoDeclaration;
|
0
|
9 import dmd.backend.dt_t;
|
|
10 import dmd.backend.Util;
|
|
11 import dmd.backend.TYM;
|
|
12
|
72
|
13 import std.string : toStringz;
|
|
14
|
0
|
15 class TypeInfoEnumDeclaration : TypeInfoDeclaration
|
|
16 {
|
|
17 this(Type tinfo)
|
|
18 {
|
|
19 super(tinfo, 0);
|
73
|
20 type = Type.typeinfoenum.type;
|
0
|
21 }
|
|
22
|
72
|
23 override void toDt(dt_t** pdt)
|
0
|
24 {
|
|
25 //printf("TypeInfoEnumDeclaration::toDt()\n");
|
|
26 dtxoff(pdt, Type.typeinfoenum.toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfo_Enum
|
|
27 dtdword(pdt, 0); // monitor
|
|
28
|
|
29 assert(tinfo.ty == Tenum);
|
|
30
|
|
31 TypeEnum tc = cast(TypeEnum)tinfo;
|
|
32 EnumDeclaration sd = tc.sym;
|
|
33
|
|
34 /* Put out:
|
|
35 * TypeInfo base;
|
|
36 * char[] name;
|
|
37 * void[] m_init;
|
|
38 */
|
|
39
|
|
40 if (sd.memtype)
|
|
41 {
|
|
42 sd.memtype.getTypeInfo(null);
|
|
43 dtxoff(pdt, sd.memtype.vtinfo.toSymbol(), 0, TYnptr); // TypeInfo for enum members
|
|
44 }
|
|
45 else
|
|
46 dtdword(pdt, 0);
|
|
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 (!sd.defaultval || tinfo.isZeroInit(Loc(0)))
|
|
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
|