#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 { typedef StylesheetConstant SC; typedef AttributeValidators AV; 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 AV rules = AV::rule(SC::name, true); std::map attrs = rules.gather(qName, atts); string_type name = context_.processInternalQName(attrs[SC::name]).clarkName(); callTemplate_ = new CallTemplate(name); return; } // if(callTemplate_ == 0) if((namespaceURI == StylesheetConstant::NamespaceURI) && (localName == SC::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