summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2010-05-22 20:50:43 -0400
committerJohn Wiegley <johnw@newartisans.com>2010-05-22 21:35:03 -0400
commit9557a9d955f4272ac4ad7b727af18ab388b1f92e (patch)
tree84ce926764f70555d027a163decadcbfbf975c9d
parenta7c28aa20057525a9247d0ae69eb063b53b21811 (diff)
downloadfork-ledger-9557a9d955f4272ac4ad7b727af18ab388b1f92e.tar.gz
fork-ledger-9557a9d955f4272ac4ad7b727af18ab388b1f92e.tar.bz2
fork-ledger-9557a9d955f4272ac4ad7b727af18ab388b1f92e.zip
A minor fix to transaction auto-balancing
It allows transactions like the following to auto-balance: 1999/08/16 Sell AAPL Assets:Broker $585 Expense:Broker:Commissions $15 Assets:Broker -10 AAPL {$30} @ $60 Income:Capital Gains
-rw-r--r--src/xact.cc85
1 files changed, 40 insertions, 45 deletions
diff --git a/src/xact.cc b/src/xact.cc
index 3c2505af..f63835c9 100644
--- a/src/xact.cc
+++ b/src/xact.cc
@@ -172,44 +172,8 @@ bool xact_base_t::finalize()
add_post(null_post);
}
- if (null_post != NULL) {
- // If one post has no value at all, its value will become the inverse of
- // the rest. If multiple commodities are involved, multiple posts are
- // generated to balance them all.
-
- DEBUG("xact.finalize", "there was a null posting");
-
- if (balance.is_balance()) {
- bool first = true;
- const balance_t& bal(balance.as_balance());
- foreach (const balance_t::amounts_map::value_type& pair, bal.amounts) {
- if (first) {
- null_post->amount = pair.second.negated();
- null_post->add_flags(POST_CALCULATED);
- first = false;
- } else {
- post_t * p = new post_t(null_post->account, pair.second.negated(),
- ITEM_GENERATED | POST_CALCULATED);
- p->set_state(null_post->state());
- add_post(p);
- }
- }
- }
- else if (balance.is_amount()) {
- null_post->amount = balance.as_amount().negated();
- null_post->add_flags(POST_CALCULATED);
- }
- else if (balance.is_long()) {
- null_post->amount = amount_t(- balance.as_long());
- null_post->add_flags(POST_CALCULATED);
- }
- else if (! balance.is_null() && ! balance.is_realzero()) {
- throw_(balance_error, _("Transaction does not balance"));
- }
- balance = NULL_VALUE;
- }
- else if (balance.is_balance() &&
- balance.as_balance().amounts.size() == 2) {
+ if (balance.is_balance() &&
+ balance.as_balance().amounts.size() == 2) {
// When an xact involves two different commodities (regardless of how
// many posts there are) determine the conversion ratio by dividing the
// total value of one commodity by the total value of the other. This
@@ -293,12 +257,6 @@ bool xact_base_t::finalize()
}
}
- // Now that the post list has its final form, calculate the balance once
- // more in terms of total cost, accounting for any possible gain/loss
- // amounts.
-
- DEBUG("xact.finalize", "resolved balance = " << balance);
-
posts_list copy(posts);
foreach (post_t * post, copy) {
@@ -340,7 +298,44 @@ bool xact_base_t::finalize()
}
}
- DEBUG("xact.finalize", "final balance = " << balance);
+ if (null_post != NULL) {
+ // If one post has no value at all, its value will become the inverse of
+ // the rest. If multiple commodities are involved, multiple posts are
+ // generated to balance them all.
+
+ DEBUG("xact.finalize", "there was a null posting");
+
+ if (balance.is_balance()) {
+ bool first = true;
+ const balance_t& bal(balance.as_balance());
+ foreach (const balance_t::amounts_map::value_type& pair, bal.amounts) {
+ if (first) {
+ null_post->amount = pair.second.negated();
+ null_post->add_flags(POST_CALCULATED);
+ first = false;
+ } else {
+ post_t * p = new post_t(null_post->account, pair.second.negated(),
+ ITEM_GENERATED | POST_CALCULATED);
+ p->set_state(null_post->state());
+ add_post(p);
+ }
+ }
+ }
+ else if (balance.is_amount()) {
+ null_post->amount = balance.as_amount().negated();
+ null_post->add_flags(POST_CALCULATED);
+ }
+ else if (balance.is_long()) {
+ null_post->amount = amount_t(- balance.as_long());
+ null_post->add_flags(POST_CALCULATED);
+ }
+ else if (! balance.is_null() && ! balance.is_realzero()) {
+ throw_(balance_error, _("Transaction does not balance"));
+ }
+ balance = NULL_VALUE;
+
+ }
+ DEBUG("xact.finalize", "resolved balance = " << balance);
if (! balance.is_null() && ! balance.is_zero()) {
add_error_context(item_context(*this, _("While balancing transaction")));