/usr/include/xalanc/XSLT/XSLTProcessor.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 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 | /*
* 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_XSLTPROCESSOR_HEADER_GUARD)
#define XALAN_XSLTPROCESSOR_HEADER_GUARD
// Base include file. Must be first.
#include "XSLTDefinitions.hpp"
#include <cstddef>
XALAN_DECLARE_XERCES_CLASS(Locator)
XALAN_CPP_NAMESPACE_BEGIN
typedef XERCES_CPP_NAMESPACE_QUALIFIER Locator LocatorType;
class ElemTemplateElement;
class FormatterListener;
class GenerateEvent;
class NodeRefListBase;
class PrefixResolver;
class PrintWriter;
class SelectionEvent;
class StylesheetConstructionContext;
class StylesheetExecutionContext;
class StylesheetRoot;
class TraceListener;
class TracerEvent;
class XalanDOMString;
class XalanDocument;
class XalanElement;
class XalanNode;
class XMLParserLiaison;
class XObject;
class XObjectPtr;
class XPath;
class XPathExecutionContext;
class XSLTInputSource;
class XSLTResultTarget;
/**
* This is an interface for an XSLT Processor engine. It's the responsibility
* of the implementation of the XSLTProcessor interface, collaborating with a
* XMLParserLiaison, the DOM, and the XPath engine, to transform a source tree
* of nodes into a result tree according to instructions and templates
* specified by a stylesheet tree. The methods process(...) are
* the primary public entry points.
*
* If you reuse the processor instance, you should call reset() between calls.
*/
class XALAN_XSLT_EXPORT XSLTProcessor
{
public:
typedef size_t size_type;
XSLTProcessor();
virtual
~XSLTProcessor();
/**
* Transform the source tree to the output in the given result tree target.
* The processor will process the input source, the stylesheet source,
* and transform to the output target.
*
* @param inputSource input source
* @param stylesheetSource stylesheet source
* @param outputTarget output source tree
* @param constructionContext context for construction of objects
* @param executionContext current execution context
* @exception XSLProcessorException
*/
virtual void
process(
const XSLTInputSource& inputSource,
const XSLTInputSource& stylesheetSource,
XSLTResultTarget& outputTarget,
StylesheetConstructionContext& constructionContext,
StylesheetExecutionContext& executionContext) = 0;
/**
* Transform the source tree to the output in the given result tree target.
* This function does not create a stylesheet tree, it assumes the
* provided StylesheetExecutionContext has the stylesheet tree to use. This
* is set by calling StylesheetExecutionContext::setStylesheetRoot().
*
* @param inputSource input source
* @param outputTarget output source tree
* @param executionContext current execution context
* @exception XSLProcessorException
*/
virtual void
process(
const XSLTInputSource& inputSource,
XSLTResultTarget& outputTarget,
StylesheetExecutionContext& executionContext) = 0;
/**
* Given a stylesheet input source, compile the stylesheet into an internal
* representation.
*
* @param stylesheetSource input source for the stylesheet
* @param constructionContext context for construction of objects
* @return pointer to the compiled stylesheet object
* @exception XSLProcessorException
*/
virtual StylesheetRoot*
processStylesheet(
const XSLTInputSource& stylesheetSource,
StylesheetConstructionContext& constructionContext) = 0;
/**
* Given a URI to an XSL stylesheet, compile the stylesheet into an internal
* representation.
*
* @param xmldocURLString URI to the input XML document
* @param constructionContext context for construction of objects
* @return pointer to compiled stylesheet object
* @exception XSLProcessorException
*/
virtual StylesheetRoot*
processStylesheet(
const XalanDOMString& xsldocURLString,
StylesheetConstructionContext& constructionContext) = 0;
/**
* Reset the state. This needs to be called after a process() call
* is invoked, if the processor is to be used again.
*/
virtual void
reset() = 0;
/**
* Given an input source, get the source tree.
*
* @param inputSource pointer to input source
* @return source tree
*/
virtual XalanNode*
getSourceTreeFromInput(const XSLTInputSource& inputSource) = 0;
/**
* Retrieve the root stylesheet.
*
* @return pointer to root stylesheet
*/
virtual const StylesheetRoot*
getStylesheetRoot() const = 0;
/**
* Set the root stylesheet.
*
* @param theStylesheet pointer to new root stylesheet
*/
virtual void
setStylesheetRoot(const StylesheetRoot* theStylesheet) = 0;
/**
* Set the execution context. Must be set if after calling
* setStylesheetRoot.
*
* @param theExecutionContext pointer to new execution context.
*/
virtual void
setExecutionContext(StylesheetExecutionContext* theExecutionContext) = 0;
/**
* Resolve the params that were pushed by the caller.
*/
virtual void
resolveTopLevelParams(StylesheetExecutionContext& executionContext) = 0;
/**
* Get the XML Parser Liaison that this processor uses.
*
* @return XML parser liaison object
*/
virtual XMLParserLiaison&
getXMLParserLiaison() const = 0;
/**
* Generate a random namespace prefix guaranteed to be unique.
*
* @param theValue A string for returning the new prefix
*/
virtual void
getUniqueNamespaceValue(XalanDOMString& theValue) = 0;
/**
* Push a top-level stylesheet parameter. This value can be evaluated via
* xsl:param-variable.
*
* @param key name of the parameter
* @param value XObject value for parameter
*/
virtual void
setStylesheetParam(
const XalanDOMString& key,
XObjectPtr value) = 0;
/**
* Push a top-level stylesheet parameter. This value can be evaluated via
* xsl:param-variable.
*
* @param key name of the param
* @param expression expression that will be evaluated
*/
virtual void
setStylesheetParam(
const XalanDOMString& key,
const XalanDOMString& expression) = 0;
/**
* Get the current formatter listener.
*
* @return pointer to formatter listener
*/
virtual FormatterListener*
getFormatterListener() const = 0;
/**
* Set the current formatter listener.
*
* @param flistener pointer to new formatter listener
*/
virtual void
setFormatterListener(FormatterListener* flistener) = 0;
/**
* Determine the number of trace listeners.
*
* @return number of listeners
*/
virtual size_type
getTraceListeners() const = 0;
/**
* Add a trace listener for the purposes of debugging and diagnosis.
*
* @param tl pointer to listener to add
*/
virtual void
addTraceListener(TraceListener* tl) = 0;
/**
* Remove a trace listener.
*
* @param tl Trace listener to be removed.
*/
virtual void
removeTraceListener(TraceListener* tl) = 0;
/**
* Fire a generate event.
*
* @param ge generate event to fire
*/
virtual void
fireGenerateEvent(const GenerateEvent& ge) = 0;
/**
* Fire a trace event.
*
* @param te trace event to fire
*/
virtual void
fireTraceEvent(const TracerEvent& te) = 0;
/**
* Fire a selection event.
*
* @param se selection event to fire
*/
virtual void
fireSelectEvent(const SelectionEvent& se) = 0;
/**
* If this is set to true, simple traces of template calls are made.
*
* @return true if traces made
*/
virtual bool
getTraceSelects() const = 0;
/**
* Compose a diagnostic trace of the current selection
*
* @param executionContext The current execution context
* @param theStylesheetElement The executing stylesheet element
* @param nl The list of selected nodes
* @param xpath A pointer to the XPath which generated the list of nodes, if any.
*/
virtual void
traceSelect(
StylesheetExecutionContext& executionContext,
const ElemTemplateElement& theStylesheetElement,
const NodeRefListBase& nl,
const XPath* xpath) const = 0;
/**
* If the quietConflictWarnings property is set to
* true, warnings about pattern conflicts won't be
* printed to the diagnostics stream.
* True by default.
*
* @param b true if conflict warnings should be suppressed.
*/
virtual void
setQuietConflictWarnings(bool b) = 0;
/**
* If this is set, diagnostics will be
* written to the m_diagnosticsPrintWriter stream. If
* the value is null, then diagnostics will be turned
* off.
*
* @param pw pointer to print writer
*/
virtual void
setDiagnosticsOutput(PrintWriter* pw) = 0;
/**
* Report a message.
*
* @param msg text of message to output
* @param sourceNode node in source where message occurred
* @param styleNode node in stylesheet where message occurred
*/
virtual void
message(
const XalanDOMString& msg,
const XalanNode* sourceNode = 0,
const ElemTemplateElement* styleNode = 0) const = 0;
/**
* Report a message.
*
* @param msg text of message to output
* @param locator A LocatorType for error reporting
* @param sourceNode node in source where message occurred
*/
virtual void
message(
const XalanDOMString& msg,
const LocatorType& locator,
const XalanNode* sourceNode = 0) const = 0;
/**
* Report a warning.
*
* @param msg text of message to output
* @param sourceNode node in source where warning occurred
* @param styleNode node in stylesheet where warning occurred
*/
virtual void
warn(
const XalanDOMString& msg,
const XalanNode* sourceNode = 0,
const ElemTemplateElement* styleNode = 0) const = 0;
/**
* Report a warning.
*
* @param msg text of message to output
* @param locator A LocatorType for error reporting
* @param sourceNode node in source where error occurred
*/
virtual void
warn(
const XalanDOMString& msg,
const LocatorType& locator,
const XalanNode* sourceNode = 0) const = 0;
/**
* Report an error and throw an exception.
*
* @param msg text of message to output
* @param sourceNode node in source where error occurred
* @param styleNode node in stylesheet where error occurred
*/
virtual void
error(
const XalanDOMString& msg,
const XalanNode* sourceNode = 0,
const ElemTemplateElement* styleNode = 0) const = 0;
/**
* Report an error and throw an exception.
*
* @param msg text of message to output
* @param locator A LocatorType for error reporting
* @param sourceNode node in source where error occurred
*/
virtual void
error(
const XalanDOMString& msg,
const LocatorType& locator,
const XalanNode* sourceNode = 0) const = 0;
};
XALAN_CPP_NAMESPACE_END
#endif // XALAN_XSLTPROCESSOR_HEADER_GUARD
|