mirror of
https://github.com/RPCSX/llvm.git
synced 2024-12-11 05:35:11 +00:00
make ConstantFP::isExactlyValue work for long double as well.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@49410 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
cba931f601
commit
def286408f
@ -251,16 +251,13 @@ public:
|
||||
/// As such, this method can be used to do an exact bit-for-bit comparison of
|
||||
/// two floating point values. The version with a double operand is retained
|
||||
/// because it's so convenient to write isExactlyValue(2.0), but please use
|
||||
/// it only for constants.
|
||||
/// it only for simple constants.
|
||||
bool isExactlyValue(const APFloat& V) const;
|
||||
|
||||
bool isExactlyValue(double V) const {
|
||||
if (&Val.getSemantics() == &APFloat::IEEEdouble)
|
||||
return isExactlyValue(APFloat(V));
|
||||
else if (&Val.getSemantics() == &APFloat::IEEEsingle)
|
||||
return isExactlyValue(APFloat((float)V));
|
||||
assert(0);
|
||||
return false;
|
||||
APFloat FV(V);
|
||||
FV.convert(Val.getSemantics(), APFloat::rmNearestTiesToEven);
|
||||
return isExactlyValue(FV);
|
||||
}
|
||||
/// Methods for support type inquiry through isa, cast, and dyn_cast:
|
||||
static inline bool classof(const ConstantFP *) { return true; }
|
||||
|
Loading…
Reference in New Issue
Block a user