#ifndef ARABICA_XSLT_ATTRIBUTE_HPP #define ARABICA_XSLT_ATTRIBUTE_HPP #include "xslt_item.hpp" namespace Arabica { namespace XSLT { template class Attribute : public ItemContainer { public: typedef stringT string_type; typedef adaptorT string_adaptor; Attribute(const Arabica::XPath::XPathExpressionPtr& name, const Arabica::XPath::XPathExpressionPtr& name_space) : name_(name), namespace_(name_space) { } // Attribute Attribute(const Arabica::XPath::XPathExpressionPtr& name, const std::map& namespaces) : name_(name), namespaces_(namespaces) { } // Attribute virtual ~Attribute() { } virtual void execute(const DOM::Node& node, ExecutionContext& context) const { string_type name = name_->evaluateAsString(node, context.xpathContext()); if(string_adaptor::empty(name)) throw SAX::SAXException("xsl:attribute 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); if(!string_adaptor::empty(qn.prefix)) { typename std::map::const_iterator ns = namespaces_.find(qn.prefix); if(ns == namespaces_.end()) throw SAX::SAXException("xsl:attribute Runtime Error - Undeclared prefix " + string_adaptor::asStdString(qn.prefix)); namesp = ns->second; } // if(!qn.prefix.empty()) } // if ... context.sink().start_attribute(name, namesp); ChainStackFrame frame(context); this->execute_children(node, context); context.sink().end_attribute(); } // execute private: Arabica::XPath::XPathExpressionPtr name_; Arabica::XPath::XPathExpressionPtr namespace_; std::map namespaces_; }; // class Attribute } // namespace XSLT } // namespace Arabica #endif