mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 12:12:47 +01:00
bf27c54995
llvm-svn: 13797
51 lines
1.7 KiB
C++
51 lines
1.7 KiB
C++
//===-- iSwitch.cpp - Implement the Switch instruction --------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file was developed by the LLVM research group and is distributed under
|
|
// the University of Illinois Open Source License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file implements the Switch instruction...
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/iTerminators.h"
|
|
#include "llvm/BasicBlock.h"
|
|
using namespace llvm;
|
|
|
|
void SwitchInst::init(Value *Value, BasicBlock *Default)
|
|
{
|
|
assert(Value && Default);
|
|
Operands.push_back(Use(Value, this));
|
|
Operands.push_back(Use(Default, this));
|
|
}
|
|
|
|
SwitchInst::SwitchInst(const SwitchInst &SI)
|
|
: TerminatorInst(Instruction::Switch) {
|
|
Operands.reserve(SI.Operands.size());
|
|
|
|
for (unsigned i = 0, E = SI.Operands.size(); i != E; i+=2) {
|
|
Operands.push_back(Use(SI.Operands[i], this));
|
|
Operands.push_back(Use(SI.Operands[i+1], this));
|
|
}
|
|
}
|
|
|
|
/// addCase - Add an entry to the switch instruction...
|
|
///
|
|
void SwitchInst::addCase(Constant *OnVal, BasicBlock *Dest) {
|
|
Operands.push_back(Use((Value*)OnVal, this));
|
|
Operands.push_back(Use((Value*)Dest, this));
|
|
}
|
|
|
|
/// removeCase - This method removes the specified successor from the switch
|
|
/// instruction. Note that this cannot be used to remove the default
|
|
/// destination (successor #0).
|
|
///
|
|
void SwitchInst::removeCase(unsigned idx) {
|
|
assert(idx != 0 && "Cannot remove the default case!");
|
|
assert(idx*2 < Operands.size() && "Successor index out of range!!!");
|
|
Operands.erase(Operands.begin()+idx*2, Operands.begin()+(idx+1)*2);
|
|
}
|