8 #ifndef INCLUDED_ORCUS_SAX_NS_PARSER_HPP 9 #define INCLUDED_ORCUS_SAX_NS_PARSER_HPP 11 #include "sax_parser.hpp" 12 #include "xml_namespace.hpp" 15 #include <unordered_set> 27 std::ptrdiff_t begin_pos;
28 std::ptrdiff_t end_pos;
48 ns(_ns), name(_name) {}
52 return other.ns == ns && other.name == name;
60 return hasher(v.ns) + hasher(v.name);
65 typedef std::unordered_set<pstring, pstring::hash> ns_keys_type;
66 typedef std::unordered_set<entity_name, entity_name::hash> entity_names_type;
75 typedef std::vector<std::unique_ptr<elem_scope>> elem_scopes_type;
82 void operator() (
const pstring& key)
113 template<
typename _Handler>
117 typedef _Handler handler_type;
120 sax_ns_parser(
const char* content,
const size_t size,
bool transient_stream,
131 class handler_wrapper
133 __sax::elem_scopes_type m_scopes;
134 __sax::ns_keys_type m_ns_keys;
135 __sax::entity_names_type m_attrs;
141 handler_type& m_handler;
146 handler_wrapper(
xmlns_context& ns_cxt, handler_type& handler) : m_ns_cxt(ns_cxt), m_handler(handler), m_declaration(
false) {}
150 m_handler.doctype(dtd);
153 void start_declaration(
const pstring& name)
155 m_declaration =
true;
156 m_handler.start_declaration(name);
159 void end_declaration(
const pstring& name)
161 m_declaration =
false;
162 m_handler.end_declaration(name);
167 m_scopes.push_back(orcus::make_unique<__sax::elem_scope>());
169 scope.ns = m_ns_cxt.
get(elem.ns);
170 scope.name = elem.name;
171 scope.ns_keys.swap(m_ns_keys);
173 m_elem.ns = scope.ns;
174 m_elem.ns_alias = elem.ns;
175 m_elem.name = scope.name;
176 m_elem.begin_pos = elem.begin_pos;
177 m_elem.end_pos = elem.end_pos;
178 m_handler.start_element(m_elem);
186 if (scope.ns != m_ns_cxt.
get(elem.ns) || scope.name != elem.name)
189 m_elem.ns = scope.ns;
190 m_elem.ns_alias = elem.ns;
191 m_elem.name = scope.name;
192 m_elem.begin_pos = elem.begin_pos;
193 m_elem.end_pos = elem.end_pos;
194 m_handler.end_element(m_elem);
202 void characters(
const pstring& val,
bool transient)
204 m_handler.characters(val,
transient);
212 m_handler.attribute(attr.name, attr.value);
218 "You can't define two attributes of the same name in the same element.", -1);
222 if (attr.ns.empty() && attr.name ==
"xmlns")
225 m_ns_cxt.push(
pstring(), attr.value);
230 if (attr.ns ==
"xmlns")
233 if (!attr.name.empty())
235 m_ns_cxt.push(attr.name, attr.value);
236 m_ns_keys.insert(attr.name);
241 m_attr.ns = attr.ns.empty() ? XMLNS_UNKNOWN_ID : m_ns_cxt.
get(attr.ns);
242 m_attr.ns_alias = attr.ns;
243 m_attr.name = attr.name;
244 m_attr.value = attr.value;
245 m_attr.transient = attr.transient;
246 m_handler.attribute(m_attr);
251 handler_wrapper m_wrapper;
255 template<
typename _Handler>
257 const char* content,
const size_t size,
xmlns_context& ns_cxt, handler_type& handler) :
258 m_wrapper(ns_cxt, handler), m_parser(content, size, m_wrapper)
262 template<
typename _Handler>
263 sax_ns_parser<_Handler>::sax_ns_parser(
264 const char* content,
const size_t size,
bool transient_stream, xmlns_context& ns_cxt, handler_type& handler) :
265 m_wrapper(ns_cxt, handler), m_parser(content, size, transient_stream, m_wrapper)
269 template<
typename _Handler>
270 sax_ns_parser<_Handler>::~sax_ns_parser()
274 template<
typename _Handler>
275 void sax_ns_parser<_Handler>::parse()
Definition: pstring.hpp:82
Definition: sax_ns_parser.hpp:68
Definition: pstring.hpp:27
Definition: sax_ns_parser.hpp:55
Definition: sax_ns_parser.hpp:42
Definition: sax_ns_parser.hpp:31
Definition: sax_ns_parser.hpp:114
Definition: xml_namespace.hpp:82
Definition: sax_ns_parser.hpp:22
Definition: sax_parser_base.hpp:100
Definition: sax_parser_base.hpp:85
Definition: sax_parser_base.hpp:45
Definition: sax_ns_parser.hpp:77
xmlns_id_t get(const pstring &key) const
Definition: sax_ns_parser.hpp:90
Definition: base64.hpp:15