mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-04-08 02:31:41 +00:00
[APFloat] Added support for parsing float strings which contain {inf,-inf,NaN,-NaN}.
llvm-svn: 184713
This commit is contained in:
parent
82b2233f5f
commit
a893ca16f4
@ -510,6 +510,7 @@ private:
|
|||||||
/// \name Miscellany
|
/// \name Miscellany
|
||||||
/// @{
|
/// @{
|
||||||
|
|
||||||
|
bool convertFromStringSpecials(StringRef str);
|
||||||
opStatus normalize(roundingMode, lostFraction);
|
opStatus normalize(roundingMode, lostFraction);
|
||||||
opStatus addOrSubtract(const APFloat &, roundingMode, bool subtract);
|
opStatus addOrSubtract(const APFloat &, roundingMode, bool subtract);
|
||||||
cmpResult compareAbsoluteValue(const APFloat &) const;
|
cmpResult compareAbsoluteValue(const APFloat &) const;
|
||||||
|
@ -2575,11 +2575,40 @@ APFloat::convertFromDecimalString(StringRef str, roundingMode rounding_mode)
|
|||||||
return fs;
|
return fs;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool
|
||||||
|
APFloat::convertFromStringSpecials(StringRef str) {
|
||||||
|
if (str.equals("inf") || str.equals("INFINITY")) {
|
||||||
|
makeInf(false);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (str.equals("-inf") || str.equals("-INFINITY")) {
|
||||||
|
makeInf(true);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (str.equals("nan") || str.equals("NaN")) {
|
||||||
|
makeNaN(false, false);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (str.equals("-nan") || str.equals("-NaN")) {
|
||||||
|
makeNaN(false, true);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
APFloat::opStatus
|
APFloat::opStatus
|
||||||
APFloat::convertFromString(StringRef str, roundingMode rounding_mode)
|
APFloat::convertFromString(StringRef str, roundingMode rounding_mode)
|
||||||
{
|
{
|
||||||
assert(!str.empty() && "Invalid string length");
|
assert(!str.empty() && "Invalid string length");
|
||||||
|
|
||||||
|
// Handle special cases.
|
||||||
|
if (convertFromStringSpecials(str))
|
||||||
|
return opOK;
|
||||||
|
|
||||||
/* Handle a leading minus sign. */
|
/* Handle a leading minus sign. */
|
||||||
StringRef::iterator p = str.begin();
|
StringRef::iterator p = str.begin();
|
||||||
size_t slen = str.size();
|
size_t slen = str.size();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user