#ifndef ARABICA_XSLT_ELEMENT_HPP #define ARABICA_XSLT_ELEMENT_HPP #include "xslt_item.hpp" namespace Arabica { namespace XSLT { class Element : public ItemContainer { public: Element(const Arabica::XPath::XPathExpressionPtr& name, const Arabica::XPath::XPathExpressionPtr& name_space, const std::string& 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 std::string& 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 { std::string 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"); std::string namesp; if(namespace_ != 0) namesp = namespace_->evaluateAsString(node, context.xpathContext()); else { QName qn = QName::createQName(name); std::map::const_iterator ns = namespaces_.find(qn.prefix); if(ns == namespaces_.end()) throw SAX::SAXException("xsl:element Runtime Error - Undeclared prefix " + 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: Arabica::XPath::XPathExpressionPtr name_; Arabica::XPath::XPathExpressionPtr namespace_; std::map namespaces_; std::string use_attribute_sets_; }; // class Element } // namespace XSLT } // namespace Arabica #endif