Class StaticQueryContext
- java.lang.Object
- 
- net.sf.saxon.query.StaticQueryContext
 
- 
- Direct Known Subclasses:
- StaticQueryContextPE
 
 public class StaticQueryContext extends java.lang.ObjectStaticQueryContext contains information used to build a StaticContext for use when processing XQuery expressions.Despite its name, StaticQueryContextno longer implements theStaticContextinterface, which means it cannot be used directly by Saxon when parsing a query. Instead it is first copied to create aQueryModuleobject, which does implement theStaticContextinterface.The application constructs a StaticQueryContext and initializes it with information about the context, for example, default namespaces, base URI, and so on. When a query is compiled using this StaticQueryContext, the query parser makes a copy of the StaticQueryContext and uses this internally, modifying it with information obtained from the query prolog, as well as information such as namespace and variable declarations that can occur at any point in the query. The query parser does not modify the original StaticQueryContext supplied by the calling application, which may therefore be used for compiling multiple queries, serially or even in multiple threads. This class forms part of Saxon's published XQuery API. Methods that are considered stable are labelled with the JavaDoc "since" tag. The value 8.4 indicates a method introduced at or before Saxon 8.4; other values indicate the version at which the method was introduced. In the longer term, this entire API may at some stage be superseded by a proposed standard Java API for XQuery. - Since:
- 8.4
 
