summaryrefslogtreecommitdiff
path: root/src/filters.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/filters.h')
-rw-r--r--src/filters.h57
1 files changed, 42 insertions, 15 deletions
diff --git a/src/filters.h b/src/filters.h
index 08dd18d5..2916857d 100644
--- a/src/filters.h
+++ b/src/filters.h
@@ -411,7 +411,7 @@ class collapse_posts : public item_handler<post_t>
xact_t * last_xact;
post_t * last_post;
temporaries_t temps;
- account_t& totals_account;
+ account_t * totals_account;
bool only_collapse_if_zero;
std::list<post_t *> component_posts;
report_t& report;
@@ -429,14 +429,18 @@ public:
display_predicate(_display_predicate),
only_predicate(_only_predicate), count(0),
last_xact(NULL), last_post(NULL),
- totals_account(temps.create_account(_("<Total>"))),
only_collapse_if_zero(_only_collapse_if_zero), report(_report) {
TRACE_CTOR(collapse_posts, "post_handler_ptr, ...");
+ create_accounts();
}
virtual ~collapse_posts() {
TRACE_DTOR(collapse_posts);
}
+ void create_accounts() {
+ totals_account = &temps.create_account(_("<Total>"));
+ }
+
virtual void flush() {
report_subtotal();
item_handler<post_t>::flush();
@@ -457,6 +461,7 @@ public:
last_post = NULL;
temps.clear();
+ create_accounts();
component_posts.clear();
item_handler<post_t>::clear();
@@ -505,12 +510,12 @@ class display_filter_posts : public item_handler<post_t>
bool show_rounding;
value_t last_display_total;
temporaries_t temps;
- account_t& rounding_account;
+ account_t * rounding_account;
display_filter_posts();
public:
- account_t& revalued_account;
+ account_t * revalued_account;
display_filter_posts(post_handler_ptr handler,
report_t& _report,
@@ -520,6 +525,11 @@ public:
TRACE_DTOR(display_filter_posts);
}
+ void create_accounts() {
+ rounding_account = &temps.create_account(_("<Adjustment>"));
+ revalued_account = &temps.create_account(_("<Revalued>"));
+ }
+
bool output_rounding(post_t& post);
virtual void operator()(post_t& post);
@@ -531,6 +541,7 @@ public:
last_display_total = value_t();
temps.clear();
+ create_accounts();
item_handler<post_t>::clear();
}
@@ -551,7 +562,7 @@ class changed_value_posts : public item_handler<post_t>
value_t last_total;
value_t repriced_total;
temporaries_t temps;
- account_t& revalued_account;
+ account_t * revalued_account;
account_t * gains_equity_account;
account_t * losses_equity_account;
@@ -570,6 +581,11 @@ public:
TRACE_DTOR(changed_value_posts);
}
+ void create_accounts() {
+ revalued_account = (display_filter ? display_filter->revalued_account :
+ &temps.create_account(_("<Revalued>")));
+ }
+
virtual void flush();
void output_revaluation(post_t& post, const date_t& current);
@@ -585,6 +601,7 @@ public:
last_total = value_t();
temps.clear();
+ create_accounts();
item_handler<post_t>::clear();
}
@@ -666,7 +683,7 @@ class interval_posts : public subtotal_posts
date_interval_t interval;
date_interval_t last_interval;
post_t * last_post;
- account_t& empty_account;
+ account_t * empty_account;
bool exact_periods;
bool generate_empty_posts;
@@ -681,16 +698,20 @@ public:
bool _generate_empty_posts = false)
: subtotal_posts(_handler, amount_expr), start_interval(_interval),
interval(start_interval), last_post(NULL),
- empty_account(temps.create_account(_("<None>"))),
exact_periods(_exact_periods),
generate_empty_posts(_generate_empty_posts) {
TRACE_CTOR(interval_posts,
"post_handler_ptr, expr_t&, date_interval_t, bool, bool");
+ create_accounts();
}
virtual ~interval_posts() throw() {
TRACE_DTOR(interval_posts);
}
+ void create_accounts() {
+ empty_account = &temps.create_account(_("<None>"));
+ }
+
void report_subtotal(const date_interval_t& interval);
virtual void flush() {
@@ -707,29 +728,34 @@ public:
last_interval = date_interval_t();
last_post = NULL;
- item_handler<post_t>::clear();
+ subtotal_posts::clear();
+ create_accounts();
}
};
class posts_as_equity : public subtotal_posts
{
post_t * last_post;
- account_t& equity_account;
+ account_t * equity_account;
account_t * balance_account;
posts_as_equity();
public:
posts_as_equity(post_handler_ptr _handler, expr_t& amount_expr)
- : subtotal_posts(_handler, amount_expr),
- equity_account(temps.create_account(_("Equity"))) {
+ : subtotal_posts(_handler, amount_expr) {
TRACE_CTOR(posts_as_equity, "post_handler_ptr, expr_t&");
- balance_account = equity_account.find_account(_("Opening Balances"));
+ create_accounts();
}
virtual ~posts_as_equity() throw() {
TRACE_DTOR(posts_as_equity);
}
+ void create_accounts() {
+ equity_account = &temps.create_account(_("Equity"));
+ balance_account = equity_account->find_account(_("Opening Balances"));
+ }
+
void report_subtotal();
virtual void flush() {
@@ -739,7 +765,8 @@ public:
virtual void clear() {
last_post = NULL;
- item_handler<post_t>::clear();
+ subtotal_posts::clear();
+ create_accounts();
}
};
@@ -837,7 +864,7 @@ public:
for (int i = 0; i < 7; i++)
days_of_the_week[i].clear();
- item_handler<post_t>::clear();
+ subtotal_posts::clear();
}
};
@@ -928,7 +955,7 @@ class forecast_posts : public generate_posts
virtual void clear() {
pred.mark_uncompiled();
- item_handler<post_t>::clear();
+ generate_posts::clear();
}
};