diff options
author | John Wiegley <johnw@newartisans.com> | 2010-06-12 14:58:44 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2010-06-12 14:58:44 -0400 |
commit | 0555e7f61ef14ec667f8ba611e60fd96133a9676 (patch) | |
tree | c8b853c67515613d832820bd8471099793403a11 | |
parent | 28c65cda512135bde36542351533941b019b6ee8 (diff) | |
download | fork-ledger-0555e7f61ef14ec667f8ba611e60fd96133a9676.tar.gz fork-ledger-0555e7f61ef14ec667f8ba611e60fd96133a9676.tar.bz2 fork-ledger-0555e7f61ef14ec667f8ba611e60fd96133a9676.zip |
Improved value expression function 'commodity'
Without arguments -- and in a posting -- it is equivalent to
"commodity(amount)". Otherwise, it returns the commodity symbol of its
argument.
-rw-r--r-- | src/post.cc | 23 | ||||
-rw-r--r-- | src/report.cc | 8 | ||||
-rw-r--r-- | src/report.h | 1 |
3 files changed, 24 insertions, 8 deletions
diff --git a/src/post.cc b/src/post.cc index 2a8abddc..fa8bab4f 100644 --- a/src/post.cc +++ b/src/post.cc @@ -197,13 +197,20 @@ namespace { return post.has_xdata() && post.xdata().has_flags(POST_EXT_DIRECT_AMT); } - value_t get_commodity(post_t& post) { - if (post.has_xdata() && - post.xdata().has_flags(POST_EXT_COMPOUND)) - return string_value(post.xdata().compound_value.to_amount() - .commodity().symbol()); - else - return string_value(post.amount.commodity().symbol()); + value_t get_commodity(call_scope_t& scope) + { + in_context_t<post_t> env(scope, "&v"); + if (env.has(0)) { + return string_value(env.value_at(0).to_amount().commodity().symbol()); + } else { + post_t& post(find_scope<post_t>(scope)); + if (post.has_xdata() && + post.xdata().has_flags(POST_EXT_COMPOUND)) + return string_value(post.xdata().compound_value.to_amount() + .commodity().symbol()); + else + return string_value(post.amount.commodity().symbol()); + } } value_t get_commodity_is_primary(post_t& post) { @@ -427,7 +434,7 @@ expr_t::ptr_op_t post_t::lookup(const symbol_t::kind_t kind, else if (name == "calculated") return WRAP_FUNCTOR(get_wrapper<&get_is_calculated>); else if (name == "commodity") - return WRAP_FUNCTOR(get_wrapper<&get_commodity>); + return WRAP_FUNCTOR(&get_commodity); break; case 'd': diff --git a/src/report.cc b/src/report.cc index c5cdb843..9656d57a 100644 --- a/src/report.cc +++ b/src/report.cc @@ -686,6 +686,12 @@ value_t report_t::fn_price(call_scope_t& scope) return args.value_at(0).price(); } +value_t report_t::fn_commodity(call_scope_t& scope) +{ + in_context_t<post_t> env(scope, "v"); + return string_value(env.value_at(0).to_amount().commodity().symbol()); +} + value_t report_t::fn_lot_date(call_scope_t& scope) { interactive_t args(scope, "v"); @@ -1172,6 +1178,8 @@ expr_t::ptr_op_t report_t::lookup(const symbol_t::kind_t kind, case 'c': if (is_eq(p, "cyan")) return WRAP_FUNCTOR(fn_cyan); + else if (is_eq(p, "commodity")) + return MAKE_FUNCTOR(report_t::fn_commodity); break; case 'd': diff --git a/src/report.h b/src/report.h index f1a213c1..082c204b 100644 --- a/src/report.h +++ b/src/report.h @@ -160,6 +160,7 @@ public: value_t fn_ansify_if(call_scope_t& scope); value_t fn_percent(call_scope_t& scope); value_t fn_price(call_scope_t& scope); + value_t fn_commodity(call_scope_t& scope); value_t fn_lot_date(call_scope_t& scope); value_t fn_lot_price(call_scope_t& scope); value_t fn_lot_tag(call_scope_t& scope); |