- 
- 
Constructor SummaryConstructors Modifier Constructor Description protectedStaticQueryContext()Private constructor used when copying a contextStaticQueryContext(Configuration config)Create a StaticQueryContext using a given Configuration.StaticQueryContext(Configuration config, boolean initialize)Create a StaticQueryContext using a given Configuration.StaticQueryContext(StaticQueryContext c)Create a copy of a supplied StaticQueryContext
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voidclearDeclaredGlobalVariables()Clear all declared global variablesvoidclearNamespaces()Clear all the user-declared namespacesvoidcompileLibrary(java.io.InputStream source, java.lang.String encoding)Prepare an XQuery library module for subsequent evaluation.voidcompileLibrary(java.io.Reader source)Prepare an XQuery library module for subsequent evaluation.voidcompileLibrary(java.lang.String query)Compile an XQuery library module for subsequent evaluation.XQueryExpressioncompileQuery(java.io.InputStream source, java.lang.String encoding)Prepare an XQuery query for subsequent evaluation.XQueryExpressioncompileQuery(java.io.Reader source)Prepare an XQuery query for subsequent evaluation.XQueryExpressioncompileQuery(java.lang.String query)Prepare an XQuery query for subsequent evaluation.voidcopyFrom(StaticQueryContext c)Copy details from another StaticQueryContextvoiddeclareDefaultCollation(java.lang.String name)Set the default collation.voiddeclareGlobalVariable(StructuredQName qName, SequenceType type, Sequence value, boolean external)Declare a global variable.voiddeclareNamespace(java.lang.String prefix, java.lang.String uri)Declare a namespace whose prefix can be used in expressions.java.lang.StringgetBaseURI()Get the Base URI of the query, for resolving any relative URI's used in the expression.CodeInjectorgetCodeInjector()Get any CodeInjector that has been registeredjava.util.Collection<QueryLibrary>getCompiledLibraries()QueryLibrarygetCompiledLibrary(java.lang.String namespace)Get a previously compiled library moduleConfigurationgetConfiguration()Get the Configuration optionsintgetConstructionMode()Get the current construction modejava.lang.StringgetDefaultCollationName()Get the name of the default collation.java.lang.StringgetDefaultElementNamespace()Get the default namespace for elements and typesjava.lang.StringgetDefaultFunctionNamespace()Get the default function namespacejavax.xml.transform.ErrorListenergetErrorListener()Deprecated.since 10.0: usegetErrorReporter()ErrorReportergetErrorReporter()Get the error reporter: that is, a used-supplied object that is to receive notification of static errors found in the stylesheetFunctionLibrarygetExtensionFunctionLibrary()Get any extension function library that was previously set.intgetLanguageVersion()Get the language versionLocationgetModuleLocation()Get the module location.ModuleURIResolvergetModuleURIResolver()Get the user-defined ModuleURIResolver for resolving URIs used in "import module" declarations in the XQuery prolog; returns null if none has been explicitly set either on the StaticQueryContext or on the Configuration.NamePoolgetNamePool()Get the NamePool used for compiling expressionsjava.lang.StringgetNamespaceForPrefix(java.lang.String prefix)Get the namespace URI for a given prefix, which must have been declared using the methoddeclareNamespace(java.lang.String, java.lang.String).OptimizerOptionsgetOptimizerOptions()Get the optimizer options being used for compiling queries that use this static context.ItemTypegetRequiredContextItemType()Get the required type of the context item.java.lang.StringgetSystemId()Get the system ID of the container of the expression.protected java.util.HashMap<java.lang.String,java.lang.String>getUserDeclaredNamespaces()Get the map of user-declared namespacesbooleanisCompileWithTracing()Ask whether compile-time generation of trace code was requestedbooleanisEmptyLeast()Ask where an empty sequence should appear in the collation order, if not otherwise specified in the "order by" clausebooleanisInheritNamespaces()Get the namespace inheritance modebooleanisPreserveBoundarySpace()Ask whether the policy for boundary space is "preserve" or "strip"booleanisPreserveNamespaces()Get the namespace copy modebooleanisSchemaAware()Ask whether this query is schema-awarebooleanisStreaming()Ask whether the streaming option has been set, that is, whether subsequent calls on compile() will compile queries to be capable of executing in streaming mode.booleanisUpdating()Ask whether XQuery Update is allowedbooleanisUpdatingEnabled()Ask whether the query is allowed to be updatingjava.util.Iterator<GlobalVariable>iterateDeclaredGlobalVariables()Iterate over all the declared global variablesjava.util.Iterator<java.lang.String>iterateDeclaredPrefixes()Get the namespace prefixes that have been declared using the methoddeclareNamespace(java.lang.String, java.lang.String)static StaticQueryContextmakeDefaultStaticQueryContext(Configuration config)Static method used to create the default static context: intended for internal use onlyExecutablemakeExecutable()Get the executable containing this queryvoidreset()Reset the state of this StaticQueryContext to an uninitialized statevoidsetBaseURI(java.lang.String baseURI)Set the Base URI of the queryvoidsetCodeInjector(CodeInjector injector)Request that the parser should insert custom code into the expression tree by calling a supplied CodeInjector to process each expression as it is parsed, for example for tracing or performance measurementvoidsetCompileWithTracing(boolean trace)Request compile-time generation of trace code (or not)voidsetConfiguration(Configuration config)Set the Configuration optionsvoidsetConstructionMode(int mode)Set the construction mode for this modulevoidsetDefaultElementNamespace(java.lang.String uri)Set the default element namespacevoidsetDefaultFunctionNamespace(java.lang.String defaultFunctionNamespace)Set the default function namespacevoidsetEmptyLeast(boolean least)Set the option for where an empty sequence appears in the collation order, if not otherwise specified in the "order by" clausevoidsetErrorListener(javax.xml.transform.ErrorListener listener)Deprecated.since 10.0: usesetErrorReporter(ErrorReporter)voidsetErrorReporter(ErrorReporter reporter)Set an error reporter: that is, a used-supplied object that is to receive notification of static errors found in the stylesheetvoidsetInheritNamespaces(boolean inherit)Set the namespace inheritance modevoidsetLanguageVersion(int version)Deprecated.since 10.0voidsetModuleLocation(Location location)Set the module location.voidsetModuleURIResolver(ModuleURIResolver resolver)Set a user-defined ModuleURIResolver for resolving URIs used in "import module" declarations in the XQuery prolog.voidsetOptimizerOptions(OptimizerOptions options)Set the optimizer options to be used for compiling queries that use this static context.voidsetPreserveBoundarySpace(boolean preserve)Set the policy for preserving boundary spacevoidsetPreserveNamespaces(boolean inherit)Set the namespace copy modevoidsetRequiredContextItemType(ItemType type)Declare the static type of the context item.voidsetSchemaAware(boolean aware)Say whether this query is schema-awarevoidsetStreaming(boolean option)Say whether the query should be compiled and evaluated to use streaming.voidsetUpdatingEnabled(boolean updating)Say whether the query is allowed to be updating.
 
