summaryrefslogtreecommitdiff
path: root/src/report.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2009-11-05 14:27:58 -0500
committerJohn Wiegley <johnw@newartisans.com>2009-11-05 14:27:58 -0500
commit67ce33430c1f37f0fa7da62e5bd055c5a00b614d (patch)
tree3357a0a2fd100f8dbf65e01ae1272770852c3e23 /src/report.cc
parent15555d497f56e4b4d39e9a14f74b2c82cce52b90 (diff)
parent09ace752d604d5afce698f7cc240e1a83cee934d (diff)
downloadfork-ledger-67ce33430c1f37f0fa7da62e5bd055c5a00b614d.tar.gz
fork-ledger-67ce33430c1f37f0fa7da62e5bd055c5a00b614d.tar.bz2
fork-ledger-67ce33430c1f37f0fa7da62e5bd055c5a00b614d.zip
Merge branch 'next'
Diffstat (limited to 'src/report.cc')
-rw-r--r--src/report.cc27
1 files changed, 27 insertions, 0 deletions
diff --git a/src/report.cc b/src/report.cc
index e6f3ccb4..3b570682 100644
--- a/src/report.cc
+++ b/src/report.cc
@@ -313,6 +313,31 @@ value_t report_t::fn_price(call_scope_t& scope)
return args.value_at(0).price();
}
+value_t report_t::fn_account_total(call_scope_t& args)
+{
+ account_t * acct = NULL;
+ string name;
+ if (args[0].is_string()) {
+ name = args[0].as_string();
+ acct = session.journal->find_account(name, false);
+ }
+ else if (args[0].is_mask()) {
+ name = args[0].as_mask().expr.str();
+ acct = session.journal->find_account_re(name);
+ }
+ else {
+ throw_(std::runtime_error,
+ _("Expected string or mask for argument 1, but received %1")
+ << args[0].label());
+ }
+
+ if (! acct)
+ throw_(std::runtime_error,
+ _("Could not find an account matching ") << name);
+
+ return acct->amount();
+}
+
value_t report_t::fn_lot_date(call_scope_t& scope)
{
interactive_t args(scope, "v");
@@ -730,6 +755,8 @@ expr_t::ptr_op_t report_t::lookup(const symbol_t::kind_t kind,
return MAKE_FUNCTOR(report_t::fn_ansify_if);
else if (is_eq(p, "abs"))
return MAKE_FUNCTOR(report_t::fn_abs);
+ else if (is_eq(p, "account_total"))
+ return MAKE_FUNCTOR(report_t::fn_account_total);
break;
case 'b':