Mercurial > projects > ddmd
diff dmd/TypeInfoEnumDeclaration.d @ 174:af724d3510d7
lot os toCBuffer methods implemented
moved shared Type.* stuff into Global
author | korDen |
---|---|
date | Sun, 10 Oct 2010 03:47:23 +0400 |
parents | e28b18c23469 |
children | e3afd1303184 |
line wrap: on
line diff
--- a/dmd/TypeInfoEnumDeclaration.d Sun Oct 10 01:55:35 2010 +0400 +++ b/dmd/TypeInfoEnumDeclaration.d Sun Oct 10 03:47:23 2010 +0400 @@ -5,6 +5,8 @@ import dmd.Type; import dmd.Loc; import dmd.TypeEnum; +import dmd.Type; +import dmd.Global; import dmd.EnumDeclaration; import dmd.TypeInfoDeclaration; import dmd.backend.dt_t; @@ -18,13 +20,13 @@ this(Type tinfo) { super(tinfo, 0); - type = Type.typeinfoenum.type; + type = global.typeinfoenum.type; } override void toDt(dt_t** pdt) { //printf("TypeInfoEnumDeclaration::toDt()\n"); - dtxoff(pdt, Type.typeinfoenum.toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfo_Enum + dtxoff(pdt, global.typeinfoenum.toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfo_Enum dtdword(pdt, 0); // monitor assert(tinfo.ty == Tenum); @@ -39,7 +41,7 @@ */ if (sd.memtype) - { + { sd.memtype.getTypeInfo(null); dtxoff(pdt, sd.memtype.vtinfo.toSymbol(), 0, TYnptr); // TypeInfo for enum members } @@ -53,7 +55,7 @@ // void[] init; if (!sd.defaultval || tinfo.isZeroInit(Loc(0))) - { + { // 0 initializer, or the same as the base type dtdword(pdt, 0); // init.length dtdword(pdt, 0); // init.ptr