org.apache.velocity.runtime.resource

Class ResourceManagerImpl

public class ResourceManagerImpl extends Object implements ResourceManager

Class to manage the text resource for the Velocity Runtime.

Version: $Id: ResourceManagerImpl.java,v 1.7.4.1 2004/03/03 23:23:01 geirm Exp $

Author: Jason van Zyl Paulo Gaspar Geir Magnusson Jr.

Field Summary
protected ResourceCacheglobalCache
Object implementing ResourceCache to be our resource manager's Resource cache.
booleanlogWhenFound
switch to turn off log notice when a resource is found for the first time.
booleanresourceLoaderInitializersActive
Each loader needs a configuration object for its initialization, this flags keeps track of whether or not the configuration objects have been created for the resource loaders.
protected ArrayListresourceLoaders
The List of templateLoaders that the Runtime will use to locate the InputStream source of a template.
protected RuntimeServicesrsvc
static intRESOURCE_CONTENT
A static content resource.
static StringRESOURCE_LOADER_IDENTIFIER
token used to identify the loader internally
static intRESOURCE_TEMPLATE
A template resources.
ArrayListsourceInitializerList
This is a list of the template input stream source initializers, basically properties for a particular template stream source.
HashtablesourceInitializerMap
This is a map of public name of the template stream source to it's initializer.
Method Summary
voidassembleResourceLoaderInitializers()
This will produce a List of Hashtables, each hashtable contains the intialization info for a particular resource loader.
StringgetLoaderNameForResource(String resourceName)
Determines is a template exists, and returns name of the loader that provides it.
ResourcegetResource(String resourceName, int resourceType, String encoding)
Gets the named resource.
ResourcegetResource(String resourceName, int resourceType)
Gets the named resource.
voidinitialize(RuntimeServices rs)
Initialize the ResourceManager.
protected ResourceloadResource(String resourceName, int resourceType, String encoding)
Loads a resource from the current set of resource loaders
protected voidrefreshResource(Resource resource, String encoding)
Takes an existing resource, and 'refreshes' it.

Field Detail

globalCache

protected ResourceCache globalCache
Object implementing ResourceCache to be our resource manager's Resource cache.

logWhenFound

private boolean logWhenFound
switch to turn off log notice when a resource is found for the first time.

resourceLoaderInitializersActive

private boolean resourceLoaderInitializersActive
Each loader needs a configuration object for its initialization, this flags keeps track of whether or not the configuration objects have been created for the resource loaders.

resourceLoaders

protected ArrayList resourceLoaders
The List of templateLoaders that the Runtime will use to locate the InputStream source of a template.

rsvc

protected RuntimeServices rsvc

RESOURCE_CONTENT

public static final int RESOURCE_CONTENT
A static content resource.

RESOURCE_LOADER_IDENTIFIER

private static final String RESOURCE_LOADER_IDENTIFIER
token used to identify the loader internally

RESOURCE_TEMPLATE

public static final int RESOURCE_TEMPLATE
A template resources.

sourceInitializerList

private ArrayList sourceInitializerList
This is a list of the template input stream source initializers, basically properties for a particular template stream source. The order in this list reflects numbering of the properties i.e. .resource.loader. =

sourceInitializerMap

private Hashtable sourceInitializerMap
This is a map of public name of the template stream source to it's initializer. This is so that clients of velocity can set properties of a template source stream with its public name. So for example, a client could set the File.resource.path property and this would change the resource.path property for the file template stream source.

Method Detail

assembleResourceLoaderInitializers

private void assembleResourceLoaderInitializers()
This will produce a List of Hashtables, each hashtable contains the intialization info for a particular resource loader. This Hastable will be passed in when initializing the the template loader.

getLoaderNameForResource

public String getLoaderNameForResource(String resourceName)
Determines is a template exists, and returns name of the loader that provides it. This is a slightly less hokey way to support the Velocity.templateExists() utility method, which was broken when per-template encoding was introduced. We can revisit this.

Parameters: resourceName Name of template or content resource

Returns: class name of loader than can provide it

getResource

public Resource getResource(String resourceName, int resourceType, String encoding)
Gets the named resource. Returned class type corresponds to specified type (i.e. Template to RESOURCE_TEMPLATE).

Parameters: resourceName The name of the resource to retrieve. resourceType The type of resource (RESOURCE_TEMPLATE, RESOURCE_CONTENT, etc.). encoding The character encoding to use.

Returns: Resource with the template parsed and ready.

Throws: ResourceNotFoundException if template not found from any available source. ParseErrorException if template cannot be parsed due to syntax (or other) error. Exception if a problem in parse

getResource

public Resource getResource(String resourceName, int resourceType)

Deprecated: Use ResourceManagerImpl

Gets the named resource. Returned class type corresponds to specified type (i.e. Template to RESOURCE_TEMPLATE).

Parameters: resourceName The name of the resource to retrieve. resourceType The type of resource (RESOURCE_TEMPLATE, RESOURCE_CONTENT, etc.).

Returns: Resource with the template parsed and ready.

Throws: ResourceNotFoundException if template not found from any available source. ParseErrorException if template cannot be parsed due to syntax (or other) error. Exception if a problem in parse

initialize

public void initialize(RuntimeServices rs)
Initialize the ResourceManager.

loadResource

protected Resource loadResource(String resourceName, int resourceType, String encoding)
Loads a resource from the current set of resource loaders

Parameters: resourceName The name of the resource to retrieve. resourceType The type of resource (RESOURCE_TEMPLATE, RESOURCE_CONTENT, etc.). encoding The character encoding to use.

Returns: Resource with the template parsed and ready.

Throws: ResourceNotFoundException if template not found from any available source. ParseErrorException if template cannot be parsed due to syntax (or other) error. Exception if a problem in parse

refreshResource

protected void refreshResource(Resource resource, String encoding)
Takes an existing resource, and 'refreshes' it. This generally means that the source of the resource is checked for changes according to some cache/check algorithm and if the resource changed, then the resource data is reloaded and re-parsed.

Parameters: resource resource to refresh

Throws: ResourceNotFoundException if template not found from current source for this Resource ParseErrorException if template cannot be parsed due to syntax (or other) error. Exception if a problem in parse

Copyright B) 2002 Apache Software Foundation. All Rights Reserved.