#ifndef ARABICA_XSLT_ELEMENT_HPP #define ARABICA_XSLT_ELEMENT_HPP #include "xslt_item.hpp" namespace Arabica { namespace XSLT { template class Element : public ItemContainer { public: typedef stringT string_type; typedef adaptorT string_adaptor; Element(const Arabica::XPath::XPathExpressionPtr& name, const Arabica::XPath::XPathExpressionPtr& name_space, const string_type& use_attribute_sets) : name_(name), namespace_(name_space), use_attribute_sets_(use_attribute_sets) { } // Element Element(const Arabica::XPath::XPathExpressionPtr& name, const std::map& namespaces, const string_type& use_attribute_sets) : name_(name), namespaces_(namespaces), use_attribute_sets_(use_attribute_sets) { } // Element virtual ~Element() { } virtual void execute(const DOM::Node& node, ExecutionContext& context) const { string_type name = name_->evaluateAsString(node, context.xpathContext()); if(!Arabica::XML::is_qname(name)) throw SAX::SAXException("xsl:element name attribute must evaluate to a valid element name"); string_type namesp; if(namespace_ != 0) namesp = namespace_->evaluateAsString(node, context.xpathContext()); else { QName qn = QName::create(name); typename std::map::const_iterator ns = namespaces_.find(qn.prefix); if(ns == namespaces_.end()) throw SAX::SAXException("xsl:element Runtime Error - Undeclared prefix " + string_adaptor::asStdString(qn.prefix)); namesp = ns->second; } // if ... if(context.sink().start_element(name, namesp)) { ChainStackFrame frame(context); execute_children(node, context); context.sink().end_element(name, namesp); } } // execute private: const Arabica::XPath::XPathExpressionPtr name_; const Arabica::XPath::XPathExpressionPtr namespace_; const std::map namespaces_; const string_type use_attribute_sets_; }; // class Element } // namespace XSLT } // namespace Arabica #endif