Xalan-C++ API Reference 1.12.0
ElemCallTemplate.hpp
Go to the documentation of this file.
1/*
2 * Licensed to the Apache Software Foundation (ASF) under one
3 * or more contributor license agreements. See the NOTICE file
4 * distributed with this work for additional information
5 * regarding copyright ownership. The ASF licenses this file
6 * to you under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
17 */
18#if !defined(XALAN_ELEMCALLTEMPLATE_HEADER_GUARD)
19#define XALAN_ELEMCALLTEMPLATE_HEADER_GUARD
20
21
22
23// Base include file. Must be first.
24#include "XSLTDefinitions.hpp"
25
26
27
28// Base class header file.
30
31
32
33namespace XALAN_CPP_NAMESPACE {
34
35
36
37class ElemTemplate;
38
39
40
42{
43public:
44
45 /**
46 * Construct an object corresponding to an "xsl:call-template" element
47 *
48 * @param constructionContext context for construction of object
49 * @param stylesheetTree stylesheet containing element
50 * @param atts list of attributes for element
51 * @param lineNumber line number in document
52 * @param columnNumber column number in document
53 */
60
61 virtual
63
64 // These methods are inherited from ElemTemplateElement ...
65
66 virtual const XalanDOMString&
68
69#if !defined(XALAN_RECURSIVE_STYLESHEET_EXECUTION)
70 virtual const ElemTemplateElement*
72
73 virtual void
75
76 virtual const ElemTemplateElement*
79 const ElemTemplateElement* currentElem) const;
80
81 virtual const ElemTemplateElement*
84#else
85 virtual void
87#endif
88 virtual void
92
93 const ElemTemplate*
95 {
96 return m_template;
97 }
98
99protected:
100
101 virtual bool
103
104private:
105
106 // not implemented
108
110 operator=(const ElemCallTemplate&);
111
112 // Data members...
113 const XalanQName* m_templateName;
114
115 const ElemTemplate* m_template;
116};
117
118
119
120}
121
122
123
124#endif // XALAN_ELEMCALLTEMPLATE_HEADER_GUARD
#define XALAN_CPP_NAMESPACE
Xalan-C++ namespace, including major and minor version.
ElemCallTemplate(StylesheetConstructionContext &constructionContext, Stylesheet &stylesheetTree, const AttributeListType &atts, XalanFileLoc lineNumber, XalanFileLoc columnNumber)
Construct an object corresponding to an "xsl:call-template" element.
virtual const ElemTemplateElement * getNextChildElemToExecute(StylesheetExecutionContext &executionContext, const ElemTemplateElement *currentElem) const
Returns the next sub-element (i.e.
const ElemTemplate * getTemplate() const
virtual void endElement(StylesheetExecutionContext &executionContext) const
Completes "post-processing" afer any sub-elements are invoked (i.e.
virtual void postConstruction(StylesheetConstructionContext &constructionContext, const NamespacesHandler &theParentHandler)
Called after construction is completed.
virtual const ElemTemplateElement * getFirstChildElemToExecute(StylesheetExecutionContext &executionContext) const
Returns the first sub-element (i.e.
virtual bool childTypeAllowed(int xslToken) const
Given an xsl token type, determine whether or not a child of that type is allowed.
virtual const XalanDOMString & getElementName() const
Get a string for the name of the element.
virtual const ElemTemplateElement * startElement(StylesheetExecutionContext &executionContext) const
Completes "pre-processing" before any sub-elements are invoked (i.e.
This class represents the base stylesheet or an "import" stylesheet.
Class to represent a qualified name.
xercesc::AttributeList AttributeListType