- 
- 
- 
Constructor Detail- 
StaticQueryContextprotected StaticQueryContext() Private constructor used when copying a context
 - 
StaticQueryContextpublic StaticQueryContext(Configuration config) Create a StaticQueryContext using a given Configuration. This creates a StaticQueryContext for a main module (that is, a module that is not a library module). The static query context is initialized from the default static query context held in the configuration.- Parameters:
- config- the Saxon Configuration
- Since:
- 8.4
 
 - 
StaticQueryContextpublic StaticQueryContext(Configuration config, boolean initialize) Create a StaticQueryContext using a given Configuration. This creates a StaticQueryContext for a main module (that is, a module that is not a library module). The static query context is initialized from the default static query context held in the configuration only if theinitializeargument is set to true.- Parameters:
- config- the Saxon Configuration
- initialize- specifies whether the static context should be initialized using defaults held in the configuration. Setting this to true has the same effect as calling the single-argument constructor. Setting it to false is typically used only when creating the default static query context held by the configuration.
- Since:
- 9.9
 
 - 
StaticQueryContextpublic StaticQueryContext(StaticQueryContext c) Create a copy of a supplied StaticQueryContext- Parameters:
- c- the StaticQueryContext to be copied
 
 
- 
 - 
Method Detail- 
makeDefaultStaticQueryContextpublic static StaticQueryContext makeDefaultStaticQueryContext(Configuration config) Static method used to create the default static context: intended for internal use only
 - 
copyFrompublic void copyFrom(StaticQueryContext c) Copy details from another StaticQueryContext- Parameters:
- c- the other StaticQueryContext
 
 - 
resetpublic void reset() Reset the state of this StaticQueryContext to an uninitialized state- Since:
- 8.4
 
 - 
setConfigurationpublic void setConfiguration(Configuration config) Set the Configuration options- Parameters:
- config- the Saxon Configuration
- Throws:
- java.lang.IllegalArgumentException- if the configuration supplied is different from the existing configuration
- Since:
- 8.4
 
 - 
getConfigurationpublic Configuration getConfiguration() Get the Configuration options- Returns:
- the Saxon configuration
- Since:
- 8.4
 
 - 
makeExecutablepublic Executable makeExecutable() Get the executable containing this query- Returns:
- the executable (which is newly created by this method)
 
 - 
setSchemaAwarepublic void setSchemaAware(boolean aware) Say whether this query is schema-aware- Parameters:
- aware- true if this query is schema-aware
- Since:
- 9.2.1.2
 
 - 
isSchemaAwarepublic boolean isSchemaAware() Ask whether this query is schema-aware- Returns:
- true if this query is schema-aware
- Since:
- 9.2.1.2
 
 - 
setStreamingpublic void setStreaming(boolean option) Say whether the query should be compiled and evaluated to use streaming. This affects subsequent calls on the compile() methods. This option requires Saxon-EE.- Parameters:
- option- if true, the compiler will attempt to compile a query to be capable of executing in streaming mode. If the query cannot be streamed, a compile-time exception is reported. In streaming mode, the source document is supplied as a stream, and no tree is built in memory. The default is false. Setting the value to true has the side-effect of setting the required context item type to "document node"; this is to ensure that expresions such as //BOOK are streamable.
- Since:
- 9.6
 
 - 
isStreamingpublic boolean isStreaming() Ask whether the streaming option has been set, that is, whether subsequent calls on compile() will compile queries to be capable of executing in streaming mode.- Returns:
- true if the streaming option has been set.
- Since:
- 9.6
 
 - 
