summaryrefslogtreecommitdiff
path: root/src/main/java/com/redstoner/modules/crashutils/CrashUtils.java
diff options
context:
space:
mode:
authorDavid Panić <david@panic.tk>2019-06-07 21:07:45 +0200
committerDavid Panić <david@panic.tk>2019-06-07 21:07:45 +0200
commitc30fdec97e87f92a05290a8a0482c36e91b367c7 (patch)
treeb83da3fcd82e7032f13d83439c8c9d787c2485b6 /src/main/java/com/redstoner/modules/crashutils/CrashUtils.java
parent62cf62adc3b3b2d5c11cf1a144e49e98a0bedced (diff)
parentfac1212bd9e9f9bd66ef2aaa556b91acaec0221d (diff)
Merge branch 'dev'HEADmaster
Diffstat (limited to 'src/main/java/com/redstoner/modules/crashutils/CrashUtils.java')
-rw-r--r--src/main/java/com/redstoner/modules/crashutils/CrashUtils.java53
1 files changed, 53 insertions, 0 deletions
diff --git a/src/main/java/com/redstoner/modules/crashutils/CrashUtils.java b/src/main/java/com/redstoner/modules/crashutils/CrashUtils.java
new file mode 100644
index 0000000..eb9590f
--- /dev/null
+++ b/src/main/java/com/redstoner/modules/crashutils/CrashUtils.java
@@ -0,0 +1,53 @@
+package com.redstoner.modules.crashutils;
+
+import com.nemez.cmdmgr.Command;
+import com.redstoner.annotations.AutoRegisterListener;
+import com.redstoner.annotations.Commands;
+import com.redstoner.annotations.Version;
+import com.redstoner.misc.CommandHolderType;
+import com.redstoner.modules.Module;
+import org.bukkit.Location;
+import org.bukkit.Material;
+import org.bukkit.block.Block;
+import org.bukkit.command.CommandSender;
+import org.bukkit.entity.Player;
+
+@Commands (CommandHolderType.File)
+@AutoRegisterListener
+@Version (major = 5, minor = 0, revision = 0, compatible = 4)
+public class CrashUtils implements Module {
+
+ @Command (hook = "findnear", async = Command.AsyncType.ALWAYS)
+ public boolean findNear(CommandSender sender, int range, String block) {
+ Player player = (Player) sender;
+
+ Material mat = Material.matchMaterial(block);
+
+ if (mat == null) {
+ getLogger().message(sender, true, block + " is not a valid block.");
+ return true;
+ }
+
+ Location playerLoc = player.getLocation();
+
+ for (int x = playerLoc.getBlockX() - range; x < playerLoc.getBlockX() + range; x++) {
+ for (int z = playerLoc.getBlockZ() - range; z < playerLoc.getBlockZ() + range; z++) {
+ for (int y = 0; y < 256; y++) {
+ Block b = player.getWorld().getBlockAt(x, y, z);
+
+ if (b.getType() == mat) {
+ Location loc = b.getLocation();
+ getLogger().message(
+ sender,
+ false,
+ String.format("Found %s @ %d %d %d", mat.toString(), loc.getBlockX(), loc.getBlockY(), loc.getBlockZ()));
+ }
+ }
+ }
+ }
+
+ getLogger().message(sender, false, String.format("Done searching for %s in a %d block radius.", mat.toString(), range));
+
+ return true;
+ }
+}