00001 /* 00002 * Licensed to the Apache Software Foundation (ASF) under one 00003 * or more contributor license agreements. See the NOTICE file 00004 * distributed with this work for additional information 00005 * regarding copyright ownership. The ASF licenses this file 00006 * to you under the Apache License, Version 2.0 (the "License"); 00007 * you may not use this file except in compliance with the License. 00008 * You may obtain a copy of the License at 00009 * 00010 * http://www.apache.org/licenses/LICENSE-2.0 00011 * 00012 * Unless required by applicable law or agreed to in writing, software 00013 * distributed under the License is distributed on an "AS IS" BASIS, 00014 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 00015 * See the License for the specific language governing permissions and 00016 * limitations under the License. 00017 */ 00018 #if !defined(XALAN_ELEMEXTENSIONCALL_HEADER_GUARD) 00019 #define XALAN_ELEMEXTENSIONCALL_HEADER_GUARD 00020 00021 00022 00023 // Base include file. Must be first. 00024 #include "XSLTDefinitions.hpp" 00025 00026 00027 00028 // Base class header file. 00029 #include "ElemLiteralResult.hpp" 00030 00031 00032 00033 XALAN_CPP_NAMESPACE_BEGIN 00034 00035 00036 00037 class ExtensionNSHandler; 00038 class XalanQName; 00039 00040 00041 00042 class ElemExtensionCall: public ElemLiteralResult 00043 { 00044 public: 00045 00046 /** 00047 * Construct an object corresponding to calling an XSL extension 00048 * 00049 * @param constructionContext context for construction of object 00050 * @param stylesheetTree stylesheet containing element 00051 * @param name name of element 00052 * @param atts list of attributes for element 00053 * @param lineNumber line number in document 00054 * @param columnNumber column number in document 00055 * @param ns handler for the extension 00056 */ 00057 ElemExtensionCall( 00058 StylesheetConstructionContext& constructionContext, 00059 Stylesheet& stylesheetTree, 00060 const XalanDOMChar* name, 00061 const AttributeListType& atts, 00062 XalanFileLoc lineNumber, 00063 XalanFileLoc columnNumber, 00064 ExtensionNSHandler& ns); 00065 00066 static ElemExtensionCall* 00067 create( 00068 MemoryManager& theManager, 00069 StylesheetConstructionContext& constructionContext, 00070 Stylesheet& stylesheetTree, 00071 const XalanDOMChar* name, 00072 const AttributeListType& atts, 00073 XalanFileLoc lineNumber, 00074 XalanFileLoc columnNumber, 00075 ExtensionNSHandler& ns); 00076 00077 // These methods are inherited from ElemLiteralResult ... 00078 00079 #if !defined(XALAN_RECURSIVE_STYLESHEET_EXECUTION) 00080 virtual const ElemTemplateElement* 00081 startElement(StylesheetExecutionContext& executionContext) const; 00082 00083 virtual void 00084 endElement(StylesheetExecutionContext& executionContext) const; 00085 00086 virtual bool 00087 executeChildElement( 00088 StylesheetExecutionContext& executionContext, 00089 const ElemTemplateElement* element) const; 00090 00091 #else 00092 virtual void 00093 execute(StylesheetExecutionContext& executionContext) const; 00094 #endif 00095 00096 bool 00097 elementAvailable(StylesheetExecutionContext& executionContext) const; 00098 00099 private: 00100 00101 const XalanQName* const m_qname; 00102 00103 ExtensionNSHandler& m_nsh; 00104 }; 00105 00106 00107 00108 XALAN_CPP_NAMESPACE_END 00109 00110 00111 00112 #endif // XALAN_ELEMEXTENSIONCALL_HEADER_GUARD
Doxygen and GraphViz are used to generate this API documentation from the Xalan-C header files.
Xalan-C++ XSLT Processor Version 1.11 |
|