summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2010-06-12 14:58:44 -0400
committerJohn Wiegley <johnw@newartisans.com>2010-06-12 14:58:44 -0400
commit0555e7f61ef14ec667f8ba611e60fd96133a9676 (patch)
treec8b853c67515613d832820bd8471099793403a11
parent28c65cda512135bde36542351533941b019b6ee8 (diff)
downloadfork-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.cc23
-rw-r--r--src/report.cc8
-rw-r--r--src/report.h1
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);