summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-02-01 01:22:56 +0000
committerChris Lattner <sabre@nondot.org>2005-02-01 01:22:56 +0000
commitf98a7bffb33449c3f920f3311dc86cd0fbc71642 (patch)
treead622d5b9dffefe9788a63994878bb78482ab4b4 /llvm/lib
parentef55a1a775f48a31d094c454b6605b6a05bf9f16 (diff)
downloadbcm5719-llvm-f98a7bffb33449c3f920f3311dc86cd0fbc71642.tar.gz
bcm5719-llvm-f98a7bffb33449c3f920f3311dc86cd0fbc71642.zip
Hacks to make this ugly ugly code work with the new use lists.
llvm-svn: 19957
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Transforms/ExprTypeConvert.cpp29
1 files changed, 12 insertions, 17 deletions
diff --git a/llvm/lib/Transforms/ExprTypeConvert.cpp b/llvm/lib/Transforms/ExprTypeConvert.cpp
index 58221242310..675ad7b1aa6 100644
--- a/llvm/lib/Transforms/ExprTypeConvert.cpp
+++ b/llvm/lib/Transforms/ExprTypeConvert.cpp
@@ -539,13 +539,14 @@ Value *llvm::ConvertExpressionToType(Value *V, const Type *Ty,
VMC.ExprMap[I] = Res;
- unsigned NumUses = I->use_size();
+ //// WTF is this code! FIXME: remove this.
+ unsigned NumUses = I->getNumUses();
for (unsigned It = 0; It < NumUses; ) {
unsigned OldSize = NumUses;
Value::use_iterator UI = I->use_begin();
std::advance(UI, It);
ConvertOperandToType(*UI, I, Res, VMC, TD);
- NumUses = I->use_size();
+ NumUses = I->getNumUses();
if (NumUses == OldSize) ++It;
}
@@ -898,13 +899,14 @@ void llvm::ConvertValueToNewType(Value *V, Value *NewVal, ValueMapCache &VMC,
const TargetData &TD) {
ValueHandle VH(VMC, V);
- unsigned NumUses = V->use_size();
+ // FIXME: This is horrible!
+ unsigned NumUses = V->getNumUses();
for (unsigned It = 0; It < NumUses; ) {
unsigned OldSize = NumUses;
Value::use_iterator UI = V->use_begin();
std::advance(UI, It);
ConvertOperandToType(*UI, V, NewVal, VMC, TD);
- NumUses = V->use_size();
+ NumUses = V->getNumUses();
if (NumUses == OldSize) ++It;
}
}
@@ -1237,22 +1239,15 @@ static void ConvertOperandToType(User *U, Value *OldVal, Value *NewVal,
if (I->getType() != Res->getType())
ConvertValueToNewType(I, Res, VMC, TD);
else {
- bool FromStart = true;
- Value::use_iterator UI;
- while (1) {
- if (FromStart) UI = I->use_begin();
- if (UI == I->use_end()) break;
-
+ for (Value::use_iterator UI = I->use_begin(), E = I->use_end();
+ UI != E; )
if (isa<ValueHandle>(*UI)) {
++UI;
- FromStart = false;
} else {
- User *U = *UI;
- if (!FromStart) --UI;
- U->replaceUsesOfWith(I, Res);
- if (!FromStart) ++UI;
+ Use &U = UI.getUse();
+ ++UI; // Do not invalidate UI.
+ U.set(Res);
}
- }
}
}
@@ -1301,7 +1296,7 @@ ValueHandle::~ValueHandle() {
RecursiveDelete(Cache, dyn_cast<Instruction>(V));
} else {
//DEBUG(std::cerr << "VH RELEASING: " << (void*)Operands[0].get() << " "
- // << Operands[0]->use_size() << " " << Operands[0]);
+ // << Operands[0]->getNumUses() << " " << Operands[0]);
}
}
OpenPOWER on IntegriCloud