setBaseURIpublic void setBaseURI(java.lang.String baseURI) Set the Base URI of the query- Parameters:
- baseURI- the base URI of the query, or null to indicate that no base URI is available. This should be a valid absolute URI.
- Since:
- 8.4
 
 - 
setLanguageVersionpublic void setLanguageVersion(int version) Deprecated.since 10.0Set the language version.- Parameters:
- version- The XQuery language version. Must be 10 (="1.0") or 30 (="3.0") or 31 (="3.1").
- Since:
- 9.2; changed in 9.3 to expect a DecimalValue rather than a string. Changed in 9.7 to accept an int (30 = "3.0") and to allow "3.1". From 9.8.0.3 the supplied value is ignored and the language version is always set to "3.1".
 
 - 
getLanguageVersionpublic int getLanguageVersion() Get the language version- Returns:
- the language version. Either "1.0" or "1.1". Default is "1.0".
- Since:
- 9.2; changed in 9.3 to return a DecimalValue rather than a string; changed in 9.7 to return an int (30 = "3.0" and so on). Changed in 9.8.0.3 to always return 31.
 
 - 
getExtensionFunctionLibrarypublic FunctionLibrary getExtensionFunctionLibrary() Get any extension function library that was previously set.- Returns:
- the extension function library, or null if none has been set. The result will always be null if called in Saxon-HE; setting an extension function library requires the Saxon-PE or Saxon-EE versions of this class.
- Since:
- 9.4
 
 - 
isCompileWithTracingpublic boolean isCompileWithTracing() Ask whether compile-time generation of trace code was requested- Returns:
- true if compile-time generation of code was requested
- Since:
- 9.0
 
 - 
setCompileWithTracingpublic void setCompileWithTracing(boolean trace) Request compile-time generation of trace code (or not)- Parameters:
- trace- true if compile-time generation of trace code is required
- Since:
- 9.0
 
 - 
setCodeInjectorpublic void setCodeInjector(CodeInjector injector) Request that the parser should insert custom code into the expression tree by calling a supplied CodeInjector to process each expression as it is parsed, for example for tracing or performance measurement- Parameters:
- injector- the CodeInjector to be used. May be null, in which case no code is injected
- Since:
- 9.4
 
 - 
getCodeInjectorpublic CodeInjector getCodeInjector() Get any CodeInjector that has been registered- Returns:
- the registered CodeInjector, or null
- Since:
- 9.4
 
 - 
isUpdatingpublic boolean isUpdating() Ask whether XQuery Update is allowed- Returns:
- true if XQuery update is supported by queries using this context
 
 - 
setInheritNamespacespublic void setInheritNamespaces(boolean inherit) Set the namespace inheritance mode- Parameters:
- inherit- true if namespaces are inherited, false if not
- Since:
- 8.4
 
 - 
isInheritNamespacespublic boolean isInheritNamespaces() Get the namespace inheritance mode- Returns:
- true if namespaces are inherited, false if not
- Since:
- 8.4
 
 - 
setPreserveNamespacespublic void setPreserveNamespaces(boolean inherit) Set the namespace copy mode- Parameters:
- inherit- true if namespaces are preserved, false if not
- Since:
- 8.4
 
 - 
isPreserveNamespacespublic boolean isPreserveNamespaces() Get the namespace copy mode- Returns:
- true if namespaces are preserved, false if not
- Since:
- 8.4
 
 - 
setConstructionModepublic void setConstructionMode(int mode) Set the construction mode for this module- Parameters:
- mode- one of- Validation.STRIP,- Validation.PRESERVE
- Since:
- 8.4
 
 - 
getConstructionModepublic int getConstructionMode() Get the current construction mode- Returns:
- one of Validation.STRIP,Validation.PRESERVE
- Since:
- 8.4
 
 - 
setModuleLocationpublic void setModuleLocation(Location location) Set the module location. Normally the module location is assumed to be line 1, column 1 of the resource identified by the base URI. But a different location can be set, for example if the query is embedded in an XML document, and this information will be available in diagnostics.- Parameters:
- location- the module location
- Since:
- 9.7
 
 - 
