summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2012-11-06 12:49:09 -0800
committerJohn Wiegley <johnw@newartisans.com>2012-11-06 12:49:09 -0800
commit3a766aa7c5e58f65833966b4ca1a1d261b647b1b (patch)
tree245130564aa228c57d6b135154cdca7b15c45ee2
parentab887ad7d7e9ebaa1f874862b1649329a7019cd1 (diff)
parenta6d40ada1f33ebce5ed55ddd2d54a187a1f70c59 (diff)
downloadfork-ledger-3a766aa7c5e58f65833966b4ca1a1d261b647b1b.tar.gz
fork-ledger-3a766aa7c5e58f65833966b4ca1a1d261b647b1b.tar.bz2
fork-ledger-3a766aa7c5e58f65833966b4ca1a1d261b647b1b.zip
Merge pull request #104 from csrhodes/next
justification
-rw-r--r--src/filters.cc8
-rw-r--r--src/print.cc13
2 files changed, 12 insertions, 9 deletions
diff --git a/src/filters.cc b/src/filters.cc
index f5694133..5e2bf983 100644
--- a/src/filters.cc
+++ b/src/filters.cc
@@ -530,9 +530,11 @@ bool display_filter_posts::output_rounding(post_t& post)
}
// Allow the posting to be displayed if:
- // 1. It's display_amount would display as non-zero
- // 2. The --empty option was specified
- // 3. The account of the posting is <Revalued>
+ // 1. Its display_amount would display as non-zero, or
+ // 2. The --empty option was specified, or
+ // 3. a) The account of the posting is <Revalued>, and
+ // b) the revalued option is specified, and
+ // c) the --no-rounding option is not specified.
if (post.account == revalued_account) {
if (show_rounding)
diff --git a/src/print.cc b/src/print.cc
index 79d83161..a4a0bc6f 100644
--- a/src/print.cc
+++ b/src/print.cc
@@ -203,9 +203,15 @@ namespace {
(static_cast<std::string::size_type>(account_width) -
static_cast<std::string::size_type>(name.length()));
+ std::size_t amount_width =
+ (report.HANDLED(amount_width_) ?
+ lexical_cast<std::size_t>(report.HANDLER(amount_width_).str()) :
+ 12);
string amt;
if (post->amount_expr) {
- amt = post->amount_expr->text();
+ std::ostringstream amt_str;
+ justify(amt_str, post->amount_expr->text(), amount_width, true);
+ amt = amt_str.str();
}
else if (count == 2 && index == 2 &&
post_has_simple_amount(*post) &&
@@ -218,11 +224,6 @@ namespace {
// first.
}
else {
- std::size_t amount_width =
- (report.HANDLED(amount_width_) ?
- lexical_cast<std::size_t>(report.HANDLER(amount_width_).str()) :
- 12);
-
std::ostringstream amt_str;
value_t(post->amount).print(amt_str, static_cast<int>(amount_width),
-1, AMOUNT_PRINT_RIGHT_JUSTIFY |