summaryrefslogtreecommitdiff
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
parentc30f52090012f4632f4cfe6536abc4af7edfe363 (diff)
downloadfork-ledger-a13a6d645e6b5c2a444cfc1cce20d56f0b400320.tar.gz
fork-ledger-a13a6d645e6b5c2a444cfc1cce20d56f0b400320.tar.bz2
fork-ledger-a13a6d645e6b5c2a444cfc1cce20d56f0b400320.zip
Optimized XML auto-doc memory usage
-rw-r--r--value.h2
-rw-r--r--xml.cc62
-rw-r--r--xml.h28
3 files changed, 56 insertions, 36 deletions
diff --git a/value.h b/value.h
index 3128ceb7..f7a13f05 100644
--- a/value.h
+++ b/value.h
@@ -5,8 +5,6 @@
#include "balance.h"
#include "error.h"
-#include "linked_list.h" // code by Donovan Rebbechi
-
#include <vector>
#include <exception>
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) {
diff --git a/xml.h b/xml.h
index 6fafbf5b..b9daa912 100644
--- a/xml.h
+++ b/xml.h
@@ -93,9 +93,9 @@ public:
return NULL;
}
- node_t * lookup_child(const char * _name);
- node_t * lookup_child(const string& _name);
- virtual node_t * lookup_child(int /* _name_id */) {
+ node_t * lookup_child(const char * _name) const;
+ node_t * lookup_child(const string& _name) const;
+ virtual node_t * lookup_child(int /* _name_id */) const {
return NULL;
}
@@ -296,8 +296,7 @@ public:
class transaction_node_t : public parent_node_t
{
- int payee_id;
- terminal_node_t * payee_virtual_node;
+ mutable terminal_node_t * payee_virtual_node;
public:
transaction_t * transaction;
@@ -309,7 +308,6 @@ public:
transaction(_transaction) {
TRACE_CTOR(transaction_node_t, "document_t *, transaction_t *, parent_node_t *");
set_name("transaction");
- payee_id = document->register_name("payee");
}
virtual ~transaction_node_t() {
TRACE_DTOR(transaction_node_t);
@@ -318,13 +316,15 @@ public:
}
virtual node_t * children() const;
- virtual node_t * lookup_child(int _name_id);
+ virtual node_t * lookup_child(int _name_id) const;
virtual value_t to_value() const;
};
class entry_node_t : public parent_node_t
{
- entry_t * entry;
+ static int code_id;
+ static int payee_id;
+ entry_t * entry;
public:
entry_node_t(document_t * _document, entry_t * _entry,
@@ -332,12 +332,19 @@ public:
: parent_node_t(_document, _parent), entry(_entry) {
TRACE_CTOR(entry_node_t, "document_t *, entry_t *, parent_node_t *");
set_name("entry");
+ if (code_id == -1)
+ payee_id = document->register_name("code");
+ if (payee_id == -1)
+ payee_id = document->register_name("payee");
}
virtual ~entry_node_t() {
TRACE_DTOR(entry_node_t);
}
virtual node_t * children() const;
+ virtual node_t * lookup_child(int _name_id) const;
+
+ friend class transaction_node_t;
};
class account_node_t : public parent_node_t
@@ -360,6 +367,7 @@ public:
class journal_node_t : public parent_node_t
{
+ static int account_id;
journal_t * journal;
public:
@@ -368,12 +376,16 @@ public:
: parent_node_t(_document, _parent), journal(_journal) {
TRACE_CTOR(journal_node_t, "document_t *, journal_t *, parent_node_t *");
set_name("journal");
+ if (account_id == -1)
+ account_id = document->register_name("account");
}
virtual ~journal_node_t() {
TRACE_DTOR(journal_node_t);
}
virtual node_t * children() const;
+
+ friend class transaction_node_t;
};
template <typename T>