Mercurial > projects > ldc
view ir/irstruct.cpp @ 490:f8c979770af3
Fixed a critical bug in the runtime, where _d_allocmemoryT would mark
the memory block as having pointers (for scanning) opposite of what it
should. So pointers would not be seen and freed. Should fix a bunch of
regressions with AAs.
author | Tomas Lindquist Olsen <tomas.l.olsen@gmail.com> |
---|---|
date | Sun, 10 Aug 2008 17:28:01 +0200 |
parents | 74101be2a553 |
children | 041c1596d217 |
line wrap: on
line source
#include "gen/llvm.h" #include "mtype.h" #include "aggregate.h" #include "ir/irstruct.h" #include "gen/irstate.h" IrInterface::IrInterface(BaseClass* b) { base = b; decl = b->base; vtblTy = NULL; vtblInit = NULL; vtbl = NULL; infoTy = NULL; infoInit = NULL; info = NULL; index = -1; } IrInterface::~IrInterface() { delete vtblTy; } ////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////// IrStruct::IrStruct(Type* t) : recty((t->ir.type) ? *t->ir.type : llvm::OpaqueType::get()) { type = t; defined = false; constinited = false; interfaceInfosTy = NULL; interfaceInfos = NULL; vtbl = NULL; constVtbl = NULL; init = NULL; constInit = NULL; classInfo = NULL; constClassInfo = NULL; hasUnions = false; dunion = NULL; classDeclared = false; classDefined = false; packed = false; dwarfComposite = NULL; } IrStruct::~IrStruct() { }