summaryrefslogtreecommitdiff
path: root/lib/utfcpp/v4/source/utf8/cpp11.h
diff options
context:
space:
mode:
authorMax Nikulin <manikulin@gmail.com>2024-07-08 17:17:30 +0700
committerJohn Wiegley <johnw@newartisans.com>2024-08-05 08:35:14 -0700
commite6dae78c033ea970a459b1a0ccc2f1310d1bff96 (patch)
tree510dc67c111f786f3a2ecdb861b4602c73a04e64 /lib/utfcpp/v4/source/utf8/cpp11.h
parent064012a0d8c18aac253de79154175400fe7ad9cc (diff)
downloadfork-ledger-e6dae78c033ea970a459b1a0ccc2f1310d1bff96.tar.gz
fork-ledger-e6dae78c033ea970a459b1a0ccc2f1310d1bff96.tar.bz2
fork-ledger-e6dae78c033ea970a459b1a0ccc2f1310d1bff96.zip
Fix denominator of roundto result
Multiprecision rational created from a double value may have large power of 2 denominator since fractional decimal numbers can not be represented as binary floating point numbers. It leads to failed assertion when result is compared to a value converted directly from strings. Use integer multiprecision arithmetics to round numbers to ensure proper denominator. Inspired by python gmpy2 package <https://github.com/aleaxit/gmpy/blob/3e4564ae9d/src/gmpy2_mpq_misc.c#L315> The change makes `roundto` symmetric for positive/negative arguments. Halves are rounded to nearest even. Rounded away from zero are discussed in #1663 and it may be achieved with minimal modification. - See #2329 - Closes #1983
Diffstat (limited to 'lib/utfcpp/v4/source/utf8/cpp11.h')
0 files changed, 0 insertions, 0 deletions