diff options
-rw-r--r-- | src/report.h | 11 | ||||
-rw-r--r-- | src/xact.cc | 24 |
2 files changed, 33 insertions, 2 deletions
diff --git a/src/report.h b/src/report.h index c94cbb91..d4e592b8 100644 --- a/src/report.h +++ b/src/report.h @@ -197,7 +197,11 @@ public: OPTION(report_t, abbrev_len_); OPTION(report_t, account_); - OPTION(report_t, actual); // -L + + OPTION_(report_t, actual, DO() { // -L + parent->append_predicate("actual"); + }); + OPTION_(report_t, add_budget, DO() { parent->budget_flags = BUDGET_BUDGETED | BUDGET_UNBUDGETED; }); @@ -386,7 +390,10 @@ public: parent->prefix_to_period("quarterly"); }); - OPTION(report_t, real); // -R + OPTION_(report_t, real, DO() { // -R + parent->append_predicate("real"); + }); + OPTION(report_t, register_format_); OPTION(report_t, related); // -r OPTION(report_t, related_all); diff --git a/src/xact.cc b/src/xact.cc index 1942e175..24846cf2 100644 --- a/src/xact.cc +++ b/src/xact.cc @@ -80,6 +80,18 @@ namespace { return xact.has_flags(XACT_CALCULATED); } + value_t get_virtual(xact_t& xact) { + return xact.has_flags(XACT_VIRTUAL); + } + + value_t get_real(xact_t& xact) { + return ! xact.has_flags(XACT_VIRTUAL); + } + + value_t get_actual(xact_t& xact) { + return ! xact.has_flags(XACT_AUTO); + } + value_t get_entry(xact_t& xact) { return value_t(static_cast<scope_t *>(xact.entry)); } @@ -172,6 +184,8 @@ expr_t::ptr_op_t xact_t::lookup(const string& name) return WRAP_FUNCTOR(get_account); else if (name == "account_base") return WRAP_FUNCTOR(get_wrapper<&get_account_base>); + else if (name == "actual") + return WRAP_FUNCTOR(get_wrapper<&get_actual>); break; case 'c': @@ -188,6 +202,11 @@ expr_t::ptr_op_t xact_t::lookup(const string& name) return WRAP_FUNCTOR(get_wrapper<&get_entry>); break; + case 'r': + if (name == "real") + return WRAP_FUNCTOR(get_wrapper<&get_real>); + break; + case 'p': if (name == "payee") return WRAP_FUNCTOR(get_wrapper<&get_payee>); @@ -200,6 +219,11 @@ expr_t::ptr_op_t xact_t::lookup(const string& name) return WRAP_FUNCTOR(get_wrapper<&get_total_cost>); break; + case 'v': + if (name == "virtual") + return WRAP_FUNCTOR(get_wrapper<&get_virtual>); + break; + case 'x': if (name == "xact") return WRAP_FUNCTOR(get_wrapper<&get_this>); |