summaryrefslogtreecommitdiff
path: root/src/report.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/report.cc')
-rw-r--r--src/report.cc71
1 files changed, 48 insertions, 23 deletions
diff --git a/src/report.cc b/src/report.cc
index 5fff77c7..548d39df 100644
--- a/src/report.cc
+++ b/src/report.cc
@@ -289,7 +289,7 @@ void report_t::parse_query_args(const value_t& args, const string& whence)
normalize_period(); // it needs normalization
}
-}
+}
namespace {
struct posts_flusher
@@ -318,7 +318,7 @@ void report_t::posts_report(post_handler_ptr handler)
handler = chain_pre_post_handlers(handler, *this);
journal_posts_iterator walker(*session.journal.get());
- pass_down_posts(handler, walker);
+ pass_down_posts<journal_posts_iterator>(handler, walker);
if (! HANDLED(group_by_))
posts_flusher(handler, *this)(value_t());
@@ -334,7 +334,7 @@ void report_t::generate_report(post_handler_ptr handler)
HANDLED(head_) ?
static_cast<unsigned int>(HANDLER(head_).value.to_long()) : 50);
- pass_down_posts(handler, walker);
+ pass_down_posts<generate_posts_iterator>(handler, walker);
}
void report_t::xact_report(post_handler_ptr handler, xact_t& xact)
@@ -342,7 +342,7 @@ void report_t::xact_report(post_handler_ptr handler, xact_t& xact)
handler = chain_handlers(handler, *this);
xact_posts_iterator walker(xact);
- pass_down_posts(handler, walker);
+ pass_down_posts<xact_posts_iterator>(handler, walker);
xact.clear_xdata();
}
@@ -382,25 +382,34 @@ namespace {
report.HANDLER(display_total_).expr.mark_uncompiled();
report.HANDLER(revalued_total_).expr.mark_uncompiled();
- scoped_ptr<accounts_iterator> iter;
- if (! report.HANDLED(sort_)) {
- iter.reset(new basic_accounts_iterator(*report.session.journal->master));
- } else {
- expr_t sort_expr(report.HANDLER(sort_).str());
- sort_expr.set_context(&report);
- iter.reset(new sorted_accounts_iterator(*report.session.journal->master,
- sort_expr, report.HANDLED(flat)));
- }
-
if (report.HANDLED(display_)) {
DEBUG("report.predicate",
"Display predicate = " << report.HANDLER(display_).str());
- pass_down_accounts(handler, *iter.get(),
- predicate_t(report.HANDLER(display_).str(),
- report.what_to_keep()),
- report);
+ if (! report.HANDLED(sort_)) {
+ basic_accounts_iterator iter(*report.session.journal->master);
+ pass_down_accounts<basic_accounts_iterator>
+ (handler, iter, predicate_t(report.HANDLER(display_).str(),
+ report.what_to_keep()), report);
+ } else {
+ expr_t sort_expr(report.HANDLER(sort_).str());
+ sort_expr.set_context(&report);
+ sorted_accounts_iterator iter(*report.session.journal->master,
+ sort_expr, report.HANDLED(flat));
+ pass_down_accounts<sorted_accounts_iterator>
+ (handler, iter, predicate_t(report.HANDLER(display_).str(),
+ report.what_to_keep()), report);
+ }
} else {
- pass_down_accounts(handler, *iter.get());
+ if (! report.HANDLED(sort_)) {
+ basic_accounts_iterator iter(*report.session.journal->master);
+ pass_down_accounts<basic_accounts_iterator>(handler, iter);
+ } else {
+ expr_t sort_expr(report.HANDLER(sort_).str());
+ sort_expr.set_context(&report);
+ sorted_accounts_iterator iter(*report.session.journal->master,
+ sort_expr, report.HANDLED(flat));
+ pass_down_accounts<sorted_accounts_iterator>(handler, iter);
+ }
}
report.session.journal->clear_xdata();
@@ -428,7 +437,7 @@ void report_t::accounts_report(acct_handler_ptr handler)
// objects created within it during the call to pass_down_posts, which will
// be needed later by the pass_down_accounts.
journal_posts_iterator walker(*session.journal.get());
- pass_down_posts(chain, walker);
+ pass_down_posts<journal_posts_iterator>(chain, walker);
if (! HANDLED(group_by_))
accounts_flusher(handler, *this)(value_t());
@@ -439,7 +448,7 @@ void report_t::commodities_report(post_handler_ptr handler)
handler = chain_handlers(handler, *this);
posts_commodities_iterator walker(*session.journal.get());
- pass_down_posts(handler, walker);
+ pass_down_posts<posts_commodities_iterator>(handler, walker);
session.journal->clear_xdata();
}
@@ -613,6 +622,16 @@ value_t report_t::fn_floor(call_scope_t& args)
return args[0].floored();
}
+value_t report_t::fn_round(call_scope_t& args)
+{
+ return args[0].rounded();
+}
+
+value_t report_t::fn_unround(call_scope_t& args)
+{
+ return args[0].unrounded();
+}
+
value_t report_t::fn_abs(call_scope_t& args)
{
return args[0].abs();
@@ -648,7 +667,8 @@ value_t report_t::fn_quoted(call_scope_t& args)
std::ostringstream out;
out << '"';
- foreach (const char ch, args.get<string>(0)) {
+ string arg(args.get<string>(0));
+ foreach (const char ch, arg) {
if (ch == '"')
out << "\\\"";
else
@@ -663,7 +683,8 @@ value_t report_t::fn_join(call_scope_t& args)
{
std::ostringstream out;
- foreach (const char ch, args.get<string>(0)) {
+ string arg(args.get<string>(0));
+ foreach (const char ch, arg) {
if (ch != '\n')
out << ch;
else
@@ -1270,6 +1291,8 @@ expr_t::ptr_op_t report_t::lookup(const symbol_t::kind_t kind,
return MAKE_FUNCTOR(report_t::fn_rounded);
else if (is_eq(p, "red"))
return WRAP_FUNCTOR(fn_red);
+ else if (is_eq(p, "round"))
+ return MAKE_FUNCTOR(report_t::fn_round);
break;
case 's':
@@ -1322,6 +1345,8 @@ expr_t::ptr_op_t report_t::lookup(const symbol_t::kind_t kind,
case 'u':
if (is_eq(p, "underline"))
return WRAP_FUNCTOR(fn_underline);
+ else if (is_eq(p, "unround"))
+ return MAKE_FUNCTOR(report_t::fn_unround);
else if (is_eq(p, "unrounded"))
return MAKE_FUNCTOR(report_t::fn_unrounded);
break;