Package net.sf.saxon.lib
Interface ResourceCollection
-
- All Known Implementing Classes:
AbstractResourceCollection
,CatalogCollection
,DirectoryCollection
,JarCollection
public interface ResourceCollection
This interface defines a ResourceCollection. This is a counterpart to the JAXP URIResolver, but is used to map the URI of collection into a sequence of Resource objects. It is used to support the fn:collection() and fn:uri-collection() functions.- Since:
- 9.7
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description java.lang.String
getCollectionURI()
Get the URI of the collectionjava.util.Iterator<? extends Resource>
getResources(XPathContext context)
Get the resources in the collection.java.util.Iterator<java.lang.String>
getResourceURIs(XPathContext context)
Get the URIs of the resources in the collection.boolean
isStable(XPathContext context)
Ask whether the collection is stable: in this case Saxon will retain the contents of the collection in memory, and will not make a second request on the CollectionFinder for the same collection URI.boolean
stripWhitespace(SpaceStrippingRule rules)
Supply information about the whitespace stripping rules that apply to this collection.
-
-
-
Method Detail
-
getCollectionURI
java.lang.String getCollectionURI()
Get the URI of the collection- Returns:
- The URI as passed to the fn:collection() or fn:uri-collection() function, resolved if it is relative against the static base URI. If the collection() or uri-collection() function was called with no arguments (to get the "default collection") this will be the URI of the default collection registered with the Configuration.
-
getResourceURIs
java.util.Iterator<java.lang.String> getResourceURIs(XPathContext context) throws XPathException
Get the URIs of the resources in the collection. This supports the fn:uri-collection() function. It is not required that all collections expose a list of URIs in this way, or that the URIs bear any particular relationship to the resources returned by the getResources() method for the same collection URI. The URIs that are returned should be suitable for passing to the registered URIResolver (in the case of XML resources), or theUnparsedTextURIResolver
(in the case of unparsed text and JSON resources), etc.- Parameters:
context
- the XPath evaluation context- Returns:
- an iterator over the URIs of the resources in the collection. The URIs are represented as Strings. They should preferably be absolute URIs.
- Throws:
XPathException
- in the event of any error (for example, if the collection URI is not recognized)
-
getResources
java.util.Iterator<? extends Resource> getResources(XPathContext context) throws XPathException
Get the resources in the collection. This supports the fn:collection() function. It is not required that all collections expose a set of resources in this way, or that the resources returned bear any particular relationship to the URIs returned by the getResourceURIs() method for the same collection URI.- Parameters:
context
- the XPath evaluation context- Returns:
- an iterator over the resources in the collection. This returns objects of class
Resource
. - Throws:
XPathException
- in the event of any error (for example, if the collection URI is not recognized)
-
isStable
boolean isStable(XPathContext context)
Ask whether the collection is stable: in this case Saxon will retain the contents of the collection in memory, and will not make a second request on the CollectionFinder for the same collection URI.- Parameters:
context
- the XPath dynamic evaluation context (in case the decision is context dependent)
-
stripWhitespace
boolean stripWhitespace(SpaceStrippingRule rules)
Supply information about the whitespace stripping rules that apply to this collection. This method will only be called when the collection() function is invoked from XSLT. (If in doubt, the implementation of this method should do nothing and return false.)- Parameters:
rules
- the space-stripping rules that apply to this collection, derived from the xsl:strip-space and xsl:preserve-space declarations in the stylesheet package containing the call to the collection() function.- Returns:
- true if the collection finder intends to take responsibility for whitespace stripping according to these rules; false if it wishes Saxon itself to post-process any returned XML documents to strip whitespace. Returning true may either indicate that the collection finder will strip whitespace before returning a document, or it may indicate that it does not wish the space stripping rules to be applied.
- Since:
- 9.8
-
-