diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/post.cc | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/src/post.cc b/src/post.cc index 18f84f7a..79add9b9 100644 --- a/src/post.cc +++ b/src/post.cc @@ -209,6 +209,35 @@ namespace { return string_value(post.reported_account()->name); } + value_t get_account_amount(call_scope_t& scope) + { + in_context_t<post_t> env(scope, "&v"); + + account_t * account = NULL; + if (env.has(0)) { + account_t * master = env->account; + while (master->parent) + master = master->parent; + + if (env.value_at(0).is_string()) + account = master->find_account(env.get<string>(0), false); + else if (env.value_at(0).is_mask()) + account = master->find_account_re(env.get<mask_t>(0).expr.str()); + } else { + account = env->reported_account(); + } + + if (! account) + throw_(std::runtime_error, _("Cannot locate referenced account")); + + DEBUG("post.account_amount", "Found account: " << account->fullname()); + + if (account->xdata().value.is_null()) + return 0L; + else + return account->xdata().value.simplified(); + } + value_t get_account_depth(post_t& post) { return long(post.reported_account()->depth); } @@ -227,6 +256,8 @@ expr_t::ptr_op_t post_t::lookup(const string& name) return WRAP_FUNCTOR(get_wrapper<&get_amount>); else if (name == "account") return WRAP_FUNCTOR(get_account); + else if (name == "account_amount") + return WRAP_FUNCTOR(get_account_amount); else if (name == "account_base") return WRAP_FUNCTOR(get_wrapper<&get_account_base>); break; |