summaryrefslogtreecommitdiff
path: root/src/builder.h
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2007-05-11 07:25:15 +0000
committerJohn Wiegley <johnw@newartisans.com>2008-04-13 03:38:46 -0400
commit76a2e60e3911c01fc0c0521714debfb4fb5d6faf (patch)
tree3ae733572ff34c6325f136a04a0752351bf56767 /src/builder.h
parentbc3b0b5577bd08e131e2c0884b30d364e6d3b38a (diff)
downloadfork-ledger-76a2e60e3911c01fc0c0521714debfb4fb5d6faf.tar.gz
fork-ledger-76a2e60e3911c01fc0c0521714debfb4fb5d6faf.tar.bz2
fork-ledger-76a2e60e3911c01fc0c0521714debfb4fb5d6faf.zip
Added builder.h
Diffstat (limited to 'src/builder.h')
-rw-r--r--src/builder.h83
1 files changed, 83 insertions, 0 deletions
diff --git a/src/builder.h b/src/builder.h
new file mode 100644
index 00000000..00adf483
--- /dev/null
+++ b/src/builder.h
@@ -0,0 +1,83 @@
+#ifndef _BUILDER_H
+#define _BUILDER_H
+
+#include "xml.h"
+
+namespace ledger {
+
+/**
+ * @class builder_t
+ *
+ * @brief Represents an interface for building a data hierarchy.
+ *
+ * This interface is much like .NET's XmlWriter facility. It
+ * abstracts the kind of hierarchy we're building, instead focusing
+ * only on the relationships.
+ */
+class builder_t
+{
+ virtual void pushAttribute(const string& name,
+ const string& value) = 0;
+ virtual void pushAttribute(const nameid_t name_id,
+ const string& value) = 0;
+
+ virtual void beginNode(const string& name) = 0;
+ virtual void beginNode(const nameid_t name_id) = 0;
+
+ virtual void appendText(const string& text) = 0;
+
+ virtual node_t * endNode(const optional<string>& name =
+ optional<string>()) = 0;
+ virtual node_t * endNode(const nameid_t name_id) = 0;
+};
+
+/**
+ * @class xml_builder_t
+ *
+ * @brief Build a generic node_t hierarchy.
+ *
+ * This builder can be used to parse ordinary XML into a document
+ * object structure which can then be traversed in memory.
+ */
+class xml_builder_t : public builder_t
+{
+};
+
+/**
+ * @class journal_builder_t
+ *
+ * @brief This custom builder creates an XML-mirrored Ledger journal.
+ *
+ * Rather than simply creating a node_t hierarchy, as xml_builder_t
+ * does, this code creates the associated journal elements referred to
+ * by those nodes, and then refers to those elements via minimalist
+ * "shadow nodes".
+ *
+ * Thus, after building a <transaction> element, the element itself
+ * will have no children, but instead will point to a transaction_t
+ * object. If later an XPath expression desires to traverse the
+ * <transaction> element, all of the appropriate child nodes will be
+ * constructed on the fly, as if they'd been created in the first
+ * place by a regular xml_builder_t.
+ */
+class journal_builder_t : public xml_builder_t
+{
+};
+
+/**
+ * @class xml_writer_t
+ *
+ * @brief Create textual XML on the given output stream.
+ *
+ * This builder, rather than manipulating data structures in memory,
+ * simply streams its contents on the fly to the given output stream.
+ * It uses only enough memory to remember the currently push
+ * attributes and text.
+ */
+class xml_writer_t : public builder_t
+{
+};
+
+} // namespace ledger
+
+#endif // _BUILDER_H