mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-25 16:24:23 +00:00
Remove DEFINE_TRANSPARENT_CASTED_OPERAND_ACCESSORS, folding its
functionality into DEFINE_TRANSPARENT_OPERAND_ACCESSORS. A side-effect of this is that the operand accessors for Constants will tolerate NULL operands, fixing PR10663. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@138230 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -136,45 +136,8 @@ CLASS::const_op_iterator CLASS::op_end() const { \
|
||||
VALUECLASS *CLASS::getOperand(unsigned i_nocapture) const { \
|
||||
assert(i_nocapture < OperandTraits<CLASS>::operands(this) \
|
||||
&& "getOperand() out of range!"); \
|
||||
return static_cast<VALUECLASS*>( \
|
||||
OperandTraits<CLASS>::op_begin(const_cast<CLASS*>(this))[i_nocapture]); \
|
||||
} \
|
||||
void CLASS::setOperand(unsigned i_nocapture, VALUECLASS *Val_nocapture) { \
|
||||
assert(i_nocapture < OperandTraits<CLASS>::operands(this) \
|
||||
&& "setOperand() out of range!"); \
|
||||
OperandTraits<CLASS>::op_begin(this)[i_nocapture] = Val_nocapture; \
|
||||
} \
|
||||
unsigned CLASS::getNumOperands() const { \
|
||||
return OperandTraits<CLASS>::operands(this); \
|
||||
} \
|
||||
template <int Idx_nocapture> Use &CLASS::Op() { \
|
||||
return this->OpFrom<Idx_nocapture>(this); \
|
||||
} \
|
||||
template <int Idx_nocapture> const Use &CLASS::Op() const { \
|
||||
return this->OpFrom<Idx_nocapture>(this); \
|
||||
}
|
||||
|
||||
|
||||
/// Macro for generating out-of-class operand accessor
|
||||
/// definitions with casted result
|
||||
#define DEFINE_TRANSPARENT_CASTED_OPERAND_ACCESSORS(CLASS, VALUECLASS) \
|
||||
CLASS::op_iterator CLASS::op_begin() { \
|
||||
return OperandTraits<CLASS>::op_begin(this); \
|
||||
} \
|
||||
CLASS::const_op_iterator CLASS::op_begin() const { \
|
||||
return OperandTraits<CLASS>::op_begin(const_cast<CLASS*>(this)); \
|
||||
} \
|
||||
CLASS::op_iterator CLASS::op_end() { \
|
||||
return OperandTraits<CLASS>::op_end(this); \
|
||||
} \
|
||||
CLASS::const_op_iterator CLASS::op_end() const { \
|
||||
return OperandTraits<CLASS>::op_end(const_cast<CLASS*>(this)); \
|
||||
} \
|
||||
VALUECLASS *CLASS::getOperand(unsigned i_nocapture) const { \
|
||||
assert(i_nocapture < OperandTraits<CLASS>::operands(this) \
|
||||
&& "getOperand() out of range!"); \
|
||||
return cast<VALUECLASS>( \
|
||||
OperandTraits<CLASS>::op_begin(const_cast<CLASS*>(this))[i_nocapture]); \
|
||||
return cast_or_null<VALUECLASS>( \
|
||||
OperandTraits<CLASS>::op_begin(const_cast<CLASS*>(this))[i_nocapture].get()); \
|
||||
} \
|
||||
void CLASS::setOperand(unsigned i_nocapture, VALUECLASS *Val_nocapture) { \
|
||||
assert(i_nocapture < OperandTraits<CLASS>::operands(this) \
|
||||
|
Reference in New Issue
Block a user