package com.planet_ink.coffee_mud.Commands;
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.Common.interfaces.Session.InputCallback;
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 2005-2016 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 AutoInvoke extends StdCommand
{
public AutoInvoke(){}
private final String[] access=I(new String[]{"AUTOINVOKE"});
@Override public String[] getAccessWords(){return access;}
protected enum AutoInvokeCommand
{
TOGGLE,
INVOKE,
UNINVOKE
}
protected void autoInvoke(MOB mob, Ability foundA, String s, Set<String> effects, AutoInvokeCommand cmd)
{
final PlayerStats pStats = mob.playerStats();
if(foundA==null)
mob.tell(L("'@x1' is invalid.",s));
else
if(effects.contains(foundA.ID()))
{
if((cmd == AutoInvokeCommand.UNINVOKE) || (cmd == AutoInvokeCommand.TOGGLE))
{
if(pStats != null)
pStats.addAutoInvokeList(foundA.ID());
foundA=mob.fetchEffect(foundA.ID());
if(foundA!=null)
{
mob.delEffect(foundA);
if(mob.fetchEffect(foundA.ID())!=null)
mob.tell(L("@x1 failed to successfully deactivate.",foundA.name()));
else
mob.tell(L("@x1 successfully deactivated.",foundA.name()));
}
}
}
else
{
if((cmd == AutoInvokeCommand.INVOKE) || (cmd == AutoInvokeCommand.TOGGLE))
{
if(pStats != null)
pStats.removeAutoInvokeList(foundA.ID());
foundA.autoInvocation(mob, true);
if(mob.fetchEffect(foundA.ID())!=null)
mob.tell(L("@x1 successfully invoked.",foundA.name()));
else
mob.tell(L("@x1 failed to successfully invoke.",foundA.name()));
}
}
}
@Override
public boolean execute(final MOB mob, final List<String> commands, final int metaFlags)
throws java.io.IOException
{
final List<Ability> abilities=new Vector<Ability>();
final Set<String> abilityids=new TreeSet<String>();
for(int a=0;a<mob.numAbilities();a++)
{
final Ability A=mob.fetchAbility(a);
if((A!=null)
&&(A.isAutoInvoked())
&&((A.classificationCode()&Ability.ALL_ACODES)!=Ability.ACODE_LANGUAGE)
&&((A.classificationCode()&Ability.ALL_ACODES)!=Ability.ACODE_PROPERTY))
{
abilities.add(A);
abilityids.add(A.ID());
}
}
final Set<String> effects=new TreeSet<String>();
for(int a=0;a<mob.numEffects();a++)
{
final Ability A=mob.fetchEffect(a);
if((A!=null)
&&(abilityids.contains(A.ID()))
&&(!A.isSavable()))
effects.add(A.ID());
}
abilityids.clear();
Collections.sort(abilities,new Comparator<Ability>()
{
@Override
public int compare(Ability o1, Ability o2)
{
if(o1==null)
{
if(o2==null)
return 0;
return -1;
}
else
if(o2==null)
return 1;
else
return o1.name().compareToIgnoreCase(o2.name());
}
});
final StringBuffer str=new StringBuffer(L("^xAuto-invoking abilities:^?^.\n\r^N"));
int col=0;
for(Ability A : abilities)
{
if(A!=null)
{
if(effects.contains(A.ID()))
str.append(L("@x1.^xACTIVE^?^.^N ",CMStrings.padRightWith(A.Name(),'.',29)));
else
str.append(L("@x1^xINACTIVE^?^.^N",CMStrings.padRightWith(A.Name(),'.',29)));
if(++col==2)
{
col=0;
str.append("\n\r");
}
else
str.append(" ");
}
}
if(col==1)
str.append("\n\r");
mob.tell(str.toString());
final Session session=mob.session();
if(session!=null)
{
final AutoInvoke me=this;
session.prompt(new InputCallback(InputCallback.Type.PROMPT,"",0)
{
@Override
public void showPrompt()
{
session.promptPrint(L("Enter one to toggle or RETURN: "));
}
@Override
public void timedOut()
{
}
@Override
public void callBack()
{
String s=this.input;
if(s.trim().length()==0)
return;
AutoInvokeCommand cmd=AutoInvokeCommand.TOGGLE;
if(s.toUpperCase().startsWith("INVOKE "))
{
s=s.substring(7).trim();
cmd=AutoInvokeCommand.INVOKE;
}
else
if(s.toUpperCase().startsWith("UNINVOKE "))
{
s=s.substring(9).trim();
cmd=AutoInvokeCommand.UNINVOKE;
}
boolean startsWith=s.endsWith("*");
if(startsWith)
s=s.substring(0,s.length()-1).toLowerCase();
boolean endsWith=s.startsWith("*");
if(endsWith)
s=s.substring(1).toLowerCase();
if(startsWith || endsWith)
{
for(Ability A : abilities)
{
if((A!=null)
&&(A.name().equalsIgnoreCase(s)
|| (startsWith && A.name().toLowerCase().startsWith(s))
|| (endsWith && A.name().toLowerCase().endsWith(s))))
{
me.autoInvoke(mob, A, s, effects, cmd);
}
}
}
else
if(s.length()>0)
{
Ability foundA=null;
for(Ability A : abilities)
{
if((A!=null)
&&(A.name().equalsIgnoreCase(s)
|| (startsWith && A.name().toLowerCase().startsWith(s))
|| (endsWith && A.name().toLowerCase().endsWith(s))))
{
foundA = A;
break;
}
}
if(foundA==null)
{
for(Ability A : abilities)
{
if((A!=null)&&(CMLib.english().containsString(A.name(),s)))
{
foundA = A;
break;
}
}
}
me.autoInvoke(mob, foundA, s, effects, cmd);
}
mob.recoverCharStats();
mob.recoverPhyStats();
mob.recoverMaxState();
if(mob.location()!=null)
mob.location().recoverRoomStats();
mob.recoverCharStats();
mob.recoverPhyStats();
mob.recoverMaxState();
CMLib.threads().executeRunnable(new Runnable()
{
public void run()
{
session.prompt(new InputCallback(InputCallback.Type.PROMPT,"",0)
{
@Override
public void showPrompt()
{
session.promptPrint(L("Enter to continue: "));
}
@Override
public void timedOut()
{
}
@Override
public void callBack()
{
try
{
me.execute(mob, commands, metaFlags);
}
catch(Exception e)
{
}
}
});
}
});
}
});
}
return false;
}
@Override public boolean canBeOrdered(){return true;}
}