]> git.saurik.com Git - apple/icu.git/blobdiff - icuSources/i18n/visibledigits.cpp
ICU-62123.0.1.tar.gz
[apple/icu.git] / icuSources / i18n / visibledigits.cpp
index a6cbd0fdce276ee73a34bda6fdce5c20c94829d8..95ab469bbbec6b338a1aa723c99dee2d1dac1355 100644 (file)
@@ -1,5 +1,7 @@
+// © 2016 and later: Unicode, Inc. and others.
+// License & terms of use: http://www.unicode.org/copyright.html
 /*
 /*
- * Copyright (C) 2015, International Business Machines
+ * Copyright (C) 2016, International Business Machines
  * Corporation and others.  All Rights Reserved.
  *
  * file name: visibledigits.cpp
  * Corporation and others.  All Rights Reserved.
  *
  * file name: visibledigits.cpp
@@ -74,6 +76,13 @@ UBool VisibleDigits::isNaNOrInfinity() const {
     return (fFlags & (kInfinite | kNaN)) != 0;
 }
 
     return (fFlags & (kInfinite | kNaN)) != 0;
 }
 
+UBool VisibleDigits::formatFullPrecision() const { // Apple
+    return fFormatFullPrecision;
+}
+void VisibleDigits::setFormatFullPrecision(UBool formatFullPrecision) { // Apple
+    fFormatFullPrecision = formatFullPrecision;
+}
+
 double VisibleDigits::computeAbsDoubleValue() const {
     // Take care of NaN and infinity
     if (isNaN()) {
 double VisibleDigits::computeAbsDoubleValue() const {
     // Take care of NaN and infinity
     if (isNaN()) {
@@ -84,8 +93,11 @@ double VisibleDigits::computeAbsDoubleValue() const {
     }
 
     // stack allocate a decNumber to hold MAX_DBL_DIGITS+3 significant digits
     }
 
     // stack allocate a decNumber to hold MAX_DBL_DIGITS+3 significant digits
-    char rawNumber[sizeof(decNumber) + MAX_DBL_DIGITS+3];
-    decNumber *numberPtr = (decNumber *) rawNumber;
+    struct {
+        decNumber  decNum;
+        char       digits[MAX_DBL_DIGITS+3];
+    } decNumberWithStorage;
+    decNumber *numberPtr = &decNumberWithStorage.decNum;
 
     int32_t mostSig = fInterval.getMostSignificantExclusive();
     int32_t mostSigNonZero = fExponent + fDigits.length();
 
     int32_t mostSig = fInterval.getMostSignificantExclusive();
     int32_t mostSigNonZero = fExponent + fDigits.length();
@@ -109,15 +121,8 @@ double VisibleDigits::computeAbsDoubleValue() const {
     char str[MAX_DBL_DIGITS+18];
     uprv_decNumberToString(numberPtr, str);
     U_ASSERT(uprv_strlen(str) < MAX_DBL_DIGITS+18);
     char str[MAX_DBL_DIGITS+18];
     uprv_decNumberToString(numberPtr, str);
     U_ASSERT(uprv_strlen(str) < MAX_DBL_DIGITS+18);
-    char decimalSeparator = DigitList::getStrtodDecimalSeparator();
-    if (decimalSeparator != '.') {
-        char *decimalPt = strchr(str, '.');
-        if (decimalPt != NULL) {
-            *decimalPt = decimalSeparator;
-        }
-    }
     char *unused = NULL;
     char *unused = NULL;
-    return uprv_strtod(str, &unused);
+    return DigitList::decimalStrToDouble(str, &unused);
 }
 
 void VisibleDigits::getFixedDecimal(
 }
 
 void VisibleDigits::getFixedDecimal(
@@ -165,7 +170,8 @@ void VisibleDigits::getFixedDecimal(
     // f (decimal digits)
     // skip over any leading 0's in fraction digits.
     int32_t idx = -1;
     // f (decimal digits)
     // skip over any leading 0's in fraction digits.
     int32_t idx = -1;
-    for (; idx >= -v && getDigitByExponent(idx) == 0; --idx);
+    for (; idx >= -v && getDigitByExponent(idx) == 0; --idx)
+      ;
 
     // Only process up to first 18 non zero fraction digits for decimalDigits
     // since that is all we can fit into an int64.
 
     // Only process up to first 18 non zero fraction digits for decimalDigits
     // since that is all we can fit into an int64.