getModuleLocationpublic Location getModuleLocation() Get the module location. Normally the module location is assumed to be line 1, column 1 of the resource identified by the base URI. But a different location can be set, for example if the query is embedded in an XML document, and this information will be available in diagnostics.- Returns:
- the module location
- Since:
- 9.7
 
 - 
setOptimizerOptionspublic void setOptimizerOptions(OptimizerOptions options) Set the optimizer options to be used for compiling queries that use this static context. By default the optimizer options set in theConfigurationare used.- Parameters:
- options- the optimizer options to be used
 
 - 
getOptimizerOptionspublic OptimizerOptions getOptimizerOptions() Get the optimizer options being used for compiling queries that use this static context. By default the optimizer options set in theConfigurationare used.- Returns:
- the optimizer options being used
 
 - 
compileQuerypublic XQueryExpression compileQuery(java.lang.String query) throws XPathException Prepare an XQuery query for subsequent evaluation. The source text of the query is supplied as a String. The base URI of the query is taken from the static context, and defaults to the current working directory.Note that this interface makes the caller responsible for decoding the query and presenting it as a string of characters. This means it is likely that any encoding specified in the query prolog will be ignored. - Parameters:
- query- The XQuery query to be evaluated, supplied as a string.
- Returns:
- an XQueryExpression object representing the prepared expression
- Throws:
- XPathException- if the syntax of the expression is wrong, or if it references namespaces, variables, or functions that have not been declared, or contains other static errors.
- Since:
- 8.4
 
 - 
compileQuerypublic XQueryExpression compileQuery(java.io.Reader source) throws XPathException, java.io.IOException Prepare an XQuery query for subsequent evaluation. The Query is supplied in the form of a Reader. The base URI of the query is taken from the static context, and defaults to the current working directory.Note that this interface makes the Reader responsible for decoding the query and presenting it as a stream of characters. This means it is likely that any encoding specified in the query prolog will be ignored. Also, some implementations of Reader cannot handle a byte order mark. - Parameters:
- source- A Reader giving access to the text of the XQuery query to be compiled.
- Returns:
- an XPathExpression object representing the prepared expression.
- Throws:
- XPathException- if the syntax of the expression is wrong, or if it references namespaces, variables, or functions that have not been declared, or any other static error is reported.
- java.io.IOException- if a failure occurs reading the supplied input.
- Since:
- 8.4
 
 - 
compileQuerypublic XQueryExpression compileQuery(java.io.InputStream source, java.lang.String encoding) throws XPathException Prepare an XQuery query for subsequent evaluation. The Query is supplied in the form of a InputStream, with an optional encoding. If the encoding is not specified, the query parser attempts to obtain the encoding by inspecting the input stream: it looks specifically for a byte order mark, and for the encoding option in the version declaration of an XQuery prolog. The encoding defaults to UTF-8. The base URI of the query is taken from the static context, and defaults to the current working directory.- Parameters:
- source- An InputStream giving access to the text of the XQuery query to be compiled, as a stream of octets
- encoding- The encoding used to translate characters to octets in the query source. The parameter may be null: in this case the query parser attempts to infer the encoding by inspecting the source, and if that fails, it assumes UTF-8 encoding
- Returns:
- an XPathExpression object representing the prepared expression.
- Throws:
- XPathException- if the syntax of the expression is wrong, or if it references namespaces, variables, or functions that have not been declared, or any other static error is reported.
- Since:
- 8.5
 
 - 
compileLibrarypublic void compileLibrary(java.lang.String query) throws XPathExceptionCompile an XQuery library module for subsequent evaluation. This method is supported only in Saxon-EE- Parameters:
- query- the content of the module, as a string
- Throws:
- XPathException- if a static error exists in the query
- java.lang.UnsupportedOperationException- if not using Saxon-EE
- Since:
- 9.2 (changed in 9.3 to return void)
 
 - 
