summaryrefslogtreecommitdiff
path: root/xact.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2008-08-02 16:23:58 -0400
committerJohn Wiegley <johnw@newartisans.com>2008-08-02 16:32:16 -0400
commite52a6a9bd8e2bbf3a497696eed735eb00a8b9dde (patch)
tree2eb460e8512c91af08ff5884b680d1a49fe0c743 /xact.cc
parent9a9e06554eb9f57be8c839fb0af49a0473614172 (diff)
downloadfork-ledger-e52a6a9bd8e2bbf3a497696eed735eb00a8b9dde.tar.gz
fork-ledger-e52a6a9bd8e2bbf3a497696eed735eb00a8b9dde.tar.bz2
fork-ledger-e52a6a9bd8e2bbf3a497696eed735eb00a8b9dde.zip
More infrastructure work toward getting journal objects to provide their own
information in an abstract manner.
Diffstat (limited to 'xact.cc')
-rw-r--r--xact.cc39
1 files changed, 20 insertions, 19 deletions
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<xact_t>(*scope.parent));
return xact.amount;
}
- value_t get_date(call_scope_t& scope)
- {
- xact_t& xact(downcast<xact_t>(*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<xact_t>(*scope.parent));
- return string_value(xact.entry->payee);
+ return xact.date();
}
value_t get_account(call_scope_t& scope)
{
xact_t& xact(downcast<xact_t>(*scope.parent));
+ long width = 0;
+ if (scope.size() == 1)
+ width = var_t<long>(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 (*Func)(xact_t&)>
+ value_t get_wrapper(call_scope_t& scope) {
+ return (*Func)(find_scope<xact_t>(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);
}