X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=lib%2FVMCore%2FBasicBlock.cpp;h=2e3b426e2b2e882b78e56ca6d4815380b8847c4e;hb=dec628eead87b20773c98a00830580df211acc98;hp=13907c10389817a9dedf0123507a9a2cf093aedf;hpb=9ef7e06ccef062dfa5df516913b12b7c3ca17805;p=oota-llvm.git diff --git a/lib/VMCore/BasicBlock.cpp b/lib/VMCore/BasicBlock.cpp index 13907c10389..2e3b426e2b2 100644 --- a/lib/VMCore/BasicBlock.cpp +++ b/lib/VMCore/BasicBlock.cpp @@ -17,7 +17,7 @@ #include "llvm/Type.h" #include "llvm/Support/CFG.h" #include "llvm/Support/LeakDetector.h" -#include "llvm/Support/Visibility.h" +#include "llvm/Support/Compiler.h" #include "SymbolTableListTraitsImpl.h" #include using namespace llvm; @@ -62,7 +62,7 @@ template class SymbolTableListTraits; BasicBlock::BasicBlock(const std::string &Name, Function *Parent, BasicBlock *InsertBefore) - : Value(Type::LabelTy, Value::BasicBlockVal, Name) { + : Value(Type::LabelTy, Value::BasicBlockVal) { // Initialize the instlist... InstList.setItemParent(this); @@ -76,6 +76,8 @@ BasicBlock::BasicBlock(const std::string &Name, Function *Parent, } else if (Parent) { Parent->getBasicBlockList().push_back(this); } + + setName(Name); } @@ -103,14 +105,21 @@ void BasicBlock::eraseFromParent() { getParent()->getBasicBlockList().erase(this); } -/// moveBefore - Unlink this instruction from its current function and -/// insert it into the function that MovePos lives in, right before -/// MovePos. +/// moveBefore - Unlink this basic block from its current function and +/// insert it into the function that MovePos lives in, right before MovePos. void BasicBlock::moveBefore(BasicBlock *MovePos) { MovePos->getParent()->getBasicBlockList().splice(MovePos, getParent()->getBasicBlockList(), this); } +/// moveAfter - Unlink this basic block from its current function and +/// insert it into the function that MovePos lives in, right after MovePos. +void BasicBlock::moveAfter(BasicBlock *MovePos) { + Function::iterator I = MovePos; + MovePos->getParent()->getBasicBlockList().splice(++I, + getParent()->getBasicBlockList(), this); +} + TerminatorInst *BasicBlock::getTerminator() { if (InstList.empty()) return 0;