diff options
author | John Wiegley <johnw@newartisans.com> | 2008-08-02 16:23:58 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2008-08-02 16:32:16 -0400 |
commit | e52a6a9bd8e2bbf3a497696eed735eb00a8b9dde (patch) | |
tree | 2eb460e8512c91af08ff5884b680d1a49fe0c743 /entry.cc | |
parent | 9a9e06554eb9f57be8c839fb0af49a0473614172 (diff) | |
download | fork-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.cc | 31 |
1 files changed, 15 insertions, 16 deletions
@@ -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 |