summaryrefslogtreecommitdiff
path: root/walk.h
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2008-07-26 04:08:55 -0400
committerJohn Wiegley <johnw@newartisans.com>2008-07-26 04:08:55 -0400
commit961b30926b3b9f2b3e9c1a99df3f25fea6b13118 (patch)
treef0f5efcc0b63f337c4838b8aad46dea2cd7926e4 /walk.h
parentee396957226e2273bc60ede7192c27038c432f24 (diff)
downloadfork-ledger-961b30926b3b9f2b3e9c1a99df3f25fea6b13118.tar.gz
fork-ledger-961b30926b3b9f2b3e9c1a99df3f25fea6b13118.tar.bz2
fork-ledger-961b30926b3b9f2b3e9c1a99df3f25fea6b13118.zip
--verify works again, but the memory totals at the end still need work.
Diffstat (limited to 'walk.h')
-rw-r--r--walk.h339
1 files changed, 252 insertions, 87 deletions
diff --git a/walk.h b/walk.h
index 67b0fe4d..4ac50df1 100644
--- a/walk.h
+++ b/walk.h
@@ -12,18 +12,19 @@
namespace ledger {
template <typename T>
-struct item_handler {
+struct item_handler : public noncopyable
+{
item_handler * handler;
- public:
+public:
item_handler() : handler(NULL) {
- DEBUG("ledger.memory.ctors", "ctor item_handler<T>");
+ TRACE_CTOR(item_handler, "");
}
item_handler(item_handler * _handler) : handler(_handler) {
- DEBUG("ledger.memory.ctors", "ctor item_handler<T>");
+ TRACE_CTOR(item_handler, "item_handler *");
}
virtual ~item_handler() {
- DEBUG("ledger.memory.dtors", "dtor item_handler<T>");
+ TRACE_DTOR(item_handler);
}
virtual void flush() {
@@ -37,10 +38,22 @@ struct item_handler {
};
template <typename T>
-class compare_items {
+class compare_items
+{
value_expr sort_order;
- public:
- compare_items(value_expr _sort_order) : sort_order(_sort_order) {}
+
+ compare_items();
+
+public:
+ compare_items(const compare_items& other) : sort_order(other.sort_order) {
+ TRACE_CTOR(compare_items, "copy");
+ }
+ compare_items(const value_expr& _sort_order) : sort_order(_sort_order) {
+ TRACE_CTOR(compare_items, "const value_expr&");
+ }
+ ~compare_items() throw() {
+ TRACE_DTOR(compare_items);
+ }
bool operator()(const T * left, const T * right);
};
@@ -79,7 +92,7 @@ bool compare_items<account_t>::operator()(const account_t * left,
#define TRANSACTION_COMPOUND 0x0040
#define TRANSACTION_MATCHES 0x0080
-struct transaction_xdata_t
+struct transaction_xdata_t : public noncopyable
{
value_t total;
value_t sort_value;
@@ -95,13 +108,13 @@ struct transaction_xdata_t
transaction_xdata_t()
: index(0), dflags(0),
account(NULL), ptr(NULL), component_xacts(NULL) {
- DEBUG("ledger.memory.ctors", "ctor transaction_xdata_t " << this);
+ TRACE_CTOR(transaction_xdata_t, "");
}
~transaction_xdata_t() {
- DEBUG("ledger.memory.dtors", "dtor transaction_xdata_t " << this);
+ TRACE_DTOR(transaction_xdata_t);
if (component_xacts)
- delete component_xacts;
+ checked_delete(component_xacts);
}
void remember_xact(transaction_t& xact) {
@@ -181,13 +194,13 @@ inline void walk_entries(entries_list& list,
class ignore_transactions : public item_handler<transaction_t>
{
- public:
+public:
virtual void operator()(transaction_t& xact) {}
};
class clear_transaction_xdata : public item_handler<transaction_t>
{
- public:
+public:
virtual void operator()(transaction_t& xact) {
if (xact.data) {
delete (transaction_xdata_t *) xact.data;
@@ -203,11 +216,18 @@ class truncate_entries : public item_handler<transaction_t>
transactions_list xacts;
- public:
+ truncate_entries();
+
+public:
truncate_entries(item_handler<transaction_t> * handler,
int _head_count, int _tail_count)
: item_handler<transaction_t>(handler),
- head_count(_head_count), tail_count(_tail_count) {}
+ head_count(_head_count), tail_count(_tail_count) {
+ TRACE_CTOR(truncate_entries, "item_handler<transaction_t> *, int, int");
+ }
+ virtual ~truncate_entries() {
+ TRACE_DTOR(truncate_entries);
+ }
virtual void flush();
virtual void operator()(transaction_t& xact) {
@@ -217,7 +237,7 @@ class truncate_entries : public item_handler<transaction_t>
class set_account_value : public item_handler<transaction_t>
{
- public:
+public:
set_account_value(item_handler<transaction_t> * handler = NULL)
: item_handler<transaction_t>(handler) {}
@@ -226,11 +246,18 @@ class set_account_value : public item_handler<transaction_t>
class push_to_transactions_list : public item_handler<transaction_t>
{
- public:
+ push_to_transactions_list();
+
+public:
transactions_list& xact_list;
push_to_transactions_list(transactions_list& _xact_list)
- : xact_list(_xact_list) {}
+ : xact_list(_xact_list) {
+ TRACE_CTOR(push_to_transactions_list, "transactions_list&");
+ }
+ virtual ~push_to_transactions_list() {
+ TRACE_DTOR(push_to_transactions_list);
+ }
virtual void operator()(transaction_t& xact) {
xact_list.push_back(&xact);
@@ -244,16 +271,26 @@ class sort_transactions : public item_handler<transaction_t>
transactions_deque transactions;
const value_expr sort_order;
- public:
+ sort_transactions();
+
+public:
sort_transactions(item_handler<transaction_t> * handler,
const value_expr& _sort_order)
: item_handler<transaction_t>(handler),
- sort_order(_sort_order) {}
-
+ sort_order(_sort_order) {
+ TRACE_CTOR(sort_transactions,
+ "item_handler<transaction_t> *, const value_expr&");
+ }
sort_transactions(item_handler<transaction_t> * handler,
const string& _sort_order)
: item_handler<transaction_t>(handler),
- sort_order(_sort_order) {}
+ sort_order(_sort_order) {
+ TRACE_CTOR(sort_transactions,
+ "item_handler<transaction_t> *, const string&");
+ }
+ virtual ~sort_transactions() {
+ TRACE_DTOR(sort_transactions);
+ }
virtual void post_accumulated_xacts();
@@ -270,16 +307,26 @@ class sort_transactions : public item_handler<transaction_t>
class sort_entries : public item_handler<transaction_t>
{
sort_transactions sorter;
- entry_t * last_entry;
+ entry_t * last_entry;
- public:
+ sort_entries();
+
+public:
sort_entries(item_handler<transaction_t> * handler,
const value_expr& _sort_order)
- : sorter(handler, _sort_order) {}
-
+ : sorter(handler, _sort_order) {
+ TRACE_CTOR(sort_entries,
+ "item_handler<transaction_t> *, const value_expr&");
+ }
sort_entries(item_handler<transaction_t> * handler,
const string& _sort_order)
- : sorter(handler, _sort_order) {}
+ : sorter(handler, _sort_order) {
+ TRACE_CTOR(sort_entries,
+ "item_handler<transaction_t> *, const string&");
+ }
+ virtual ~sort_entries() {
+ TRACE_DTOR(sort_entries);
+ }
virtual void flush() {
sorter.flush();
@@ -300,14 +347,25 @@ class filter_transactions : public item_handler<transaction_t>
{
item_predicate<transaction_t> pred;
- public:
+ filter_transactions();
+
+public:
filter_transactions(item_handler<transaction_t> * handler,
const value_expr& predicate)
- : item_handler<transaction_t>(handler), pred(predicate) {}
+ : item_handler<transaction_t>(handler), pred(predicate) {
+ TRACE_CTOR(filter_transactions,
+ "item_handler<transaction_t> *, const value_expr&");
+ }
filter_transactions(item_handler<transaction_t> * handler,
const string& predicate)
- : item_handler<transaction_t>(handler), pred(predicate) {}
+ : item_handler<transaction_t>(handler), pred(predicate) {
+ TRACE_CTOR(filter_transactions,
+ "item_handler<transaction_t> *, const string&");
+ }
+ virtual ~filter_transactions() {
+ TRACE_DTOR(filter_transactions);
+ }
virtual void operator()(transaction_t& xact) {
if (pred(xact)) {
@@ -321,16 +379,25 @@ class calc_transactions : public item_handler<transaction_t>
{
transaction_t * last_xact;
- public:
+ calc_transactions();
+
+public:
calc_transactions(item_handler<transaction_t> * handler)
- : item_handler<transaction_t>(handler), last_xact(NULL) {}
+ : item_handler<transaction_t>(handler), last_xact(NULL) {
+ TRACE_CTOR(calc_transactions, "item_handler<transaction_t> *");
+ }
+ virtual ~calc_transactions() {
+ TRACE_DTOR(calc_transactions);
+ }
virtual void operator()(transaction_t& xact);
};
class invert_transactions : public item_handler<transaction_t>
{
- public:
+ invert_transactions();
+
+public:
invert_transactions(item_handler<transaction_t> * handler)
: item_handler<transaction_t>(handler) {}
@@ -355,13 +422,17 @@ class collapse_transactions : public item_handler<transaction_t>
std::list<entry_t> entry_temps;
std::list<transaction_t> xact_temps;
- public:
+ collapse_transactions();
+
+public:
collapse_transactions(item_handler<transaction_t> * handler)
: item_handler<transaction_t>(handler), count(0),
last_entry(NULL), last_xact(NULL),
- totals_account(NULL, "<Total>") {}
-
- ~collapse_transactions() {
+ totals_account(NULL, "<Total>") {
+ TRACE_CTOR(collapse_transactions, "item_handler<transaction_t> *");
+ }
+ virtual ~collapse_transactions() {
+ TRACE_DTOR(collapse_transactions);
clear_entries_transactions(entry_temps);
}
@@ -380,14 +451,24 @@ class component_transactions : public item_handler<transaction_t>
{
item_predicate<transaction_t> pred;
- public:
+ component_transactions();
+
+public:
component_transactions(item_handler<transaction_t> * handler,
const value_expr& predicate)
- : item_handler<transaction_t>(handler), pred(predicate) {}
-
+ : item_handler<transaction_t>(handler), pred(predicate) {
+ TRACE_CTOR(component_transactions,
+ "item_handler<transaction_t> *, const value_expr&");
+ }
component_transactions(item_handler<transaction_t> * handler,
const string& predicate)
- : item_handler<transaction_t>(handler), pred(predicate) {}
+ : item_handler<transaction_t>(handler), pred(predicate) {
+ TRACE_CTOR(component_transactions,
+ "item_handler<transaction_t> *, const string&");
+ }
+ virtual ~component_transactions() throw() {
+ TRACE_DTOR(component_transactions);
+ }
virtual void operator()(transaction_t& xact);
};
@@ -397,11 +478,19 @@ class related_transactions : public item_handler<transaction_t>
transactions_list transactions;
bool also_matching;
- public:
+ related_transactions();
+
+public:
related_transactions(item_handler<transaction_t> * handler,
const bool _also_matching = false)
: item_handler<transaction_t>(handler),
- also_matching(_also_matching) {}
+ also_matching(_also_matching) {
+ TRACE_CTOR(related_transactions,
+ "item_handler<transaction_t> *, const bool");
+ }
+ virtual ~related_transactions() throw() {
+ TRACE_DTOR(related_transactions);
+ }
virtual void flush();
virtual void operator()(transaction_t& xact) {
@@ -422,13 +511,18 @@ class changed_value_transactions : public item_handler<transaction_t>
std::list<entry_t> entry_temps;
std::list<transaction_t> xact_temps;
- public:
+ changed_value_transactions();
+
+public:
changed_value_transactions(item_handler<transaction_t> * handler,
bool _changed_values_only)
: item_handler<transaction_t>(handler),
- changed_values_only(_changed_values_only), last_xact(NULL) {}
-
- ~changed_value_transactions() {
+ changed_values_only(_changed_values_only), last_xact(NULL) {
+ TRACE_CTOR(changed_value_transactions,
+ "item_handler<transaction_t> *, bool");
+ }
+ virtual ~changed_value_transactions() {
+ TRACE_DTOR(changed_value_transactions);
clear_entries_transactions(entry_temps);
}
@@ -447,42 +541,57 @@ class changed_value_transactions : public item_handler<transaction_t>
class subtotal_transactions : public item_handler<transaction_t>
{
- struct acct_value_t {
+ class acct_value_t
+ {
+ acct_value_t();
+
+ public:
account_t * account;
value_t value;
transactions_list components;
- acct_value_t(account_t * a) : account(a) {}
- acct_value_t(account_t * a, value_t& v) : account(a), value(v) {}
+ acct_value_t(account_t * a) : account(a) {
+ TRACE_CTOR(acct_value_t, "acount_t *");
+ }
+ acct_value_t(account_t * a, value_t& v) : account(a), value(v) {
+ TRACE_CTOR(acct_value_t, "acount_t *, value_t&");
+ }
acct_value_t(const acct_value_t& av)
- : account(av.account), value(av.value) {}
+ : account(av.account), value(av.value),
+ components(av.components) {
+ TRACE_CTOR(acct_value_t, "copy");
+ }
+ ~acct_value_t() throw() {
+ TRACE_DTOR(acct_value_t);
+ }
};
typedef std::map<string, acct_value_t> values_map;
typedef std::pair<string, acct_value_t> values_pair;
- protected:
+ subtotal_transactions();
+
+protected:
values_map values;
bool remember_components;
std::list<entry_t> entry_temps;
std::list<transaction_t> xact_temps;
- public:
+public:
datetime_t start;
datetime_t finish;
subtotal_transactions(item_handler<transaction_t> * handler,
bool _remember_components = false)
: item_handler<transaction_t>(handler),
- remember_components(_remember_components) {}
-#ifdef DEBUG_ENABLED
- subtotal_transactions(const subtotal_transactions&) {
- assert(false);
+ remember_components(_remember_components) {
+ TRACE_CTOR(subtotal_transactions,
+ "item_handler<transaction_t> *, bool");
}
-#endif
virtual ~subtotal_transactions() {
+ TRACE_DTOR(subtotal_transactions);
clear_entries_transactions(entry_temps);
}
@@ -510,18 +619,28 @@ class interval_transactions : public subtotal_transactions
transaction_t * last_xact;
bool started;
- public:
+ interval_transactions();
+
+public:
interval_transactions(item_handler<transaction_t> * _handler,
const interval_t& _interval,
bool remember_components = false)
: subtotal_transactions(_handler, remember_components),
- interval(_interval), last_xact(NULL), started(false) {}
-
+ interval(_interval), last_xact(NULL), started(false) {
+ TRACE_CTOR(interval_transactions,
+ "item_handler<transaction_t> *, const interval_t&, bool");
+ }
interval_transactions(item_handler<transaction_t> * _handler,
const string& _interval,
bool remember_components = false)
: subtotal_transactions(_handler, remember_components),
- interval(_interval), last_xact(NULL), started(false) {}
+ interval(_interval), last_xact(NULL), started(false) {
+ TRACE_CTOR(interval_transactions,
+ "item_handler<transaction_t> *, const string&, bool");
+ }
+ virtual ~interval_transactions() throw() {
+ TRACE_DTOR(interval_transactions);
+ }
void report_subtotal(const datetime_t& moment = datetime_t());
@@ -539,13 +658,18 @@ class by_payee_transactions : public item_handler<transaction_t>
typedef std::pair<string, subtotal_transactions *> payee_subtotals_pair;
payee_subtotals_map payee_subtotals;
- bool remember_components;
+ bool remember_components;
+
+ by_payee_transactions();
public:
by_payee_transactions(item_handler<transaction_t> * handler,
bool _remember_components = false)
: item_handler<transaction_t>(handler),
- remember_components(_remember_components) {}
+ remember_components(_remember_components) {
+ TRACE_CTOR(by_payee_transactions,
+ "item_handler<transaction_t> *, bool");
+ }
virtual ~by_payee_transactions();
virtual void flush();
@@ -557,11 +681,15 @@ class set_comm_as_payee : public item_handler<transaction_t>
std::list<entry_t> entry_temps;
std::list<transaction_t> xact_temps;
- public:
- set_comm_as_payee(item_handler<transaction_t> * handler)
- : item_handler<transaction_t>(handler) {}
+ set_comm_as_payee();
- ~set_comm_as_payee() {
+public:
+ set_comm_as_payee(item_handler<transaction_t> * handler)
+ : item_handler<transaction_t>(handler) {
+ TRACE_CTOR(set_comm_as_payee, "item_handler<transaction_t> *");
+ }
+ virtual ~set_comm_as_payee() {
+ TRACE_DTOR(set_comm_as_payee);
clear_entries_transactions(entry_temps);
}
@@ -573,11 +701,15 @@ class set_code_as_payee : public item_handler<transaction_t>
std::list<entry_t> entry_temps;
std::list<transaction_t> xact_temps;
- public:
- set_code_as_payee(item_handler<transaction_t> * handler)
- : item_handler<transaction_t>(handler) {}
+ set_code_as_payee();
- ~set_code_as_payee() {
+public:
+ set_code_as_payee(item_handler<transaction_t> * handler)
+ : item_handler<transaction_t>(handler) {
+ TRACE_CTOR(set_code_as_payee, "item_handler<transaction_t> *");
+ }
+ virtual ~set_code_as_payee() {
+ TRACE_DTOR(set_code_as_payee);
clear_entries_transactions(entry_temps);
}
@@ -588,10 +720,17 @@ class dow_transactions : public subtotal_transactions
{
transactions_list days_of_the_week[7];
- public:
+ dow_transactions();
+
+public:
dow_transactions(item_handler<transaction_t> * handler,
bool remember_components = false)
- : subtotal_transactions(handler, remember_components) {}
+ : subtotal_transactions(handler, remember_components) {
+ TRACE_CTOR(dow_transactions, "item_handler<transaction_t> *, bool");
+ }
+ virtual ~dow_transactions() throw() {
+ TRACE_DTOR(dow_transactions);
+ }
virtual void flush();
virtual void operator()(transaction_t& xact) {
@@ -601,7 +740,9 @@ class dow_transactions : public subtotal_transactions
class generate_transactions : public item_handler<transaction_t>
{
- protected:
+ generate_transactions();
+
+protected:
typedef std::pair<interval_t, transaction_t *> pending_xacts_pair;
typedef std::list<pending_xacts_pair> pending_xacts_list;
@@ -609,11 +750,14 @@ class generate_transactions : public item_handler<transaction_t>
std::list<entry_t> entry_temps;
std::list<transaction_t> xact_temps;
- public:
+public:
generate_transactions(item_handler<transaction_t> * handler)
- : item_handler<transaction_t>(handler) {}
+ : item_handler<transaction_t>(handler) {
+ TRACE_CTOR(dow_transactions, "item_handler<transaction_t> *");
+ }
- ~generate_transactions() {
+ virtual ~generate_transactions() {
+ TRACE_DTOR(generate_transactions);
clear_entries_transactions(entry_temps);
}
@@ -630,10 +774,18 @@ class budget_transactions : public generate_transactions
{
unsigned short flags;
- public:
+ budget_transactions();
+
+public:
budget_transactions(item_handler<transaction_t> * handler,
unsigned long _flags = BUDGET_BUDGETED)
- : generate_transactions(handler), flags(_flags) {}
+ : generate_transactions(handler), flags(_flags) {
+ TRACE_CTOR(budget_transactions,
+ "item_handler<transaction_t> *, unsigned long");
+ }
+ virtual ~budget_transactions() throw() {
+ TRACE_DTOR(budget_transactions);
+ }
void report_budget_items(const datetime_t& moment);
@@ -647,11 +799,19 @@ class forecast_transactions : public generate_transactions
public:
forecast_transactions(item_handler<transaction_t> * handler,
const value_expr& predicate)
- : generate_transactions(handler), pred(predicate) {}
-
+ : generate_transactions(handler), pred(predicate) {
+ TRACE_CTOR(forecast_transactions,
+ "item_handler<transaction_t> *, const value_expr&");
+ }
forecast_transactions(item_handler<transaction_t> * handler,
const string& predicate)
- : generate_transactions(handler), pred(predicate) {}
+ : generate_transactions(handler), pred(predicate) {
+ TRACE_CTOR(forecast_transactions,
+ "item_handler<transaction_t> *, const string&");
+ }
+ virtual ~forecast_transactions() throw() {
+ TRACE_DTOR(forecast_transactions);
+ }
virtual void add_transaction(const interval_t& period,
transaction_t& xact);
@@ -670,7 +830,7 @@ class forecast_transactions : public generate_transactions
#define ACCOUNT_HAS_NON_VIRTUALS 0x0008
#define ACCOUNT_HAS_UNB_VIRTUALS 0x0010
-struct account_xdata_t
+struct account_xdata_t : public noncopyable
{
value_t value;
value_t total;
@@ -680,7 +840,12 @@ struct account_xdata_t
unsigned int virtuals;
unsigned short dflags;
- account_xdata_t() : count(0), total_count(0), virtuals(0), dflags(0) {}
+ account_xdata_t() : count(0), total_count(0), virtuals(0), dflags(0) {
+ TRACE_CTOR(account_xdata_t, "");
+ }
+ ~account_xdata_t() throw() {
+ TRACE_DTOR(account_xdata_t);
+ }
};
inline bool account_has_xdata(const account_t& account) {
@@ -697,7 +862,7 @@ account_xdata_t& account_xdata(const account_t& account);
class clear_account_xdata : public item_handler<account_t>
{
- public:
+public:
virtual void operator()(account_t& acct) {
if (acct.data) {
delete (account_xdata_t *) acct.data;