Class ResourceManager
- java.lang.Object
-
- org.pentaho.reporting.libraries.resourceloader.ResourceManager
-
public final class ResourceManager extends Object
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, theResourceLoaderaccesses the physical storage or network connection to read in the binary data. The loadedResourceDatacarries versioning information with it an can be cached indendently from the produced result. Once the loading is complete, aResourceFactoryinterprets 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:
ResourceData,ResourceLoader,ResourceFactory
-
-
Field Summary
Fields Modifier and Type Field Description static StringBUNDLE_LOADER_PREFIXstatic StringFACTORY_TYPE_PREFIXstatic StringLOADER_PREFIX
-
Constructor Summary
Constructors Constructor Description ResourceManager()Default Constructor.ResourceManager(ResourceManagerBackend resourceManagerBackend)ResourceManager(ResourceManager parent, ResourceManagerBackend backend)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description Resourcecreate(ResourceKey key, ResourceKey context)Resourcecreate(ResourceKey key, ResourceKey context, Class target)Resourcecreate(ResourceKey key, ResourceKey context, Class[] target)ResourcecreateDirectly(Object keyValue, Class target)ResourceKeycreateKey(Object data)Creates a ResourceKey that carries no Loader-Parameters from the given object.ResourceKeycreateKey(Object data, Map<? extends ParameterKey,? extends Object> parameters)Creates a ResourceKey that carries the given Loader-Parameters contained in the optional map.ResourceKeycreateOrDeriveKey(ResourceKey context, Object value, Object baseURL)ResourceKeyderiveKey(ResourceKey parent, String path)Derives a new key from the given resource-key.ResourceKeyderiveKey(ResourceKey parent, String path, Map<? extends ParameterKey,? extends Object> parameters)Derives a new key from the given resource-key.ResourceKeydeserialize(ResourceKey bundleKey, String serializedKey)Converts a serialized version of aResourceKeyinto an actualResourceKeyby locating the properResourceLoaderthat can perform the deserialization.ResourceManagerBackendgetBackend()ResourceBundleDataCachegetBundleCache()ResourceDataCachegetDataCache()ResourceFactoryCachegetFactoryCache()ResourceDataload(ResourceKey key)ResourceDataloadRawData(ResourceKey key)ResourceBundleDataloadResourceBundle(ResourceKey key)Tries to find the first resource-bundle-loader that would be able to process the key.voidregisterBundleDataCache()voidregisterBundleLoader(ResourceBundleLoader loader)voidregisterDataCache()voidregisterDefaultFactories()voidregisterDefaultLoaders()voidregisterDefaults()voidregisterFactory(ResourceFactory factory)voidregisterFactoryCache()voidregisterLoader(ResourceLoader loader)Stringserialize(ResourceKey bundleKey, ResourceKey key)Creates a String version of theResourceKeythat can be deserialized with thedeserialize()method.voidsetBundleCache(ResourceBundleDataCache bundleCache)voidsetDataCache(ResourceDataCache dataCache)voidsetFactoryCache(ResourceFactoryCache factoryCache)voidshutDown()URLtoURL(ResourceKey key)Tries to convert the resource-key into an URL.
-
-
-
Field Detail
-
BUNDLE_LOADER_PREFIX
public static final String BUNDLE_LOADER_PREFIX
- See Also:
- Constant Field Values
-
LOADER_PREFIX
public static final String LOADER_PREFIX
- See Also:
- Constant Field Values
-
FACTORY_TYPE_PREFIX
public static final String FACTORY_TYPE_PREFIX
- See Also:
- Constant Field Values
-
-
Constructor Detail
-
ResourceManager
public ResourceManager()
Default Constructor.
-
ResourceManager
public ResourceManager(ResourceManagerBackend resourceManagerBackend)
-
ResourceManager
public ResourceManager(ResourceManager parent, ResourceManagerBackend backend)
-
-
Method Detail
-
getBackend
public ResourceManagerBackend getBackend()
-
createKey
public ResourceKey createKey(Object data) throws ResourceKeyCreationException
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 ResourceKeyCreationException
Creates 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
public ResourceKey deriveKey(ResourceKey parent, String path) throws ResourceKeyCreationException
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 ResourceKeyCreationException
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. 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
public URL toURL(ResourceKey key)
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
public ResourceBundleData loadResourceBundle(ResourceKey key) throws ResourceLoadingException
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
public ResourceData load(ResourceKey key) throws ResourceLoadingException
- 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
public ResourceDataCache getDataCache()
-
setDataCache
public void setDataCache(ResourceDataCache dataCache)
-
getFactoryCache
public ResourceFactoryCache getFactoryCache()
-
setFactoryCache
public void setFactoryCache(ResourceFactoryCache factoryCache)
-
getBundleCache
public ResourceBundleDataCache getBundleCache()
-
setBundleCache
public void setBundleCache(ResourceBundleDataCache bundleCache)
-
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
public void registerBundleLoader(ResourceBundleLoader loader)
-
registerLoader
public void registerLoader(ResourceLoader loader)
-
registerFactory
public void registerFactory(ResourceFactory factory)
-
shutDown
public void shutDown()
-
serialize
public String serialize(ResourceKey bundleKey, ResourceKey key) throws ResourceException
Creates a String version of theResourceKeythat 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 aResourceKeyinto an actualResourceKeyby locating the properResourceLoaderthat can perform the deserialization.- Parameters:
serializedKey- the String serialized key to be deserialized- Returns:
- the
ResourceKeythat has been deserialized - Throws:
ResourceKeyCreationException- indicates an error trying to create theResourceKeyfrom the deserialized version
-
createOrDeriveKey
public ResourceKey createOrDeriveKey(ResourceKey context, Object value, Object baseURL) throws ResourceKeyCreationException
- Throws:
ResourceKeyCreationException
-
-