summaryrefslogtreecommitdiff
path: root/entry.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 /entry.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 'entry.cc')
-rw-r--r--entry.cc31
1 files changed, 15 insertions, 16 deletions
diff --git a/entry.cc b/entry.cc
index 287f6555..e9b932fe 100644
--- a/entry.cc
+++ b/entry.cc
@@ -357,17 +357,23 @@ void entry_t::add_xact(xact_t * xact)
}
namespace {
- value_t get_date(call_scope_t& scope)
- {
- entry_t& entry(downcast<entry_t>(*scope.parent));
+ value_t get_date(entry_t& entry) {
return entry.date();
}
- value_t get_payee(call_scope_t& scope)
+ value_t get_payee(entry_t& entry)
{
- entry_t& entry(downcast<entry_t>(*scope.parent));
return string_value(entry.payee);
}
+
+ typedef value_t (*entry_func_t)(entry_t&);
+
+ template <entry_func_t Func>
+ value_t get_wrapper(call_scope_t& scope)
+ {
+ xact_t& xact(downcast<xact_t>(*scope.parent));
+ return (*Func)(*xact.entry);
+ }
}
expr_t::ptr_op_t entry_t::lookup(const string& name)
@@ -375,21 +381,14 @@ expr_t::ptr_op_t entry_t::lookup(const string& name)
switch (name[0]) {
case 'd':
if (name[1] == '\0' || name == "date")
- return WRAP_FUNCTOR(bind(get_date, _1));
+ return WRAP_FUNCTOR(get_wrapper<&get_date>);
break;
case 'p':
if (name[1] == '\0' || name == "payee")
- return WRAP_FUNCTOR(bind(get_payee, _1));
+ return WRAP_FUNCTOR(get_wrapper<&get_payee>);
break;
}
-
-#if 0
- // jww (2008-07-29): Should it go to the containing journal next, or to the
- // session?
- return entry->lookup(name);
-#else
return expr_t::ptr_op_t();
-#endif
}
bool entry_t::valid() const
@@ -465,10 +464,10 @@ void auto_entry_t::extend_entry(entry_base_t& entry, bool post)
}
}
-void extend_entry_base(journal_t * journal, entry_base_t& entry, bool post)
+void extend_entry_base(journal_t * journal, entry_base_t& base, bool post)
{
foreach (auto_entry_t * entry, journal->auto_entries)
- entry->extend_entry(*entry, post);
+ entry->extend_entry(base, post);
}
} // namespace ledger