diff options
author | Tanya Lattner <tonic@nondot.org> | 2004-05-23 19:35:12 +0000 |
---|---|---|
committer | Tanya Lattner <tonic@nondot.org> | 2004-05-23 19:35:12 +0000 |
commit | 466b534a570f574ed485d875bbca8454f68dcb52 (patch) | |
tree | fe90790ff8f78957e1b98186cd3380eb41228a4d /lib/CodeGen/MachineInstr.cpp | |
parent | 8e0262f0edec9e40bfe0bdc7f1c70a3f1cbb95c7 (diff) |
Adding support to clone MachineInstr
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@13661 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/MachineInstr.cpp')
-rw-r--r-- | lib/CodeGen/MachineInstr.cpp | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/lib/CodeGen/MachineInstr.cpp b/lib/CodeGen/MachineInstr.cpp index 38cd62e83f..e1e44fd47e 100644 --- a/lib/CodeGen/MachineInstr.cpp +++ b/lib/CodeGen/MachineInstr.cpp @@ -69,11 +69,29 @@ MachineInstr::MachineInstr(MachineBasicBlock *MBB, short opcode, MBB->push_back(this); // Add instruction to end of basic block! } +///MachineInstr ctor - Copies MachineInstr arg exactly +MachineInstr::MachineInstr(const MachineInstr &MI) { + Opcode = MI.getOpcode(); + numImplicitRefs = MI.getNumImplicitRefs(); + + //Add operands + for(unsigned i=0; i < MI.getNumOperands(); ++i) + operands.push_back(MachineOperand(MI.getOperand(i))); +} + + MachineInstr::~MachineInstr() { LeakDetector::removeGarbageObject(this); } +///clone - Create a copy of 'this' instruction that is identical in +///all ways except the following: The instruction has no parent The +///instruction has no name +MachineInstr* MachineInstr::clone() { + MachineInstr* newInst = new MachineInstr(*this); +} + /// OperandComplete - Return true if it's illegal to add a new operand /// bool MachineInstr::OperandsComplete() const { @@ -93,6 +111,7 @@ void MachineInstr::replace(short opcode, unsigned numOperands) { Opcode = opcode; operands.clear(); operands.resize(numOperands, MachineOperand()); + } void MachineInstr::SetMachineOperandVal(unsigned i, |