Class UseWhenStaticContext

    • Constructor Detail

      • UseWhenStaticContext

        public UseWhenStaticContext​(Configuration config,
                                    NamespaceResolver namespaceContext)
        Create a static context for evaluating use-when expressions
        Parameters:
        config - the Saxon configuration
        namespaceContext - the namespace context in which the use-when expression appears
    • Method Detail

      • issueWarning

        public void issueWarning​(java.lang.String s,
                                 javax.xml.transform.SourceLocator locator)
        Issue a compile-time warning
        Specified by:
        issueWarning in interface StaticContext
        Overrides:
        issueWarning in class AbstractStaticContext
        Parameters:
        s - The warning message. This should not contain any prefix such as "Warning".
        locator - the location of the construct in question. May be null.
      • getSystemId

        public java.lang.String getSystemId()
        Get the System ID of the container of the expression. This is the containing entity (file) and is therefore useful for diagnostics. Use getBaseURI() to get the base URI, which may be different.
        Specified by:
        getSystemId in interface javax.xml.transform.SourceLocator
        Specified by:
        getSystemId in interface StaticContext
        Overrides:
        getSystemId in class AbstractStaticContext
        Returns:
        "" always
      • getURIForPrefix

        public java.lang.String getURIForPrefix​(java.lang.String prefix)
                                         throws XPathException
        Get the URI for a namespace prefix. The default namespace is NOT used when the prefix is empty.
        Specified by:
        getURIForPrefix in interface StaticContext
        Parameters:
        prefix - The prefix
        Returns:
        the corresponding namespace URI
        Throws:
        XPathException - if the prefix is not declared
      • bindVariable

        public VariableReference bindVariable​(StructuredQName qName)
                                       throws XPathException
        Bind a variable used in this element to the XSLVariable element in which it is declared
        Specified by:
        bindVariable in interface StaticContext
        Parameters:
        qName - the name of the variable
        Returns:
        a VariableReference representing the variable reference, suitably initialized to refer to the corresponding variable declaration
        Throws:
        XPathException
      • getCollation

        public StringCollator getCollation​(java.lang.String name)
        Get a named collation.
        Specified by:
        getCollation in interface StaticContext
        Overrides:
        getCollation in class AbstractStaticContext
        Parameters:
        name - The name of the required collation. Supply null to get the default collation.
        Returns:
        the collation; or null if the required collation is not found.
      • isImportedSchema

        public boolean isImportedSchema​(java.lang.String namespace)
        Determine whether a Schema for a given target namespace has been imported. Note that the in-scope element declarations, attribute declarations and schema types are the types registered with the (schema-aware) configuration, provided that their namespace URI is registered in the static context as being an imported schema namespace. (A consequence of this is that within a Configuration, there can only be one schema for any given namespace, including the null namespace).
        Specified by:
        isImportedSchema in interface StaticContext
        Parameters:
        namespace - the target namespace in question
        Returns:
        true if the given namespace has been imported
      • getImportedSchemaNamespaces

        public java.util.Set getImportedSchemaNamespaces()
        Get the set of imported schemas
        Specified by:
        getImportedSchemaNamespaces in interface StaticContext
        Returns:
        a Set, the set of URIs representing the names of imported schemas
      • isAllowedBuiltInType

        public boolean isAllowedBuiltInType​(BuiltInAtomicType type)
        Determine whether a built-in type is available in this context. This method caters for differences between host languages as to which set of types are built in.
        Specified by:
        isAllowedBuiltInType in interface StaticContext
        Overrides:
        isAllowedBuiltInType in class AbstractStaticContext
        Parameters:
        type - the supposedly built-in type. This will always be a type in the XS or XDT namespace.
        Returns:
        true if this type can be used in this static context
      • getNamespaceResolver

        public NamespaceResolver getNamespaceResolver()
        Get a namespace resolver to resolve the namespaces declared in this static context.
        Specified by:
        getNamespaceResolver in interface StaticContext
        Returns:
        a namespace resolver.