Class WebScriptPropertyResourceBundle

java.lang.Object
java.util.ResourceBundle
org.springframework.extensions.webscripts.WebScriptPropertyResourceBundle

public class WebScriptPropertyResourceBundle extends ResourceBundle

Extends PropertyResourceBundle in order to provide two new capabilities. The first is to store the path where the properties file used to create the InputStream is located and the second is to allow additional ResourceBundle properties to be merged into an instance.

The rational of these capabilities is to allow a WebScript to locate and merge extension module properties files.

Author:
David Draper
  • Constructor Details

    • WebScriptPropertyResourceBundle

      public WebScriptPropertyResourceBundle(InputStream stream, String resourcePath) throws IOException

      Instantiates a new WebScriptPropertyResourceBundle.

      Parameters:
      stream - The InputStream passed on to the super class constructor.
      resourcePath - The location of the properties file used to create the InputStream
      Throws:
      IOException
    • WebScriptPropertyResourceBundle

      public WebScriptPropertyResourceBundle(ResourceBundle baseBundle, String resourcePath)

      Constructor for instantiating from an existing ResourceBundle. This calls the merge method to copy the properties from the bundle into the resources map.

      Parameters:
      baseBundle - ResourceBundle
      resourcePath - String
  • Method Details

    • getResourcePath

      public String getResourcePath()
      Returns:
      The location of the properties file that was used to instantiate the WebScriptPropertyResourceBundle instance.
    • getMergedBundlePaths

      public StringBuilder getMergedBundlePaths()
      Returns:
      Returns the StringBuilder instance containing the paths of all the ResourceBundle instances that have been merged into this instance.
    • merge

      public void merge(String bundlePath, ResourceBundle resourceBundle)

      Merges the properties of a ResourceBundle into the current WebScriptPropertyResourceBundle instance. This will override any values mapped to duplicate keys in the current merged properties.

      Parameters:
      resourceBundle - The ResourceBundle to merge the properties of.
    • handleGetObject

      public Object handleGetObject(String key)

      Overrides the super class implementation to return an object located in the merged bundles

      Specified by:
      handleGetObject in class ResourceBundle
      Returns:
      An Object from the merged bundles
    • getKeys

      public Enumeration<String> getKeys()

      Overrides the super class implementation to return an enumeration of keys from all the merged bundles

      Specified by:
      getKeys in class ResourceBundle
      Returns:
      An Enumeration of the keys across all the merged bundles.
    • handleKeySet

      protected Set<String> handleKeySet()

      Overrides the super class implementation to return the Set of keys from all merged bundles

      Overrides:
      handleKeySet in class ResourceBundle
      Returns:
      A Set of keys obtained from all merged bundles
    • containsKey

      public boolean containsKey(String key)

      Overrides the super class implementation to check the existence of a key across all merged bundles

      Overrides:
      containsKey in class ResourceBundle
      Returns:
      true if the key is present and false otherwise.
    • keySet

      public Set<String> keySet()

      Overrides the super class implementation to return the Set of keys from all merged bundles

      Overrides:
      keySet in class ResourceBundle
      Returns:
      A Set of keys obtained from all merged bundles