package com.planet_ink.coffee_mud.Abilities.Thief;
import com.planet_ink.coffee_mud.core.interfaces.*;
import com.planet_ink.coffee_mud.core.*;
import com.planet_ink.coffee_mud.core.collections.*;
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.Libraries.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 2006-2019 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.
*/
public class Thief_ConcealDoor extends ThiefSkill
{
@Override
public String ID()
{
return "Thief_ConcealDoor";
}
private final static String localizedName = CMLib.lang().L("Conceal Door");
@Override
public String name()
{
return localizedName;
}
@Override
protected int canAffectCode()
{
return Ability.CAN_ITEMS;
}
@Override
protected int canTargetCode()
{
return Ability.CAN_ITEMS;
}
@Override
public int abstractQuality()
{
return Ability.QUALITY_INDIFFERENT;
}
@Override
public int classificationCode()
{
return Ability.ACODE_THIEF_SKILL|Ability.DOMAIN_STEALTHY;
}
private static final String[] triggerStrings =I(new String[] {"DOORCONCEAL","DCONCEAL","CONCEALDOOR"});
@Override
public String[] triggerStrings()
{
return triggerStrings;
}
@Override
public int usageType()
{
return USAGE_MOVEMENT|USAGE_MANA;
}
public int code=Integer.MIN_VALUE;
@Override
public int abilityCode()
{
if(code<0)
code=CMath.s_int(text());
return code;
}
@Override
public void setAbilityCode(final int newCode)
{
code=newCode;
super.miscText=""+newCode;
}
@Override
public void affectPhyStats(final Physical host, final PhyStats stats)
{
super.affectPhyStats(host,stats);
if((host instanceof Exit)&&(!((Exit)host).isOpen()))
{
stats.setDisposition(stats.disposition()|PhyStats.IS_HIDDEN);
// cant affect level because will make it unpickable, therefore unopenable
// need some other way to designate its hiddenitude.
//stats.setLevel(stats.level()+abilityCode());
}
}
@Override
public void executeMsg(final Environmental host, final CMMsg msg)
{
super.executeMsg(host,msg);
if((msg.target()==affected)
&&(msg.targetMinor()==CMMsg.TYP_OPEN)
&&(super.canBeUninvoked()))
{
unInvoke();
if(affected!=null)
{
affected.delEffect(this);
affected.recoverPhyStats();
}
}
else
if(canBeUninvoked() && (invoker()!=null) && (!msg.source().isMonster()) && (msg.source()!=invoker()) && (msg.sourceMinor()==CMMsg.TYP_ENTER) && (affected!=null))
{
if(!CMLib.flags().isInTheGame(invoker(), true))
{
unInvoke();
if(affected!=null)
{
affected.delEffect(this);
affected.recoverPhyStats();
}
}
else
{
final Set<MOB> grp=invoker().getGroupMembers(new HashSet<MOB>());
if(!grp.contains(msg.source()))
{
unInvoke();
if(affected!=null)
{
affected.delEffect(this);
affected.recoverPhyStats();
}
}
}
}
}
@Override
public boolean invoke(final MOB mob, final List<String> commands, final Physical givenTarget, final boolean auto, final int asLevel)
{
if((commands.size()<1)&&(givenTarget==null))
{
mob.tell(L("Which door would you like to conceal?"));
return false;
}
Environmental chkE=null;
final String typed=CMParms.combine(commands,0);
if(CMLib.directions().getGoodDirectionCode(typed)<0)
chkE=mob.location().fetchFromMOBRoomItemExit(mob,null,typed,Wearable.FILTER_WORNONLY);
else
chkE=mob.location().getExitInDir(CMLib.directions().getGoodDirectionCode(typed));
if((!(chkE instanceof Exit))||(!CMLib.flags().canBeSeenBy(chkE,mob)))
{
mob.tell(L("You don't see any doors called '@x1' here.",typed));
return false;
}
final Exit X=(Exit)chkE;
if(!X.hasADoor())
{
mob.tell(mob,X,null,L("<T-NAME> is not a door!"));
return false;
}
if((!auto)&&(X.phyStats().level()>((adjustedLevel(mob,asLevel)*2))))
{
mob.tell(L("You aren't good enough to conceal that door."));
return false;
}
if(X.isOpen())
{
mob.tell(mob,X,null,L("You'd better close <T-NAME> first."));
return false;
}
if(!super.invoke(mob,commands,givenTarget,auto,asLevel))
return false;
final boolean success=proficiencyCheck(mob,0,auto);
if(success)
{
final CMMsg msg=CMClass.getMsg(mob,X,this,CMMsg.MSG_THIEF_ACT,L("<S-NAME> conceal(s) <T-NAME>."),CMMsg.MSG_THIEF_ACT,null,CMMsg.MSG_THIEF_ACT,null);
if(mob.location().okMessage(mob,msg))
{
mob.location().send(mob,msg);
final Ability A=(Ability)super.copyOf();
A.setInvoker(mob);
A.setAbilityCode((adjustedLevel(mob,asLevel)*2)-X.phyStats().level());
final Room R=mob.location();
Room R2=null;
for(int d=Directions.NUM_DIRECTIONS()-1;d>=0;d--)
{
if(R.getExitInDir(d)==X)
{
R2=R.getRoomInDir(d);
break;
}
}
if((CMLib.law().doesOwnThisLand(mob,R))
||((R2!=null)&&(CMLib.law().doesOwnThisLand(mob,R2))))
{
X.addNonUninvokableEffect(A);
CMLib.database().DBUpdateExits(mob.location());
}
else
A.startTickDown(mob,X,15*(adjustedLevel(mob,asLevel)));
X.recoverPhyStats();
}
}
else
beneficialVisualFizzle(mob,X,L("<S-NAME> attempt(s) to conceal <T-NAME>, but obviously fail(s)."));
return success;
}
}