diff options
author | KHobbits <rob@khobbits.co.uk> | 2011-12-08 02:21:10 +0000 |
---|---|---|
committer | KHobbits <rob@khobbits.co.uk> | 2011-12-08 02:21:10 +0000 |
commit | edfa47705f89bdeb2f41c4f5d33581f4711ed0b2 (patch) | |
tree | bdc6c7f482f2ea270af14a4f93ddc5a8115c8775 /EssentialsSpawn/src/com/earth2me/essentials/spawn | |
parent | ff75975ae78740a8d00540c31b1f01abf14adfbf (diff) | |
download | Essentials-edfa47705f89bdeb2f41c4f5d33581f4711ed0b2.tar Essentials-edfa47705f89bdeb2f41c4f5d33581f4711ed0b2.tar.gz Essentials-edfa47705f89bdeb2f41c4f5d33581f4711ed0b2.tar.lz Essentials-edfa47705f89bdeb2f41c4f5d33581f4711ed0b2.tar.xz Essentials-edfa47705f89bdeb2f41c4f5d33581f4711ed0b2.zip |
Adjusting /spawn to not trigger respawn event.
Diffstat (limited to 'EssentialsSpawn/src/com/earth2me/essentials/spawn')
-rw-r--r-- | EssentialsSpawn/src/com/earth2me/essentials/spawn/Commandspawn.java | 19 |
1 files changed, 13 insertions, 6 deletions
diff --git a/EssentialsSpawn/src/com/earth2me/essentials/spawn/Commandspawn.java b/EssentialsSpawn/src/com/earth2me/essentials/spawn/Commandspawn.java index f29707b82..6335d6c69 100644 --- a/EssentialsSpawn/src/com/earth2me/essentials/spawn/Commandspawn.java +++ b/EssentialsSpawn/src/com/earth2me/essentials/spawn/Commandspawn.java @@ -1,10 +1,11 @@ package com.earth2me.essentials.spawn; +import static com.earth2me.essentials.I18n._; import com.earth2me.essentials.Trade; import com.earth2me.essentials.User; import com.earth2me.essentials.commands.EssentialsCommand; import com.earth2me.essentials.commands.NotEnoughArgumentsException; -import static com.earth2me.essentials.I18n._; +import org.bukkit.Location; import org.bukkit.Server; import org.bukkit.command.CommandSender; import org.bukkit.event.player.PlayerTeleportEvent.TeleportCause; @@ -19,13 +20,13 @@ public class Commandspawn extends EssentialsCommand @Override public void run(final Server server, final User user, final String commandLabel, final String[] args) throws Exception - { + { final Trade charge = new Trade(this.getName(), ess); charge.isAffordableFor(user); if (args.length > 0 && user.isAuthorized("essentials.spawn.others")) { final User otherUser = getPlayer(server, args, 0); - otherUser.getTeleport().respawn(charge, TeleportCause.COMMAND); + respawn(otherUser, null); if (!otherUser.equals(user)) { otherUser.sendMessage(_("teleportAtoB", user.getDisplayName(), "spawn")); @@ -33,8 +34,8 @@ public class Commandspawn extends EssentialsCommand } } else - { - user.getTeleport().respawn(charge, TeleportCause.COMMAND); + { + respawn(user, null); } } @@ -46,8 +47,14 @@ public class Commandspawn extends EssentialsCommand throw new NotEnoughArgumentsException(); } final User user = getPlayer(server, args, 0); - user.getTeleport().respawn(null, TeleportCause.COMMAND); + respawn(user, null); user.sendMessage(_("teleportAtoB", user.getDisplayName(), "spawn")); sender.sendMessage(_("teleporting")); } + + private void respawn (final User user, final Trade charge) throws Exception { + final SpawnStorage spawns = (SpawnStorage)this.module; + final Location spawn = spawns.getSpawn(user.getGroup()); + user.getTeleport().teleport(spawn, charge, TeleportCause.COMMAND); + } } |