summaryrefslogtreecommitdiff
path: root/xml.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2007-04-20 23:49:25 +0000
committerJohn Wiegley <johnw@newartisans.com>2008-04-13 03:38:29 -0400
commita13a6d645e6b5c2a444cfc1cce20d56f0b400320 (patch)
tree0a26669ee4cfb137ea6c5b3009af4b4ff25d1a60 /xml.cc
parentc30f52090012f4632f4cfe6536abc4af7edfe363 (diff)
downloadfork-ledger-a13a6d645e6b5c2a444cfc1cce20d56f0b400320.tar.gz
fork-ledger-a13a6d645e6b5c2a444cfc1cce20d56f0b400320.tar.bz2
fork-ledger-a13a6d645e6b5c2a444cfc1cce20d56f0b400320.zip
Optimized XML auto-doc memory usage
Diffstat (limited to 'xml.cc')
-rw-r--r--xml.cc62
1 files changed, 36 insertions, 26 deletions
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<transaction_node_t *>(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<transaction_node_t *>(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<entry_node_t *>(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<entry_node_t *>(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<entry_node_t *>(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<entry_node_t *>(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<entry_node_t *>(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) {