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_ELEMELEMENT_HEADER_GUARD) 00019 #define XALAN_ELEMELEMENT_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 "ElemUse.hpp" 00030 00031 00032 00033 XALAN_CPP_NAMESPACE_BEGIN 00034 00035 00036 00037 class AVT; 00038 00039 00040 00041 class ElemElement: public ElemUse 00042 { 00043 public: 00044 00045 /** 00046 * Construct an object corresponding to an "xsl:element" 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 ElemElement( 00055 StylesheetConstructionContext& constructionContext, 00056 Stylesheet& stylesheetTree, 00057 const AttributeListType& atts, 00058 XalanFileLoc lineNumber, 00059 XalanFileLoc columnNumber); 00060 00061 virtual 00062 ~ElemElement(); 00063 00064 // These methods are inherited from ElemUse ... 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 bool 00077 executeChildElement( 00078 StylesheetExecutionContext& executionContext, 00079 const ElemTemplateElement* element) const; 00080 #else 00081 virtual void 00082 execute(StylesheetExecutionContext& executionContext) const; 00083 #endif 00084 00085 protected: 00086 00087 #if defined(XALAN_RECURSIVE_STYLESHEET_EXECUTION) 00088 /** 00089 * Process the children of a template. 00090 * 00091 * @param executionContext The current execution context 00092 * @param skipAttributeChildren If true, attribute children will not be executed. 00093 */ 00094 virtual void 00095 doExecuteChildren( 00096 StylesheetExecutionContext& executionContext, 00097 bool skipAttributeChildren) const; 00098 #endif 00099 00100 virtual void 00101 namespacesPostConstruction( 00102 StylesheetConstructionContext& constructionContext, 00103 const NamespacesHandler& theParentHandler, 00104 NamespacesHandler& theHandler); 00105 00106 private: 00107 00108 /** 00109 * Do any necessary fixup for the default namespace 00110 * 00111 * @param executionContext The current execution context 00112 */ 00113 void 00114 fixupDefaultNamespace(StylesheetExecutionContext& executionContext) const; 00115 00116 /** 00117 * Get the default namespace from the parent of this element. Returns 00118 * an empty string if there's no default namespace. 00119 * 00120 * @return The default namespace of the parent, if any. 00121 */ 00122 const XalanDOMString& 00123 getParentDefaultNamespace() const; 00124 00125 00126 // not implemented 00127 ElemElement(const ElemElement &); 00128 00129 ElemElement& 00130 operator=(const ElemElement &); 00131 00132 // Data members... 00133 const AVT* m_nameAVT; 00134 00135 const AVT* m_namespaceAVT; 00136 }; 00137 00138 00139 00140 XALAN_CPP_NAMESPACE_END 00141 00142 00143 00144 #endif // XALAN_ELEMELEMENT_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 |
|