mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-05 13:26:55 +00:00
Taken into account Duncan's comments for r149481 dated by 2nd Feb 2012:
http://lists.cs.uiuc.edu/pipermail/llvm-commits/Week-of-Mon-20120130/136146.html Implemented CaseIterator and it solves almost all described issues: we don't need to mix operand/case/successor indexing anymore. Base iterator class is implemented as a template since it may be initialized either from "const SwitchInst*" or from "SwitchInst*". ConstCaseIt is just a read-only iterator. CaseIt is read-write iterator; it allows to change case successor and case value. Usage of iterator allows totally remove resolveXXXX methods. All indexing convertions done automatically inside the iterator's getters. Main way of iterator usage looks like this: SwitchInst *SI = ... // intialize it somehow for (SwitchInst::CaseIt i = SI->caseBegin(), e = SI->caseEnd(); i != e; ++i) { BasicBlock *BB = i.getCaseSuccessor(); ConstantInt *V = i.getCaseValue(); // Do something. } If you want to convert case number to TerminatorInst successor index, just use getSuccessorIndex iterator's method. If you want initialize iterator from TerminatorInst successor index, use CaseIt::fromSuccessorIndex(...) method. There are also related changes in llvm-clients: klee and clang. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@152297 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -1731,12 +1731,12 @@ void AssemblyWriter::printInstruction(const Instruction &I) {
|
||||
Out << ", ";
|
||||
writeOperand(SI.getDefaultDest(), true);
|
||||
Out << " [";
|
||||
unsigned NumCases = SI.getNumCases();
|
||||
for (unsigned i = 0; i < NumCases; ++i) {
|
||||
for (SwitchInst::CaseIt i = SI.caseBegin(), e = SI.caseEnd();
|
||||
i != e; ++i) {
|
||||
Out << "\n ";
|
||||
writeOperand(SI.getCaseValue(i), true);
|
||||
writeOperand(i.getCaseValue(), true);
|
||||
Out << ", ";
|
||||
writeOperand(SI.getCaseSuccessor(i), true);
|
||||
writeOperand(i.getCaseSuccessor(), true);
|
||||
}
|
||||
Out << "\n ]";
|
||||
} else if (isa<IndirectBrInst>(I)) {
|
||||
|
@@ -3159,13 +3159,16 @@ void SwitchInst::addCase(ConstantInt *OnVal, BasicBlock *Dest) {
|
||||
// Initialize some new operands.
|
||||
assert(OpNo+1 < ReservedSpace && "Growing didn't work!");
|
||||
NumOperands = OpNo+2;
|
||||
setCaseValue(NewCaseIdx, OnVal);
|
||||
setCaseSuccessor(NewCaseIdx, Dest);
|
||||
CaseIt Case(this, NewCaseIdx);
|
||||
Case.setValue(OnVal);
|
||||
Case.setSuccessor(Dest);
|
||||
}
|
||||
|
||||
/// removeCase - This method removes the specified case and its successor
|
||||
/// from the switch instruction.
|
||||
void SwitchInst::removeCase(unsigned idx) {
|
||||
void SwitchInst::removeCase(CaseIt i) {
|
||||
unsigned idx = i.getCaseIndex();
|
||||
|
||||
assert(2 + idx*2 < getNumOperands() && "Case index out of range!!!");
|
||||
|
||||
unsigned NumOps = getNumOperands();
|
||||
|
@@ -813,11 +813,11 @@ void Verifier::visitSwitchInst(SwitchInst &SI) {
|
||||
// have the same type as the switched-on value.
|
||||
Type *SwitchTy = SI.getCondition()->getType();
|
||||
SmallPtrSet<ConstantInt*, 32> Constants;
|
||||
for (unsigned i = 0, e = SI.getNumCases(); i != e; ++i) {
|
||||
Assert1(SI.getCaseValue(i)->getType() == SwitchTy,
|
||||
for (SwitchInst::CaseIt i = SI.caseBegin(), e = SI.caseEnd(); i != e; ++i) {
|
||||
Assert1(i.getCaseValue()->getType() == SwitchTy,
|
||||
"Switch constants must all be same type as switch value!", &SI);
|
||||
Assert2(Constants.insert(SI.getCaseValue(i)),
|
||||
"Duplicate integer as switch case", &SI, SI.getCaseValue(i));
|
||||
Assert2(Constants.insert(i.getCaseValue()),
|
||||
"Duplicate integer as switch case", &SI, i.getCaseValue());
|
||||
}
|
||||
|
||||
visitTerminatorInst(SI);
|
||||
|
Reference in New Issue
Block a user