summaryrefslogtreecommitdiff
path: root/src/filters.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2015-08-04 14:33:03 -0700
committerJohn Wiegley <johnw@newartisans.com>2015-08-04 14:33:03 -0700
commita3e946f90f902600819f64217c8cd98c72bb21ba (patch)
treed7f0de1c234b457ce608c38d71040bca4cff43eb /src/filters.cc
parent947a46ebebd141e928a9fcebb584e34df4e210a7 (diff)
parentfbba9adc16c515632a5009d2ec88c9fcab532676 (diff)
downloadledger-a3e946f90f902600819f64217c8cd98c72bb21ba.tar.gz
ledger-a3e946f90f902600819f64217c8cd98c72bb21ba.tar.bz2
ledger-a3e946f90f902600819f64217c8cd98c72bb21ba.zip
Merge remote-tracking branch 'origin/master' into next
Diffstat (limited to 'src/filters.cc')
-rw-r--r--src/filters.cc33
1 files changed, 26 insertions, 7 deletions
diff --git a/src/filters.cc b/src/filters.cc
index b6530c04..d9fb64b0 100644
--- a/src/filters.cc
+++ b/src/filters.cc
@@ -448,16 +448,20 @@ void collapse_posts::report_subtotal()
DEBUG("filters.collapse", "Pseudo-xact date = " << *xact._date);
DEBUG("filters.collapse", "earliest date = " << earliest_date);
DEBUG("filters.collapse", "latest date = " << latest_date);
+
+ foreach (totals_map::value_type& pat, totals) {
+ handle_value(/* value= */ pat.second,
+ /* account= */ &temps.create_account(pat.first),
+ /* xact= */ &xact,
+ /* temps= */ temps,
+ /* handler= */ handler,
+ /* date= */ latest_date,
+ /* act_date_p= */ false);
+ }
- handle_value(/* value= */ subtotal,
- /* account= */ totals_account,
- /* xact= */ &xact,
- /* temps= */ temps,
- /* handler= */ handler,
- /* date= */ latest_date,
- /* act_date_p= */ false);
}
+ totals.clear();
component_posts.clear();
last_xact = NULL;
@@ -466,6 +470,20 @@ void collapse_posts::report_subtotal()
count = 0;
}
+value_t& collapse_posts::find_totals(account_t* account)
+{
+ unsigned short depth=3;
+
+ if(depth==0)
+ return totals[_("<Total>")];
+
+ if(account->depth==depth)
+ return totals[account->fullname()];
+
+ //else recurse
+ return find_totals(account->parent);
+}
+
void collapse_posts::operator()(post_t& post)
{
// If we've reached a new xact, report on the subtotal
@@ -475,6 +493,7 @@ void collapse_posts::operator()(post_t& post)
report_subtotal();
post.add_to_value(subtotal, amount_expr);
+ post.add_to_value(find_totals(post.account), amount_expr);
component_posts.push_back(&post);