Class UseWhenStaticContext
java.lang.Object
net.sf.saxon.sxpath.AbstractStaticContext
net.sf.saxon.style.UseWhenStaticContext
- All Implemented Interfaces:
Serializable, SourceLocator, Container, StaticContext, XSLTStaticContext
public class UseWhenStaticContext
extends AbstractStaticContext
implements XSLTStaticContext, Container
This class implements the static context used for evaluating use-when expressions in XSLT 2.0
A new instance of this class is created for each use-when expression encountered; there are
therefore no issues with reusability. The class provides a Container for the expression as well
as the static context information; the Executable contains the single XPath expression only, and
is created for the purpose.
- See Also:
-
Field Summary
Fields inherited from class AbstractStaticContext
usingDefaultFunctionLibrary -
Constructor Summary
ConstructorsConstructorDescriptionUseWhenStaticContext(Configuration config, NamespaceResolver namespaceContext) Create a static context for evaluating use-when expressions -
Method Summary
Modifier and TypeMethodDescriptionbindVariable(StructuredQName qName) Bind a variable used in this element to the XSLVariable element in which it is declaredgetCollation(String name) Get a named collation.intGet the granularity of the container.Get a DecimalFormatManager to resolve the names of decimal formats used in calls to the format-number() function.Get the name of the default collation.Get the default function namespaceGet the Executable representing the containing XSLT stylesheetGet the function library containing all the in-scope functions available in this static contextGet the set of imported schemasGet a namespace resolver to resolve the namespaces declared in this static context.Get the System ID of the container of the expression.getURIForPrefix(String prefix) Get the URI for a namespace prefix.booleanDetermine whether a built-in type is available in this context.booleanisElementAvailable(String qname) Determine if an extension element is availablebooleanisImportedSchema(String namespace) Determine whether a Schema for a given target namespace has been imported.booleanDetermine whether Backwards Compatible Mode is usedvoidissueWarning(String s, SourceLocator locator) Issue a compile-time warningMethods inherited from class AbstractStaticContext
addFunctionLibrary, declareCollation, getBaseURI, getCollationMap, getColumnNumber, getConfiguration, getDefaultElementNamespace, getHostLanguage, getLineNumber, getLocationMap, getLocationProvider, getNamePool, getPublicId, getRequiredContextItemType, getXPathLanguageLevel, isSchemaAware, makeEarlyEvaluationContext, setBackwardsCompatibilityMode, setBaseURI, setCollationMap, setConfiguration, setDecimalFormatManager, setDefaultElementNamespace, setDefaultFunctionLibrary, setDefaultFunctionNamespace, setFunctionLibrary, setLocationMap, setSchemaAware, setXPathLanguageLevelMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface Container
getHostLanguage, getLocationProviderMethods inherited from interface SourceLocator
getColumnNumber, getLineNumber, getPublicIdMethods inherited from interface StaticContext
getBaseURI, getConfiguration, getDefaultElementNamespace, getLineNumber, getLocationMap, getNamePool, getRequiredContextItemType, getXPathLanguageLevel, isSchemaAware, makeEarlyEvaluationContext
-
Constructor Details
-
UseWhenStaticContext
Create a static context for evaluating use-when expressions- Parameters:
config- the Saxon configurationnamespaceContext- the namespace context in which the use-when expression appears
-
-
Method Details
-
getExecutable
Get the Executable representing the containing XSLT stylesheet- Specified by:
getExecutablein interfaceContainer- Returns:
- the Executable
-
issueWarning
Issue a compile-time warning- Specified by:
issueWarningin interfaceStaticContext- Overrides:
issueWarningin classAbstractStaticContext- 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
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 interfaceSourceLocator- Specified by:
getSystemIdin interfaceStaticContext- Overrides:
getSystemIdin classAbstractStaticContext- Returns:
- "" always
-
getContainerGranularity
public int getContainerGranularity()Get the granularity of the container.- Specified by:
getContainerGranularityin interfaceContainer- Returns:
- 0 for a temporary container created during parsing; 1 for a container that operates at the level of an XPath expression; 2 for a container at the level of a global function or template
-
getURIForPrefix
Get 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- Returns:
- the corresponding namespace URI
- Throws:
XPathException- if the prefix is not declared
-
bindVariable
Bind a variable used in this element to the XSLVariable element in which it is declared- Specified by:
bindVariablein interfaceStaticContext- Parameters:
qName- the name of the variable- Returns:
- an expression representing the variable reference, This will often be
a
VariableReference, suitably initialized to refer to the corresponding variable declaration, but in general it can be any expression. - Throws:
XPathException
-
getFunctionLibrary
Get the function library containing all the in-scope functions available in this static context- Specified by:
getFunctionLibraryin interfaceStaticContext- Overrides:
getFunctionLibraryin classAbstractStaticContext- Returns:
- the function library
-
getCollation
Get a named collation.- Specified by:
getCollationin interfaceStaticContext- Overrides:
getCollationin classAbstractStaticContext- 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
Get the name of the default collation.- Specified by:
getDefaultCollationNamein interfaceStaticContext- Overrides:
getDefaultCollationNamein classAbstractStaticContext- Returns:
- the name of the default collation; or the name of the codepoint collation if no default collation has been defined
-
getDefaultFunctionNamespace
Get the default function namespace- Specified by:
getDefaultFunctionNamespacein interfaceStaticContext- Overrides:
getDefaultFunctionNamespacein classAbstractStaticContext- Returns:
- the default namesapce for functions
-
isInBackwardsCompatibleMode
public boolean isInBackwardsCompatibleMode()Determine whether Backwards Compatible Mode is used- Specified by:
isInBackwardsCompatibleModein interfaceStaticContext- Overrides:
isInBackwardsCompatibleModein classAbstractStaticContext- Returns:
- true if XPath 1.0 compatibility mode is to be set to true; otherwise false
-
isImportedSchema
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- Parameters:
namespace- the target namespace in question- Returns:
- true if the given namespace has been imported
-
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
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- Overrides:
isAllowedBuiltInTypein classAbstractStaticContext- 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
Get a namespace resolver to resolve the namespaces declared in this static context.- Specified by:
getNamespaceResolverin interfaceStaticContext- Returns:
- a namespace resolver.
-
getDecimalFormatManager
Get a DecimalFormatManager to resolve the names of decimal formats used in calls to the format-number() function.- Specified by:
getDecimalFormatManagerin interfaceStaticContext- Overrides:
getDecimalFormatManagerin classAbstractStaticContext- Returns:
- the decimal format manager for this static context, or null if named decimal formats are not supported in this environment.
-
isElementAvailable
Determine if an extension element is available- Specified by:
isElementAvailablein interfaceXSLTStaticContext- Throws:
XPathException- if the name is invalid or the prefix is not declared
-