diff options
author | Chris Lattner <sabre@nondot.org> | 2001-06-06 20:29:01 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2001-06-06 20:29:01 +0000 |
commit | 009505452b713ed2e3a8e99c5545a6e721c65495 (patch) | |
tree | 136a71c5b87bdf534d1f20a67558b49226b5a4d6 /lib/VMCore/InstrTypes.cpp | |
parent | 8d0afd3d32d1d67f9aa5df250a1d6955aa8f1ac9 (diff) | |
download | llvm-009505452b713ed2e3a8e99c5545a6e721c65495.tar.gz llvm-009505452b713ed2e3a8e99c5545a6e721c65495.tar.bz2 llvm-009505452b713ed2e3a8e99c5545a6e721c65495.tar.xz |
Initial revision
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/VMCore/InstrTypes.cpp')
-rw-r--r-- | lib/VMCore/InstrTypes.cpp | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/lib/VMCore/InstrTypes.cpp b/lib/VMCore/InstrTypes.cpp new file mode 100644 index 0000000000..29b293f1aa --- /dev/null +++ b/lib/VMCore/InstrTypes.cpp @@ -0,0 +1,66 @@ +//===-- InstrTypes.cpp - Implement Instruction subclasses --------*- C++ -*--=// +// +// This file implements +// +//===----------------------------------------------------------------------===// + +#include "llvm/iOther.h" +#include "llvm/BasicBlock.h" +#include "llvm/Method.h" +#include "llvm/SymbolTable.h" +#include "llvm/Type.h" +#include <algorithm> + +//===----------------------------------------------------------------------===// +// TerminatorInst Class +//===----------------------------------------------------------------------===// + +TerminatorInst::TerminatorInst(unsigned iType) + : Instruction(Type::VoidTy, iType, "") { +} + + +//===----------------------------------------------------------------------===// +// MethodArgument Class +//===----------------------------------------------------------------------===// + +// Specialize setName to take care of symbol table majik +void MethodArgument::setName(const string &name) { + Method *P; + if ((P = getParent()) && hasName()) P->getSymbolTable()->remove(this); + Value::setName(name); + if (P && hasName()) P->getSymbolTable()->insert(this); +} + + +//===----------------------------------------------------------------------===// +// PHINode Class +//===----------------------------------------------------------------------===// + +PHINode::PHINode(const Type *Ty, const string &name) + : Instruction(Ty, Instruction::PHINode, name) { +} + +PHINode::PHINode(const PHINode &PN) + : Instruction(PN.getType(), Instruction::PHINode) { + + for (unsigned i = 0; i < PN.IncomingValues.size(); i++) + IncomingValues.push_back(Use(PN.IncomingValues[i], this)); +} + +void PHINode::dropAllReferences() { + IncomingValues.clear(); +} + +bool PHINode::setOperand(unsigned i, Value *Val) { + assert(Val && "PHI node must only reference nonnull definitions!"); + if (i >= IncomingValues.size()) return false; + + IncomingValues[i] = Val; + return true; +} + +void PHINode::addIncoming(Value *D) { + IncomingValues.push_back(Use(D, this)); +} + |