From 627e2af265cd05b76932b11ed5e2a18996bce9a8 Mon Sep 17 00:00:00 2001 From: sunkid Date: Fri, 16 Sep 2011 19:49:56 -0700 Subject: addition of PlayerGameModeChangeEvent --- .../bukkit/command/defaults/GameModeCommand.java | 4 ++++ src/main/java/org/bukkit/event/Event.java | 7 ++++++ .../event/player/PlayerGameModeChangeEvent.java | 28 ++++++++++++++++++++++ .../org/bukkit/event/player/PlayerListener.java | 7 ++++++ .../org/bukkit/plugin/java/JavaPluginLoader.java | 7 ++++++ 5 files changed, 53 insertions(+) create mode 100644 src/main/java/org/bukkit/event/player/PlayerGameModeChangeEvent.java (limited to 'src') diff --git a/src/main/java/org/bukkit/command/defaults/GameModeCommand.java b/src/main/java/org/bukkit/command/defaults/GameModeCommand.java index 50fb339d..da52629f 100644 --- a/src/main/java/org/bukkit/command/defaults/GameModeCommand.java +++ b/src/main/java/org/bukkit/command/defaults/GameModeCommand.java @@ -39,6 +39,10 @@ public class GameModeCommand extends VanillaCommand { Command.broadcastCommandMessage(sender, "Setting " + player.getName() + " to game mode " + mode.getValue()); player.setGameMode(mode); + + if (mode != player.getGameMode()) { + Command.broadcastCommandMessage(sender, "The game mode change for " + player.getName() + " was cancelled!"); + } } else { sender.sendMessage(player.getName() + " already has game mode " + mode.getValue()); } diff --git a/src/main/java/org/bukkit/event/Event.java b/src/main/java/org/bukkit/event/Event.java index acfb252c..5066622e 100644 --- a/src/main/java/org/bukkit/event/Event.java +++ b/src/main/java/org/bukkit/event/Event.java @@ -301,6 +301,13 @@ public abstract class Event implements Serializable { */ PLAYER_FISH(Category.PLAYER), + /** + * Called when the game mode of a player is changed + * + * @see org.bukkit.event.player.PlayerGameModeChangeEvent + */ + PLAYER_GAME_MODE_CHANGE(Category.PLAYER), + /** * BLOCK EVENTS */ diff --git a/src/main/java/org/bukkit/event/player/PlayerGameModeChangeEvent.java b/src/main/java/org/bukkit/event/player/PlayerGameModeChangeEvent.java new file mode 100644 index 00000000..bc160161 --- /dev/null +++ b/src/main/java/org/bukkit/event/player/PlayerGameModeChangeEvent.java @@ -0,0 +1,28 @@ +package org.bukkit.event.player; + +import org.bukkit.GameMode; +import org.bukkit.entity.Player; +import org.bukkit.event.Cancellable; + +public class PlayerGameModeChangeEvent extends PlayerEvent implements Cancellable { + + private boolean cancelled; + private GameMode newGameMode; + + public PlayerGameModeChangeEvent(Player player, GameMode newGameMode) { + super(Type.PLAYER_GAME_MODE_CHANGE, player); + this.newGameMode = newGameMode; + } + + public boolean isCancelled() { + return cancelled; + } + + public void setCancelled(boolean cancel) { + this.cancelled = cancel; + } + + public GameMode getNewGameMode() { + return newGameMode; + } +} diff --git a/src/main/java/org/bukkit/event/player/PlayerListener.java b/src/main/java/org/bukkit/event/player/PlayerListener.java index 6a5137df..2b634589 100644 --- a/src/main/java/org/bukkit/event/player/PlayerListener.java +++ b/src/main/java/org/bukkit/event/player/PlayerListener.java @@ -191,4 +191,11 @@ public class PlayerListener implements Listener { * @param event Relevant event details */ public void onPlayerFish(PlayerFishEvent event) {} + + /** + * Called when a player's game mode is changed + * + * @param event Relevant event details + */ + public void onPlayerGameModeChange(PlayerGameModeChangeEvent event) {} } diff --git a/src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java b/src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java index a320e49e..a5dbf5e7 100644 --- a/src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java +++ b/src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java @@ -419,6 +419,13 @@ public class JavaPluginLoader implements PluginLoader { ((PlayerListener) listener).onPlayerFish((PlayerFishEvent) event); } }; + + case PLAYER_GAME_MODE_CHANGE: + return new EventExecutor() { + public void execute(Listener listener, Event event) { + ((PlayerListener) listener).onPlayerGameModeChange((PlayerGameModeChangeEvent) event); + } + }; // Block Events case BLOCK_PHYSICS: -- cgit v1.2.3