/
codebase/
codebase/area/
codebase/doc/
codebase/etc/
codebase/src/net/sourceforge/pain/data/trigger/
codebase/src/net/sourceforge/pain/logic/
codebase/src/net/sourceforge/pain/logic/affect/
codebase/src/net/sourceforge/pain/logic/event/
codebase/src/net/sourceforge/pain/logic/event/deploy/
codebase/src/net/sourceforge/pain/logic/event/guitool/
codebase/src/net/sourceforge/pain/logic/event/guitool/event/
codebase/src/net/sourceforge/pain/logic/fn/util/
codebase/src/net/sourceforge/pain/logic/trigger/
codebase/src/net/sourceforge/pain/logic/trigger/impl/
codebase/src/net/sourceforge/pain/network/console/
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/plugin/command/
codebase/src/net/sourceforge/pain/plugin/reset/
codebase/src/net/sourceforge/pain/plugin/shutdown/
codebase/src/net/sourceforge/pain/plugin/social/
codebase/src/net/sourceforge/pain/util/
db/doc/javadoc/resources/
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/
tests/
tests/src/
tests/src/net/sourceforge/pain/db/data/
package net.sourceforge.pain.logic.affect;

import net.sourceforge.pain.logic.*;
import net.sourceforge.pain.logic.fn.*;
import net.sourceforge.pain.data.*;
import net.sourceforge.pain.data.type.*;
import net.sourceforge.pain.*;

/**
 * Immobility affect controller.
 * This class could be created
 * 1) by user while affecting some object with affect + providing affect specific params
 * 2) by codebase core, during affectOn(delayed), onAffectTimeExpired methods calls
 * <p/>
 * Codebase require from all affect controllers (Affect subclasses) to have constructor with (AffectData d) param.
 * this constructor is used for automatically affect controller instantiation and initialization with
 * persistent image
 */
public class ImmobilityAffect extends TimedAffect {


    /**
     * this constructor is required by codebase
     */
    public ImmobilityAffect(AffectData ad) {
        super(ad);
    }

    public static void applyToObject(Mobile mob, int duration) throws Exception {
        if (mob == null) {
            throw new NullPointerException("Mob is null!");
        }
        new TimedAffectData(Core.getDB(), mob, ImmobilityAffect.class, AffectType.AFFECT_IMMOBILE, duration);
        MessageOutFn.outln(mob, "You can't move anymore");//just an example
    }

    /**
     * called by affect timer
     */
    public void onAffectTimeExpired() {
        _cancelAffect(ad, ad.getAffectedRole());
    }

    /**
     * user is allowed to calncel affect manualy
     */
    public static void cancelAffect(Mobile mob) {
        TimedAffectData ad = (TimedAffectData) mob.getAffectData(AffectType.AFFECT_IMMOBILE);
        _cancelAffect(ad, mob);
    }

    private static void _cancelAffect(AffectData ad, Role mob) {
        ad.delete();
        MessageOutFn.outln(mob, "You can move now");//just an example
    }

    public Affect newInstance(AffectData ad) {
        return new ImmobilityAffect(ad);
    }

}