summaryrefslogtreecommitdiff
path: root/svl/source
diff options
context:
space:
mode:
authorKohei Yoshida <kyoshida@novell.com>2010-05-12 10:35:18 -0400
committerKohei Yoshida <kyoshida@novell.com>2010-05-12 10:35:18 -0400
commit95d72876f31b2b0d4c398236354401ee93ac6b72 (patch)
tree994cdfeb076e8219a9616b84f625c65a55224e6f /svl/source
parent0c088315f95751a2911a1144fc2d0d770cdc0a55 (diff)
koheiautodecimal: #i111533# Adjust the default display format for general number format cells.
Diffstat (limited to 'svl/source')
-rw-r--r--svl/source/numbers/zformat.cxx12
1 files changed, 6 insertions, 6 deletions
diff --git a/svl/source/numbers/zformat.cxx b/svl/source/numbers/zformat.cxx
index accf306a20df..589bfd1b31dd 100644
--- a/svl/source/numbers/zformat.cxx
+++ b/svl/source/numbers/zformat.cxx
@@ -1824,14 +1824,14 @@ void SvNumberformat::ImpGetOutputStdToPrecision(double& rNumber, String& rOutStr
}
#endif
- // If truncating the value to desired precision alters the original value,
- // we should show the trailing zeros, otherwise strip them.
- double fRounded = ::rtl::math::round(rNumber, nPrecision);
- bool bRemoveZeros = ::rtl::math::approxEqual(fRounded, rNumber);
+ // We decided to strip trailing zeros unconditionally, since binary
+ // double-precision rounding error makes it impossible to determine e.g.
+ // whether 844.10000000000002273737 is what the user has typed, or the
+ // user has typed 844.1 but IEEE 754 represents it that way internally.
rOutString = ::rtl::math::doubleToUString( rNumber,
rtl_math_StringFormat_F, nPrecision /*2*/,
- GetFormatter().GetNumDecimalSep().GetChar(0), bRemoveZeros );
+ GetFormatter().GetNumDecimalSep().GetChar(0), true );
if (rOutString.GetChar(0) == '-' &&
rOutString.GetTokenCount('0') == rOutString.Len())
rOutString.EraseLeadingChars('-'); // nicht -0
@@ -2079,7 +2079,7 @@ BOOL SvNumberformat::GetOutputString(double fNumber,
bool bSign = ::rtl::math::isSignBitSet(fNumber);
if (bSign)
fNumber = -fNumber;
- ImpGetOutputInputLine(fNumber, OutString);
+ ImpGetOutputStdToPrecision(fNumber, OutString, 10); // Use 10 decimals for general 'unlimited' format.
if (fNumber < EXP_LOWER_BOUND)
{
xub_StrLen nLen = OutString.Len();