mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-15 22:37:59 +00:00
Support/APFloat: unique_ptr-ify temp arrays
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@216359 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
97dc647e90
commit
0901b15d01
@ -1722,7 +1722,8 @@ APFloat::remainder(const APFloat &rhs)
|
|||||||
return fs;
|
return fs;
|
||||||
|
|
||||||
int parts = partCount();
|
int parts = partCount();
|
||||||
integerPart *x = new integerPart[parts];
|
auto XOwner = make_unique<integerPart[]>(parts);
|
||||||
|
auto x = XOwner.get();
|
||||||
bool ignored;
|
bool ignored;
|
||||||
fs = V.convertToInteger(x, parts * integerPartWidth, true,
|
fs = V.convertToInteger(x, parts * integerPartWidth, true,
|
||||||
rmNearestTiesToEven, &ignored);
|
rmNearestTiesToEven, &ignored);
|
||||||
@ -1741,7 +1742,6 @@ APFloat::remainder(const APFloat &rhs)
|
|||||||
|
|
||||||
if (isZero())
|
if (isZero())
|
||||||
sign = origSign; // IEEE754 requires this
|
sign = origSign; // IEEE754 requires this
|
||||||
delete[] x;
|
|
||||||
return fs;
|
return fs;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1762,7 +1762,8 @@ APFloat::mod(const APFloat &rhs, roundingMode rounding_mode)
|
|||||||
return fs;
|
return fs;
|
||||||
|
|
||||||
int parts = partCount();
|
int parts = partCount();
|
||||||
integerPart *x = new integerPart[parts];
|
auto XOwner = make_unique<integerPart[]>(parts);
|
||||||
|
auto x = XOwner.get();
|
||||||
bool ignored;
|
bool ignored;
|
||||||
fs = V.convertToInteger(x, parts * integerPartWidth, true,
|
fs = V.convertToInteger(x, parts * integerPartWidth, true,
|
||||||
rmTowardZero, &ignored);
|
rmTowardZero, &ignored);
|
||||||
@ -1781,7 +1782,6 @@ APFloat::mod(const APFloat &rhs, roundingMode rounding_mode)
|
|||||||
|
|
||||||
if (isZero())
|
if (isZero())
|
||||||
sign = origSign; // IEEE754 requires this
|
sign = origSign; // IEEE754 requires this
|
||||||
delete[] x;
|
|
||||||
}
|
}
|
||||||
return fs;
|
return fs;
|
||||||
}
|
}
|
||||||
@ -2284,15 +2284,14 @@ APFloat::convertFromSignExtendedInteger(const integerPart *src,
|
|||||||
|
|
||||||
if (isSigned &&
|
if (isSigned &&
|
||||||
APInt::tcExtractBit(src, srcCount * integerPartWidth - 1)) {
|
APInt::tcExtractBit(src, srcCount * integerPartWidth - 1)) {
|
||||||
integerPart *copy;
|
auto C = make_unique<integerPart[]>(srcCount);
|
||||||
|
auto copy = C.get();
|
||||||
|
|
||||||
/* If we're signed and negative negate a copy. */
|
/* If we're signed and negative negate a copy. */
|
||||||
sign = true;
|
sign = true;
|
||||||
copy = new integerPart[srcCount];
|
|
||||||
APInt::tcAssign(copy, src, srcCount);
|
APInt::tcAssign(copy, src, srcCount);
|
||||||
APInt::tcNegate(copy, srcCount);
|
APInt::tcNegate(copy, srcCount);
|
||||||
status = convertFromUnsignedParts(copy, srcCount, rounding_mode);
|
status = convertFromUnsignedParts(copy, srcCount, rounding_mode);
|
||||||
delete [] copy;
|
|
||||||
} else {
|
} else {
|
||||||
sign = false;
|
sign = false;
|
||||||
status = convertFromUnsignedParts(src, srcCount, rounding_mode);
|
status = convertFromUnsignedParts(src, srcCount, rounding_mode);
|
||||||
@ -2545,7 +2544,6 @@ APFloat::convertFromDecimalString(StringRef str, roundingMode rounding_mode)
|
|||||||
/* Overflow and round. */
|
/* Overflow and round. */
|
||||||
fs = handleOverflow(rounding_mode);
|
fs = handleOverflow(rounding_mode);
|
||||||
} else {
|
} else {
|
||||||
integerPart *decSignificand;
|
|
||||||
unsigned int partCount;
|
unsigned int partCount;
|
||||||
|
|
||||||
/* A tight upper bound on number of bits required to hold an
|
/* A tight upper bound on number of bits required to hold an
|
||||||
@ -2554,7 +2552,8 @@ APFloat::convertFromDecimalString(StringRef str, roundingMode rounding_mode)
|
|||||||
tcMultiplyPart. */
|
tcMultiplyPart. */
|
||||||
partCount = static_cast<unsigned int>(D.lastSigDigit - D.firstSigDigit) + 1;
|
partCount = static_cast<unsigned int>(D.lastSigDigit - D.firstSigDigit) + 1;
|
||||||
partCount = partCountForBits(1 + 196 * partCount / 59);
|
partCount = partCountForBits(1 + 196 * partCount / 59);
|
||||||
decSignificand = new integerPart[partCount + 1];
|
auto DecSignificandOwner = make_unique<integerPart[]>(partCount + 1);
|
||||||
|
auto decSignificand = DecSignificandOwner.get();
|
||||||
partCount = 0;
|
partCount = 0;
|
||||||
|
|
||||||
/* Convert to binary efficiently - we do almost all multiplication
|
/* Convert to binary efficiently - we do almost all multiplication
|
||||||
@ -2595,8 +2594,6 @@ APFloat::convertFromDecimalString(StringRef str, roundingMode rounding_mode)
|
|||||||
category = fcNormal;
|
category = fcNormal;
|
||||||
fs = roundSignificandWithExponent(decSignificand, partCount,
|
fs = roundSignificandWithExponent(decSignificand, partCount,
|
||||||
D.exponent, rounding_mode);
|
D.exponent, rounding_mode);
|
||||||
|
|
||||||
delete [] decSignificand;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return fs;
|
return fs;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user