Use APInt::tcExtract. It's cleaner, and works :)

llvm-svn: 42746
This commit is contained in:
Neil Booth 2007-10-08 14:39:42 +00:00
parent b618216e56
commit 49c6aab7b8
1 changed files with 14 additions and 19 deletions

View File

@ -1556,32 +1556,27 @@ APFloat::convertFromUnsignedParts(const integerPart *src,
unsigned int srcCount,
roundingMode rounding_mode)
{
unsigned int dstCount;
lostFraction lost_fraction;
unsigned int omsb, precision, dstCount;
integerPart *dst;
lostFraction lost_fraction;
category = fcNormal;
exponent = semantics->precision - 1;
omsb = APInt::tcMSB(src, srcCount) + 1;
dst = significandParts();
dstCount = partCount();
precision = semantics->precision;
/* We need to capture the non-zero most significant parts. */
while (srcCount > dstCount && src[srcCount - 1] == 0)
srcCount--;
/* Copy the bit image of as many parts as we can. If we are wider,
zero-out remaining parts. */
if (dstCount >= srcCount) {
APInt::tcAssign(dst, src, srcCount);
while (srcCount < dstCount)
dst[srcCount++] = 0;
lost_fraction = lfExactlyZero;
} else {
exponent += (srcCount - dstCount) * integerPartWidth;
APInt::tcAssign(dst, src + (srcCount - dstCount), dstCount);
/* We want the most significant PRECISON bits of SRC. There may not
be that many; extract what we can. */
if (precision <= omsb) {
exponent = omsb - 1;
lost_fraction = lostFractionThroughTruncation(src, srcCount,
dstCount * integerPartWidth);
omsb - precision);
APInt::tcExtract(dst, dstCount, src, precision, omsb - precision);
} else {
exponent = precision - 1;
lost_fraction = lfExactlyZero;
APInt::tcExtract(dst, dstCount, src, omsb, 0);
}
return normalize(rounding_mode, lost_fraction);