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_ELEMAPPLYTEMPLATES_HEADER_GUARD) 00019 #define XALAN_ELEMAPPLYTEMPLATES_HEADER_GUARD 00020 00021 // Base include file. Must be first. 00022 #include <xalanc/XSLT/XSLTDefinitions.hpp> 00023 00024 00025 00026 // Base class header file. 00027 #include <xalanc/XSLT/ElemForEach.hpp> 00028 00029 00030 00031 XALAN_CPP_NAMESPACE_BEGIN 00032 00033 00034 00035 class XalanQName; 00036 00037 00038 00039 class ElemApplyTemplates : public ElemForEach 00040 { 00041 public: 00042 00043 typedef ElemForEach ParentType; 00044 00045 /** 00046 * Construct an object corresponding to an "xsl:apply-template" element 00047 * 00048 * @param constructionContext context for construction of object 00049 * @param stylesheetTree stylesheet containing element 00050 * @param atts list of attributes for element 00051 * @param lineNumber line number in document 00052 * @param columnNumber column number in document 00053 */ 00054 ElemApplyTemplates( 00055 StylesheetConstructionContext& constructionContext, 00056 Stylesheet& stylesheetTree, 00057 const AttributeListType& atts, 00058 XalanFileLoc lineNumber, 00059 XalanFileLoc columnNumber); 00060 00061 virtual 00062 ~ElemApplyTemplates(); 00063 00064 // These methods are inherited from ElemTemplateElement ... 00065 00066 virtual const XalanDOMString& 00067 getElementName() const; 00068 00069 #if !defined(XALAN_RECURSIVE_STYLESHEET_EXECUTION) 00070 virtual const ElemTemplateElement* 00071 startElement(StylesheetExecutionContext& executionContext) const; 00072 00073 virtual void 00074 endElement(StylesheetExecutionContext& executionContext) const; 00075 00076 virtual const ElemTemplateElement* 00077 getNextChildElemToExecute( 00078 StylesheetExecutionContext& executionContext, 00079 const ElemTemplateElement* currentElem) const; 00080 00081 virtual const ElemTemplateElement* 00082 getFirstChildElemToExecute( 00083 StylesheetExecutionContext& executionContext) const; 00084 #else 00085 virtual void 00086 execute(StylesheetExecutionContext& executionContext) const; 00087 #endif 00088 00089 00090 00091 protected: 00092 00093 virtual bool 00094 childTypeAllowed(int xslToken) const; 00095 00096 #if !defined(XALAN_RECURSIVE_STYLESHEET_EXECUTION) 00097 const ElemTemplateElement* 00098 findNextTemplateToExecute(StylesheetExecutionContext& executionContext) const; 00099 #else 00100 virtual void 00101 transformChild( 00102 StylesheetExecutionContext& executionContext, 00103 const ElemTemplateElement& xslInstruction, 00104 const ElemTemplateElement* theTemplate, 00105 XalanNode* child) const; 00106 00107 using ParentType::transformChild; 00108 00109 virtual void 00110 selectAndSortChildren( 00111 StylesheetExecutionContext& executionContext, 00112 const ElemTemplateElement* theTemplate, 00113 NodeSorter* sorter, 00114 int selectStackFrameIndex) const; 00115 #endif 00116 00117 private: 00118 00119 const XalanQName* m_mode; 00120 }; 00121 00122 00123 00124 XALAN_CPP_NAMESPACE_END 00125 00126 00127 00128 #endif // XALAN_ELEMAPPLYTEMPLATES_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 |
|