/
codebase/src/net/sourceforge/pain/admin/console/command/
codebase/src/net/sourceforge/pain/data/role/
codebase/src/net/sourceforge/pain/network/console/telnet/
codebase/src/net/sourceforge/pain/network/guitool/
codebase/src/net/sourceforge/pain/plugin/
codebase/src/net/sourceforge/pain/util/
db/src/net/sourceforge/pain/util/
gui/
gui/lib/
gui/src/net/sourceforge/pain/tools/guitool/dbbrowse/
gui/src/net/sourceforge/pain/tools/guitool/dialog/
gui/src/net/sourceforge/pain/tools/guitool/menu/
gui/src/net/sourceforge/pain/tools/guitool/resources/
gui/src/net/sourceforge/pain/tools/guitool/resources/images/
gui/src/net/sourceforge/pain/tools/guitool/resources/images/explorer/
mudlibs/tinylib/
mudlibs/tinylib/area/
mudlibs/tinylib/etc/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/data/affect/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/data/prototype/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/data/trigger/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/logic/affect/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/logic/event/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/logic/event/deploy/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/logic/event/guitool/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/logic/event/guitool/event/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/logic/fn/util/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/logic/trigger/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/logic/trigger/impl/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/plugin/command/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/plugin/reset/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/plugin/shutdown/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/plugin/social/
mudlibs/tinylib/src/net/sourceforge/pain/tinylib/util/
tests/
tests/src/
tests/src/net/sourceforge/pain/db/data/
package net.sourceforge.pain.logic;

import net.sourceforge.pain.*;
import net.sourceforge.pain.data.*;

import java.util.*;

/**
 * User: fmike  Date: May 29, 2004  Time: 6:56:19 PM
 */
public class TriggersLogicFactory {
    private static final Map triggerImplsCache = new HashMap();
    private static Object[] triggerParamsValues = new TriggerData[1];
    private static Class[] triggerParamsTypes = new Class[]{TriggerData.class};

    //todo: test cache performance: do we need it at all -->> yes reflection 10 times slower (jdk1.4.2)
    public static Trigger provideTriggerImpl(TriggerData td) throws Exception {
        String classNameSuffix = td.getTriggerClassName();
        Trigger sample = (Trigger) triggerImplsCache.get(classNameSuffix);
        if (sample == null) {
            Class c = Class.forName(Codebase.TRIGGERS_LOGIC_PACKAGE_PREFIX + classNameSuffix);
            sample = (Trigger) c.getDeclaredConstructor(triggerParamsTypes).newInstance(triggerParamsValues);
            triggerImplsCache.put(classNameSuffix, sample);
        }
        triggerParamsValues[0] = td;
        Trigger t = sample.newInstance(td);
        triggerParamsValues[0] = null;
        return t;
    }

    /**
     * codebase internal-use method
     */
    static void __cleanCaches() {
        triggerImplsCache.clear();
    }

}