/
com/planet_ink/coffee_mud/Abilities/
com/planet_ink/coffee_mud/Abilities/Common/
com/planet_ink/coffee_mud/Abilities/Diseases/
com/planet_ink/coffee_mud/Abilities/Druid/
com/planet_ink/coffee_mud/Abilities/Fighter/
com/planet_ink/coffee_mud/Abilities/Prayers/
com/planet_ink/coffee_mud/Abilities/Properties/
com/planet_ink/coffee_mud/Abilities/Skills/
com/planet_ink/coffee_mud/Abilities/Songs/
com/planet_ink/coffee_mud/Abilities/Spells/
com/planet_ink/coffee_mud/Abilities/Thief/
com/planet_ink/coffee_mud/Abilities/Traps/
com/planet_ink/coffee_mud/Areas/interfaces/
com/planet_ink/coffee_mud/Behaviors/
com/planet_ink/coffee_mud/CharClasses/interfaces/
com/planet_ink/coffee_mud/Commands/
com/planet_ink/coffee_mud/Commands/interfaces/
com/planet_ink/coffee_mud/Exits/interfaces/
com/planet_ink/coffee_mud/Items/Armor/
com/planet_ink/coffee_mud/Items/Basic/
com/planet_ink/coffee_mud/Items/MiscMagic/
com/planet_ink/coffee_mud/Items/Software/
com/planet_ink/coffee_mud/Items/Weapons/
com/planet_ink/coffee_mud/Libraries/interfaces/
com/planet_ink/coffee_mud/Locales/
com/planet_ink/coffee_mud/Locales/interfaces/
com/planet_ink/coffee_mud/MOBS/
com/planet_ink/coffee_mud/MOBS/interfaces/
com/planet_ink/coffee_mud/Races/
com/planet_ink/coffee_mud/Races/interfaces/
com/planet_ink/coffee_mud/WebMacros/
com/planet_ink/coffee_mud/WebMacros/interfaces/
com/planet_ink/coffee_mud/application/
com/planet_ink/coffee_mud/core/smtp/
com/planet_ink/siplet/applet/
lib/
resources/examples/
resources/fakedb/
resources/quests/delivery/
resources/quests/diseased/
resources/quests/drowning/
resources/quests/gobwar/
resources/quests/holidays/
resources/quests/robbed/
resources/quests/smurfocide/
resources/quests/stolen/
resources/quests/templates/
resources/quests/treasurehunt/
resources/quests/vengeance/
web/
web/admin.templates/
web/admin/images/
web/pub.templates/
web/pub/images/mxp/
web/pub/sounds/
package com.planet_ink.coffee_mud.Abilities.interfaces;
import com.planet_ink.coffee_mud.core.interfaces.*;
import com.planet_ink.coffee_mud.core.*;
import com.planet_ink.coffee_mud.Abilities.Misc.Amputation;
import com.planet_ink.coffee_mud.Abilities.interfaces.*;
import com.planet_ink.coffee_mud.Areas.interfaces.*;
import com.planet_ink.coffee_mud.Behaviors.interfaces.*;
import com.planet_ink.coffee_mud.CharClasses.interfaces.*;
import com.planet_ink.coffee_mud.Commands.interfaces.*;
import com.planet_ink.coffee_mud.Common.interfaces.*;
import com.planet_ink.coffee_mud.Exits.interfaces.*;
import com.planet_ink.coffee_mud.Items.interfaces.*;
import com.planet_ink.coffee_mud.Locales.interfaces.*;
import com.planet_ink.coffee_mud.MOBS.interfaces.*;
import com.planet_ink.coffee_mud.Races.interfaces.*;

import java.util.*;

/* 
   Copyright 2000-2006 Bo Zimmerman

   Licensed under the Apache License, Version 2.0 (the "License");
   you may not use this file except in compliance with the License.
   You may obtain a copy of the License at

       http://www.apache.org/licenses/LICENSE-2.0

   Unless required by applicable law or agreed to in writing, software
   distributed under the License is distributed on an "AS IS" BASIS,
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   See the License for the specific language governing permissions and
   limitations under the License.
*/
/**
 * An Amputator is a kind of ability that denotes missing parts.  Usually
 * the missing parts are body parts from mobs, but they can technically be
 * anything that can go missing as parts from the hosted object.
 */
public interface Amputator extends Ability
{
    /**
     * Returns a fully-qualified list of those parts of the given object which
     * have not yet gone missing from it.  This would be a string set denoting the names
     * of the specific parts not yet missing.
     * @param E the object to scrutinize 
     * @return the set of the name of the remaining pieces. 
     */
    public Vector remainingLimbNameSet(Environmental E);
    /**
     * Performs the very dirty business of amputating the item of the given
     * name from the given target.  An existing instanceof of the amputator
     * which will act as a property for the target must also be passed in.
     * It will generate messages if necessary, toss the piece on the groud
     * if that is appropriate, and do all thats needed.
     * @param target the thing to take the part away from
     * @param A the instanceof this object to use as a marker
     * @param gone the name of the piece to remove, fully qualified.
     * @return the item object representing the newly missing piece.
     */
    public Item amputate(Environmental target, Amputator A, String gone);
    /**
     * The opposite of the remainingLimbNameSet method, this method returns
     * the list of the names of those parts which have been amputated.
     * @return the list of the names of the parts that are GONE!
     */
    public Vector missingLimbNameSet();
    /**
     * Often losing one part means that other parts are instantly affected, like
     * removing an engine includes the spark plugs.  This method is called to
     * generate the list of those parts which also must go due to the parts
     * described by the missing string, but which are not currently included
     * in the given missingLimbs set.
     * @param O the mob/race/object frame of reference to use
     * @param missing the name of the part that was removed
     * @param missingLimbs the parts already missing from the target
     * @return the set of parts that are not yet missing, but now should be.
     */
    public Vector affectedLimbNameSet(Object O, String missing, Vector missingLimbs);
    /**
     * Restores a missing part, denoted by the given string, and managed by the
     * given Amputator property
     * @param target the unfortunate target
     * @param A the amputator object managing the targets missing stuff
     * @param gone the name of the part to restore.
     */
    public void unamputate(Environmental target, Amputator A, String gone);

}