Class StaticQueryContextEE


public class StaticQueryContextEE extends StaticQueryContextPE
A version of StaticQueryContext for Saxon-EE, that extends the capability by allowing compilation of library modules.
  • Constructor Details

    • StaticQueryContextEE

      public StaticQueryContextEE(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 StaticQueryContext is initialized from defaults held in the Configuration.
      Parameters:
      config - the Saxon Configuration
      Since:
      9.2
    • StaticQueryContextEE

      public StaticQueryContextEE(EnterpriseConfiguration config, boolean initialize)
  • Method Details

    • copyFrom

      public void copyFrom(StaticQueryContext c)
      Description copied from class: StaticQueryContext
      Copy details from another StaticQueryContext
      Overrides:
      copyFrom in class StaticQueryContext
      Parameters:
      c - the other StaticQueryContext
    • setSchemaAware

      public void setSchemaAware(boolean aware)
      Say whether this query is schema-aware
      Overrides:
      setSchemaAware in class StaticQueryContext
      Parameters:
      aware - true if this query is schema-aware
      Since:
      9.2.1.2
    • isSchemaAware

      public boolean isSchemaAware()
      Ask whether this query is schema-aware
      Overrides:
      isSchemaAware in class StaticQueryContext
      Returns:
      true if this query is schema-aware
      Since:
      9.2.1.2
    • setStreaming

      public 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.
      Overrides:
      setStreaming in class StaticQueryContext
      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 expressions such as //BOOK are streamable.
      Since:
      9.6
    • isStreaming

      public 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.
      Overrides:
      isStreaming in class StaticQueryContext
      Returns:
      true if the streaming option has been set.
      Since:
      9.6
    • compileLibrary

      public void compileLibrary(String query) throws XPathException
      Compile an XQuery library module 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.

      Overrides:
      compileLibrary in class StaticQueryContext
      Parameters:
      query - The XQuery library module to be compiled, supplied as a string.
      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:
      9.2 (changed in 9.3 to return void)
    • compileLibrary

      public void compileLibrary(Reader source) throws XPathException, IOException
      Prepare an XQuery library module 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. 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.

      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.

      Overrides:
      compileLibrary in class StaticQueryContext
      Parameters:
      source - A Reader giving access to the text of the XQuery query to be compiled.
      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.
      IOException - if a failure occurs reading the supplied input.
      Since:
      9.2 (changed in 9.3 to return void)
    • compileLibrary

      public void compileLibrary(InputStream source, String encoding) throws XPathException, IOException
      Prepare an XQuery library module 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 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. 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.
      Overrides:
      compileLibrary in class StaticQueryContext
      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
      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.
      IOException - if a failure occurs reading the supplied input.
      Since:
      9.2 (changed in 9.3 to return void)
    • getCompiledLibrary

      public QueryLibrary getCompiledLibrary(NamespaceUri namespace)
      Get a previously compiled library module
      Overrides:
      getCompiledLibrary in class StaticQueryContext
      Parameters:
      namespace - the module namespace
      Returns:
      the QueryLibrary if a module with this namespace has been compiled as a library module; otherwise null.
      Since:
      9.3
    • getCompiledLibraries

      public Iterable<QueryLibrary> getCompiledLibraries()
      Overrides:
      getCompiledLibraries in class StaticQueryContext