summaryrefslogtreecommitdiff
path: root/walk.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2004-08-21 23:18:45 -0400
committerJohn Wiegley <johnw@newartisans.com>2004-08-21 23:18:45 -0400
commit6d5333b89618734e59853ba7da75b920ac40dae0 (patch)
tree3ddcc232a2c229a2ace5ca739ba7de3889fb6edc /walk.cc
parent3ff84b7363575c63129e5b7a5b142896b76dcf06 (diff)
downloadfork-ledger-6d5333b89618734e59853ba7da75b920ac40dae0.tar.gz
fork-ledger-6d5333b89618734e59853ba7da75b920ac40dae0.tar.bz2
fork-ledger-6d5333b89618734e59853ba7da75b920ac40dae0.zip
use value_t instead of balance_pair_t; gains for 10% binary, 2% textual
Diffstat (limited to 'walk.cc')
-rw-r--r--walk.cc17
1 files changed, 12 insertions, 5 deletions
diff --git a/walk.cc b/walk.cc
index 00e4213f..fff19645 100644
--- a/walk.cc
+++ b/walk.cc
@@ -55,9 +55,10 @@ void collapse_transactions::report_cumulative_subtotal()
assert(count > 1);
totals_account->total = subtotal;
- balance_t result;
+ value_t result;
format_t::compute_total(result, details_t(totals_account));
+#if 0
for (amounts_map::const_iterator i = result.amounts.begin();
i != result.amounts.end();
i++) {
@@ -69,6 +70,7 @@ void collapse_transactions::report_cumulative_subtotal()
(*handler)(total_xact);
}
+#endif
}
subtotal = 0;
@@ -78,8 +80,8 @@ void collapse_transactions::report_cumulative_subtotal()
void changed_value_transactions::operator()(transaction_t * xact)
{
if (last_xact) {
- balance_t prev_bal;
- balance_t cur_bal;
+ value_t prev_bal;
+ value_t cur_bal;
std::time_t current = xact ? xact->entry->date : std::time(NULL);
std::time_t prev_date = last_xact->entry->date;
@@ -89,13 +91,15 @@ void changed_value_transactions::operator()(transaction_t * xact)
format_t::compute_total(cur_bal, details_t(last_xact));
last_xact->entry->date = prev_date;
- if (balance_t diff = cur_bal - prev_bal) {
+ cur_bal -= prev_bal;
+ if (cur_bal) {
entry_t * entry = new entry_t;
entry_temps.push_back(entry);
entry->payee = "Commodities revalued";
entry->date = current;
+#if 0
for (amounts_map::const_iterator i = diff.amounts.begin();
i != diff.amounts.end();
i++) {
@@ -108,6 +112,7 @@ void changed_value_transactions::operator()(transaction_t * xact)
(*handler)(temp_xact);
}
+#endif
}
}
@@ -150,10 +155,11 @@ void subtotal_transactions::flush(const char * spec_fmt)
transaction_t temp((*i).first);
temp.entry = entry;
temp.total = (*i).second;
- balance_t result;
+ value_t result;
format_t::compute_total(result, details_t(&temp));
entry->date = start;
+#if 0
for (amounts_map::const_iterator j = result.amounts.begin();
j != result.amounts.end();
j++) {
@@ -165,6 +171,7 @@ void subtotal_transactions::flush(const char * spec_fmt)
(*handler)(xact);
}
+#endif
}
balances.clear();