From a13a6d645e6b5c2a444cfc1cce20d56f0b400320 Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Fri, 20 Apr 2007 23:49:25 +0000 Subject: Optimized XML auto-doc memory usage --- xml.cc | 62 ++++++++++++++++++++++++++++++++++++-------------------------- 1 file changed, 36 insertions(+), 26 deletions(-) (limited to 'xml.cc') diff --git a/xml.cc b/xml.cc index b4be437f..f35a9134 100644 --- a/xml.cc +++ b/xml.cc @@ -158,13 +158,13 @@ int node_t::set_name(const char * _name) return name_id; } -node_t * node_t::lookup_child(const char * _name) +node_t * node_t::lookup_child(const char * _name) const { int id = document->lookup_name_id(_name); return lookup_child(id); } -node_t * node_t::lookup_child(const string& _name) +node_t * node_t::lookup_child(const string& _name) const { int id = document->lookup_name_id(_name); return lookup_child(id); @@ -405,22 +405,20 @@ node_t * amount_node_t::children() const node_t * transaction_node_t::children() const { - if (! _children) { - terminal_node_t * account_node = - new terminal_node_t(document, const_cast(this)); - account_node->set_name("account"); - account_node->set_text(transaction->account->fullname()); - } return parent_node_t::children(); } -node_t * transaction_node_t::lookup_child(int _name_id) +node_t * transaction_node_t::lookup_child(int _name_id) const { - if (_name_id == payee_id) { + if (_name_id == entry_node_t::payee_id) { payee_virtual_node = new terminal_node_t(document); payee_virtual_node->set_text(transaction->entry->payee); return payee_virtual_node; } + else if (_name_id == journal_node_t::account_id) { + return new account_node_t(document, transaction->account, + const_cast(this)); + } return NULL; } @@ -429,31 +427,41 @@ value_t transaction_node_t::to_value() const return transaction->amount; } +int entry_node_t::code_id = -1; +int entry_node_t::payee_id = -1; + node_t * entry_node_t::children() const { - if (! _children) { - if (! entry->code.empty()) { - terminal_node_t * code_node = - new terminal_node_t(document, const_cast(this)); - code_node->set_name("code"); - code_node->set_text(entry->code); - } - - if (! entry->payee.empty()) { - terminal_node_t * payee_node = - new terminal_node_t(document, const_cast(this)); - payee_node->set_name("payee"); - payee_node->set_text(entry->payee); - } - + if (! _children) for (transactions_list::iterator i = entry->transactions.begin(); i != entry->transactions.end(); i++) new transaction_node_t(document, *i, const_cast(this)); - } + return parent_node_t::children(); } +node_t * entry_node_t::lookup_child(int _name_id) const +{ + if (_name_id == entry_node_t::code_id) { + // jww (2007-04-20): I have to save this and then delete it later + terminal_node_t * code_node = + new terminal_node_t(document, const_cast(this)); + code_node->set_name("code"); + code_node->set_text(entry->code); + return code_node; + } + else if (_name_id == entry_node_t::payee_id) { + // jww (2007-04-20): I have to save this and then delete it later + terminal_node_t * payee_node = + new terminal_node_t(document, const_cast(this)); + payee_node->set_name("payee"); + payee_node->set_text(entry->payee); + return payee_node; + } + return NULL; +} + node_t * account_node_t::children() const { if (! _children) { @@ -479,6 +487,8 @@ node_t * account_node_t::children() const return parent_node_t::children(); } +int journal_node_t::account_id = -1; + node_t * journal_node_t::children() const { if (! _children) { -- cgit v1.2.3