compileLibrarypublic void compileLibrary(java.io.Reader source) throws XPathException, java.io.IOExceptionPrepare an XQuery library module for subsequent evaluation. This method is supported only in Saxon-EE. The effect of the method is that subsequent query compilations using this static context can import the module URI without specifying a location hint; the import then takes effect without requiring the module to be compiled each time it is imported.- Parameters:
- source- the content of the module, as a Reader which supplies the source code
- Throws:
- XPathException- if a static error exists in the query
- java.io.IOException- if the input cannot be read
- java.lang.UnsupportedOperationException- if not using Saxon-EE
- Since:
- 9.2 (changed in 9.3 to return void)
 
 - 
compileLibrarypublic void compileLibrary(java.io.InputStream source, java.lang.String encoding) throws XPathException, java.io.IOExceptionPrepare an XQuery library module for subsequent evaluation. This method is supported only in Saxon-EE. The effect of the method is that subsequent query compilations using this static context can import the module URI without specifying a location hint; the import then takes effect without requiring the module to be compiled each time it is imported.- Parameters:
- source- the content of the module, as an InputStream which supplies the source code
- encoding- the character encoding of the input stream. May be null, in which case the encoding is inferred, for example by looking at the query declaration
- Throws:
- XPathException- if a static error exists in the query
- java.io.IOException- if the input cannot be read
- java.lang.UnsupportedOperationException- if not using Saxon-EE
- Since:
- 9.2 (changed in 9.3 to return void)
 
 - 
getCompiledLibrarypublic QueryLibrary getCompiledLibrary(java.lang.String namespace) Get a previously compiled library module- Parameters:
- namespace- the module namespace
- Returns:
- the QueryLibrary if a module with this namespace has been compiled as a library module; otherwise null. Always null when not using Saxon-EE.
- Since:
- 9.3
 
 - 
getCompiledLibrariespublic java.util.Collection<QueryLibrary> getCompiledLibraries() 
 - 
declareNamespacepublic void declareNamespace(java.lang.String prefix, java.lang.String uri)Declare a namespace whose prefix can be used in expressions. This is equivalent to declaring a prefix in the Query prolog. Any namespace declared in the Query prolog overrides a namespace declared using this API.- Parameters:
- prefix- The namespace prefix. Must not be null. Setting this to "" means that the namespace will be used as the default namespace for elements and types.
- uri- The namespace URI. Must not be null. The value "" (zero-length string) is used to undeclare a namespace; it is not an error if there is no existing binding for the namespace prefix.
- Throws:
- java.lang.NullPointerException- if either the prefix or URI is null
- java.lang.IllegalArgumentException- if the prefix is "xml" and the namespace is not the XML namespace, or vice versa; or if the prefix is "xmlns", or the URI is "http://www.w3.org/2000/xmlns/"
- Since:
- 9.0
 
 - 
clearNamespacespublic void clearNamespaces() Clear all the user-declared namespaces- Since:
- 9.0
 
 - 
getUserDeclaredNamespacesprotected java.util.HashMap<java.lang.String,java.lang.String> getUserDeclaredNamespaces() Get the map of user-declared namespaces- Returns:
- the user-declared namespaces
 
 - 
iterateDeclaredPrefixespublic java.util.Iterator<java.lang.String> iterateDeclaredPrefixes() Get the namespace prefixes that have been declared using the methoddeclareNamespace(java.lang.String, java.lang.String)- Returns:
- an iterator that returns the namespace prefixes that have been explicitly declared, as strings. The default namespace for elements and types will be included, using the prefix "".
- Since:
- 9.0
 
 - 
getNamespaceForPrefixpublic java.lang.String getNamespaceForPrefix(java.lang.String prefix) Get the namespace URI for a given prefix, which must have been declared using the methoddeclareNamespace(java.lang.String, java.lang.String).- Parameters:
- prefix- the namespace prefix, or "" to represent the null prefix
- Returns:
- the namespace URI. Returns "" to represent the non-namespace, null to indicate that the prefix has not been declared
 
 - 
getDefaultFunctionNamespacepublic java.lang.String getDefaultFunctionNamespace() Get the default function namespace- Returns:
- the default function namespace (defaults to the fn: namespace)
- Since:
- 8.4
 
 - 
