diff --git a/paper-api/src/main/java/org/bukkit/World.java b/paper-api/src/main/java/org/bukkit/World.java index 5b03ebffad..e9d008104b 100644 --- a/paper-api/src/main/java/org/bukkit/World.java +++ b/paper-api/src/main/java/org/bukkit/World.java @@ -20,6 +20,14 @@ public interface World { */ public Block getBlockAt(int x, int y, int z); + /** + * Gets the highest non-air coordinate at the given (x,z) location + * @param x X-coordinate of the blocks + * @param z Z-coordinate of the blocks + * @return Y-coordinate of the highest non-air block + */ + public int getHighestBlockYAt(int x, int z); + /** * Gets the chunk at the given location * diff --git a/paper-api/src/main/java/org/bukkit/fillr/Fillr.java b/paper-api/src/main/java/org/bukkit/fillr/Fillr.java index eafb205c81..b185fea24a 100644 --- a/paper-api/src/main/java/org/bukkit/fillr/Fillr.java +++ b/paper-api/src/main/java/org/bukkit/fillr/Fillr.java @@ -1,13 +1,11 @@ package org.bukkit.fillr; import org.bukkit.*; -import org.bukkit.event.player.PlayerChatEvent; import org.bukkit.plugin.*; import org.bukkit.plugin.java.*; import org.bukkit.event.*; import java.io.File; -import org.bukkit.event.player.PlayerListener; public class Fillr extends JavaPlugin { private FillrListener listener; @@ -24,27 +22,7 @@ public class Fillr extends JavaPlugin { public void onEnable() {} private void registerEvents() { - listener = new FillrListener(); + listener = new FillrListener(getServer()); getServer().getPluginManager().registerEvent(Event.Type.PLAYER_COMMAND, listener, Event.Priority.Normal, this); } - - private class FillrListener extends PlayerListener { - @Override - public void onPlayerCommand(PlayerChatEvent event) { - if (!event.isCancelled()) { - String[] split = event.getMessage().split(" ", 2); - - if (split[0].equalsIgnoreCase("/get")) { - if (split.length == 2) { - Getter getter = new Getter(getServer()); - getter.get(split[1], event.getPlayer()); - } else { - event.getPlayer().sendMessage("Usage: /get (Plugin Name)"); - } - - event.setCancelled(true); - } - } - } - } } diff --git a/paper-api/src/main/java/org/bukkit/fillr/FillrListener.java b/paper-api/src/main/java/org/bukkit/fillr/FillrListener.java new file mode 100644 index 0000000000..f25c111b73 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/fillr/FillrListener.java @@ -0,0 +1,45 @@ +package org.bukkit.fillr; + +import org.bukkit.*; +import org.bukkit.event.player.*; + +public class FillrListener extends PlayerListener { + + private final Server server; + + public FillrListener(Server server) { + this.server = server; + } + + public void onPlayerCommand(PlayerChatEvent event) { + String[] split = event.getMessage().split(" "); + Player player = event.getPlayer(); + + if (split[0].equalsIgnoreCase("/check")) { + new Checker().check(player); + event.setCancelled(true); + } else if (split[0].equalsIgnoreCase("/updateAll")) { + new Updater(server).updateAll(player); + event.setCancelled(true); + } else if (split[0].equalsIgnoreCase("/update")) { + if (split.length == 1) { + player.sendMessage("Usage is /update "); + } else { + new Updater(server).update(split[1], player); + } + event.setCancelled(true); + } else if (split[0].equalsIgnoreCase("/get")) { + if (split.length == 1) { + player.sendMessage("Usage is /get "); + } else { + try { + new Getter(server).get(split[1], player); + } catch (Exception e) { + player.sendMessage("There was an error downloading " + + split[1]); + } + } + event.setCancelled(true); + } + } +}