Package net.sf.saxon.style
Class UseWhenStaticContext
- java.lang.Object
-
- net.sf.saxon.style.UseWhenStaticContext
-
- All Implemented Interfaces:
StaticContext,XSLTStaticContext
public class UseWhenStaticContext extends java.lang.Object implements XSLTStaticContext
This class implements the static context used for evaluating use-when expressions in XSLT 2.0
-
-
Field Summary
Fields Modifier and Type Field Description java.lang.StringbaseURIConfigurationconfigshortdefaultXPathNamespaceFunctionLibraryfunctionLibraryLocationMaplocationMapNamespaceResolvernamespaceContextStyleNodeFactorynodeFactory
-
Constructor Summary
Constructors Constructor Description UseWhenStaticContext(Configuration config, NamespaceResolver namespaceContext)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description VariableReferencebindVariable(int fingerprint)Bind a variable used in this element to the XSLVariable element in which it is declaredjava.lang.StringgetBaseURI()Get the Base URI of the stylesheet element, for resolving any relative URI's used in the expression.java.util.ComparatorgetCollation(java.lang.String name)Get a named collation.ConfigurationgetConfiguration()Get the system configurationjava.lang.StringgetDefaultCollationName()Get the name of the default collation.shortgetDefaultElementNamespace()Get the default XPath namespace, as a namespace code that can be looked up in the NamePooljava.lang.StringgetDefaultFunctionNamespace()Get the default function namespaceFunctionLibrarygetFunctionLibrary()Get the function library containing all the in-scope functions available in this static contextjava.util.SetgetImportedSchemaNamespaces()Get the set of imported schemasintgetLineNumber()Get the line number of the expression within its containing entity Returns -1 if no line number is availableLocationMapgetLocationMap()Get the location mapNamePoolgetNamePool()Get the NamePool used for compiling expressionsNamespaceResolvergetNamespaceResolver()Get a namespace resolver to resolve the namespaces declared in this static context.java.lang.StringgetSystemId()Get the System ID of the container of the expression.java.lang.StringgetURIForPrefix(java.lang.String prefix)Get the URI for a namespace prefix.booleanisAllowedBuiltInType(AtomicType type)Determine whether a built-in type is available in this context.booleanisElementAvailable(java.lang.String qname)Determine if an extension element is availablebooleanisImportedSchema(java.lang.String namespace)Determine whether a Schema for a given target namespace has been imported.booleanisInBackwardsCompatibleMode()Determine whether Backwards Compatible Mode is usedvoidissueWarning(java.lang.String s, javax.xml.transform.SourceLocator locator)Issue a compile-time warningXPathContextmakeEarlyEvaluationContext()Construct a dynamic context for early evaluation of constant subexpressionsvoidsetBaseURI(java.lang.String uri)Set the base URIvoidsetDefaultElementNamespace(short code)Set the default namespace for elements and types
-
-
-
Field Detail
-
config
public Configuration config
-
namespaceContext
public NamespaceResolver namespaceContext
-
functionLibrary
public FunctionLibrary functionLibrary
-
locationMap
public LocationMap locationMap
-
nodeFactory
public StyleNodeFactory nodeFactory
-
baseURI
public java.lang.String baseURI
-
defaultXPathNamespace
public short defaultXPathNamespace
-
-
Constructor Detail
-
UseWhenStaticContext
public UseWhenStaticContext(Configuration config, NamespaceResolver namespaceContext)
-
-
Method Detail
-
getConfiguration
public Configuration getConfiguration()
Get the system configuration- Specified by:
getConfigurationin interfaceStaticContext
-
makeEarlyEvaluationContext
public XPathContext makeEarlyEvaluationContext()
Construct a dynamic context for early evaluation of constant subexpressions- Specified by:
makeEarlyEvaluationContextin interfaceStaticContext
-
getLocationMap
public LocationMap getLocationMap()
Get the location map- Specified by:
getLocationMapin interfaceStaticContext
-
issueWarning
public void issueWarning(java.lang.String s, javax.xml.transform.SourceLocator locator)Issue a compile-time warning- Specified by:
issueWarningin interfaceStaticContext
-
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:
getSystemIdin interfaceStaticContext
-
getLineNumber
public int getLineNumber()
Get the line number of the expression within its containing entity Returns -1 if no line number is available- Specified by:
getLineNumberin interfaceStaticContext
-
getBaseURI
public java.lang.String getBaseURI()
Get the Base URI of the stylesheet element, for resolving any relative URI's used in the expression. Used by the document(), doc(), resolve-uri(), and base-uri() functions. May return null if the base URI is not known.- Specified by:
getBaseURIin interfaceStaticContext
-
getURIForPrefix
public java.lang.String getURIForPrefix(java.lang.String prefix) throws XPathExceptionGet the URI for a namespace prefix. The default namespace is NOT used when the prefix is empty.- Specified by:
getURIForPrefixin interfaceStaticContext- Parameters:
prefix- The prefix- Throws:
XPathException- if the prefix is not declared
-
getNamePool
public NamePool getNamePool()
Get the NamePool used for compiling expressions- Specified by:
getNamePoolin interfaceStaticContext
-
bindVariable
public VariableReference bindVariable(int fingerprint) throws StaticError
Bind a variable used in this element to the XSLVariable element in which it is declared- Specified by:
bindVariablein interfaceStaticContext- Parameters:
fingerprint- the name of the variable- Returns:
- a VariableReference representing the variable reference, suitably initialized to refer to the corresponding variable declaration
- Throws:
StaticError
-
getFunctionLibrary
public FunctionLibrary getFunctionLibrary()
Get the function library containing all the in-scope functions available in this static context- Specified by:
getFunctionLibraryin interfaceStaticContext
-
getCollation
public java.util.Comparator getCollation(java.lang.String name)
Get a named collation.- Specified by:
getCollationin interfaceStaticContext- 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.
-
getDefaultCollationName
public java.lang.String getDefaultCollationName()
Get the name of the default collation.- Specified by:
getDefaultCollationNamein interfaceStaticContext- Returns:
- the name of the default collation; or the name of the codepoint collation if no default collation has been defined
-
getDefaultElementNamespace
public short getDefaultElementNamespace()
Get the default XPath namespace, as a namespace code that can be looked up in the NamePool- Specified by:
getDefaultElementNamespacein interfaceStaticContext
-
getDefaultFunctionNamespace
public java.lang.String getDefaultFunctionNamespace()
Get the default function namespace- Specified by:
getDefaultFunctionNamespacein interfaceStaticContext
-
isInBackwardsCompatibleMode
public boolean isInBackwardsCompatibleMode()
Determine whether Backwards Compatible Mode is used- Specified by:
isInBackwardsCompatibleModein interfaceStaticContext
-
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:
isImportedSchemain interfaceStaticContext
-
getImportedSchemaNamespaces
public java.util.Set getImportedSchemaNamespaces()
Get the set of imported schemas- Specified by:
getImportedSchemaNamespacesin interfaceStaticContext- Returns:
- a Set, the set of URIs representing the names of imported schemas
-
isAllowedBuiltInType
public boolean isAllowedBuiltInType(AtomicType 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:
isAllowedBuiltInTypein interfaceStaticContext- 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:
getNamespaceResolverin interfaceStaticContext- Returns:
- a namespace resolver.
-
isElementAvailable
public boolean isElementAvailable(java.lang.String qname) throws XPathExceptionDetermine if an extension element is available- Specified by:
isElementAvailablein interfaceXSLTStaticContext- Throws:
XPathException- if the name is invalid or the prefix is not declared
-
setBaseURI
public void setBaseURI(java.lang.String uri)
Set the base URI
-
setDefaultElementNamespace
public void setDefaultElementNamespace(short code)
Set the default namespace for elements and types
-
-