Support new setName itf
authorChris Lattner <sabre@nondot.org>
Fri, 7 Sep 2001 16:44:17 +0000 (16:44 +0000)
committerChris Lattner <sabre@nondot.org>
Fri, 7 Sep 2001 16:44:17 +0000 (16:44 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@459 91177308-0d34-0410-b5e6-96231b3b80d8

lib/VMCore/BasicBlock.cpp

index cf8fc41bd747a0721dcbaff66f4e669ba33f1b46..4c480db631c415649168dd9a71741724647abf56 100644 (file)
@@ -7,7 +7,6 @@
 #include "llvm/ValueHolderImpl.h"
 #include "llvm/BasicBlock.h"
 #include "llvm/iTerminators.h"
-#include "llvm/Module.h"
 #include "llvm/Method.h"
 #include "llvm/SymbolTable.h"
 #include "llvm/Type.h"
 template class ValueHolder<Instruction, BasicBlock, Method>;
 
 BasicBlock::BasicBlock(const string &name, Method *Parent)
-  : Value(Type::LabelTy, Value::BasicBlockVal, name),
-    InstList(this, 0),
-    machineInstrVec(new MachineCodeForBasicBlock)
-{
+  : Value(Type::LabelTy, Value::BasicBlockVal, name), InstList(this, 0),
+    machineInstrVec(new MachineCodeForBasicBlock) {
   if (Parent)
     Parent->getBasicBlocks().push_back(this);
 }
@@ -36,8 +33,10 @@ BasicBlock::~BasicBlock() {
 }
 
 // Specialize setName to take care of symbol table majik
-void BasicBlock::setName(const string &name) {
+void BasicBlock::setName(const string &name, SymbolTable *ST) {
   Method *P;
+  assert((ST == 0 || (!getParent() || ST == getParent()->getSymbolTable())) &&
+        "Invalid symtab argument!");
   if ((P = getParent()) && hasName()) P->getSymbolTable()->remove(this);
   Value::setName(name);
   if (P && hasName()) P->getSymbolTable()->insert(this);