diff options
| author | Chris Lattner <sabre@nondot.org> | 2002-04-09 18:00:49 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2002-04-09 18:00:49 +0000 |
| commit | 46df9aec96edce750cb2d653ea13b45fc791fdda (patch) | |
| tree | 7c48582cb6b20c335ffdcb0649d57dfece8b85f3 | |
| parent | c71deb8412d24b5c66fd0a3fb1821015ea1a9a0c (diff) | |
| download | bcm5719-llvm-46df9aec96edce750cb2d653ea13b45fc791fdda.tar.gz bcm5719-llvm-46df9aec96edce750cb2d653ea13b45fc791fdda.zip | |
Rewrite MachineCodeForBasicBlock in terms of containment rather than
inheritance.
llvm-svn: 2200
| -rw-r--r-- | llvm/include/llvm/CodeGen/MachineInstr.h | 49 |
1 files changed, 45 insertions, 4 deletions
diff --git a/llvm/include/llvm/CodeGen/MachineInstr.h b/llvm/include/llvm/CodeGen/MachineInstr.h index 78933044064..dacd4bd1f21 100644 --- a/llvm/include/llvm/CodeGen/MachineInstr.h +++ b/llvm/include/llvm/CodeGen/MachineInstr.h @@ -434,10 +434,54 @@ MachineInstr::setImplicitRef(unsigned int i, //--------------------------------------------------------------------------- -class MachineCodeForBasicBlock: public std::vector<MachineInstr*> { +class MachineCodeForBasicBlock { + std::vector<MachineInstr*> Insts; public: + ~MachineCodeForBasicBlock() { +#if 0 + for (unsigned i = 0, e = Insts.size(); i != e; ++i) + delete Insts[i]; +#endif + } + typedef std::vector<MachineInstr*>::iterator iterator; typedef std::vector<MachineInstr*>::const_iterator const_iterator; + typedef std::reverse_iterator<const_iterator> const_reverse_iterator; + typedef std::reverse_iterator<iterator> reverse_iterator; + + unsigned size() const { return Insts.size(); } + bool empty() const { return Insts.empty(); } + + MachineInstr * operator[](unsigned i) const { return Insts[i]; } + MachineInstr *&operator[](unsigned i) { return Insts[i]; } + + MachineInstr *front() const { return Insts.front(); } + MachineInstr *back() const { return Insts.back(); } + + iterator begin() { return Insts.begin(); } + const_iterator begin() const { return Insts.begin(); } + iterator end() { return Insts.end(); } + const_iterator end() const { return Insts.end(); } + reverse_iterator rbegin() { return Insts.rbegin(); } + const_reverse_iterator rbegin() const { return Insts.rbegin(); } + reverse_iterator rend () { return Insts.rend(); } + const_reverse_iterator rend () const { return Insts.rend(); } + + void push_back(MachineInstr *MI) { Insts.push_back(MI); } + template<typename IT> + void insert(iterator I, IT S, IT E) { Insts.insert(I, S, E); } + iterator insert(iterator I, MachineInstr *M) { return Insts.insert(I, M); } + + // erase - Remove the specified range from the instruction list. This does + // not delete in instructions removed. + // + iterator erase(iterator I, iterator E) { return Insts.erase(I, E); } + + MachineInstr *pop_back() { + MachineInstr *R = back(); + Insts.pop_back(); + return R; + } }; @@ -454,7 +498,4 @@ std::ostream& operator<< (std::ostream& os, const MachineOperand& mop); void PrintMachineInstructions(const Function *F); - -//**************************************************************************/ - #endif |

