view gnv-artifacts/src/main/java/de/intevation/gnv/state/StateFactory.java @ 829:95733e564896

Bugfix: Put some Code that is responsible for Synchonization into the final-block to prevent that the lock is not released. gnv-artifacts/trunk@923 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author Tim Englich <tim.englich@intevation.de>
date Tue, 13 Apr 2010 14:26:21 +0000
parents 22c18083225e
children 05bf8534a35a
line wrap: on
line source
package de.intevation.gnv.state;

import de.intevation.gnv.artifacts.GNVArtifactBase;

import org.apache.log4j.Logger;

import org.w3c.dom.Node;

/**
 * This factory should be used to create new state objects with help of a
 * configuration segment.
 *
 * @author <a href="mailto:tim.englich@intevation.de">Tim Englich</a>
 *
 */
public class StateFactory {

    /**
     * the logger, used to log exceptions and additonaly information
     */
    private static Logger log = Logger.getLogger(GNVArtifactBase.class);

    private static StateFactory instance = null;

    /**
     * Constructor
     */
    public StateFactory() {
        super();
    }

    /**
     * Return the instance of this class.
     */
    public static StateFactory getInstance() {
        if (instance == null) {
            instance = new StateFactory();
        }
        return instance;
    }

    /**
     * This method creates a new state with help of the information in <i>
     * configuration</i> and calls its setup method after creation.
     *
     * @return the new state.
     */
    public State createState(Node configuration) {
        log.debug("StateFactory.createState");
        State state = null;
        try {
            String classname = ((org.w3c.dom.Element)configuration).getAttribute("state");
            state = (State) (Class.forName(classname).newInstance());
            state.setup(configuration);
        } catch (InstantiationException e) {
            log.error(e, e);
        } catch (IllegalAccessException e) {
            log.error(e, e);
        } catch (ClassNotFoundException e) {
            log.error(e, e);
        }
        return state;
    }
}
// vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :

http://dive4elements.wald.intevation.org