summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2004-09-24 23:22:48 -0400
committerJohn Wiegley <johnw@newartisans.com>2004-09-24 23:22:48 -0400
commitfbd8fd2caf25a06b4433b799e6f6fb2b4ed3bf70 (patch)
tree5c1ecc79c46ac1793e2b48cfac9aa32bcd02a116
parenteda733a56eae156044a879ab2ce1a15a0cf0eef8 (diff)
downloadfork-ledger-fbd8fd2caf25a06b4433b799e6f6fb2b4ed3bf70.tar.gz
fork-ledger-fbd8fd2caf25a06b4433b799e6f6fb2b4ed3bf70.tar.bz2
fork-ledger-fbd8fd2caf25a06b4433b799e6f6fb2b4ed3bf70.zip
fixed printing of amounts that have a null commodity (was always precision 0)
-rw-r--r--amount.cc18
-rw-r--r--config.cc2
2 files changed, 15 insertions, 5 deletions
diff --git a/amount.cc b/amount.cc
index a01ac9f9..98f7cf63 100644
--- a/amount.cc
+++ b/amount.cc
@@ -541,27 +541,37 @@ std::ostream& operator<<(std::ostream& _out, const amount_t& amt)
// Ensure the value is rounded to the commodity's precision before
// outputting it. NOTE: `rquotient' is used here as a temp variable!
- commodity_t& commodity(amt.commodity());
+ commodity_t& commodity(amt.commodity());
+ unsigned short precision;
- if (commodity.precision < amt.quantity->prec) {
+ if (commodity == *commodity_t::null_commodity) {
+ mpz_ui_pow_ui(divisor, 10, amt.quantity->prec);
+ mpz_tdiv_qr(quotient, remainder, MPZ(amt.quantity), divisor);
+ precision = amt.quantity->prec;
+ }
+ else if (commodity.precision < amt.quantity->prec) {
mpz_round(rquotient, MPZ(amt.quantity), amt.quantity->prec,
commodity.precision);
mpz_ui_pow_ui(divisor, 10, commodity.precision);
mpz_tdiv_qr(quotient, remainder, rquotient, divisor);
+ precision = commodity.precision;
}
else if (commodity.precision > amt.quantity->prec) {
mpz_ui_pow_ui(divisor, 10, commodity.precision - amt.quantity->prec);
mpz_mul(rquotient, MPZ(amt.quantity), divisor);
mpz_ui_pow_ui(divisor, 10, commodity.precision);
mpz_tdiv_qr(quotient, remainder, rquotient, divisor);
+ precision = commodity.precision;
}
else if (amt.quantity->prec) {
mpz_ui_pow_ui(divisor, 10, amt.quantity->prec);
mpz_tdiv_qr(quotient, remainder, MPZ(amt.quantity), divisor);
+ precision = amt.quantity->prec;
}
else {
mpz_set(quotient, MPZ(amt.quantity));
mpz_set_ui(remainder, 0);
+ precision = 0;
}
if (mpz_sgn(quotient) < 0 || mpz_sgn(remainder) < 0) {
@@ -626,10 +636,10 @@ std::ostream& operator<<(std::ostream& _out, const amount_t& amt)
}
}
- if (commodity.precision) {
+ if (precision) {
out << ((commodity.flags & COMMODITY_STYLE_EUROPEAN) ? ',' : '.');
- out.width(commodity.precision);
+ out.width(precision);
out.fill('0');
char * p = mpz_get_str(NULL, 10, rquotient);
diff --git a/config.cc b/config.cc
index dc789602..d393c269 100644
--- a/config.cc
+++ b/config.cc
@@ -525,7 +525,7 @@ OPT_BEGIN(total_expr, "T:") {
} OPT_END(total_expr);
OPT_BEGIN(value_data, "j") {
- config.amount_expr = "S" + config.amount_expr;
+ config.amount_expr = "S" + config.amount_expr;
config.format_string = config.plot_value_format;
} OPT_END(value_data);