#ifndef ARABICA_XSLT_CALL_TEMPLATE_HANDLER_HPP #define ARABICA_XSLT_CALL_TEMPLATE_HANDLER_HPP #include "../xslt_call_template.hpp" #include "xslt_with_param_handler.hpp" namespace Arabica { namespace XSLT { template class CallTemplateHandler : public SAX::DefaultHandler { public: typedef stringT string_type; typedef adaptorT string_adaptor; CallTemplateHandler(CompilationContext& context) : context_(context), callTemplate_(0) { } // CallTemplateHandler virtual void startElement(const string_type& namespaceURI, const string_type& localName, const string_type& qName, const SAX::Attributes& atts) { if(callTemplate_ == 0) { static const ValueRule rules[] = { { "name", true, 0, 0 }, { 0, false, 0, 0 } }; std::map attrs = gatherAttributes(qName, atts, rules); string_type name = context_.processInternalQName(attrs["name"]).clarkName(); callTemplate_ = new CallTemplate(name); return; } // if(callTemplate_ == 0) if((namespaceURI == StylesheetConstant::NamespaceURI()) && (localName == "with-param")) { context_.push(0, new WithParamHandler(context_, *callTemplate_), namespaceURI, localName, qName, atts); return; } // if(localName == "with-param") throw SAX::SAXException("xsl:call-template can only contain xsl:sort and xsl:with-param elements."); } // startElement virtual void endElement(const string_type& /* namespaceURI */, const string_type& /* localName */, const string_type& /* qName */) { context_.parentContainer().add_item(callTemplate_); context_.pop(); } // endElement virtual void characters(const string_type& /* ch */) { } // characters private: CompilationContext& context_; CallTemplate* callTemplate_; }; // class CallTemplateHandler } // namespace XSLT } // namespace Arabica #endif // ARABICA_XSLT_CALL_TEMPLATE_HANDLER_HPP