setDefaultFunctionNamespacepublic void setDefaultFunctionNamespace(java.lang.String defaultFunctionNamespace) Set the default function namespace- Parameters:
- defaultFunctionNamespace- The namespace to be used for unprefixed function calls
- Since:
- 8.4
 
 - 
setDefaultElementNamespacepublic void setDefaultElementNamespace(java.lang.String uri) Set the default element namespace- Parameters:
- uri- the namespace URI to be used as the default namespace for elements and types
- Since:
- 8.4
 
 - 
getDefaultElementNamespacepublic java.lang.String getDefaultElementNamespace() Get the default namespace for elements and types- Returns:
- the namespace URI to be used as the default namespace for elements and types
- Since:
- 8.9 Modified in 8.9 to return the namespace URI as a string rather than an integer code
 
 - 
declareGlobalVariablepublic void declareGlobalVariable(StructuredQName qName, SequenceType type, Sequence value, boolean external) throws XPathException Declare a global variable. This has the same effect as including a global variable declaration in the Query Prolog of the main query module. A static error occurs when compiling the query if the query prolog contains a declaration of the same variable.- Parameters:
- qName- the qualified name of the variable
- type- the declared type of the variable
- value- the initial value of the variable. May be null if the variable is external.
- external- true if the variable is external, that is, if its value may be set at run-time.
- Throws:
- java.lang.NullPointerException- if the value is null, unless the variable is external
- XPathException- if the value of the variable is not consistent with its type.
- Since:
- 9.1
 
 - 
iterateDeclaredGlobalVariablespublic java.util.Iterator<GlobalVariable> iterateDeclaredGlobalVariables() Iterate over all the declared global variables- Returns:
- an iterator over all the global variables that have been declared. They are returned
         as instances of class GlobalVariable
- Since:
- 9.1
 
 - 
clearDeclaredGlobalVariablespublic void clearDeclaredGlobalVariables() Clear all declared global variables- Since:
- 9.1
 
 - 
setModuleURIResolverpublic void setModuleURIResolver(ModuleURIResolver resolver) Set a user-defined ModuleURIResolver for resolving URIs used in "import module" declarations in the XQuery prolog. This will be used for resolving URIs in XQuery "import module" declarations, overriding any ModuleURIResolver that was specified as part of the configuration.- Parameters:
- resolver- the ModuleURIResolver to be used
 
 - 
getModuleURIResolverpublic ModuleURIResolver getModuleURIResolver() Get the user-defined ModuleURIResolver for resolving URIs used in "import module" declarations in the XQuery prolog; returns null if none has been explicitly set either on the StaticQueryContext or on the Configuration.- Returns:
- the registered ModuleURIResolver
 
 - 
declareDefaultCollationpublic void declareDefaultCollation(java.lang.String name) Set the default collation.- Parameters:
- name- The collation name, as specified in the query prolog. Must be the name of a known registered collation.
- Throws:
- java.lang.NullPointerException- if the supplied value is null
- java.lang.IllegalStateException- if the supplied value is not a known collation URI registered with the configuration.
- Since:
- 8.4. Changed in 9.7.0.15 so that it validates the collation name: see bug 3121.
 
 - 
getDefaultCollationNamepublic java.lang.String getDefaultCollationName() Get the name of the default collation.- Returns:
- the name of the default collation; or the name of the codepoint collation if no default collation has been defined. The name is returned in the form it was specified; that is, it is not yet resolved against the base URI. (This is because the base URI declaration can follow the default collation declaration in the query prolog.) If no default collation has been specified, the "default default" (that is, the Unicode codepoint collation) is returned.
- Since:
- 8.4
 
 - 
setRequiredContextItemTypepublic void setRequiredContextItemType(ItemType type) Declare the static type of the context item. If this type is declared, and if a context item is supplied when the query is invoked, then the context item must conform to this type (no type conversion will take place to force it into this type).- Parameters:
- type- the required type of the context item
 
 - 
