/usr/include/xalanc/XSLT/ElemForEach.hpp is in libxalan110-dev 1.10-6.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 | /*
* Copyright 1999-2004 The Apache Software Foundation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#if !defined(XALAN_ELEMFOREACH_HEADER_GUARD)
#define XALAN_ELEMFOREACH_HEADER_GUARD
// Base include file. Must be first.
#include "XSLTDefinitions.hpp"
#include <xalanc/Include/XalanVector.hpp>
// Base class header file.
#include "ElemTemplateElement.hpp"
#include <xalanc/XPath/NodeRefListBase.hpp>
#include <xalanc/XPath/MutableNodeRefList.hpp>
#include <xalanc/XPath/XObject.hpp>
#include "Constants.hpp"
XALAN_CPP_NAMESPACE_BEGIN
class ElemSort;
class ElemTemplate;
class NodeSorter;
class XPath;
class ElemForEach: public ElemTemplateElement
{
public:
/**
* Construct an object corresponding to an "xsl:for-each" element
*
* @param constructionContext context for construction of object
* @param stylesheetTree stylesheet containing element
* @param atts list of attributes for element
* @param lineNumber line number in document
* @param columnNumber column number in document
*/
ElemForEach(
StylesheetConstructionContext& constructionContext,
Stylesheet& stylesheetTree,
const AttributeListType& atts,
int lineNumber,
int columnNumber);
virtual
~ElemForEach();
typedef XalanVector<ElemSort*> SortElemsVectorType;
// These methods are inherited from ElemTemplateElement ...
virtual const XalanDOMString&
getElementName() const;
virtual void
processSortElement(
StylesheetConstructionContext& constructionContext,
Stylesheet& theStylesheet,
const AttributeListType& atts,
const LocatorType* locator = 0);
virtual void
postConstruction(
StylesheetConstructionContext& constructionContext,
const NamespacesHandler& theParentHandler);
#if !defined(XALAN_RECURSIVE_STYLESHEET_EXECUTION)
virtual const ElemTemplateElement*
startElement(StylesheetExecutionContext& executionContext) const;
virtual void
endElement(StylesheetExecutionContext& executionContext) const;
virtual const ElemTemplateElement*
getNextChildElemToExecute(
StylesheetExecutionContext& executionContext,
const ElemTemplateElement* currentElem) const;
#else
virtual void
execute(StylesheetExecutionContext& executionContext) const;
#endif
virtual const XPath*
getXPath(unsigned int index = 0) const;
protected:
/**
* Construct an object derived from ElemForEach
*
* @param constructionContext context for construction of object
* @param stylesheetTree stylesheet containing element
* @param lineNumber line number in document
* @param columnNumber column number in document
* @param xslToken an integer representing the type of instance.
*/
ElemForEach(
StylesheetConstructionContext& constructionContext,
Stylesheet& stylesheetTree,
int lineNumber,
int columnNumber,
int xslToken);
#if !defined(XALAN_RECURSIVE_STYLESHEET_EXECUTION)
/*
* Returns a pointer to a list of the selected nodes. The
* nodes are sorted if required.
*
* @param executionContext context for executing this element
* @return pointer to the list of selected (and sorted) nodes
*/
virtual const NodeRefListBase*
createSelectedAndSortedNodeList(
StylesheetExecutionContext& executionContext) const;
/*
* Release any objects used to maintain the last selected
* (and sorted) node list to be created
*
* @param executionContext context for executing this element
*/
virtual void
releaseSelectedAndSortedNodeList(
StylesheetExecutionContext& executionContext) const;
/*
* Sorts a list of nodes
*
* @param executionContext context for executing this element
* @param selectedNodeList list of nodes to be sorted
* @param sortedNodeList list for sorted nodes
*
* @returns pointer to list of sorted nodes
*/
virtual const NodeRefListBase*
sortChildren(
StylesheetExecutionContext& executionContext,
const NodeRefListBase& selectedNodeList,
MutableNodeRefList& sortedNodeList) const;
#else
/**
* Perform a query if needed, and call transformChild for each child.
*
* @param executionContext The current execution context
* @param template The owning template context.
* @param sourceNodeContext The current source node context.
*/
void
transformSelectedChildren(
StylesheetExecutionContext& executionContext,
const ElemTemplateElement* theTemplate) const;
/**
* Perform a query if needed, and call transformChild for each child.
*
* @param executionContext The current execution context
* @param theTemplate The owning template context.
* @param sourceNodes The source nodes to transform.
* @param sourceNodesCount The count of source nodes to transform.
*/
void
transformSelectedChildren(
StylesheetExecutionContext& executionContext,
const ElemTemplateElement* theTemplate,
const NodeRefListBase& sourceNodes,
NodeRefListBase::size_type sourceNodesCount) const;
/**
* Perform a query if needed, and call transformChild for each child.
*
* @param executionContext The current execution context
* @param template The owning template context.
* @param sorter The NodeSorter instance, if any.
* @param selectStackFrameIndex stack frame context for executing the
* select statement
*/
virtual void
selectAndSortChildren(
StylesheetExecutionContext& executionContext,
const ElemTemplateElement* theTemplate,
NodeSorter* sorter,
int selectStackFrameIndex) const;
#endif
const XPath* m_selectPattern;
private:
SortElemsVectorType m_sortElems;
SortElemsVectorType::size_type m_sortElemsCount;
};
XALAN_CPP_NAMESPACE_END
#endif // XALAN_ELEMFOREACH_HEADER_GUARD
|