#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 { public: struct position_t { typedef uint_least32_t file_pos_t; typedef uint_least32_t file_line_t; path pathname; file_pos_t offset; file_line_t linenum; position_t() : offset(0), linenum(0) {} explicit position_t(path _pathname, file_pos_t _offset, file_line_t _linenum) : pathname(_pathname), offset(_offset), linenum(_linenum) {} }; position_t current_position; virtual void start_position(const std::istream& in, const path& pathname) { set_position(position_t(pathname, in.tellg(), 1)); } virtual void set_position(const position_t& position) { current_position = position; } virtual position_t& position() { return current_position; } virtual void push_attr(const string& name, const string& value) = 0; virtual void push_attr(const nameid_t name_id, const string& value) = 0; virtual void begin_node(const string& name) = 0; virtual void begin_node(const nameid_t name_id) = 0; template virtual void begin_node(typename T::pointer data) = 0; virtual void push_node(const string& name, const optional& end_pos) = 0; virtual void push_node(const nameid_t name_id, const optional& end_pos) = 0; virtual node_t * current_node() = 0; template virtual T * current_node() = 0; virtual void append_text(const string& text) = 0; virtual node_t * end_node(const string& name, const optional& end_pos) = 0; virtual node_t * end_node(const nameid_t name_id, const optional& end_pos) = 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 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 * 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