Class CatalogResolver

  • All Implemented Interfaces:
    org.xml.sax.EntityResolver

    public class CatalogResolver
    extends java.lang.Object
    implements org.xml.sax.EntityResolver
    Thin wrapper around xml commons CatalogResolver to allow list of catalogs to be provided.
    Since:
    1.7
    Version:
    $Id: CatalogResolver.java 1735895 2016-03-20 18:40:47Z oheger $
    Author:
    Commons Configuration team
    • Nested Class Summary

      Nested Classes 
      Modifier and Type Class Description
      static class  CatalogResolver.Catalog
      Overrides the Catalog implementation to use the underlying FileSystem.
      static class  CatalogResolver.CatalogManager
      Extend the CatalogManager to make the FileSystem and base directory accessible.
    • Constructor Summary

      Constructors 
      Constructor Description
      CatalogResolver()
      Constructs the CatalogResolver
    • Constructor Detail

      • CatalogResolver

        public CatalogResolver()
        Constructs the CatalogResolver
    • Method Detail

      • setCatalogFiles

        public void setCatalogFiles​(java.lang.String catalogs)
        Set the list of catalog file names
        Parameters:
        catalogs - The delimited list of catalog files.
      • setFileSystem

        public void setFileSystem​(FileSystem fileSystem)
        Set the FileSystem.
        Parameters:
        fileSystem - The FileSystem.
      • setBaseDir

        public void setBaseDir​(java.lang.String baseDir)
        Set the base path.
        Parameters:
        baseDir - The base path String.
      • setInterpolator

        public void setInterpolator​(ConfigurationInterpolator ci)
        Set the ConfigurationInterpolator.
        Parameters:
        ci - the ConfigurationInterpolator
      • setDebug

        public void setDebug​(boolean debug)
        Enables debug logging of xml-commons Catalog processing.
        Parameters:
        debug - True if debugging should be enabled, false otherwise.
      • resolveEntity

        public org.xml.sax.InputSource resolveEntity​(java.lang.String publicId,
                                                     java.lang.String systemId)
                                              throws org.xml.sax.SAXException

        Implements the resolveEntity method for the SAX interface.

        Presented with an optional public identifier and a system identifier, this function attempts to locate a mapping in the catalogs.

        If such a mapping is found, the resolver attempts to open the mapped value as an InputSource and return it. Exceptions are ignored and null is returned if the mapped value cannot be opened as an input source.

        If no mapping is found (or an error occurs attempting to open the mapped value as an input source), null is returned and the system will use the specified system identifier as if no entityResolver was specified.

        Specified by:
        resolveEntity in interface org.xml.sax.EntityResolver
        Parameters:
        publicId - The public identifier for the entity in question. This may be null.
        systemId - The system identifier for the entity in question. XML requires a system identifier on all external entities, so this value is always specified.
        Returns:
        An InputSource for the mapped identifier, or null.
        Throws:
        org.xml.sax.SAXException - if an error occurs.
      • getLogger

        public ConfigurationLogger getLogger()
        Returns the logger used by this configuration object.
        Returns:
        the logger
      • setLogger

        public void setLogger​(ConfigurationLogger log)
        Allows setting the logger to be used by this object. This method makes it possible for clients to exactly control logging behavior. Per default a logger is set that will ignore all log messages. Derived classes that want to enable logging should call this method during their initialization with the logger to be used. Passing in null as argument disables logging.
        Parameters:
        log - the new logger