PaperMC/nms-patches/CommandGamemode.patch

35 lines
1.7 KiB
Diff
Raw Normal View History

2015-05-25 20:37:24 +10:00
--- a/net/minecraft/server/CommandGamemode.java
+++ b/net/minecraft/server/CommandGamemode.java
2016-05-10 21:47:39 +10:00
@@ -28,6 +28,12 @@
2016-03-01 08:32:46 +11:00
EntityPlayer entityplayer = astring.length >= 2 ? a(minecraftserver, icommandlistener, astring[1]) : a(icommandlistener);
2016-06-09 11:43:49 +10:00
entityplayer.a(enumgamemode);
+ // CraftBukkit start - handle event cancelling the change
2016-06-09 11:43:49 +10:00
+ if (entityplayer.playerInteractManager.getGameMode() != enumgamemode) {
+ icommandlistener.sendMessage(new ChatComponentText("Failed to set the gamemode of '" + entityplayer.getName() + "'"));
+ return;
+ }
+ // CraftBukkit end
2016-06-09 11:43:49 +10:00
ChatMessage chatmessage = new ChatMessage("gameMode." + enumgamemode.b(), new Object[0]);
2016-03-01 08:32:46 +11:00
if (icommandlistener.getWorld().getGameRules().getBoolean("sendCommandFeedback")) {
2016-05-10 21:47:39 +10:00
@@ -50,10 +56,17 @@
2016-03-01 08:32:46 +11:00
}
2016-05-10 21:47:39 +10:00
public List<String> tabComplete(MinecraftServer minecraftserver, ICommandListener icommandlistener, String[] astring, @Nullable BlockPosition blockposition) {
2016-03-01 08:32:46 +11:00
- return astring.length == 1 ? a(astring, new String[] { "survival", "creative", "adventure", "spectator"}) : (astring.length == 2 ? a(astring, minecraftserver.getPlayers()) : Collections.emptyList());
+ return astring.length == 1 ? a(astring, new String[] { "survival", "creative", "adventure", "spectator"}) : (astring.length == 2 ? a(astring, minecraftserver.getPlayers()) : Collections.<String>emptyList()); // CraftBukkit - decompile error
}
public boolean isListStart(String[] astring, int i) {
return i == 1;
}
+
+ // CraftBukkit start - fix decompiler error
+ @Override
2015-02-26 22:41:06 +00:00
+ public int compareTo(ICommand o) {
+ return a((ICommand) o);
+ }
+ // CraftBukkit end
}