Class ResourceManager
java.lang.Object
org.pentaho.reporting.libraries.resourceloader.ResourceManager
The resource manager takes care about the loaded resources, performs caching, if needed and is the central instance
when dealing with resources. Resource loading is a two-step process. In the first step, the
ResourceLoader
accesses the physical storage or network connection to read in the binary data. The loaded ResourceData
carries versioning information with it an can be cached indendently from the produced result. Once the loading is
complete, a ResourceFactory
interprets the binary data and produces a Java-Object from it.
Resources are identified by an Resource-Key and some optional loader parameters (which can be used to parametrize the
resource-factories).- Author:
- Thomas Morgner
- See Also:
-
Field Summary
-
Constructor Summary
ConstructorDescriptionDefault Constructor.ResourceManager
(ResourceManagerBackend resourceManagerBackend) ResourceManager
(ResourceManager parent, ResourceManagerBackend backend) -
Method Summary
Modifier and TypeMethodDescriptioncreate
(ResourceKey key, ResourceKey context) create
(ResourceKey key, ResourceKey context, Class target) create
(ResourceKey key, ResourceKey context, Class[] target) createDirectly
(Object keyValue, Class target) Creates a ResourceKey that carries no Loader-Parameters from the given object.createKey
(Object data, Map<? extends ParameterKey, ? extends Object> parameters) Creates a ResourceKey that carries the given Loader-Parameters contained in the optional map.createOrDeriveKey
(ResourceKey context, Object value, Object baseURL) deriveKey
(ResourceKey parent, String path) Derives a new key from the given resource-key.deriveKey
(ResourceKey parent, String path, Map<? extends ParameterKey, ? extends Object> parameters) Derives a new key from the given resource-key.deserialize
(ResourceKey bundleKey, String serializedKey) Converts a serialized version of aResourceKey
into an actualResourceKey
by locating the properResourceLoader
that can perform the deserialization.load
(ResourceKey key) loadRawData
(ResourceKey key) Tries to find the first resource-bundle-loader that would be able to process the key.void
void
void
void
void
void
void
registerFactory
(ResourceFactory factory) void
void
registerLoader
(ResourceLoader loader) serialize
(ResourceKey bundleKey, ResourceKey key) Creates a String version of theResourceKey
that can be deserialized with thedeserialize()
method.void
setBundleCache
(ResourceBundleDataCache bundleCache) void
setDataCache
(ResourceDataCache dataCache) void
setFactoryCache
(ResourceFactoryCache factoryCache) void
shutDown()
toURL
(ResourceKey key) Tries to convert the resource-key into an URL.
-
Field Details
-
BUNDLE_LOADER_PREFIX
- See Also:
-
LOADER_PREFIX
- See Also:
-
FACTORY_TYPE_PREFIX
- See Also:
-
-
Constructor Details
-
ResourceManager
public ResourceManager()Default Constructor. -
ResourceManager
-
ResourceManager
-
-
Method Details
-
getBackend
-
createKey
Creates a ResourceKey that carries no Loader-Parameters from the given object.- Parameters:
data
- the key-data- Returns:
- the generated resource-key, never null.
- Throws:
ResourceKeyCreationException
- if the key-creation failed.
-
createKey
public ResourceKey createKey(Object data, Map<? extends ParameterKey, ? extends Object> parameters) throws ResourceKeyCreationExceptionCreates a ResourceKey that carries the given Loader-Parameters contained in the optional map.- Parameters:
data
- the key-dataparameters
- an optional map of parameters.- Returns:
- the generated resource-key, never null.
- Throws:
ResourceKeyCreationException
- if the key-creation failed.
-
deriveKey
Derives a new key from the given resource-key. Only keys for a hierarchical storage system (like file-systems or URLs) can have derived keys. Since LibLoader 0.3.0 only hierarchical keys can be derived. For that, the deriving path must be given as String. Before trying to derive the key, the system tries to interpret the path as absolute key-value.- Parameters:
parent
- the parent key, must never be nullpath
- the relative path, that is used to derive the key.- Returns:
- the derived key.
- Throws:
ResourceKeyCreationException
- if deriving the key failed.
-
deriveKey
public ResourceKey deriveKey(ResourceKey parent, String path, Map<? extends ParameterKey, ? extends Object> parameters) throws ResourceKeyCreationExceptionDerives a new key from the given resource-key. Only keys for a hierarchical storage system (like file-systems or URLs) can have derived keys. Since LibLoader 0.3.0 only hierarchical keys can be derived. For that, the deriving path must be given as String. The optional parameter-map will be applied to the derived key after the parent's parameters have been copied to the new key. Before trying to derive the key, the system tries to interpret the path as absolute key-value.- Parameters:
parent
- the parent key, or null to interpret the path as absolute key.path
- the relative path, that is used to derive the key.parameters
- a optional map containing resource-key parameters.- Returns:
- the derived key.
- Throws:
ResourceKeyCreationException
- if deriving the key failed.
-
toURL
Tries to convert the resource-key into an URL. Not all resource-keys have an URL representation. This method exists to make it easier to connect LibLoader to other resource-loading frameworks.- Parameters:
key
- the resource-key- Returns:
- the URL for the key, or null if there is no such key.
-
createDirectly
public Resource createDirectly(Object keyValue, Class target) throws ResourceLoadingException, ResourceCreationException, ResourceKeyCreationException -
loadResourceBundle
Tries to find the first resource-bundle-loader that would be able to process the key.- Parameters:
key
- the resource-key.- Returns:
- the resourceloader for that key, or null, if no resource-loader is able to process the key.
- Throws:
ResourceLoadingException
- if an error occured.
-
load
- Throws:
ResourceLoadingException
-
loadRawData
public ResourceData loadRawData(ResourceKey key) throws UnrecognizedLoaderException, ResourceLoadingException -
create
public Resource create(ResourceKey key, ResourceKey context, Class target) throws ResourceLoadingException, ResourceCreationException -
create
public Resource create(ResourceKey key, ResourceKey context) throws ResourceLoadingException, ResourceCreationException -
create
public Resource create(ResourceKey key, ResourceKey context, Class[] target) throws ResourceLoadingException, ResourceCreationException -
getDataCache
-
setDataCache
-
getFactoryCache
-
setFactoryCache
-
getBundleCache
-
setBundleCache
-
registerDefaults
public void registerDefaults() -
registerDefaultFactories
public void registerDefaultFactories() -
registerBundleDataCache
public void registerBundleDataCache() -
registerDataCache
public void registerDataCache() -
registerFactoryCache
public void registerFactoryCache() -
registerDefaultLoaders
public void registerDefaultLoaders() -
registerBundleLoader
-
registerLoader
-
registerFactory
-
shutDown
public void shutDown() -
serialize
Creates a String version of theResourceKey
that can be deserialized with thedeserialize()
method.- Parameters:
bundleKey
- the key to the bundle containing the resource, or null if no bundle exists.key
- the key to be serialized- Throws:
ResourceException
- indicates an error trying to serialize the keyNullPointerException
- indicates the supplied key isnull
-
deserialize
public ResourceKey deserialize(ResourceKey bundleKey, String serializedKey) throws ResourceKeyCreationException Converts a serialized version of aResourceKey
into an actualResourceKey
by locating the properResourceLoader
that can perform the deserialization.- Parameters:
serializedKey
- the String serialized key to be deserialized- Returns:
- the
ResourceKey
that has been deserialized - Throws:
ResourceKeyCreationException
- indicates an error trying to create theResourceKey
from the deserialized version
-
createOrDeriveKey
public ResourceKey createOrDeriveKey(ResourceKey context, Object value, Object baseURL) throws ResourceKeyCreationException - Throws:
ResourceKeyCreationException
-