mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-22 10:16:43 +00:00
Fix Bug: test/Regression/Other/2002-04-07-InfConstant.ll
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2142 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
ace9103ebe
commit
f862b6d374
@ -165,9 +165,18 @@ std::string ConstantUInt::getStrValue() const {
|
||||
//
|
||||
std::string ConstantFP::getStrValue() const {
|
||||
std::string StrVal = ftostr(Val);
|
||||
double TestVal = atof(StrVal.c_str()); // Reparse stringized version!
|
||||
if (TestVal == Val)
|
||||
return StrVal;
|
||||
|
||||
// Check to make sure that the stringized number is not some string like "Inf"
|
||||
// or NaN, that atof will accept, but the lexer will not. Check that the
|
||||
// string matches the "[-+]?[0-9]" regex.
|
||||
//
|
||||
if ((StrVal[0] >= '0' && StrVal[0] <= '9') ||
|
||||
((StrVal[0] == '-' || StrVal[0] == '+') &&
|
||||
(StrVal[0] >= '0' && StrVal[0] <= '9'))) {
|
||||
double TestVal = atof(StrVal.c_str()); // Reparse stringized version!
|
||||
if (TestVal == Val)
|
||||
return StrVal;
|
||||
}
|
||||
|
||||
// Otherwise we could not reparse it to exactly the same value, so we must
|
||||
// output the string in hexadecimal format!
|
||||
|
Loading…
x
Reference in New Issue
Block a user