Package net.sf.saxon.style
Class StylesheetPackage
- java.lang.Object
- 
- net.sf.saxon.expr.PackageData
- 
- net.sf.saxon.style.StylesheetPackage
 
 
- 
- Direct Known Subclasses:
- StylesheetPackageEE
 
 public class StylesheetPackage extends PackageData A (compiled) stylesheet package. This may be created either by compiling a source XSLT package, or by loading a saved package from disk. It therefore has no references to source XSLT documents.
- 
- 
Field SummaryFields Modifier and Type Field Description protected java.util.PropertiesdefaultOutputPropertiesprotected GlobalContextRequirementglobalContextRequirementprotected java.util.List<Component>hiddenComponentsprotected java.util.Map<StructuredQName,java.util.Properties>namedOutputPropertiesprotected java.util.HashMap<SymbolicName,Component>overriddenComponentsprotected java.util.Set<java.lang.String>schemaIndexprotected SpaceStrippingRulestripperRules- 
Fields inherited from class net.sf.saxon.expr.PackageDataconfig, keyManager
 
- 
 - 
Constructor SummaryConstructors Constructor Description StylesheetPackage(Configuration config)Create a stylesheet package
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddCompletionAction(Action action)Register a callback action to be performed during the completion phase of building the packagevoidaddComponent(Component component)Add a component to the packagevoidaddComponentsFromUsedPackage(StylesheetPackage usedPackage, java.util.List<XSLAccept> acceptors, java.util.Set<SymbolicName> overrides)Add modified copies of components from a package that is referenced from this one in an xsl:use-package declarationvoidaddGlobalVariable(GlobalVariable variable)Add a global variable to the list of global variables contained in this packagevoidaddHiddenComponent(Component component)protected voidaddIxslFunctionLibrary(FunctionLibraryList functionLibrary)voidaddOverriddenComponent(Component comp)voidaddUsedPackage(StylesheetPackage pack)Add a package to the list of packages directly used by this onevoidallocateBinderySlots()Allocate slots to global variables.voidcheckForAbstractComponents()protected voidcomplete()Perform all registered completion actions for the packagebooleancontains(StylesheetPackage pack)Ask whether a given library package is within the package subtree rooted at this packagevoidcreateFunctionLibrary()Create the function library containing stylesheet functions declared in this packagevoidexport(ExpressionPresenter presenter)Output the abstract expression tree to the supplied destination.java.util.Map<SymbolicName,Component>getAbstractComponents()CharacterMapIndexgetCharacterMapIndex()Get the index of named character maps defined in this packageComponentgetComponent(SymbolicName name)Get the component within this package having a given symbolic namejava.util.HashMap<SymbolicName,Component>getComponentIndex()Get a map containing all the components in this package, indexed by symbolic nameGlobalContextRequirementgetContextItemRequirements()Get the required context item type and other details of the global context item.StructuredQNamegetDefaultMode()Get the default mode for the packageprotected UserFunctiongetFunction(SymbolicName.F name)Get the function with a given name and arityFunctionLibraryListgetFunctionLibrary()Get the function library.intgetMaxFunctionArity()Get the maximum arity of functions in this packagejava.util.PropertiesgetNamedOutputProperties(StructuredQName name)Get a set of named output propertiesComponentgetOverriddenComponent(SymbolicName name)If this component overrides a component named N, get the component that N overrides (that is, the component identified by xsl:original appearing within the overriding declaration of N)java.lang.StringgetPackageName()Get the name identifier of the xsl:package as an absolute URIPackageVersiongetPackageVersion()Get the package-version identifier appearing on the xsl:package elementFunctionLibrarygetPublicFunctions()Get the library of functions exposed by this stylesheet package, that is, functions whose visibility is public or finalRuleManagergetRuleManager()Get the rule manager, which knows about all the modes present in the packagejava.util.Set<java.lang.String>getSchemaNamespaces()Get the set of namespaces of schema declarations imported into this packageSpaceStrippingRulegetSpaceStrippingRule()Get the whitespace stripping rules for this packageSpaceStrippingRulegetStripperRules()Get the whitespace stripping rules for source documents loaded from within this packagejava.lang.Iterable<StylesheetPackage>getUsedPackages()Get the packages referenced from this package in an xsl:use-package declarationintgetVersion()Get the version of the XSLT language specification to which the package manifest conformsXQueryFunctionLibrarygetXQueryFunctionLibrary()Get the library of functions imported from XQuerybooleanisCreatesSecondaryResultDocuments()Ask whether the package contains an xsl:result-document instructionbooleanisDeclaredModes()Ask whether it is required that modes be explicitly declaredbooleanisFallbackToNonStreaming()Ask whether a non-streamable construct has been found, forcing the entire stylesheet to fall back to unstreamed processingbooleanisImplicitPackage()Ask if this is an implicit package (one rooted at xsl:stylesheet or xsl:transform rather than xsl:packagebooleanisJustInTimeCompilation()Ask whether the package was compiled with just-in-time compilation of template rules enabledbooleanisRetainUnusedFunctions()Ask whether private functions for which there are no static references need to be retainedbooleanisStripsTypeAnnotations()Ask whether the package defines that type annotations should be stripped from input documents loaded from within this packagebooleanisStripsWhitespace()Ask whether there is an xsl:strip-space declaration in the stylesheet packagevoidmarkNonExportable(java.lang.String message, java.lang.String errorCode)Mark the package as non-exportable, supplying an error message to be reported if export is attemptedvoidsetCharacterMapIndex(CharacterMapIndex characterMapIndex)Set the index of named character maps defined in this packagevoidsetContextItemRequirements(GlobalContextRequirement requirement)Set the required context item type.voidsetCreatesSecondaryResultDocuments(boolean createsSecondaryResultDocuments)Say whether the package contains an xsl:result-document instructionvoidsetDeclaredModes(boolean declared)Say whether it is required that modes be explicitly declaredvoidsetDefaultMode(StructuredQName defaultMode)Set the default mode for the packagevoidsetDefaultOutputProperties(java.util.Properties props)Set the default (unnamed) serialization properties to be used for documents output using xsl:result-document instructions within this packagevoidsetFallbackToNonStreaming()voidsetFunctionLibraryDetails(FunctionLibraryList library, ExecutableFunctionLibrary overriding, ExecutableFunctionLibrary underriding)Set details of functions available for calling anywhere in this package.voidsetImplicitPackage(boolean implicitPackage)Say whether this is an implicit package (one rooted at xsl:stylesheet or xsl:transform rather than xsl:packagevoidsetJustInTimeCompilation(boolean justInTimeCompilation)Say whether the package was compiled with just-in-time compilation of template rules enabled.voidsetNamedOutputProperties(StructuredQName name, java.util.Properties props)Define a named set serialization properties to be used for documents output using xsl:result-document instructions within this packagevoidsetPackageName(java.lang.String packageName)Set the name of the packagevoidsetPackageVersion(PackageVersion version)Set the package-version identifier appearing on the xsl:package elementvoidsetRetainUnusedFunctions()Say that private functions need to be retained, typically because the stylesheet package uses xsl:evaluate or fn:function-lookupvoidsetRuleManager(RuleManager ruleManager)Set the rule manager, which knows about all the modes present in the packagevoidsetStripperRules(SpaceStrippingRule stripperRules)Set the whitespace stripping rules for source documents loaded from within this packagevoidsetStripsTypeAnnotations(boolean stripsTypeAnnotations)Say whether the package defines that type annotations should be stripped from input documents loaded from within this packagevoidsetStripsWhitespace(boolean strips)Say whether there is an xsl:strip-space declaration in the stylesheet packagevoidsetVersion(int version)Set the version of the XSLT language specification to which the package manifest conformsvoidupdatePreparedStylesheet(PreparedStylesheet pss)Copy information from this package to the PreparedStylesheet.- 
Methods inherited from class net.sf.saxon.expr.PackageDatagetAccumulatorRegistry, getConfiguration, getDecimalFormatManager, getGlobalSlotManager, getGlobalVariableList, getHostLanguage, getKeyManager, getLocalLicenseId, getTargetEdition, isRelocatable, isSchemaAware, isXSLT, obtainTypeAliasManager, setAccumulatorRegistry, setConfiguration, setDecimalFormatManager, setGlobalSlotManager, setHostLanguage, setKeyManager, setLocalLicenseId, setRelocatable, setSchemaAware, setTargetEdition, setTypeAliasManager
 
- 
 
- 
- 
- 
Field Detail- 
globalContextRequirementprotected GlobalContextRequirement globalContextRequirement 
 - 
stripperRulesprotected SpaceStrippingRule stripperRules 
 - 
defaultOutputPropertiesprotected java.util.Properties defaultOutputProperties 
 - 
namedOutputPropertiesprotected java.util.Map<StructuredQName,java.util.Properties> namedOutputProperties 
 - 
schemaIndexprotected java.util.Set<java.lang.String> schemaIndex 
 - 
hiddenComponentsprotected java.util.List<Component> hiddenComponents 
 - 
overriddenComponentsprotected java.util.HashMap<SymbolicName,Component> overriddenComponents 
 
- 
 - 
Constructor Detail- 
StylesheetPackagepublic StylesheetPackage(Configuration config) Create a stylesheet package- Parameters:
- config- the Saxon Configuration
 
 
- 
 - 
Method Detail- 
getComponentIndexpublic java.util.HashMap<SymbolicName,Component> getComponentIndex() Get a map containing all the components in this package, indexed by symbolic name- Returns:
- a map containing all the components in the package. This does not include components in used packages, except to the extent that they have been copied into this package.
 
 - 
getUsedPackagespublic java.lang.Iterable<StylesheetPackage> getUsedPackages() Get the packages referenced from this package in an xsl:use-package declaration- Returns:
- the packages used by this package
 
 - 
addUsedPackagepublic void addUsedPackage(StylesheetPackage pack) Add a package to the list of packages directly used by this one- Parameters:
- pack- the used package
 
 - 
containspublic boolean contains(StylesheetPackage pack) Ask whether a given library package is within the package subtree rooted at this package- Parameters:
- pack- the library package
- Returns:
- true if the given library package is in the transitive contents of this package
 
 - 
setVersionpublic void setVersion(int version) Set the version of the XSLT language specification to which the package manifest conforms- Parameters:
- version- the version (times ten) as an integer
 
 - 
setPackageNamepublic void setPackageName(java.lang.String packageName) Set the name of the package- Parameters:
- packageName- the name of the package. This is supposed to be an absolute URI, but Saxon accepts any string.
 
 - 
getVersionpublic int getVersion() Get the version of the XSLT language specification to which the package manifest conforms- Returns:
- the version of the xslPackage, times ten, as an integer
 
 - 
getPackageVersionpublic PackageVersion getPackageVersion() Get the package-version identifier appearing on the xsl:package element- Returns:
- the version identifier as a structured entity
 
 - 
setPackageVersionpublic void setPackageVersion(PackageVersion version) Set the package-version identifier appearing on the xsl:package element- Parameters:
- version- the version identifier as a structured entity
 
 - 
getPackageNamepublic java.lang.String getPackageName() Get the name identifier of the xsl:package as an absolute URI- Returns:
- a string value. This is supposed to be an absolute URI, but Saxon accepts any string.
 
 - 
isImplicitPackagepublic boolean isImplicitPackage() Ask if this is an implicit package (one rooted at xsl:stylesheet or xsl:transform rather than xsl:package- Returns:
- true if this package was rooted at an xsl:stylesheet or xsl:transform element
 
 - 
setImplicitPackagepublic void setImplicitPackage(boolean implicitPackage) Say whether this is an implicit package (one rooted at xsl:stylesheet or xsl:transform rather than xsl:package- Parameters:
- implicitPackage- true if this package was rooted at an xsl:stylesheet or xsl:transform element
 
 - 
isJustInTimeCompilationpublic boolean isJustInTimeCompilation() Ask whether the package was compiled with just-in-time compilation of template rules enabled- Returns:
- false (always) for Saxon-HE
 
 - 
setJustInTimeCompilationpublic void setJustInTimeCompilation(boolean justInTimeCompilation) Say whether the package was compiled with just-in-time compilation of template rules enabled. This method is called by the compiler itself and should not be called by users. The setting is ignored in Saxon-HE.- Parameters:
- justInTimeCompilation- set to true if just-in-time compilation was enabled when the package was compiled
 
 - 
getRuleManagerpublic RuleManager getRuleManager() Get the rule manager, which knows about all the modes present in the package- Returns:
- the rule manager
 
 - 
setRuleManagerpublic void setRuleManager(RuleManager ruleManager) Set the rule manager, which knows about all the modes present in the package- Parameters:
- ruleManager- the rule manager
 
 - 
getDefaultModepublic StructuredQName getDefaultMode() Get the default mode for the package- Returns:
- the default mode for the package as a whole (this may change for individual elements/subtrees within the package)
 
 - 
setDefaultModepublic void setDefaultMode(StructuredQName defaultMode) Set the default mode for the package- Parameters:
- defaultMode- the default mode for the package
 
 - 
setDeclaredModespublic void setDeclaredModes(boolean declared) Say whether it is required that modes be explicitly declared- Parameters:
- declared- true if modes referenced within this package must be explicitly declared
 
 - 
isDeclaredModespublic boolean isDeclaredModes() Ask whether it is required that modes be explicitly declared- Returns:
- true if modes referenced within this package must be explicitly declared
 
 - 
getSpaceStrippingRulepublic SpaceStrippingRule getSpaceStrippingRule() Get the whitespace stripping rules for this package- Returns:
- the whitespace stripping rules (based on xsl:strip-space and xsl:preserve-space)
 
 - 
getCharacterMapIndexpublic CharacterMapIndex getCharacterMapIndex() Get the index of named character maps defined in this package- Returns:
- the index of character maps
 
 - 
setCharacterMapIndexpublic void setCharacterMapIndex(CharacterMapIndex characterMapIndex) Set the index of named character maps defined in this package- Parameters:
- characterMapIndex- the index of named character maps
 
 - 
isCreatesSecondaryResultDocumentspublic boolean isCreatesSecondaryResultDocuments() Ask whether the package contains an xsl:result-document instruction- Returns:
- true if the package contains an xsl:result-document instruction
 
 - 
setCreatesSecondaryResultDocumentspublic void setCreatesSecondaryResultDocuments(boolean createsSecondaryResultDocuments) Say whether the package contains an xsl:result-document instruction- Parameters:
- createsSecondaryResultDocuments- true if the package contains an xsl:result-document instruction
 
 - 
isStripsTypeAnnotationspublic boolean isStripsTypeAnnotations() Ask whether the package defines that type annotations should be stripped from input documents loaded from within this package- Returns:
- true if documents loaded by this package should have any type annotations stripped.
 
 - 
setStripsTypeAnnotationspublic void setStripsTypeAnnotations(boolean stripsTypeAnnotations) Say whether the package defines that type annotations should be stripped from input documents loaded from within this package- Parameters:
- stripsTypeAnnotations- set to true if documents loaded by this package should have any type annotations stripped.
 
 - 
getStripperRulespublic SpaceStrippingRule getStripperRules() Get the whitespace stripping rules for source documents loaded from within this package- Returns:
- the whitespace stripping rules for this package
 
 - 
setStripperRulespublic void setStripperRules(SpaceStrippingRule stripperRules) Set the whitespace stripping rules for source documents loaded from within this package- Parameters:
- stripperRules- the whitespace stripping rules for this package
 
 - 
setDefaultOutputPropertiespublic void setDefaultOutputProperties(java.util.Properties props) Set the default (unnamed) serialization properties to be used for documents output using xsl:result-document instructions within this package- Parameters:
- props- the default serialization properties for this package
 
 - 
setNamedOutputPropertiespublic void setNamedOutputProperties(StructuredQName name, java.util.Properties props) Define a named set serialization properties to be used for documents output using xsl:result-document instructions within this package- Parameters:
- name- the name of the serialization property set
- props- the serialization properties
 
 - 
getNamedOutputPropertiespublic java.util.Properties getNamedOutputProperties(StructuredQName name) Get a set of named output properties- Parameters:
- name- the output declaration name
- Returns:
- the corresponding properties; or null if the name is unknown
 
 - 
getSchemaNamespacespublic java.util.Set<java.lang.String> getSchemaNamespaces() Get the set of namespaces of schema declarations imported into this package- Returns:
- the set of imported namespaces
 
 - 
setContextItemRequirementspublic void setContextItemRequirements(GlobalContextRequirement requirement) throws XPathException Set the required context item type. Used when there is an xsl:global-context-item child element- Parameters:
- requirement- details of the requirement for the global context item
- Throws:
- XPathException
 
 - 
getContextItemRequirementspublic GlobalContextRequirement getContextItemRequirements() Get the required context item type and other details of the global context item. Used when there is an xsl:global-context-item child element- Returns:
- details of the requirement for the global context item
 
 - 
setStripsWhitespacepublic void setStripsWhitespace(boolean strips) Say whether there is an xsl:strip-space declaration in the stylesheet package- Parameters:
- strips- true if an xsl:strip-space declaration has been found
 
 - 
isStripsWhitespacepublic boolean isStripsWhitespace() Ask whether there is an xsl:strip-space declaration in the stylesheet package- Returns:
- true if an xsl:strip-space declaration has been found
 
 - 
addCompletionActionpublic void addCompletionAction(Action action) Register a callback action to be performed during the completion phase of building the package- Parameters:
- action- the callback action
 
 - 
completeprotected void complete() throws XPathExceptionPerform all registered completion actions for the package- Throws:
- XPathException- if any of these completion actions fails
 
 - 
allocateBinderySlotspublic void allocateBinderySlots() Allocate slots to global variables. Slot numbers are unique within a package
 - 
addComponentpublic void addComponent(Component component) Add a component to the package- Parameters:
- component- the component to be added
 
 - 
addGlobalVariablepublic void addGlobalVariable(GlobalVariable variable) Description copied from class:PackageDataAdd a global variable to the list of global variables contained in this package- Overrides:
- addGlobalVariablein class- PackageData
- Parameters:
- variable- the global variable to be added
 
 - 
getMaxFunctionAritypublic int getMaxFunctionArity() Get the maximum arity of functions in this package- Returns:
- the maximum arity
 
 - 
getComponentpublic Component getComponent(SymbolicName name) Get the component within this package having a given symbolic name- Parameters:
- name- the symbolic name of the required component
- Returns:
- the requested component, or null if it does not exist in the package
 
 - 
addHiddenComponentpublic void addHiddenComponent(Component component) 
 - 
getOverriddenComponentpublic Component getOverriddenComponent(SymbolicName name) If this component overrides a component named N, get the component that N overrides (that is, the component identified by xsl:original appearing within the overriding declaration of N)- Parameters:
- name- the name N
- Returns:
- if there is an overriding declaration of N, then the original declaration of N from the used package; otherwise null
 
 - 
addOverriddenComponentpublic void addOverriddenComponent(Component comp) 
 - 
addComponentsFromUsedPackagepublic void addComponentsFromUsedPackage(StylesheetPackage usedPackage, java.util.List<XSLAccept> acceptors, java.util.Set<SymbolicName> overrides) throws XPathException Add modified copies of components from a package that is referenced from this one in an xsl:use-package declaration- Parameters:
- usedPackage- the used package
- acceptors- abstraction of a list of xsl:accept declarations, which can modify the visibility of accepted components
- overrides- the set of names of components from the used package that are overridden in the using package
- Throws:
- XPathException- if duplicate components are found
 
 - 
createFunctionLibrarypublic void createFunctionLibrary() Create the function library containing stylesheet functions declared in this package
 - 
addIxslFunctionLibraryprotected void addIxslFunctionLibrary(FunctionLibraryList functionLibrary) 
 - 
getFunctionLibrarypublic FunctionLibraryList getFunctionLibrary() Get the function library.- Returns:
- the function library
 
 - 
getPublicFunctionspublic FunctionLibrary getPublicFunctions() Get the library of functions exposed by this stylesheet package, that is, functions whose visibility is public or final
 - 
getXQueryFunctionLibrarypublic XQueryFunctionLibrary getXQueryFunctionLibrary() Get the library of functions imported from XQuery- Returns:
- the XQuery function library
 
 - 
setFunctionLibraryDetailspublic void setFunctionLibraryDetails(FunctionLibraryList library, ExecutableFunctionLibrary overriding, ExecutableFunctionLibrary underriding) Set details of functions available for calling anywhere in this package. This is the function library used for resolving run-time references to functions, for example from xsl:evaluate, function-available(), or function-lookup().- Parameters:
- overriding- library of stylesheet functions declared with override=yes
- underriding- library of stylesheet functions declared with override=no
 
 - 
getFunctionprotected UserFunction getFunction(SymbolicName.F name) Get the function with a given name and arity- Parameters:
- name- the symbolic name of the function (QName plus arity)
- Returns:
- the requested function, or null if none can be found
 
 - 
isRetainUnusedFunctionspublic boolean isRetainUnusedFunctions() Ask whether private functions for which there are no static references need to be retained- Returns:
- true if such functions need to be retained, typically because the stylesheet package uses xsl:evaluate or fn:function-lookup
 
 - 
setRetainUnusedFunctionspublic void setRetainUnusedFunctions() Say that private functions need to be retained, typically because the stylesheet package uses xsl:evaluate or fn:function-lookup
 - 
updatePreparedStylesheetpublic void updatePreparedStylesheet(PreparedStylesheet pss) throws XPathException Copy information from this package to the PreparedStylesheet.- Parameters:
- pss- the PreparedStylesheet to be updated
- Throws:
- XPathException- if the PreparedStylesheet cannot be updated
 
 - 
getAbstractComponentspublic java.util.Map<SymbolicName,Component> getAbstractComponents() 
 - 
markNonExportablepublic void markNonExportable(java.lang.String message, java.lang.String errorCode)Mark the package as non-exportable, supplying an error message to be reported if export is attempted- Parameters:
- message- the error message to report indicating why export is not possible
- errorCode- the error code to report if export is attempted
 
 - 
exportpublic void export(ExpressionPresenter presenter) throws XPathException Output the abstract expression tree to the supplied destination.- Parameters:
- presenter- the expression presenter used to display the structure
- Throws:
- XPathException
 
 - 
checkForAbstractComponentspublic void checkForAbstractComponents() throws XPathException- Throws:
- XPathException
 
 - 
isFallbackToNonStreamingpublic boolean isFallbackToNonStreaming() Ask whether a non-streamable construct has been found, forcing the entire stylesheet to fall back to unstreamed processing- Returns:
- true if the stylesheet must fall back to unstreamed processing
 
 - 
setFallbackToNonStreamingpublic void setFallbackToNonStreaming() 
 
- 
 
-