Mercurial > projects > ldc
view ir/irtype.cpp @ 1166:c6f39553b702
Clean up some suspicious code.
There's no guarantee a constant of integer type is a ConstantInt, so it's not
safe to just cast<> these to ConstantInt. (It could be a constant expression,
for example)
The code is shorter this way too :).
author | Frits van Bommel <fvbommel wxs.nl> |
---|---|
date | Sun, 29 Mar 2009 03:27:04 +0200 |
parents | 340acf1535d0 |
children |
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; } IrType::~IrType() { list.erase(this); } void IrType::reset() { type = NULL; }