view gnv-artifacts/src/main/java/de/intevation/gnv/utils/ArtifactFactoryUtilities.java @ 779:b1f5f2a8840f

Ordered imports. Removed needless imports. Removed empty headers. gnv-artifacts/trunk@854 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author Sascha L. Teichmann <sascha.teichmann@intevation.de>
date Mon, 29 Mar 2010 08:51:20 +0000
parents 9a828e5a2390
children c4156275c1e1
line wrap: on
line source
package de.intevation.gnv.utils;

import de.intevation.artifacts.ArtifactFactory;

import org.apache.log4j.Logger;

import org.w3c.dom.Document;
import org.w3c.dom.Node;

/**
 * @author Tim Englich <tim.englich@intevation.de>
 *
 */
public class ArtifactFactoryUtilities {
    /**
     * the logger, used to log exceptions and additonaly information
     */
    private static Logger log = Logger
            .getLogger(ArtifactFactoryUtilities.class);

    /**
     * Constructor
     */
    public ArtifactFactoryUtilities() {
    }

    public ArtifactFactory createArtitfactFactor(Document config,
                                                 Node artifactFactoryNode) {
        String className = artifactFactoryNode.getTextContent();

        ArtifactFactory factory = null;

        try {
            Class clazz = Class.forName(className);
            factory = (ArtifactFactory) clazz.newInstance();
        } catch (ClassNotFoundException cnfe) {
            log.error(cnfe.getLocalizedMessage(), cnfe);
        } catch (InstantiationException ie) {
            log.error(ie.getLocalizedMessage(), ie);
        } catch (ClassCastException cce) {
            log.error(cce.getLocalizedMessage(), cce);
        } catch (IllegalAccessException iae) {
            log.error(iae.getLocalizedMessage(), iae);
        }

        if (factory != null) {
            factory.setup(config, artifactFactoryNode);
            log.info("Registering '" + factory.getName()
                     + "' as artifact factory.");
        }
        return factory;
    }
}

http://dive4elements.wald.intevation.org