From a5abe5d95cb8a8015913be9748a9661f3e1fbda8 Mon Sep 17 00:00:00 2001 From: Victor Zverovich Date: Sun, 13 Oct 2019 13:16:09 -0700 Subject: [PATCH] Handle negative exponent and nonnegative power --- include/fmt/format-inl.h | 16 +++++++++++----- test/grisu-test.cc | 1 + 2 files changed, 12 insertions(+), 5 deletions(-) diff --git a/include/fmt/format-inl.h b/include/fmt/format-inl.h index 894b104e..30de39b2 100644 --- a/include/fmt/format-inl.h +++ b/include/fmt/format-inl.h @@ -960,25 +960,31 @@ FMT_FUNC void fallback_format(Double v, buffer& buf, int& exp10) { upper_store.assign(1); upper_store <<= fp_value.e + shift; upper = &upper_store; - } else { - upper = &lower; } denominator.assign_pow10(exp10); denominator <<= 1; - } else { + } else if (exp10 < 0) { numerator.assign_pow10(-exp10); lower.assign(numerator); if (shift != 0) { upper_store.assign(numerator); upper_store <<= 1; upper = &upper_store; - } else { - upper = &lower; } numerator *= significand; denominator.assign(1); denominator <<= 1 - fp_value.e; + } else { + numerator.assign(significand); + denominator.assign_pow10(exp10); + denominator <<= 1 - fp_value.e; + lower.assign(1); + if (shift != 0) { + upper_store.assign(1 << shift); + upper = &upper_store; + } } + if (!upper) upper = &lower; // Invariant: fp_value == (numerator / denominator) * pow(10, exp10). bool even = (fp_value.f & 1) == 0; int num_digits = 0; diff --git a/test/grisu-test.cc b/test/grisu-test.cc index 80121055..6b03b9c7 100644 --- a/test/grisu-test.cc +++ b/test/grisu-test.cc @@ -63,4 +63,5 @@ TEST(GrisuTest, Fallback) { fmt::format("{}", 5.423717798060526e+125)); EXPECT_EQ("1.372371880954233e-288", fmt::format("{}", 1.372371880954233e-288)); + EXPECT_EQ("55388492.622190244", fmt::format("{}", 55388492.622190244)); }