Archived
0

Added /lct (like /lc but for tileentities)

This commit is contained in:
Pepich
2018-06-30 14:30:07 +02:00
parent a4aaa233f8
commit a50141f2c5
2 changed files with 131 additions and 0 deletions

View File

@@ -0,0 +1,21 @@
package com.redstoner.modules.tilechunks;
import org.bukkit.Location;
import org.bukkit.World;
public class LaggyTileChunk {
public final int x, y, z, amount;
public final World world;
public LaggyTileChunk(int x, int y, int z, World world, int amount) {
this.x = x;
this.y = y;
this.z = z;
this.world = world;
this.amount = amount;
}
public Location getLocation() {
return new Location(world, x, y, z);
}
}

View File

@@ -0,0 +1,110 @@
package com.redstoner.modules.tilechunks;
import java.util.ArrayList;
import java.util.List;
import org.bukkit.Bukkit;
import org.bukkit.Chunk;
import org.bukkit.Location;
import org.bukkit.World;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import com.nemez.cmdmgr.Command;
import com.nemez.cmdmgr.Command.AsyncType;
import com.redstoner.annotations.Commands;
import com.redstoner.annotations.Version;
import com.redstoner.misc.CommandHolderType;
import com.redstoner.modules.Module;
@Commands(CommandHolderType.String)
@Version(major = 4, minor = 0, revision = 0, compatible = 4)
public class TileChunks implements Module
{
private List<LaggyTileChunk> laggyChunks = new ArrayList<>();
private void scan(int amount)
{
laggyChunks.clear();
for (World world : Bukkit.getServer().getWorlds())
{
for (Chunk chunk : world.getLoadedChunks())
{
int amount2 = chunk.getTileEntities().length;
if (amount2 > amount)
{
Location entLoc = chunk.getTileEntities()[0].getLocation();
laggyChunks.add(new LaggyTileChunk(entLoc.getBlockX(), entLoc.getBlockY(), entLoc.getBlockZ(),
world, amount2));
}
}
}
}
@Command(hook = "list_cmd")
public void list(CommandSender sender)
{
if (laggyChunks.size() > 0)
{
ArrayList<String> message = new ArrayList<>();
for (LaggyTileChunk lc : laggyChunks)
{
message.add("§b[§a" + laggyChunks.indexOf(lc) + "§b]: §a" + lc.x + "§7, §a" + lc.y + "§7, §a" + lc.z
+ " §7(" + lc.world.getName() + ") §a- §b" + lc.amount + " tile entities");
}
message.add("§2-------------------");
getLogger().message(sender, message.toArray(new String[] {}));
}
else
getLogger().message(sender, true, "Couldn't find any chunks with that many tile entities.");
}
@Command(hook = "scan_cmd", async = AsyncType.ALWAYS)
public void scan_cmd(CommandSender sender, int amount)
{
scan(amount);
list(sender);
}
@Command(hook = "tp")
public void tp(CommandSender sender, int number)
{
Player player = (Player) sender;
if (number < laggyChunks.size())
{
player.teleport(laggyChunks.get(number).getLocation());
getLogger().message(player, "§aTeleported to chunk " + number + "!");
}
else
{
getLogger().message(sender, true, "§4Invalid chunk number! Use §e/lc list §4to show laggy chunks!");
}
}
// @noformat
@Override
public String getCommandString()
{
return "command lct {\n" +
" perm utils.tilechunks;\n" +
" \n" +
" list {\n" +
" run list_cmd;\n" +
" help re-lists already scanned chunks;\n" +
" }\n" +
" \n" +
" [int:amount] {\n" +
" run scan_cmd amount;\n" +
" help scans for laggy chunks;\n" +
" }\n" +
" \n" +
" tp [int:number] {\n" +
" run tp number;\n" +
" help teleports to the specified chunk;\n" +
" type player;\n" +
" }\n" +
"}\n" +
" ";
}
// @format
}