Mercurial > projects > ddmd
view dmd/TypeInfoTupleDeclaration.d @ 191:52188e7e3fb5
Fixed deprecated features, now compiles with DMD2.058
Also changed Array allocation policy:
Now doesn't reallocate but malloc's, followed by a memcpy (no free).
(this fixes a crash while compiling druntime. Same bug in dmd)
author | korDen@korDen-pc |
---|---|
date | Sun, 25 Mar 2012 03:11:12 +0400 |
parents | b0d41ff5e0df |
children |
line wrap: on
line source
module dmd.TypeInfoTupleDeclaration; import dmd.common; import dmd.Type; import dmd.TypeInfoDeclaration; import dmd.WANT; import dmd.TypeTuple; import dmd.Parameter; import dmd.Expression; import dmd.TY; import dmd.Global; import dmd.backend.TYM; import dmd.backend.Symbol; import dmd.backend.dt_t; import dmd.backend.Util; import dmd.codegen.Util; import dmd.DDMDExtensions; class TypeInfoTupleDeclaration : TypeInfoDeclaration { mixin insertMemberExtension!(typeof(this)); this(Type tinfo) { register(); super(tinfo, 0); type = global.typeinfotypelist.type; } override void toDt(dt_t **pdt) { //printf("TypeInfoTupleDeclaration.toDt() %s\n", tinfo.toChars()); dtxoff(pdt, global.typeinfotypelist.toVtblSymbol(), 0, TYnptr); // vtbl for TypeInfoInterface dtdword(pdt, 0); // monitor assert(tinfo.ty == Ttuple); auto tu = cast(TypeTuple)tinfo; size_t dim = tu.arguments.dim; dtdword(pdt, dim); // elements.length dt_t* d = null; for (size_t i = 0; i < dim; i++) { auto arg = tu.arguments[i]; Expression e = arg.type.getTypeInfo(null); e = e.optimize(WANTvalue); e.toDt(&d); } Symbol *s; s = static_sym(); s.Sdt = d; outdata(s); dtxoff(pdt, s, 0, TYnptr); // elements.ptr } }