From e52a6a9bd8e2bbf3a497696eed735eb00a8b9dde Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Sat, 2 Aug 2008 16:23:58 -0400 Subject: More infrastructure work toward getting journal objects to provide their own information in an abstract manner. --- xact.cc | 39 ++++++++++++++++++++------------------- 1 file changed, 20 insertions(+), 19 deletions(-) (limited to 'xact.cc') diff --git a/xact.cc b/xact.cc index 6fb0d636..8c9014f4 100644 --- a/xact.cc +++ b/xact.cc @@ -32,6 +32,7 @@ #include "xact.h" #include "journal.h" #include "account.h" +#include "format.h" namespace ledger { @@ -57,32 +58,31 @@ date_t xact_t::effective_date() const } namespace { - value_t get_amount(call_scope_t& scope) + value_t get_amount(xact_t& xact) { - xact_t& xact(downcast(*scope.parent)); return xact.amount; } - value_t get_date(call_scope_t& scope) - { - xact_t& xact(downcast(*scope.parent)); - return xact.entry->date(); - } - - value_t get_payee(call_scope_t& scope) + value_t get_date(xact_t& xact) { - xact_t& xact(downcast(*scope.parent)); - return string_value(xact.entry->payee); + return xact.date(); } value_t get_account(call_scope_t& scope) { xact_t& xact(downcast(*scope.parent)); + long width = 0; + if (scope.size() == 1) + width = var_t(scope, 0); + // jww (2008-08-02): Accept a width here so that we can abbreviate the // string. string name = xact.account->fullname(); + if (width > 2) + name = format_t::truncate(name, width - 2, true); + if (xact.has_flags(XACT_VIRTUAL)) { if (xact.must_balance()) name = string("[") + name + "]"; @@ -92,11 +92,16 @@ namespace { return string_value(name); } - value_t get_account_base(call_scope_t& scope) + value_t get_account_base(xact_t& xact) { assert(false); return NULL_VALUE; } + + template + value_t get_wrapper(call_scope_t& scope) { + return (*Func)(find_scope(scope)); + } } expr_t::ptr_op_t xact_t::lookup(const string& name) @@ -104,15 +109,15 @@ expr_t::ptr_op_t xact_t::lookup(const string& name) switch (name[0]) { case 'a': if (name[1] == '\0' || name == "amount") - return WRAP_FUNCTOR(get_amount); + return WRAP_FUNCTOR(get_wrapper<&get_amount>); else if (name == "account") return WRAP_FUNCTOR(get_account); else if (name == "account_base") - return WRAP_FUNCTOR(get_account_base); + return WRAP_FUNCTOR(get_wrapper<&get_account_base>); break; case 'd': if (name[1] == '\0' || name == "date") - return WRAP_FUNCTOR(get_date); + return WRAP_FUNCTOR(get_wrapper<&get_date>); break; case 'f': if (name.find("fmt_") == 0) { @@ -120,10 +125,6 @@ expr_t::ptr_op_t xact_t::lookup(const string& name) return WRAP_FUNCTOR(get_account); } break; - case 'p': - if (name[1] == '\0' || name == "payee") - return WRAP_FUNCTOR(get_payee); - break; } return entry->lookup(name); } -- cgit v1.2.3