Package rife.resources
Class ResourceFinderDirectories
java.lang.Object
rife.resources.AbstractResourceFinder
rife.resources.ResourceFinderDirectories
- All Implemented Interfaces:
ResourceFinder
This class offers
ResourceFinder capabilities for resources that
are available through a collection of directories.
The resources are looked up in the same order as the order in which the directories were specified. This means that if a resource is found in the first directory, but it is also present in the second, only the first one will match.
- Since:
- 1.0
- See Also:
-
Constructor Summary
ConstructorsConstructorDescriptionResourceFinderDirectories(File... directories) Creates a new instance for the provided array of directories. -
Method Summary
Modifier and TypeMethodDescriptiongetContent(URL resource, String encoding) Retrieves the complete content of the provided resource.longgetModificationTime(URL resource) Retrieves the modification time of the provided resource.getResource(String name) Retrieves the resource that corresponds to the provided name.<ResultType>
ResultTypeuseStream(URL resource, InputStreamUser<ResultType, ?> user) Returns a stream that can be used to read the contents of the provided resource.Methods inherited from class rife.resources.AbstractResourceFinder
getContent, getContent, getContent, getModificationTime, useStream
-
Constructor Details
-
ResourceFinderDirectories
Creates a new instance for the provided array of directories.- Parameters:
directories- the directories where the resources should be searched in.- Since:
- 1.0
-
-
Method Details
-
getResource
Description copied from interface:ResourceFinderRetrieves the resource that corresponds to the provided name.This method never throws an exception, but returns
nullin case of an exception.- Parameters:
name- the name of the resource to retrieve- Returns:
- the
URLobject that corresponds to the provided name; ornullif the resource couldn't be found or if an error occurred.
-
useStream
public <ResultType> ResultType useStream(URL resource, InputStreamUser<ResultType, ?> user) throws ResourceFinderErrorException, InnerClassExceptionDescription copied from interface:ResourceFinderReturns a stream that can be used to read the contents of the provided resource.- Parameters:
resource- the resource to retrieveuser- an instance ofInputStreamUserthat contains the logic that will be executed with this stream- Returns:
- the return value from the
useInputStreammethod of the providedInputStreamUserinstance - Throws:
ResourceFinderErrorException- when an error occurred during the creation or opening of the stream.InnerClassException- when errors occurs inside theInputStreamUser- See Also:
-
getContent
Description copied from interface:ResourceFinderRetrieves the complete content of the provided resource.- Parameters:
resource- the resource to retrieve the content fromencoding- the encoding that should be used to read the content- Returns:
- a
Stringobject that contains the complete content of the resource with the provided name; ornullif the resource couldn't be found. - Throws:
ResourceFinderErrorException- when an error occurred during the retrieval of the content or when the encoding is not supported.- See Also:
-
getModificationTime
Description copied from interface:ResourceFinderRetrieves the modification time of the provided resource.- Parameters:
resource- the resource to retrieve the modification time from- Returns:
- a positive
longwith the modification time in milliseconds; or-1if the resource couldn't be found. - Throws:
ResourceFinderErrorException- when an error occurred during the retrieval of the modification time.- See Also:
-