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 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 the UnparsedTextURIResolver (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