summaryrefslogtreecommitdiff
path: root/walk.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2004-08-29 23:32:29 -0400
committerJohn Wiegley <johnw@newartisans.com>2004-08-29 23:32:29 -0400
commit63367e3aac062a7b55a3ba5c36a6c7fffbb6e2cc (patch)
tree6af161c7d0a7ca78a26f8b1f1f57426acddf9be9 /walk.cc
parent2d62f7b633bdaa39c650bb67425514cf1e66a4dd (diff)
downloadfork-ledger-63367e3aac062a7b55a3ba5c36a6c7fffbb6e2cc.tar.gz
fork-ledger-63367e3aac062a7b55a3ba5c36a6c7fffbb6e2cc.tar.bz2
fork-ledger-63367e3aac062a7b55a3ba5c36a6c7fffbb6e2cc.zip
the amount/balance/value logic is now a library, completely separate from ledger
Diffstat (limited to 'walk.cc')
-rw-r--r--walk.cc136
1 files changed, 70 insertions, 66 deletions
diff --git a/walk.cc b/walk.cc
index 0fadd1e6..a8111597 100644
--- a/walk.cc
+++ b/walk.cc
@@ -11,43 +11,43 @@ void sort_transactions::flush()
for (std::deque<transaction_t *>::iterator i = transactions.begin();
i != transactions.end();
i++)
- (*handler)(*i);
+ (*handler)(**i);
transactions.clear();
item_handler<transaction_t>::flush();
}
-void calc_transactions::operator()(transaction_t * xact)
+void calc_transactions::operator()(transaction_t& xact)
{
- if (! xact->data)
- xact->data = new transaction_data_t;
+ if (! xact.data)
+ xact.data = new transaction_data_t;
if (last_xact && last_xact->data) {
- XACT_DATA(xact)->total += XACT_DATA(last_xact)->total;
- XACT_DATA(xact)->index = XACT_DATA(last_xact)->index + 1;
+ XACT_DATA_(xact)->total += XACT_DATA(last_xact)->total;
+ XACT_DATA_(xact)->index = XACT_DATA(last_xact)->index + 1;
} else {
- XACT_DATA(xact)->index = 0;
+ XACT_DATA_(xact)->index = 0;
}
if (inverted) {
- xact->amount.negate();
- if (xact->cost)
- xact->cost->negate();
+ xact.amount.negate();
+ if (xact.cost)
+ xact.cost->negate();
}
- if (! (XACT_DATA(xact)->dflags & TRANSACTION_NO_TOTAL))
- XACT_DATA(xact)->total += *xact;
+ if (! (XACT_DATA_(xact)->dflags & TRANSACTION_NO_TOTAL))
+ add_transaction_to(xact, XACT_DATA_(xact)->total);
(*handler)(xact);
if (inverted) {
- xact->amount.negate();
- if (xact->cost)
- xact->cost->negate();
+ xact.amount.negate();
+ if (xact.cost)
+ xact.cost->negate();
}
- last_xact = xact;
+ last_xact = &xact;
}
@@ -65,7 +65,7 @@ static void handle_value(const value_t& value, account_t * account,
transaction_t * xact = new transaction_t(account);
temps.push_back(xact);
- xact->entry = entry;
+ xact->entry = entry;
switch (value.type) {
case value_t::BOOLEAN:
xact->amount = *((bool *) value.data);
@@ -87,7 +87,7 @@ static void handle_value(const value_t& value, account_t * account,
XACT_DATA(xact)->dflags |= flags;
}
- (*handler)(xact);
+ (*handler)(*xact);
break;
}
@@ -114,7 +114,7 @@ static void handle_value(const value_t& value, account_t * account,
XACT_DATA(xact)->dflags |= flags;
}
- (*handler)(xact);
+ (*handler)(*xact);
}
break;
@@ -127,7 +127,7 @@ static void handle_value(const value_t& value, account_t * account,
void collapse_transactions::report_cumulative_subtotal()
{
if (count == 1) {
- (*handler)(last_xact);
+ (*handler)(*last_xact);
} else {
assert(count > 1);
@@ -135,7 +135,7 @@ void collapse_transactions::report_cumulative_subtotal()
totals_account->data = new account_data_t;
ACCT_DATA(totals_account)->total = subtotal;
value_t result;
- format_t::compute_total(result, details_t(totals_account));
+ format_t::compute_total(result, details_t(*totals_account));
handle_value(result, totals_account, last_entry, 0, xact_temps, handler);
}
@@ -143,44 +143,45 @@ void collapse_transactions::report_cumulative_subtotal()
count = 0;
}
-void changed_value_transactions::operator()(transaction_t * xact)
+void changed_value_transactions::output_diff(const std::time_t current)
{
- if (last_xact) {
- 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;
+ value_t prev_bal;
+ value_t cur_bal;
+ std::time_t prev_date = last_xact->entry->date;
- format_t::compute_total(prev_bal, details_t(last_xact));
+ format_t::compute_total(prev_bal, details_t(*last_xact));
- last_xact->entry->date = current;
- format_t::compute_total(cur_bal, details_t(last_xact));
- last_xact->entry->date = prev_date;
+ last_xact->entry->date = current;
+ format_t::compute_total(cur_bal, details_t(*last_xact));
+ last_xact->entry->date = prev_date;
- cur_bal -= prev_bal;
- if (cur_bal) {
- entry_t * entry = new entry_t;
- entry_temps.push_back(entry);
+ 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;
+ entry->payee = "Commodities revalued";
+ entry->date = current;
- handle_value(cur_bal, NULL, entry, TRANSACTION_NO_TOTAL, xact_temps,
- handler);
- }
+ handle_value(cur_bal, NULL, entry, TRANSACTION_NO_TOTAL, xact_temps,
+ handler);
}
+}
- if (xact) {
- if (changed_values_only) {
- if (! xact->data)
- xact->data = new transaction_data_t;
- XACT_DATA(xact)->dflags |= TRANSACTION_DISPLAYED;
- }
+void changed_value_transactions::operator()(transaction_t& xact)
+{
+ if (last_xact)
+ output_diff(xact.entry->date);
- (*handler)(xact);
+ if (changed_values_only) {
+ if (! xact.data)
+ xact.data = new transaction_data_t;
+ XACT_DATA_(xact)->dflags |= TRANSACTION_DISPLAYED;
}
- last_xact = xact;
+ (*handler)(xact);
+
+ last_xact = &xact;
}
void subtotal_transactions::flush(const char * spec_fmt)
@@ -218,7 +219,7 @@ void subtotal_transactions::flush(const char * spec_fmt)
std::auto_ptr<transaction_data_t> xact_data(new transaction_data_t);
temp.data = xact_data.get();
((transaction_data_t *) temp.data)->total = (*i).second;
- format_t::compute_total(result, details_t(&temp));
+ format_t::compute_total(result, details_t(temp));
}
temp.data = NULL;
}
@@ -232,28 +233,31 @@ void subtotal_transactions::flush(const char * spec_fmt)
item_handler<transaction_t>::flush();
}
-void subtotal_transactions::operator()(transaction_t * xact)
+void subtotal_transactions::operator()(transaction_t& xact)
{
if (balances.size() == 0) {
- start = finish = xact->entry->date;
+ start = finish = xact.entry->date;
} else {
- if (std::difftime(xact->entry->date, start) < 0)
- start = xact->entry->date;
- if (std::difftime(xact->entry->date, finish) > 0)
- finish = xact->entry->date;
+ if (std::difftime(xact.entry->date, start) < 0)
+ start = xact.entry->date;
+ if (std::difftime(xact.entry->date, finish) > 0)
+ finish = xact.entry->date;
}
- balances_map::iterator i = balances.find(xact->account);
- if (i == balances.end())
- balances.insert(balances_pair(xact->account, *xact));
- else
- (*i).second += *xact;
+ balances_map::iterator i = balances.find(xact.account);
+ if (i == balances.end()) {
+ balance_pair_t temp;
+ add_transaction_to(xact, temp);
+ balances.insert(balances_pair(xact.account, temp));
+ } else {
+ add_transaction_to(xact, (*i).second);
+ }
}
-void interval_transactions::operator()(transaction_t * xact)
+void interval_transactions::operator()(transaction_t& xact)
{
std::time_t quant = interval.increment(begin);
- if (std::difftime(xact->entry->date, quant) > 0) {
+ if (std::difftime(xact.entry->date, quant) > 0) {
if (last_xact) {
start = begin;
finish = quant;
@@ -261,7 +265,7 @@ void interval_transactions::operator()(transaction_t * xact)
}
if (! interval.seconds) {
- struct std::tm * desc = std::localtime(&xact->entry->date);
+ struct std::tm * desc = std::localtime(&xact.entry->date);
if (interval.years)
desc->tm_mon = 0;
desc->tm_mday = 1;
@@ -272,7 +276,7 @@ void interval_transactions::operator()(transaction_t * xact)
}
std::time_t temp;
- while (std::difftime(xact->entry->date,
+ while (std::difftime(xact.entry->date,
temp = interval.increment(quant)) > 0)
quant = temp;
begin = quant;
@@ -280,7 +284,7 @@ void interval_transactions::operator()(transaction_t * xact)
subtotal_transactions::operator()(xact);
- last_xact = xact;
+ last_xact = &xact;
}
void dow_transactions::flush()
@@ -289,7 +293,7 @@ void dow_transactions::flush()
for (std::deque<transaction_t *>::iterator d = days_of_the_week[i].begin();
d != days_of_the_week[i].end();
d++)
- subtotal_transactions::operator()(*d);
+ subtotal_transactions::operator()(**d);
subtotal_transactions::flush("%As");
days_of_the_week[i].clear();
}