Mercurial > projects > ldc
view ir/irtype.cpp @ 657:c42173b3557b
Removed some checks for abstract llvm types that were too strict, a 'opaque* null' is a valid initializer... when structs in D can be just a forward reference.
author | Tomas Lindquist Olsen <tomas.l.olsen@gmail.com> |
---|---|
date | Mon, 06 Oct 2008 14:37:00 +0200 |
parents | aca17e55b7a5 |
children | 340acf1535d0 |
line wrap: on
line source
#include "gen/llvm.h" #include "ir/ir.h" #include "ir/irtype.h" std::set<IrType*> IrType::list; void IrType::resetAll() { std::set<IrType*>::iterator it; for(it = list.begin(); it != list.end(); ++it) (*it)->reset(); } IrType::IrType() { assert(list.insert(this).second); reset(); } IrType::IrType(const IrType& s) { assert(list.insert(this).second); type = s.type; #if OPAQUE_VTBLS vtblType = s.type; #endif } IrType::~IrType() { list.erase(this); } void IrType::reset() { type = NULL; #if OPAQUE_VTBLS vtblType = NULL; #endif }