PlotSquared/src/main/java/com/intellectualcrafters/plot/commands/Debug.java

91 lines
4.9 KiB
Java
Raw Normal View History

2014-11-08 20:27:09 +01:00
////////////////////////////////////////////////////////////////////////////////////////////////////
// PlotSquared - A plot manager and world generator for the Bukkit API /
// Copyright (c) 2014 IntellectualSites/IntellectualCrafters /
// /
// This program is free software; you can redistribute it and/or modify /
// it under the terms of the GNU General Public License as published by /
// the Free Software Foundation; either version 3 of the License, or /
// (at your option) any later version. /
// /
// This program is distributed in the hope that it will be useful, /
// but WITHOUT ANY WARRANTY; without even the implied warranty of /
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the /
// GNU General Public License for more details. /
// /
// You should have received a copy of the GNU General Public License /
// along with this program; if not, write to the Free Software Foundation, /
// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA /
// /
// You can contact us via: support@intellectualsites.com /
////////////////////////////////////////////////////////////////////////////////////////////////////
2014-09-22 13:02:14 +02:00
package com.intellectualcrafters.plot.commands;
import com.intellectualcrafters.plot.PS;
import com.intellectualcrafters.plot.commands.callers.PlotPlayerCaller;
2014-11-16 10:48:18 +01:00
import com.intellectualcrafters.plot.config.C;
2015-02-21 12:38:44 +01:00
import com.intellectualcrafters.plot.object.PlotPlayer;
2014-11-16 10:48:18 +01:00
import com.intellectualcrafters.plot.util.Lag;
2015-02-20 12:23:48 +01:00
import com.intellectualcrafters.plot.util.MainUtil;
import com.intellectualsites.commands.CommandDeclaration;
2015-07-27 06:30:50 +02:00
import com.intellectualsites.commands.CommandCaller;
2014-09-22 13:02:14 +02:00
@CommandDeclaration(
command = "debug",
category = CommandCategory.DEBUG,
description = "Show debug information",
usage = "/plot debug [msg]",
permission = "plots.admin"
)
public class Debug extends SubCommand {
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
@Override
public boolean onCommand(CommandCaller caller, String[] args) {
final PlotPlayer plr = caller instanceof PlotPlayerCaller ? (PlotPlayer) caller.getSuperCaller() : null;
2014-11-05 04:42:08 +01:00
if ((args.length > 0) && args[0].equalsIgnoreCase("msg")) {
final StringBuilder msg = new StringBuilder();
for (final C c : C.values()) {
2014-11-08 20:27:09 +01:00
msg.append(c.s()).append("\n");
2014-11-05 04:42:08 +01:00
}
2015-02-21 12:24:46 +01:00
MainUtil.sendMessage(plr, msg.toString());
2014-11-05 04:42:08 +01:00
return true;
}
StringBuilder information;
String header, line, section;
{
information = new StringBuilder();
2015-07-14 09:18:31 +02:00
header = C.DEBUG_HEADER.s();
2014-11-05 04:42:08 +01:00
line = C.DEBUG_LINE.s();
section = C.DEBUG_SECTION.s();
}
{
final StringBuilder worlds = new StringBuilder("");
for (final String world : PS.get().getPlotWorlds()) {
2014-11-08 20:27:09 +01:00
worlds.append(world).append(" ");
2014-11-05 04:42:08 +01:00
}
information.append(header);
information.append(getSection(section, "Lag / TPS"));
information.append(getLine(line, "Ticks Per Second", Lag.getTPS()));
information.append(getLine(line, "Lag Percentage", (int) Lag.getPercentage() + "%"));
information.append(getLine(line, "TPS Percentage", (int) Lag.getFullPercentage() + "%"));
information.append(getSection(section, "PlotWorld"));
information.append(getLine(line, "Plot Worlds", worlds));
information.append(getLine(line, "Owned Plots", PS.get().getPlots().size()));
2014-11-05 04:42:08 +01:00
information.append(getSection(section, "Messages"));
information.append(getLine(line, "Total Messages", C.values().length));
information.append(getLine(line, "View all captions", "/plot debug msg"));
}
{
2015-02-21 12:24:46 +01:00
MainUtil.sendMessage(plr, information.toString());
2014-11-05 04:42:08 +01:00
}
return true;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
private String getSection(final String line, final String val) {
return line.replaceAll("%val%", val) + "\n";
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
private String getLine(final String line, final String var, final Object val) {
return line.replaceAll("%var%", var).replaceAll("%val%", "" + val) + "\n";
}
2014-09-22 13:02:14 +02:00
}