mirror of
https://github.com/fmtlib/fmt.git
synced 2025-01-13 00:40:51 +00:00
Simplify fallback format
This commit is contained in:
parent
dce8e49b4f
commit
3813966497
@ -1002,9 +1002,9 @@ void fallback_format(Double d, int num_digits, bool binary32, buffer<char>& buf,
|
|||||||
// Shift numerator and denominator by an extra bit or two (if lower boundary
|
// Shift numerator and denominator by an extra bit or two (if lower boundary
|
||||||
// is closer) to make lower and upper integers. This eliminates multiplication
|
// is closer) to make lower and upper integers. This eliminates multiplication
|
||||||
// by 2 during later computations.
|
// by 2 during later computations.
|
||||||
int shift = (binary32 ? value.assign(static_cast<float>(d)) : value.assign(d))
|
const bool is_predecessor_closer =
|
||||||
? 2
|
binary32 ? value.assign(static_cast<float>(d)) : value.assign(d);
|
||||||
: 1;
|
int shift = is_predecessor_closer ? 2 : 1;
|
||||||
uint64_t significand = value.f << shift;
|
uint64_t significand = value.f << shift;
|
||||||
if (value.e >= 0) {
|
if (value.e >= 0) {
|
||||||
numerator.assign(significand);
|
numerator.assign(significand);
|
||||||
|
Loading…
Reference in New Issue
Block a user