getRequiredContextItemTypepublic ItemType getRequiredContextItemType() Get the required type of the context item. If no type has been explicitly declared for the context item, an instance of AnyItemType (representing the type item()) is returned.- Returns:
- the required type of the context item
 
 - 
getNamePoolpublic NamePool getNamePool() Get the NamePool used for compiling expressions- Returns:
- the name pool
- Since:
- 8.4
 
 - 
getSystemIdpublic java.lang.String getSystemId() Get the system ID of the container of the expression. Used to construct error messages. Note that the systemID and the Base URI are currently identical, but they might be distinguished in the future.- Returns:
- the Base URI
- Since:
- 8.4
 
 - 
getBaseURIpublic java.lang.String getBaseURI() Get the Base URI of the query, for resolving any relative URI's used in the expression. Note that the systemID and the Base URI are currently identical, but they might be distinguished in the future. Used by the document() function.- Returns:
- the base URI of the query
- Since:
- 8.4
 
 - 
setPreserveBoundarySpacepublic void setPreserveBoundarySpace(boolean preserve) Set the policy for preserving boundary space- Parameters:
- preserve- true if boundary space is to be preserved, false if it is to be stripped
- Since:
- 9.0
 
 - 
isPreserveBoundarySpacepublic boolean isPreserveBoundarySpace() Ask whether the policy for boundary space is "preserve" or "strip"- Returns:
- true if the policy is to preserve boundary space, false if it is to strip it
- Since:
- 9.0
 
 - 
setEmptyLeastpublic void setEmptyLeast(boolean least) Set the option for where an empty sequence appears in the collation order, if not otherwise specified in the "order by" clause- Parameters:
- least- true if the empty sequence is considered less than any other value (the default), false if it is considered greater than any other value
- Since:
- 9.0
 
 - 
isEmptyLeastpublic boolean isEmptyLeast() Ask where an empty sequence should appear in the collation order, if not otherwise specified in the "order by" clause- Returns:
- true if the empty sequence is considered less than any other value (the default), false if it is considered greater than any other value
- Since:
- 9.0
 
 - 
setErrorListenerpublic void setErrorListener(javax.xml.transform.ErrorListener listener) Deprecated.since 10.0: usesetErrorReporter(ErrorReporter)Set the ErrorListener to be used to report compile-time errors in a query. This will also be the default for the run-time error listener used to report dynamic errors.- Parameters:
- listener- the ErrorListener to be used
 
 - 
getErrorListenerpublic javax.xml.transform.ErrorListener getErrorListener() Deprecated.since 10.0: usegetErrorReporter()Get the ErrorListener in use for this static context- Returns:
- the registered ErrorListener
 
 - 
setErrorReporterpublic void setErrorReporter(ErrorReporter reporter) Set an error reporter: that is, a used-supplied object that is to receive notification of static errors found in the stylesheet- Parameters:
- reporter- the object to be notified of static errors
- Since:
- 10.0
 
 - 
getErrorReporterpublic ErrorReporter getErrorReporter() Get the error reporter: that is, a used-supplied object that is to receive notification of static errors found in the stylesheet- Returns:
- the object to be notified of static errors. This may be the error reporter
 that was previously set using setErrorReporter(ErrorReporter), or it may be a system-allocated error reporter.
- Since:
- 10.0
 
 - 
setUpdatingEnabledpublic void setUpdatingEnabled(boolean updating) Say whether the query is allowed to be updating. XQuery update syntax will be rejected during query compilation unless this flag is set.- Parameters:
- updating- true if the query is allowed to use the XQuery Update facility (requires Saxon-EE). If set to false, the query must not be an updating query. If set to true, it may be either an updating or a non-updating query.
- Since:
- 9.1
 
 - 
isUpdatingEnabledpublic boolean isUpdatingEnabled() Ask whether the query is allowed to be updating- Returns:
- true if the query is allowed to use the XQuery Update facility. Note that this does not necessarily mean that the query is an updating query; but if the value is false, the it must definitely be non-updating.
- Since:
- 9.1
 
 
- 
 
-