Xalan-C++ API Reference 1.12.0
ElemExtensionCall.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_ELEMEXTENSIONCALL_HEADER_GUARD)
19#define XALAN_ELEMEXTENSIONCALL_HEADER_GUARD
20
21
22
23// Base include file. Must be first.
24#include "XSLTDefinitions.hpp"
25
26
27
28// Base class header file.
29#include "ElemLiteralResult.hpp"
30
31
32
33namespace XALAN_CPP_NAMESPACE {
34
35
36
37class ExtensionNSHandler;
38class XalanQName;
39
40
41
43{
44public:
45
46 /**
47 * Construct an object corresponding to calling an XSL extension
48 *
49 * @param constructionContext context for construction of object
50 * @param stylesheetTree stylesheet containing element
51 * @param name name of element
52 * @param atts list of attributes for element
53 * @param lineNumber line number in document
54 * @param columnNumber column number in document
55 * @param ns handler for the extension
56 */
60 const XalanDOMChar* name,
65
66 static ElemExtensionCall*
68 MemoryManager& theManager,
71 const XalanDOMChar* name,
76
77 // These methods are inherited from ElemLiteralResult ...
78
79#if !defined(XALAN_RECURSIVE_STYLESHEET_EXECUTION)
80 virtual const ElemTemplateElement*
82
83 virtual void
85
86 virtual bool
89 const ElemTemplateElement* element) const;
90
91#else
92 virtual void
94#endif
95
96 bool
98
99private:
100
101 const XalanQName* const m_qname;
102
103 ExtensionNSHandler& m_nsh;
104};
105
106
107
108}
109
110
111
112#endif // XALAN_ELEMEXTENSIONCALL_HEADER_GUARD
#define XALAN_CPP_NAMESPACE
Xalan-C++ namespace, including major and minor version.
bool elementAvailable(StylesheetExecutionContext &executionContext) const
virtual const ElemTemplateElement * startElement(StylesheetExecutionContext &executionContext) const
Completes "pre-processing" before any sub-elements are invoked (i.e.
static ElemExtensionCall * create(MemoryManager &theManager, StylesheetConstructionContext &constructionContext, Stylesheet &stylesheetTree, const XalanDOMChar *name, const AttributeListType &atts, XalanFileLoc lineNumber, XalanFileLoc columnNumber, ExtensionNSHandler &ns)
ElemExtensionCall(StylesheetConstructionContext &constructionContext, Stylesheet &stylesheetTree, const XalanDOMChar *name, const AttributeListType &atts, XalanFileLoc lineNumber, XalanFileLoc columnNumber, ExtensionNSHandler &ns)
Construct an object corresponding to calling an XSL extension.
virtual void endElement(StylesheetExecutionContext &executionContext) const
Completes "post-processing" afer any sub-elements are invoked (i.e.
virtual bool executeChildElement(StylesheetExecutionContext &executionContext, const ElemTemplateElement *element) const
Filters sub-elements that should be executed.
This class represents the base stylesheet or an "import" stylesheet.
Class to represent a qualified name.
xercesc::AttributeList AttributeListType