summaryrefslogtreecommitdiff
path: root/src/xact.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/xact.cc')
-rw-r--r--src/xact.cc39
1 files changed, 39 insertions, 0 deletions
diff --git a/src/xact.cc b/src/xact.cc
index bd8a5955..175a1467 100644
--- a/src/xact.cc
+++ b/src/xact.cc
@@ -352,6 +352,33 @@ void xact_t::add_post(post_t * post)
}
namespace {
+ value_t get_magnitude(xact_t& xact) {
+ balance_t halfbal;
+ foreach (post_t * post, xact.posts)
+ if (post->amount.sign() > 0)
+ halfbal += post->amount.number();
+ return halfbal;
+ }
+
+ value_t get_idstring(xact_t& xact) {
+ std::ostringstream buf;
+ buf << *xact._date;
+ buf << xact.payee;
+
+ get_magnitude(xact).print(buf);
+
+ return string_value(buf.str());
+ }
+ value_t get_id(xact_t& xact) {
+ SHA1 sha;
+ sha.Reset();
+ sha << get_idstring(xact).as_string().c_str();
+
+ uint_least32_t message_digest[5];
+ sha.Result(message_digest);
+ return string_value(to_hex(message_digest));
+ }
+
value_t get_code(xact_t& xact) {
if (xact.code)
return string_value(*xact.code);
@@ -377,6 +404,18 @@ expr_t::ptr_op_t xact_t::lookup(const string& name)
return WRAP_FUNCTOR(get_wrapper<&get_code>);
break;
+ case 'i':
+ if (name == "id")
+ return WRAP_FUNCTOR(get_wrapper<&get_id>);
+ else if (name == "idstring")
+ return WRAP_FUNCTOR(get_wrapper<&get_idstring>);
+ break;
+
+ case 'm':
+ if (name == "magnitude")
+ return WRAP_FUNCTOR(get_wrapper<&get_magnitude>);
+ break;
+
case 'p':
if (name[1] == '\0' || name == "payee")
return WRAP_FUNCTOR(get_wrapper<&get_payee>);