summaryrefslogtreecommitdiff
path: root/src/compile.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/compile.h')
-rw-r--r--src/compile.h342
1 files changed, 16 insertions, 326 deletions
diff --git a/src/compile.h b/src/compile.h
index 25e12183..3c0876e3 100644
--- a/src/compile.h
+++ b/src/compile.h
@@ -29,323 +29,16 @@
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
-#ifndef _NODE_H
-#define _NODE_H
+#ifndef _COMPILE_H
+#define _COMPILE_H
+#include "node.h"
#include "journal.h"
-#include "value.h"
-//#include "parser.h"
namespace ledger {
-
-class transaction_t;
-class entry_t;
-class account_t;
-class journal_t;
-
namespace xml {
-#define XML_NODE_IS_PARENT 0x1
-
-#define ACCOUNT_ATTR "account"
-#define ACCOUNT_PATH_NODE "account-path"
-#define AMOUNT_EXPR_NODE "amount-expr"
-#define ARG_ATTR "arg"
-#define AUTO_ENTRY_NODE "auto-entry"
-#define BALANCE_ATTR "balance"
-#define CHECKIN_NODE "checkin"
-#define CLEARED_ATTR "cleared"
-#define CODE_ATTR "code"
-#define COMMODITY_CONVERSION_NODE "commodity-conversion"
-#define COMMODITY_NOMARKET_NODE "commodity-nomarket"
-#define COMMODITY_TEMPLATE_NODE "commodity-template"
-#define CURRENT_YEAR_NODE "current-year"
-#define DATE_ATTR "date"
-#define DATE_EFF_ATTR "effective"
-#define DEFAULT_ACCOUNT_NODE "default-account"
-#define DIRECTIVE_NODE "directive"
-#define ENTRY_NODE "entry"
-#define FROM_ATTR "from"
-#define JOURNAL_NODE "journal"
-#define NAME_ATTR "name"
-#define NOTE_NODE "note"
-#define PAYEE_NODE "payee"
-#define PENDING_ATTR "pending"
-#define PERIOD_ENTRY_NODE "period-entry"
-#define PERIOD_NODE "period"
-#define PRICE_ATTR "price"
-#define PRICE_HISTORY_NODE "price-history"
-#define RULE_NODE "rule"
-#define SYMBOL_ATTR "symbol"
-#define TEMPLATE_ATTR "template"
-#define TIME_ATTR "time"
-#define TO_ATTR "to"
-#define TRANSACTION_NODE "transaction"
-#define VIRTUAL_ATTR "virtual"
-#define YEAR_ATTR "year"
-
-DECLARE_EXCEPTION(conversion_error);
-
-class parent_node_t;
-class document_t;
-
-class node_t : public supports_flags<>
-{
-public:
- typedef uint_fast16_t nameid_t;
-
- nameid_t name_id;
-#ifdef THREADSAFE
- document_t * document;
-#else
- static document_t * document;
-#endif
- parent_node_t * parent;
- node_t * next;
- node_t * prev;
-
- typedef std::map<string, string> attrs_map;
-
- attrs_map * attrs;
-
- node_t(document_t * _document, parent_node_t * _parent = NULL,
- flags_t _flags = 0);
-
- virtual ~node_t() {
- TRACE_DTOR(node_t);
- if (parent) extract();
- if (attrs) checked_delete(attrs);
- }
-
- parent_node_t * as_parent_node() {
- if (! has_flags(XML_NODE_IS_PARENT))
- throw_(std::logic_error, "Request to cast leaf node to a parent node");
- return polymorphic_downcast<parent_node_t *>(this);
- }
- const parent_node_t * as_parent_node() const {
- if (! has_flags(XML_NODE_IS_PARENT))
- throw_(std::logic_error, "Request to cast leaf node to a parent node");
- return polymorphic_downcast<const parent_node_t *>(this);
- }
-
- void extract(); // extract this node from its parent's child list
-
- virtual const char * text() const {
- assert(false);
- return NULL;
- }
-
- const char * name() const;
- int set_name(const char * _name);
- int set_name(int _name_id) {
- name_id = _name_id;
- return name_id;
- }
-
- void set_attr(const char * n, const char * v) {
- if (! attrs)
- attrs = new attrs_map;
- std::pair<attrs_map::iterator, bool> result =
- attrs->insert(attrs_map::value_type(n, v));
- assert(result.second);
- }
- const char * get_attr(const char * n) {
- if (attrs) {
- attrs_map::iterator i = attrs->find(n);
- if (i != attrs->end())
- return (*i).second.c_str();
- }
- return NULL;
- }
-
- 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;
- }
-
- virtual value_t to_value() const {
- throw_(conversion_error, "Cannot convert node to a value");
- return value_t();
- }
-
- virtual void print(std::ostream& out, int depth = 0) const = 0;
-
-private:
- node_t(const node_t&);
- node_t& operator=(const node_t&);
-};
-
-class parent_node_t : public node_t
-{
-public:
- mutable node_t * _children;
- mutable node_t * _last_child;
-
- parent_node_t(document_t * _document, parent_node_t * _parent = NULL)
- : node_t(_document, _parent, XML_NODE_IS_PARENT),
- _children(NULL), _last_child(NULL)
- {
- TRACE_CTOR(parent_node_t, "document_t *, parent_node_t *");
- }
- virtual ~parent_node_t() {
- TRACE_DTOR(parent_node_t);
- if (_children) clear();
- }
-
- virtual void clear(); // clear out all child nodes
- virtual node_t * children() const {
- return _children;
- }
- virtual node_t * last_child() {
- if (! _children)
- children();
- return _last_child;
- }
- virtual void add_child(node_t * node);
-
- void print(std::ostream& out, int depth = 0) const;
-
-private:
- parent_node_t(const parent_node_t&);
- parent_node_t& operator=(const parent_node_t&);
-};
-
-class terminal_node_t : public node_t
-{
- string data;
-
-public:
- terminal_node_t(document_t * _document, parent_node_t * _parent = NULL)
- : node_t(_document, _parent)
- {
- TRACE_CTOR(terminal_node_t, "document_t *, parent_node_t *");
- }
- virtual ~terminal_node_t() {
- TRACE_DTOR(terminal_node_t);
- }
-
- virtual const char * text() const {
- return data.c_str();
- }
- virtual void set_text(const char * _data) {
- data = _data;
- }
- virtual void set_text(const string& _data) {
- data = _data;
- }
-
- virtual value_t to_value() const {
- return text();
- }
-
- void print(std::ostream& out, int depth = 0) const;
-
-private:
- terminal_node_t(const node_t&);
- terminal_node_t& operator=(const node_t&);
-};
-
-class document_t
-{
- static const char * ledger_builtins[];
- static const std::size_t ledger_builtins_size;
-
-public:
- enum ledger_builtins_t {
- ACCOUNT = 10,
- ACCOUNT_PATH,
- AMOUNT,
- CODE,
- COMMODITY,
- ENTRIES,
- ENTRY,
- JOURNAL,
- NAME,
- NOTE,
- PAYEE,
- TRANSACTION
- };
-
-private:
- typedef std::vector<string> names_array;
-
- names_array names;
-
- typedef std::map<string, int> names_map;
-
- names_map names_index;
-
-public:
- node_t * top;
-
-private:
- terminal_node_t stub;
-
-public:
- // Ids 0-9 are reserved. 10-999 are for "builtin" names. 1000+ are
- // for dynamically registered names.
- enum special_names_t {
- CURRENT, PARENT, ROOT, ALL
- };
-
- document_t(node_t * _top = NULL)
- : top(_top ? _top : &stub), stub(this) {
- TRACE_CTOR(xml::document_t, "node_t *, const char **, const int");
- }
- ~document_t();
-
- void set_top(node_t * _top);
-
- int register_name(const string& name);
- int lookup_name_id(const string& name) const;
- static int lookup_builtin_id(const string& name);
- const char * lookup_name(int id) const;
-
- void print(std::ostream& out) const;
-
-#if defined(HAVE_EXPAT) || defined(HAVE_XMLPARSE)
- class parser_t
- {
- public:
- document_t * document;
- XML_Parser parser;
- string have_error;
- const char * pending;
- node_t::attrs_map * pending_attrs;
- bool handled_data;
-
- std::list<parent_node_t *> node_stack;
-
- parser_t() : document(NULL), pending(NULL), pending_attrs(NULL),
- handled_data(false) {}
- virtual ~parser_t() {}
-
- virtual bool test(std::istream& in) const;
- virtual document_t * parse(std::istream& in);
- };
-#endif
-};
-
#if 0
-#if defined(HAVE_EXPAT) || defined(HAVE_XMLPARSE)
-
-class xml_parser_t : public parser_t
-{
- public:
- virtual bool test(std::istream& in) const;
-
- virtual unsigned int parse(std::istream& in,
- journal_t * journal,
- account_t * master = NULL,
- const optional<path>& original = none);
-};
-
-DECLARE_EXCEPTION(parse_error);
-
-#endif
-#endif
-
class commodity_node_t : public parent_node_t
{
public:
@@ -387,33 +80,29 @@ public:
return *amount;
}
};
+#endif
class transaction_node_t : public parent_node_t
{
- mutable terminal_node_t * payee_virtual_node;
-
public:
- transaction_t * transaction;
+ shared_ptr<transaction_t> transaction;
- transaction_node_t(document_t * _document,
- transaction_t * _transaction,
- parent_node_t * _parent = NULL)
- : parent_node_t(_document, _parent), payee_virtual_node(NULL),
+ transaction_node_t(nameid_t _name_id,
+ document_t& _document,
+ const optional<parent_node_t&>& _parent = none,
+ transaction_t * _transaction = NULL)
+ : parent_node_t(_name_id, _document, _parent),
transaction(_transaction) {
- TRACE_CTOR(transaction_node_t, "document_t *, transaction_t *, parent_node_t *");
- set_name(document_t::TRANSACTION);
+ TRACE_CTOR(transaction_node_t,
+ "document_t&, parent_node_t, transaction_t *");
+ assert(_name_id == TRANSACTION_NODE);
}
virtual ~transaction_node_t() {
TRACE_DTOR(transaction_node_t);
- if (payee_virtual_node)
- checked_delete(payee_virtual_node);
}
-
- virtual node_t * children() const;
- virtual node_t * lookup_child(int _name_id) const;
- virtual value_t to_value() const;
};
+#if 0
class entry_node_t : public parent_node_t
{
entry_t * entry;
@@ -503,8 +192,9 @@ inline journal_t::node_type *
wrap_node(document_t * doc, journal_t * journal, void * parent_node) {
return new journal_node_t(doc, journal, (parent_node_t *)parent_node);
}
+#endif
} // namespace xml
} // namespace ledger
-#endif // _NODE_H
+#endif // _COMPILE_H