summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Support/APFloat.cpp
diff options
context:
space:
mode:
authorDylan Noblesmith <nobled@dreamwidth.org>2014-08-25 00:58:10 +0000
committerDylan Noblesmith <nobled@dreamwidth.org>2014-08-25 00:58:10 +0000
commit49c758b769b9a787d415a9c2ce0e40fa0e482412 (patch)
treebfcfa6a617eefe575360eddd0d366463b2b1a185 /llvm/lib/Support/APFloat.cpp
parent3ecd22fcf5ae4d06d801d9d88c490931fac62ed5 (diff)
downloadbcm5719-llvm-49c758b769b9a787d415a9c2ce0e40fa0e482412.tar.gz
bcm5719-llvm-49c758b769b9a787d415a9c2ce0e40fa0e482412.zip
Support/APFloat: unique_ptr-ify temp arrays
llvm-svn: 216359
Diffstat (limited to 'llvm/lib/Support/APFloat.cpp')
-rw-r--r--llvm/lib/Support/APFloat.cpp19
1 files changed, 8 insertions, 11 deletions
diff --git a/llvm/lib/Support/APFloat.cpp b/llvm/lib/Support/APFloat.cpp
index 7989e30afae..4359061e433 100644
--- a/llvm/lib/Support/APFloat.cpp
+++ b/llvm/lib/Support/APFloat.cpp
@@ -1722,7 +1722,8 @@ APFloat::remainder(const APFloat &rhs)
return fs;
int parts = partCount();
- integerPart *x = new integerPart[parts];
+ auto XOwner = make_unique<integerPart[]>(parts);
+ auto x = XOwner.get();
bool ignored;
fs = V.convertToInteger(x, parts * integerPartWidth, true,
rmNearestTiesToEven, &ignored);
@@ -1741,7 +1742,6 @@ APFloat::remainder(const APFloat &rhs)
if (isZero())
sign = origSign; // IEEE754 requires this
- delete[] x;
return fs;
}
@@ -1762,7 +1762,8 @@ APFloat::mod(const APFloat &rhs, roundingMode rounding_mode)
return fs;
int parts = partCount();
- integerPart *x = new integerPart[parts];
+ auto XOwner = make_unique<integerPart[]>(parts);
+ auto x = XOwner.get();
bool ignored;
fs = V.convertToInteger(x, parts * integerPartWidth, true,
rmTowardZero, &ignored);
@@ -1781,7 +1782,6 @@ APFloat::mod(const APFloat &rhs, roundingMode rounding_mode)
if (isZero())
sign = origSign; // IEEE754 requires this
- delete[] x;
}
return fs;
}
@@ -2284,15 +2284,14 @@ APFloat::convertFromSignExtendedInteger(const integerPart *src,
if (isSigned &&
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. */
sign = true;
- copy = new integerPart[srcCount];
APInt::tcAssign(copy, src, srcCount);
APInt::tcNegate(copy, srcCount);
status = convertFromUnsignedParts(copy, srcCount, rounding_mode);
- delete [] copy;
} else {
sign = false;
status = convertFromUnsignedParts(src, srcCount, rounding_mode);
@@ -2545,7 +2544,6 @@ APFloat::convertFromDecimalString(StringRef str, roundingMode rounding_mode)
/* Overflow and round. */
fs = handleOverflow(rounding_mode);
} else {
- integerPart *decSignificand;
unsigned int partCount;
/* A tight upper bound on number of bits required to hold an
@@ -2554,7 +2552,8 @@ APFloat::convertFromDecimalString(StringRef str, roundingMode rounding_mode)
tcMultiplyPart. */
partCount = static_cast<unsigned int>(D.lastSigDigit - D.firstSigDigit) + 1;
partCount = partCountForBits(1 + 196 * partCount / 59);
- decSignificand = new integerPart[partCount + 1];
+ auto DecSignificandOwner = make_unique<integerPart[]>(partCount + 1);
+ auto decSignificand = DecSignificandOwner.get();
partCount = 0;
/* Convert to binary efficiently - we do almost all multiplication
@@ -2595,8 +2594,6 @@ APFloat::convertFromDecimalString(StringRef str, roundingMode rounding_mode)
category = fcNormal;
fs = roundSignificandWithExponent(decSignificand, partCount,
D.exponent, rounding_mode);
-
- delete [] decSignificand;
}
return fs;
OpenPOWER on IntegriCloud