mirror of
https://github.com/PaperMC/Paper.git
synced 2025-02-16 18:31:53 +01:00
127 lines
5.4 KiB
Java
127 lines
5.4 KiB
Java
/*
|
|
* This file is licensed under the MIT License (MIT).
|
|
*
|
|
* Copyright (c) 2014 Daniel Ennis <http://aikar.co>
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
* in the Software without restriction, including without limitation the rights
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in
|
|
* all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
* THE SOFTWARE.
|
|
*/
|
|
package co.aikar.timings;
|
|
|
|
import com.google.common.base.Preconditions;
|
|
import com.google.common.collect.ImmutableList;
|
|
import net.kyori.adventure.text.format.NamedTextColor;
|
|
import org.bukkit.command.CommandSender;
|
|
import org.bukkit.command.defaults.BukkitCommand;
|
|
import org.bukkit.util.StringUtil;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.List;
|
|
import org.jetbrains.annotations.NotNull;
|
|
|
|
import static net.kyori.adventure.text.Component.text;
|
|
|
|
/**
|
|
* @deprecated Timings will be removed in the future
|
|
*/
|
|
@Deprecated(forRemoval = true)
|
|
public class TimingsCommand extends BukkitCommand {
|
|
private static final List<String> TIMINGS_SUBCOMMANDS = ImmutableList.of("report", "reset", "on", "off", "paste", "verbon", "verboff");
|
|
private long lastResetAttempt = 0;
|
|
|
|
public TimingsCommand(@NotNull String name) {
|
|
super(name);
|
|
this.description = "Manages Spigot Timings data to see performance of the server.";
|
|
this.usageMessage = "/timings <reset|report|on|off|verbon|verboff>";
|
|
this.setPermission("bukkit.command.timings");
|
|
}
|
|
|
|
@Override
|
|
public boolean execute(@NotNull CommandSender sender, @NotNull String currentAlias, @NotNull String[] args) {
|
|
if (!testPermission(sender)) {
|
|
return true;
|
|
}
|
|
if (true) {
|
|
sender.sendMessage(Timings.deprecationMessage());
|
|
return true;
|
|
}
|
|
if (args.length < 1) {
|
|
sender.sendMessage(text("Usage: " + this.usageMessage, NamedTextColor.RED));
|
|
return true;
|
|
}
|
|
final String arg = args[0];
|
|
if ("on".equalsIgnoreCase(arg)) {
|
|
Timings.setTimingsEnabled(true);
|
|
sender.sendMessage(text("Enabled Timings & Reset"));
|
|
return true;
|
|
} else if ("off".equalsIgnoreCase(arg)) {
|
|
Timings.setTimingsEnabled(false);
|
|
sender.sendMessage(text("Disabled Timings"));
|
|
return true;
|
|
}
|
|
|
|
if (!Timings.isTimingsEnabled()) {
|
|
sender.sendMessage(text("Please enable timings by typing /timings on"));
|
|
return true;
|
|
}
|
|
|
|
long now = System.currentTimeMillis();
|
|
if ("verbon".equalsIgnoreCase(arg)) {
|
|
Timings.setVerboseTimingsEnabled(true);
|
|
sender.sendMessage(text("Enabled Verbose Timings"));
|
|
return true;
|
|
} else if ("verboff".equalsIgnoreCase(arg)) {
|
|
Timings.setVerboseTimingsEnabled(false);
|
|
sender.sendMessage(text("Disabled Verbose Timings"));
|
|
return true;
|
|
} else if ("reset".equalsIgnoreCase(arg)) {
|
|
if (now - lastResetAttempt < 30000) {
|
|
TimingsManager.reset();
|
|
sender.sendMessage(text("Timings reset. Please wait 5-10 minutes before using /timings report.", NamedTextColor.RED));
|
|
} else {
|
|
lastResetAttempt = now;
|
|
sender.sendMessage(text("WARNING: Timings v2 should not be reset. If you are experiencing lag, please wait 3 minutes and then issue a report. The best timings will include 10+ minutes, with data before and after your lag period. If you really want to reset, run this command again within 30 seconds.", NamedTextColor.RED));
|
|
}
|
|
} else if (
|
|
"paste".equalsIgnoreCase(arg) ||
|
|
"report".equalsIgnoreCase(arg) ||
|
|
"get".equalsIgnoreCase(arg) ||
|
|
"merged".equalsIgnoreCase(arg) ||
|
|
"separate".equalsIgnoreCase(arg)
|
|
) {
|
|
Timings.generateReport(sender);
|
|
} else {
|
|
sender.sendMessage(text("Usage: " + this.usageMessage, NamedTextColor.RED));
|
|
}
|
|
return true;
|
|
}
|
|
|
|
@NotNull
|
|
@Override
|
|
public List<String> tabComplete(@NotNull CommandSender sender, @NotNull String alias, @NotNull String[] args) {
|
|
Preconditions.checkNotNull(sender, "Sender cannot be null");
|
|
Preconditions.checkNotNull(args, "Arguments cannot be null");
|
|
Preconditions.checkNotNull(alias, "Alias cannot be null");
|
|
|
|
if (args.length == 1) {
|
|
return StringUtil.copyPartialMatches(args[0], TIMINGS_SUBCOMMANDS,
|
|
new ArrayList<String>(TIMINGS_SUBCOMMANDS.size()));
|
|
}
|
|
return ImmutableList.of();
|
|
}
|
|
}
|