forked from OSchip/llvm-project
Fix or remove code which seemed to think that the operand of a Constant
was always a User. llvm-svn: 129272
This commit is contained in:
parent
7c14a558fe
commit
0159a1ee11
|
@ -47,10 +47,6 @@ protected:
|
|||
: User(ty, vty, Ops, NumOps) {}
|
||||
|
||||
void destroyConstantImpl();
|
||||
|
||||
void setOperand(unsigned i, Value *V) {
|
||||
User::setOperand(i, V);
|
||||
}
|
||||
public:
|
||||
/// isNullValue - Return true if this is the value that would be returned by
|
||||
/// getNullValue.
|
||||
|
@ -90,15 +86,6 @@ public:
|
|||
/// FIXME: This really should not be in VMCore.
|
||||
PossibleRelocationsTy getRelocationInfo() const;
|
||||
|
||||
// Specialize get/setOperand for Users as their operands are always
|
||||
// constants or BasicBlocks as well.
|
||||
User *getOperand(unsigned i) {
|
||||
return static_cast<User*>(User::getOperand(i));
|
||||
}
|
||||
const User *getOperand(unsigned i) const {
|
||||
return static_cast<const User*>(User::getOperand(i));
|
||||
}
|
||||
|
||||
/// getVectorElements - This method, which is only valid on constant of vector
|
||||
/// type, returns the elements of the vector in the specified smallvector.
|
||||
/// This handles breaking down a vector undef into undef elements, etc. For
|
||||
|
|
|
@ -423,7 +423,7 @@ void ValueEnumerator::EnumerateOperandType(const Value *V) {
|
|||
// This constant may have operands, make sure to enumerate the types in
|
||||
// them.
|
||||
for (unsigned i = 0, e = C->getNumOperands(); i != e; ++i) {
|
||||
const User *Op = C->getOperand(i);
|
||||
const Value *Op = C->getOperand(i);
|
||||
|
||||
// Don't enumerate basic blocks here, this happens as operands to
|
||||
// blockaddress.
|
||||
|
|
Loading…
Reference in New Issue