diff options
author | John Wiegley <johnw@newartisans.com> | 2009-02-09 14:51:45 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2009-02-09 14:51:45 -0400 |
commit | 3ee3b8f327fa1943dba4ef6043559186b26f86b4 (patch) | |
tree | 31809a41826e69aa5ae3c3ed9789d2fb4a2fad52 /src/report.cc | |
parent | e0fab726c6e9e5e9ecc5b8cd6a7be2e8233826a6 (diff) | |
download | ledger-3ee3b8f327fa1943dba4ef6043559186b26f86b4.tar.gz ledger-3ee3b8f327fa1943dba4ef6043559186b26f86b4.tar.bz2 ledger-3ee3b8f327fa1943dba4ef6043559186b26f86b4.zip |
Recompile the amount_expr before summing account totals.
Diffstat (limited to 'src/report.cc')
-rw-r--r-- | src/report.cc | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/src/report.cc b/src/report.cc index e510ac8d..9966a339 100644 --- a/src/report.cc +++ b/src/report.cc @@ -107,12 +107,16 @@ void report_t::entry_report(xact_handler_ptr handler, entry_t& entry) void report_t::sum_all_accounts() { + expr_t& expr(HANDLER(amount_).expr); + expr.set_context(this); + session_xacts_iterator walker(session); pass_down_xacts (chain_xact_handlers(*this, xact_handler_ptr(new set_account_value), false), walker); - session.master->calculate_sums(HANDLER(amount_).expr, *this); + expr.mark_uncompiled(); // recompile, throw away xact_t bindings + session.master->calculate_sums(expr); } void report_t::accounts_report(acct_handler_ptr handler) |