summaryrefslogtreecommitdiff
path: root/src/account.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2012-05-10 04:01:16 -0500
committerJohn Wiegley <johnw@newartisans.com>2012-05-10 04:01:16 -0500
commit2bc14c3919ad58d25a348574ac2de5dfa05ee3ee (patch)
tree2b04b4c98a3c61e7fe67adc10b17b8bbf3b6feb2 /src/account.cc
parent3122182c48f5fb3da437860440bb7ab1b64cc32b (diff)
parentc0fa144ca586bfc3d48d7f2512bb90ebdde148df (diff)
downloadfork-ledger-2bc14c3919ad58d25a348574ac2de5dfa05ee3ee.tar.gz
fork-ledger-2bc14c3919ad58d25a348574ac2de5dfa05ee3ee.tar.bz2
fork-ledger-2bc14c3919ad58d25a348574ac2de5dfa05ee3ee.zip
Merge branch 't/checkout_cleared' into next
Diffstat (limited to 'src/account.cc')
-rw-r--r--src/account.cc10
1 files changed, 9 insertions, 1 deletions
diff --git a/src/account.cc b/src/account.cc
index 206e2350..1ea13330 100644
--- a/src/account.cc
+++ b/src/account.cc
@@ -309,6 +309,10 @@ namespace {
return (! account.self_details().latest_checkout.is_not_a_date_time() ?
value_t(account.self_details().latest_checkout) : NULL_VALUE);
}
+ value_t get_latest_checkout_cleared(account_t& account)
+ {
+ return account.self_details().latest_checkout_cleared;
+ }
template <value_t (*Func)(account_t&)>
value_t get_wrapper(call_scope_t& args) {
@@ -405,6 +409,8 @@ expr_t::ptr_op_t account_t::lookup(const symbol_t::kind_t kind,
return WRAP_FUNCTOR(get_wrapper<&get_latest>);
else if (fn_name == "latest_checkout")
return WRAP_FUNCTOR(get_wrapper<&get_latest_checkout>);
+ else if (fn_name == "latest_checkout_cleared")
+ return WRAP_FUNCTOR(get_wrapper<&get_latest_checkout_cleared>);
break;
case 'n':
@@ -662,8 +668,10 @@ void account_t::xdata_t::details_t::update(post_t& post,
earliest_checkin = *post.checkin;
if (post.checkout && (latest_checkout.is_not_a_date_time() ||
- *post.checkout > latest_checkout))
+ *post.checkout > latest_checkout)) {
latest_checkout = *post.checkout;
+ latest_checkout_cleared = post.state() == item_t::CLEARED;
+ }
if (post.state() == item_t::CLEARED) {
posts_cleared_count++;