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.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 2004-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 After extends StdCommand implements Tickable
{
@Override
public String name()
{
return "SysOpSkills";
} // for tickables use
@Override
public int getTickStatus()
{
return Tickable.STATUS_NOT;
}
public List<AfterCommand> afterCmds=new Vector<AfterCommand>();
public After()
{
}
private static class AfterCommand
{
long start=0;
long duration=0;
boolean every=false;
MOB M=null;
List<String> command=null;
int metaFlags=0;
}
private final String[] access = I(new String[] { "AFTER" });
@Override
public String[] getAccessWords()
{
return access;
}
@Override
public boolean execute(MOB mob, List<String> commands, int metaFlags)
throws java.io.IOException
{
boolean every=false;
commands.remove(0);
final String afterErr="format: after (every) [X] [TICKS/MINUTES/SECONDS/HOURS] [COMMAND]";
if (commands.size() == 0)
{
mob.tell(afterErr);
return false;
}
if(commands.get(0).equalsIgnoreCase("stop"))
{
afterCmds.clear();
CMLib.threads().deleteTick(this,Tickable.TICKID_AREA);
mob.tell(L("Ok."));
return false;
}
if(commands.get(0).equalsIgnoreCase("list"))
{
//afterCmds.clear();
int s=0;
final StringBuffer str=new StringBuffer(L("^xCurrently scheduled AFTERs: ^?^.^?\n\r"));
str.append(L("@x1 @x2 @x3 Command\n\r",CMStrings.padRight(L("Next run"),20),CMStrings.padRight(L(" Interval"),20),CMStrings.padRight(L("Who"),10)));
while(s<afterCmds.size())
{
final AfterCommand V=afterCmds.get(s);
every=V.every;
str.append(CMStrings.padRight(CMLib.time().date2String(V.start+V.duration),20)+" ");
str.append((every?"*":" ")+CMStrings.padRight(CMLib.english().returnTime(V.duration,0),20)+" ");
str.append(CMStrings.padRight(V.M.Name(),10)+" ");
str.append(CMStrings.limit(CMParms.combine(V.command,0),25)+"\n\r");
s++;
}
mob.tell(str.toString());
return false;
}
if(commands.get(0).equalsIgnoreCase("every"))
{
every = true;
commands.remove(0);
}
if (commands.size() == 0)
{
mob.tell(afterErr);
return false;
}
long time=CMath.s_long(commands.get(0));
if (time == 0)
{
mob.tell(L("Time may not be 0.@x1", afterErr));
return false;
}
commands.remove(0);
if (commands.size() == 0)
{
mob.tell(afterErr);
return false;
}
final String s=commands.get(0);
final long multiplier=CMLib.english().getMillisMultiplierByName(s);
if(multiplier<0)
{
mob.tell(L("'@x1 Time may not be 0. @x2",s,afterErr));
return false;
}
else
time=time*multiplier;
commands.remove(0);
if (commands.size() == 0)
{
mob.tell(afterErr);
return false;
}
final AfterCommand V=new AfterCommand();
V.start=System.currentTimeMillis();
V.duration=time;
V.every=every;
V.M=mob;
V.command=new XVector<String>(CMParms.toStringArray(commands));
V.metaFlags=metaFlags;
afterCmds.add(V);
CMLib.threads().startTickDown(this,Tickable.TICKID_AREA,1);
mob.tell(L("Ok."));
return false;
}
@Override
public boolean canBeOrdered()
{
return false;
}
@Override
public boolean securityCheck(MOB mob)
{
return CMSecurity.isAllowed(mob, mob.location(), CMSecurity.SecFlag.AFTER);
}
@Override
public boolean tick(Tickable ticking, int tickID)
{
if(afterCmds.size()==0)
return false;
int s=0;
while(s<afterCmds.size())
{
final AfterCommand cmd=afterCmds.get(s);
if(System.currentTimeMillis()>(cmd.start+cmd.duration))
{
final boolean every=cmd.every;
if(every)
{
cmd.start=System.currentTimeMillis();
s++;
}
else
afterCmds.remove(s);
cmd.M.doCommand(new XVector<String>(cmd.command),cmd.metaFlags);
}
else
s++;
}
return true;
}
}