forked from OSchip/llvm-project
parent
273207f32f
commit
02a71e7748
|
@ -105,6 +105,15 @@ void BasicBlock::setName(const std::string &name, SymbolTable *ST) {
|
|||
if (P && hasName()) P->getSymbolTable().insert(this);
|
||||
}
|
||||
|
||||
void BasicBlock::removeFromParent() {
|
||||
getParent()->getBasicBlockList().remove(this);
|
||||
}
|
||||
|
||||
void BasicBlock::eraseFromParent() {
|
||||
getParent()->getBasicBlockList().erase(this);
|
||||
}
|
||||
|
||||
|
||||
TerminatorInst *BasicBlock::getTerminator() {
|
||||
if (InstList.empty()) return 0;
|
||||
return dyn_cast<TerminatorInst>(&InstList.back());
|
||||
|
|
|
@ -147,6 +147,14 @@ const Type *Function::getReturnType() const {
|
|||
return getFunctionType()->getReturnType();
|
||||
}
|
||||
|
||||
void Function::removeFromParent() {
|
||||
getParent()->getFunctionList().remove(this);
|
||||
}
|
||||
|
||||
void Function::eraseFromParent() {
|
||||
getParent()->getFunctionList().erase(this);
|
||||
}
|
||||
|
||||
// dropAllReferences() - This function causes all the subinstructions to "let
|
||||
// go" of all references that they are maintaining. This allows one to
|
||||
// 'delete' a whole class at a time, even though there may be circular
|
||||
|
|
|
@ -106,9 +106,16 @@ void GlobalVariable::setName(const std::string &name, SymbolTable *ST) {
|
|||
if (P && hasName()) P->getSymbolTable().insert(this);
|
||||
}
|
||||
|
||||
void GlobalVariable::removeFromParent() {
|
||||
getParent()->getGlobalList().remove(this);
|
||||
}
|
||||
|
||||
void GlobalVariable::eraseFromParent() {
|
||||
getParent()->getGlobalList().erase(this);
|
||||
}
|
||||
|
||||
void GlobalVariable::replaceUsesOfWithOnConstant(Value *From, Value *To,
|
||||
bool DisableChecking )
|
||||
{
|
||||
bool DisableChecking) {
|
||||
// If you call this, then you better know this GVar has a constant
|
||||
// initializer worth replacing. Enforce that here.
|
||||
assert(getNumOperands() == 1 &&
|
||||
|
|
|
@ -72,6 +72,13 @@ void Instruction::setName(const std::string &name, SymbolTable *ST) {
|
|||
if (PP && hasName()) PP->getSymbolTable().insert(this);
|
||||
}
|
||||
|
||||
void Instruction::removeFromParent() {
|
||||
getParent()->getInstList().remove(this);
|
||||
}
|
||||
|
||||
void Instruction::eraseFromParent() {
|
||||
getParent()->getInstList().erase(this);
|
||||
}
|
||||
|
||||
const char *Instruction::getOpcodeName(unsigned OpCode) {
|
||||
switch (OpCode) {
|
||||
|
|
Loading…
Reference in New Issue