summaryrefslogtreecommitdiff
path: root/src/xact.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/xact.cc')
-rw-r--r--src/xact.cc153
1 files changed, 26 insertions, 127 deletions
diff --git a/src/xact.cc b/src/xact.cc
index 556a0776..66c08f5b 100644
--- a/src/xact.cc
+++ b/src/xact.cc
@@ -36,48 +36,32 @@
namespace ledger {
-bool xact_t::use_effective_date = false;
-
-xact_t::~xact_t()
+optional<date_t> xact_t::actual_date() const
{
- TRACE_DTOR(xact_t);
+ optional<date_t> date = item_t::actual_date();
+ if (! date && entry)
+ return entry->actual_date();
+ return date;
}
-date_t xact_t::actual_date() const
+optional<date_t> xact_t::effective_date() const
{
- if (! _date && entry)
- return entry->actual_date();
- return *_date;
+ optional<date_t> date = item_t::effective_date();
+ if (! date && entry)
+ return entry->effective_date();
+ return date;
}
-date_t xact_t::effective_date() const
+item_t::state_t xact_t::state() const
{
- if (! _date_eff && entry)
- return entry->effective_date();
- return *_date_eff;
+ state_t entry_state = entry->state();
+ if ((_state == UNCLEARED && entry_state != UNCLEARED) ||
+ (_state == PENDING && entry_state == CLEARED))
+ return entry_state;
+ return _state;
}
namespace {
- value_t get_state(xact_t& xact) {
- return long(xact.state);
- }
-
- value_t state_uncleared(call_scope_t&) {
- return 0L;
- }
-
- value_t state_cleared(call_scope_t&) {
- return 1L;
- }
-
- value_t state_pending(call_scope_t&) {
- return 2L;
- }
-
- value_t get_date(xact_t& xact) {
- return xact.date();
- }
-
value_t get_code(xact_t& xact) {
if (xact.entry->code)
return string_value(*xact.entry->code);
@@ -85,22 +69,6 @@ namespace {
return string_value(empty_string);
}
- value_t get_status(xact_t& xact) {
- xact_t::state_t status;
- xact.entry->get_state(&status);
- return long(status);
- }
- value_t get_cleared(xact_t& xact) {
- xact_t::state_t status;
- xact.entry->get_state(&status);
- return status == xact_t::CLEARED;
- }
- value_t get_pending(xact_t& xact) {
- xact_t::state_t status;
- xact.entry->get_state(&status);
- return status == xact_t::PENDING;
- }
-
value_t get_payee(xact_t& xact) {
return string_value(xact.entry->payee);
}
@@ -125,10 +93,6 @@ namespace {
return xact.cost ? *xact.cost : xact.amount;
}
- value_t get_note(xact_t& xact) {
- return string_value(xact.note ? *xact.note : empty_string);
- }
-
value_t get_account(call_scope_t& scope)
{
xact_t& xact(downcast<xact_t>(*scope.parent));
@@ -153,22 +117,6 @@ namespace {
return string_value(xact.reported_account()->name);
}
- value_t get_beg_pos(xact_t& xact) {
- return long(xact.beg_pos);
- }
-
- value_t get_beg_line(xact_t& xact) {
- return long(xact.beg_line);
- }
-
- value_t get_end_pos(xact_t& xact) {
- return long(xact.end_pos);
- }
-
- value_t get_end_line(xact_t& xact) {
- return long(xact.end_line);
- }
-
template <value_t (*Func)(xact_t&)>
value_t get_wrapper(call_scope_t& scope) {
return (*Func)(find_scope<xact_t>(scope));
@@ -188,68 +136,29 @@ expr_t::ptr_op_t xact_t::lookup(const string& name)
break;
case 'c':
- if (name == "cleared")
- return WRAP_FUNCTOR(get_wrapper<&get_cleared>);
- else if (name == "code")
+ if (name == "code")
return WRAP_FUNCTOR(get_wrapper<&get_code>);
break;
- case 'd':
- if (name[1] == '\0' || name == "date")
- return WRAP_FUNCTOR(get_wrapper<&get_date>);
- break;
-
- case 'f':
- if (name.find("fmt_") == 0) {
- switch (name[4]) {
- case 'A':
- return WRAP_FUNCTOR(get_account);
- case 'D':
- return WRAP_FUNCTOR(get_wrapper<&get_date>);
- case 'P':
- return WRAP_FUNCTOR(get_wrapper<&get_payee>);
- }
- }
- break;
-
- case 'n':
- if (name == "note")
- return WRAP_FUNCTOR(get_wrapper<&get_note>);
- break;
-
case 'p':
- if (name == "pending")
- return WRAP_FUNCTOR(get_wrapper<&get_pending>);
- else if (name == "payee")
+ if (name == "payee")
return WRAP_FUNCTOR(get_wrapper<&get_payee>);
break;
- case 's':
- if (name == "status")
- return WRAP_FUNCTOR(get_wrapper<&get_status>);
- break;
-
case 't':
if (name[1] == '\0' || name == "total")
return WRAP_FUNCTOR(get_wrapper<&get_total>);
break;
-
- case 'u':
- if (name == "uncleared")
- return expr_t::op_t::wrap_value(1L);
- break;
-
- case 'X':
- if (name[1] == '\0')
- return WRAP_FUNCTOR(get_wrapper<&get_cleared>);
- break;
-
- case 'Y':
- if (name[1] == '\0')
- return WRAP_FUNCTOR(get_wrapper<&get_pending>);
- break;
}
+
+#if 0
+ // jww (2008-09-19): I don't think we can lookup in entry, because
+ // that means the functor returned would be expecting an entry to be
+ // passed to it, rather than a transaction.
return entry->lookup(name);
+#else
+ return item_t::lookup(name);
+#endif
}
bool xact_t::valid() const
@@ -259,11 +168,6 @@ bool xact_t::valid() const
return false;
}
- if (state != UNCLEARED && state != CLEARED && state != PENDING) {
- DEBUG("ledger.validate", "xact_t: state is bad");
- return false;
- }
-
xacts_list::const_iterator i =
std::find(entry->xacts.begin(),
entry->xacts.end(), this);
@@ -287,11 +191,6 @@ bool xact_t::valid() const
return false;
}
- if (flags() & ~0x003f) {
- DEBUG("ledger.validate", "xact_t: flags are bad");
- return false;
- }
-
return true;
}