00001 /* 00002 * Copyright 1999-2004 The Apache Software Foundation. 00003 * 00004 * Licensed under the Apache License, Version 2.0 (the "License"); 00005 * you may not use this file except in compliance with the License. 00006 * You may obtain a copy of the License at 00007 * 00008 * http://www.apache.org/licenses/LICENSE-2.0 00009 * 00010 * Unless required by applicable law or agreed to in writing, software 00011 * distributed under the License is distributed on an "AS IS" BASIS, 00012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 00013 * See the License for the specific language governing permissions and 00014 * limitations under the License. 00015 */ 00016 #if !defined(XALAN_ELEMAPPLYTEMPLATES_HEADER_GUARD) 00017 #define XALAN_ELEMAPPLYTEMPLATES_HEADER_GUARD 00018 00019 // Base include file. Must be first. 00020 #include <xalanc/XSLT/XSLTDefinitions.hpp> 00021 00022 00023 00024 // Base class header file. 00025 #include <xalanc/XSLT/ElemForEach.hpp> 00026 00027 00028 00029 XALAN_CPP_NAMESPACE_BEGIN 00030 00031 00032 00033 class XalanQName; 00034 00035 00036 00037 class ElemApplyTemplates : public ElemForEach 00038 { 00039 public: 00040 00041 typedef ElemForEach ParentType; 00042 00052 ElemApplyTemplates( 00053 StylesheetConstructionContext& constructionContext, 00054 Stylesheet& stylesheetTree, 00055 const AttributeListType& atts, 00056 int lineNumber, 00057 int columnNumber); 00058 00059 virtual 00060 ~ElemApplyTemplates(); 00061 00062 // These methods are inherited from ElemTemplateElement ... 00063 00064 virtual const XalanDOMString& 00065 getElementName() const; 00066 00067 #if !defined(XALAN_RECURSIVE_STYLESHEET_EXECUTION) 00068 virtual const ElemTemplateElement* 00069 startElement(StylesheetExecutionContext& executionContext) const; 00070 00071 virtual void 00072 endElement(StylesheetExecutionContext& executionContext) const; 00073 00074 virtual const ElemTemplateElement* 00075 getNextChildElemToExecute( 00076 StylesheetExecutionContext& executionContext, 00077 const ElemTemplateElement* currentElem) const; 00078 00079 virtual const ElemTemplateElement* 00080 getFirstChildElemToExecute( 00081 StylesheetExecutionContext& executionContext) const; 00082 #else 00083 virtual void 00084 execute(StylesheetExecutionContext& executionContext) const; 00085 #endif 00086 00087 00088 00089 protected: 00090 00091 virtual bool 00092 childTypeAllowed(int xslToken) const; 00093 00094 #if !defined(XALAN_RECURSIVE_STYLESHEET_EXECUTION) 00095 const ElemTemplateElement* 00096 findNextTemplateToExecute(StylesheetExecutionContext& executionContext) const; 00097 #else 00098 virtual void 00099 transformChild( 00100 StylesheetExecutionContext& executionContext, 00101 const ElemTemplateElement& xslInstruction, 00102 const ElemTemplateElement* theTemplate, 00103 XalanNode* child) const; 00104 00105 #if !defined(XALAN_NO_USING_DECLARATION) 00106 using ParentType::transformChild; 00107 #endif 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.9 |
|