diff options
author | John Wiegley <johnw@newartisans.com> | 2009-02-27 13:58:30 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2009-02-27 13:58:30 -0400 |
commit | f7f07310f4c6b717dcc276b4a14b3fbfbaebdf27 (patch) | |
tree | 0ea2f16087e232d69052b53a0a176d3818af3fe8 /src/amount.cc | |
parent | 5e6c95e348bc85525c841a56d7467d39d8ee2ace (diff) | |
download | fork-ledger-f7f07310f4c6b717dcc276b4a14b3fbfbaebdf27.tar.gz fork-ledger-f7f07310f4c6b717dcc276b4a14b3fbfbaebdf27.tar.bz2 fork-ledger-f7f07310f4c6b717dcc276b4a14b3fbfbaebdf27.zip |
Be smarter about trimming off trailing zeroes
Diffstat (limited to 'src/amount.cc')
-rw-r--r-- | src/amount.cc | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/src/amount.cc b/src/amount.cc index 82d9b41b..70ffd603 100644 --- a/src/amount.cc +++ b/src/amount.cc @@ -565,8 +565,8 @@ namespace { void stream_out_mpq(std::ostream& out, mpq_t quant, amount_t::precision_t prec, - bool no_trailing_zeroes = false, - const optional<commodity_t&>& comm = none) + int zeros_prec = -1, + const optional<commodity_t&>& comm = none) { char * buf = NULL; try { @@ -587,7 +587,7 @@ namespace { DEBUG("amount.convert", "mpfr_print = " << buf << " (precision " << prec << ")"); - if (no_trailing_zeroes) { + if (zeros_prec >= 0) { int index = std::strlen(buf); int point = 0; for (int i = 0; i < index; i++) { @@ -597,9 +597,9 @@ namespace { } } if (point > 0) { - while (--index >= point && buf[index] == '0') + while (--index >= (point + 1 + zeros_prec) && buf[index] == '0') buf[index] = '\0'; - if (index >= point && buf[index] == '.') + if (index >= (point + zeros_prec) && buf[index] == '.') buf[index] = '\0'; } } @@ -1024,7 +1024,8 @@ void amount_t::print(std::ostream& _out) const out << " "; } - stream_out_mpq(out, MP(quantity), display_precision(), ! comm, comm); + stream_out_mpq(out, MP(quantity), display_precision(), + comm ? commodity().precision() : 0, comm); if (comm.has_flags(COMMODITY_STYLE_SUFFIXED)) { if (comm.has_flags(COMMODITY_STYLE_SEPARATED)) |