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 Follow extends StdCommand { public Follow() { } private final String[] access = I(new String[] { "FOLLOW", "FOL", "FO", "F" }); @Override public String[] getAccessWords() { return access; } @SuppressWarnings("rawtypes") private final static Class[][] internalParameters=new Class[][]{{MOB.class,Boolean.class}}; public boolean nofollow(MOB mob, boolean errorsOk, boolean quiet) { if(mob==null) return false; final Room R=mob.location(); if(R==null) return false; if(mob.amFollowing()!=null) { final CMMsg msg=CMClass.getMsg(mob,mob.amFollowing(),null,CMMsg.MSG_NOFOLLOW,quiet?null:L("<S-NAME> stop(s) following <T-NAMESELF>.")); // no room OKaffects, since the damn leader may not be here. if(mob.okMessage(mob,msg)) R.send(mob,msg); else return false; } else if(errorsOk) mob.tell(L("You aren't following anyone!")); return true; } public void unfollow(MOB mob, boolean quiet) { nofollow(mob,false,quiet); final Vector<MOB> V=new Vector<MOB>(); for(int f=0;f<mob.numFollowers();f++) { final MOB F=mob.fetchFollower(f); if(F!=null) V.add(F); } for(int v=0;v<V.size();v++) { final MOB F=V.get(v); nofollow(F,false,quiet); } } public boolean processFollow(MOB mob, MOB tofollow, boolean quiet) { if(mob==null) return false; final Room R=mob.location(); if(R==null) return false; if(tofollow!=null) { if(tofollow==mob) { return nofollow(mob,true,false); } if(mob.getGroupMembers(new HashSet<MOB>()).contains(tofollow)) { if(!quiet) mob.tell(L("You are already a member of @x1's group!",tofollow.name())); return false; } if(nofollow(mob,false,false)) { final CMMsg msg=CMClass.getMsg(mob,tofollow,null,CMMsg.MSG_FOLLOW,quiet?null:L("<S-NAME> follow(s) <T-NAMESELF>.")); if(R.okMessage(mob,msg)) R.send(mob,msg); else return false; } else return false; } else return nofollow(mob,!quiet,quiet); return true; } @Override public boolean execute(MOB mob, List<String> commands, int metaFlags) throws java.io.IOException { boolean quiet=false; if(mob==null) return false; Vector<String> origCmds=new XVector<String>(commands); final Room R=mob.location(); if(R==null) return false; if((commands.size()>2) &&(commands.get(commands.size()-1).equalsIgnoreCase("UNOBTRUSIVELY"))) { commands.remove(commands.size()-1); quiet=true; } if(commands.size()<2) { CMLib.commands().doCommandFail(mob,origCmds,L("Follow whom?")); return false; } final String whomToFollow=CMParms.combine(commands,1); if((whomToFollow.equalsIgnoreCase("self")||whomToFollow.equalsIgnoreCase("me")) ||(mob.name().toUpperCase().startsWith(whomToFollow))) { nofollow(mob,true,quiet); return false; } final MOB target=R.fetchInhabitant(whomToFollow); if((target==null)||(!CMLib.flags().canBeSeenBy(target,mob))) { CMLib.commands().doCommandFail(mob,origCmds,L("I don't see them here.")); return false; } if((target.isMonster())&&(!mob.isMonster())) { CMLib.commands().doCommandFail(mob,origCmds,L("You cannot follow '@x1'.",target.name(mob))); return false; } if(target.isAttributeSet(MOB.Attrib.NOFOLLOW)) { CMLib.commands().doCommandFail(mob,origCmds,L("@x1 is not accepting followers.",target.name(mob))); return false; } final MOB ultiTarget=target.amUltimatelyFollowing(); if((ultiTarget!=null)&&(ultiTarget.isAttributeSet(MOB.Attrib.NOFOLLOW))) { CMLib.commands().doCommandFail(mob,origCmds,L("@x1 is not accepting followers.",ultiTarget.name())); return false; } processFollow(mob,target,quiet); return false; } @Override public Object executeInternal(MOB mob, int metaFlags, Object... args) throws java.io.IOException { if(!super.checkArguments(internalParameters, args)) return Boolean.FALSE; final MOB target=(MOB)args[0]; final Boolean quiet=(Boolean)args[1]; return Boolean.valueOf(processFollow(mob,target,quiet.booleanValue())); } @Override public double combatActionsCost(final MOB mob, final List<String> cmds) { return CMProps.getCommandCombatActionCost(ID()); } @Override public double actionsCost(final MOB mob, final List<String> cmds) { return CMProps.getCommandActionCost(ID()); } @Override public boolean canBeOrdered() { return false; } }