X-Git-Url: https://git.saurik.com/apple/icu.git/blobdiff_plain/73c04bcfe1096173b00431f0cdc742894b15eef0..57a6839dcb3bba09e8228b822b290604668416fe:/icuSources/test/intltest/nmfmtrt.cpp diff --git a/icuSources/test/intltest/nmfmtrt.cpp b/icuSources/test/intltest/nmfmtrt.cpp index 0a6e9e81..e4d8d380 100644 --- a/icuSources/test/intltest/nmfmtrt.cpp +++ b/icuSources/test/intltest/nmfmtrt.cpp @@ -1,6 +1,6 @@ /*********************************************************************** * COPYRIGHT: - * Copyright (c) 1997-2006, International Business Machines Corporation + * Copyright (c) 1997-2011, International Business Machines Corporation * and others. All Rights Reserved. ***********************************************************************/ @@ -43,10 +43,14 @@ void NumberFormatRoundTripTest::runIndexedTest( int32_t index, UBool exec, const } UBool -NumberFormatRoundTripTest::failure(UErrorCode status, const char* msg) +NumberFormatRoundTripTest::failure(UErrorCode status, const char* msg, UBool possibleDataError) { if(U_FAILURE(status)) { - errln(UnicodeString("FAIL: ") + msg + " failed, error " + u_errorName(status)); + if (possibleDataError) { + dataerrln(UnicodeString("FAIL: ") + msg + " failed, error " + u_errorName(status)); + } else { + errln(UnicodeString("FAIL: ") + msg + " failed, error " + u_errorName(status)); + } return TRUE; } @@ -90,19 +94,19 @@ NumberFormatRoundTripTest::start() logln("Default Locale"); fmt = NumberFormat::createInstance(status); - if (!failure(status, "NumberFormat::createInstance")){ + if (!failure(status, "NumberFormat::createInstance", TRUE)){ test(fmt); } delete fmt; fmt = NumberFormat::createCurrencyInstance(status); - if (!failure(status, "NumberFormat::createCurrencyInstance")){ + if (!failure(status, "NumberFormat::createCurrencyInstance", TRUE)){ test(fmt); } delete fmt; fmt = NumberFormat::createPercentInstance(status); - if (!failure(status, "NumberFormat::createPercentInstance")){ + if (!failure(status, "NumberFormat::createPercentInstance", TRUE)){ test(fmt); } delete fmt; @@ -142,7 +146,7 @@ NumberFormatRoundTripTest::start() void NumberFormatRoundTripTest::test(NumberFormat *fmt) { -#if IEEE_754 && !defined(OS400) +#if IEEE_754 && U_PLATFORM != U_PF_OS400 test(fmt, uprv_getNaN()); test(fmt, uprv_getInfinity()); test(fmt, -uprv_getInfinity()); @@ -163,10 +167,10 @@ NumberFormatRoundTripTest::test(NumberFormat *fmt) test(fmt, uprv_floor((randomDouble(10000)))); test(fmt, randomDouble(1e50)); test(fmt, randomDouble(1e-50)); -#if !defined(OS390) && !defined(OS400) +#if !(U_PF_OS390 <= U_PLATFORM && U_PLATFORM <= U_PF_OS400) test(fmt, randomDouble(1e100)); #elif IEEE_754 - test(fmt, randomDouble(1e75)); /*OS390 and OS400*/ + test(fmt, randomDouble(1e75)); #endif /* OS390 and OS400 */ // {sfb} When formatting with a percent instance, numbers very close to // DBL_MAX will fail the round trip. This is because: @@ -178,34 +182,35 @@ NumberFormatRoundTripTest::test(NumberFormat *fmt) // I'll get around this by dividing by the multiplier to make sure // the double will stay in range. //if(fmt->getMultipler() == 1) - if(fmt->getDynamicClassID() == DecimalFormat::getStaticClassID()) + DecimalFormat *df = dynamic_cast(fmt); + if(df != NULL) { -#if !defined(OS390) && !defined(OS400) +#if !(U_PF_OS390 <= U_PLATFORM && U_PLATFORM <= U_PF_OS400) /* DBL_MAX/2 is here because randomDouble does a *2 in the math */ - test(fmt, randomDouble(DBL_MAX/2.0) / ((DecimalFormat*)fmt)->getMultiplier()); + test(fmt, randomDouble(DBL_MAX/2.0) / df->getMultiplier()); #elif IEEE_754 - test(fmt, randomDouble(1e75) / ((DecimalFormat*)fmt)->getMultiplier()); + test(fmt, randomDouble(1e75) / df->getMultiplier()); #else - test(fmt, randomDouble(1e65) / ((DecimalFormat*)fmt)->getMultiplier()); /*OS390*/ + test(fmt, randomDouble(1e65) / df->getMultiplier()); #endif } -#if defined XP_MAC || defined __alpha__ || defined U_OSF -// These machines don't support denormalized doubles, -// so the low-end range doesn't match Windows +#if (defined(_MSC_VER) && _MSC_VER < 1400) || defined(__alpha__) || defined(U_OSF) + // These machines and compilers don't fully support denormalized doubles, test(fmt, randomDouble(1e-292)); -#elif defined(OS390) || defined(OS400) + test(fmt, randomDouble(1e-100)); +#elif U_PF_OS390 <= U_PLATFORM && U_PLATFORM <= U_PF_OS400 + // i5/OS (OS/400) throws exceptions on denormalized numbers # if IEEE_754 - test(fmt, randomDouble(1e-78)); /*OS390 and OS400*/ + test(fmt, randomDouble(1e-78)); + test(fmt, randomDouble(1e-78)); + // #else we're using something like the old z/OS floating point. # endif #else - test(fmt, randomDouble(1e-323)); -#endif /* OS390 and OS400*/ -#if !defined(OS390) && !defined(OS400) + // This is a normal machine that can support IEEE754 denormalized doubles without throwing an error. + test(fmt, randomDouble(DBL_MIN)); /* Usually 2.2250738585072014e-308 */ test(fmt, randomDouble(1e-100)); -#elif IEEE_754 - test(fmt, randomDouble(1e-78)); /*OS390 and OS400*/ -#endif /* OS390 and OS400*/ +#endif } } @@ -225,8 +230,9 @@ void NumberFormatRoundTripTest::test(NumberFormat *fmt, const Formattable& value) { fmt->setMaximumFractionDigits(999); - if(fmt->getDynamicClassID() == DecimalFormat::getStaticClassID()) { - ((DecimalFormat *)fmt)->setRoundingIncrement(0.0); + DecimalFormat *df = dynamic_cast(fmt); + if(df != NULL) { + df->setRoundingIncrement(0.0); } UErrorCode status = U_ZERO_ERROR; UnicodeString s, s2, temp; @@ -283,8 +289,8 @@ NumberFormatRoundTripTest::test(NumberFormat *fmt, const Formattable& value) if (show) { errln(/*value.getString(temp) +*/ typeOf(value, temp) + " F> " + - escape(s) + " P> " + - /*n.getString(temp) +*/ typeOf(n, temp) + " F> " + + escape(s) + " P> " + (n.getType() == Formattable::kDouble ? n.getDouble() : (double)n.getLong()) + /*n.getString(temp) */ + typeOf(n, temp) + " F> " + escape(s2)); } }