mirror of https://github.com/cabaletta/baritone
200 lines
8.3 KiB
Java
200 lines
8.3 KiB
Java
/*
|
|
* This file is part of Baritone.
|
|
*
|
|
* Baritone is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Baritone 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 Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with Baritone. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
package baritone.command;
|
|
|
|
import baritone.api.BaritoneAPI;
|
|
import baritone.api.IBaritone;
|
|
import baritone.api.Settings;
|
|
import baritone.api.command.argument.ICommandArgument;
|
|
import baritone.api.command.exception.CommandNotEnoughArgumentsException;
|
|
import baritone.api.command.exception.CommandNotFoundException;
|
|
import baritone.api.command.helpers.TabCompleteHelper;
|
|
import baritone.api.command.manager.ICommandManager;
|
|
import baritone.api.event.events.ChatEvent;
|
|
import baritone.api.event.events.TabCompleteEvent;
|
|
import baritone.api.event.listener.AbstractGameEventListener;
|
|
import baritone.api.utils.Helper;
|
|
import baritone.api.utils.SettingsUtil;
|
|
import baritone.command.argument.ArgConsumer;
|
|
import baritone.command.argument.CommandArguments;
|
|
import baritone.command.manager.CommandManager;
|
|
import baritone.utils.accessor.IGuiScreen;
|
|
import net.minecraft.util.Tuple;
|
|
import net.minecraft.util.text.ITextComponent;
|
|
import net.minecraft.util.text.TextComponentString;
|
|
import net.minecraft.util.text.TextFormatting;
|
|
import net.minecraft.util.text.event.ClickEvent;
|
|
import net.minecraft.util.text.event.HoverEvent;
|
|
|
|
import java.net.URI;
|
|
import java.net.URISyntaxException;
|
|
import java.util.List;
|
|
import java.util.Locale;
|
|
import java.util.stream.Stream;
|
|
|
|
import static baritone.api.command.IBaritoneChatControl.FORCE_COMMAND_PREFIX;
|
|
|
|
public class ExampleBaritoneControl implements Helper, AbstractGameEventListener {
|
|
|
|
private static final Settings settings = BaritoneAPI.getSettings();
|
|
private final ICommandManager manager;
|
|
|
|
public ExampleBaritoneControl(IBaritone baritone) {
|
|
this.manager = baritone.getCommandManager();
|
|
baritone.getGameEventHandler().registerEventListener(this);
|
|
}
|
|
|
|
@Override
|
|
public void onSendChatMessage(ChatEvent event) {
|
|
String msg = event.getMessage();
|
|
String prefix = settings.prefix.value;
|
|
boolean forceRun = msg.startsWith(FORCE_COMMAND_PREFIX);
|
|
if ((settings.prefixControl.value && msg.startsWith(prefix)) || forceRun) {
|
|
event.cancel();
|
|
String commandStr = msg.substring(forceRun ? FORCE_COMMAND_PREFIX.length() : prefix.length());
|
|
if (!runCommand(commandStr) && !commandStr.trim().isEmpty()) {
|
|
new CommandNotFoundException(CommandManager.expand(commandStr).getFirst()).handle(null, null);
|
|
}
|
|
} else if ((settings.chatControl.value || settings.chatControlAnyway.value) && runCommand(msg)) {
|
|
event.cancel();
|
|
}
|
|
}
|
|
|
|
private void logRanCommand(String command, String rest) {
|
|
if (settings.echoCommands.value) {
|
|
String msg = command + rest;
|
|
String toDisplay = settings.censorRanCommands.value ? command + " ..." : msg;
|
|
ITextComponent component = new TextComponentString(String.format("> %s", toDisplay));
|
|
component.getStyle()
|
|
.setColor(TextFormatting.WHITE)
|
|
.setHoverEvent(new HoverEvent(
|
|
HoverEvent.Action.SHOW_TEXT,
|
|
new TextComponentString("Click to rerun command")
|
|
))
|
|
.setClickEvent(new ClickEvent(
|
|
ClickEvent.Action.RUN_COMMAND,
|
|
FORCE_COMMAND_PREFIX + msg
|
|
));
|
|
logDirect(component);
|
|
}
|
|
}
|
|
|
|
public boolean runCommand(String msg) {
|
|
if (msg.trim().equalsIgnoreCase("damn")) {
|
|
logDirect("daniel");
|
|
return false;
|
|
} else if (msg.trim().equalsIgnoreCase("orderpizza")) {
|
|
try {
|
|
((IGuiScreen) mc.currentScreen).openLink(new URI("https://www.dominos.com/en/pages/order/"));
|
|
} catch (NullPointerException | URISyntaxException ignored) {}
|
|
return false;
|
|
}
|
|
if (msg.isEmpty()) {
|
|
return this.runCommand("help");
|
|
}
|
|
Tuple<String, List<ICommandArgument>> pair = CommandManager.expand(msg);
|
|
String command = pair.getFirst();
|
|
String rest = msg.substring(pair.getFirst().length());
|
|
ArgConsumer argc = new ArgConsumer(this.manager, pair.getSecond());
|
|
if (!argc.hasAny()) {
|
|
Settings.Setting setting = settings.byLowerName.get(command.toLowerCase(Locale.US));
|
|
if (setting != null) {
|
|
logRanCommand(command, rest);
|
|
if (setting.getValueClass() == Boolean.class) {
|
|
this.manager.execute(String.format("set toggle %s", setting.getName()));
|
|
} else {
|
|
this.manager.execute(String.format("set %s", setting.getName()));
|
|
}
|
|
return true;
|
|
}
|
|
} else if (argc.hasExactlyOne()) {
|
|
for (Settings.Setting setting : settings.allSettings) {
|
|
if (setting.getName().equals("logger")) {
|
|
continue;
|
|
}
|
|
if (setting.getName().equalsIgnoreCase(pair.getFirst())) {
|
|
logRanCommand(command, rest);
|
|
try {
|
|
this.manager.execute(String.format("set %s %s", setting.getName(), argc.getString()));
|
|
} catch (CommandNotEnoughArgumentsException ignored) {} // The operation is safe
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
|
|
// If the command exists, then handle echoing the input
|
|
if (this.manager.getCommand(pair.getFirst()) != null) {
|
|
logRanCommand(command, rest);
|
|
}
|
|
|
|
return this.manager.execute(pair);
|
|
}
|
|
|
|
@Override
|
|
public void onPreTabComplete(TabCompleteEvent event) {
|
|
if (!settings.prefixControl.value) {
|
|
return;
|
|
}
|
|
String prefix = event.prefix;
|
|
String commandPrefix = settings.prefix.value;
|
|
if (!prefix.startsWith(commandPrefix)) {
|
|
return;
|
|
}
|
|
String msg = prefix.substring(commandPrefix.length());
|
|
List<ICommandArgument> args = CommandArguments.from(msg, true);
|
|
Stream<String> stream = tabComplete(msg);
|
|
if (args.size() == 1) {
|
|
stream = stream.map(x -> commandPrefix + x);
|
|
}
|
|
event.completions = stream.toArray(String[]::new);
|
|
}
|
|
|
|
public Stream<String> tabComplete(String msg) {
|
|
try {
|
|
List<ICommandArgument> args = CommandArguments.from(msg, true);
|
|
ArgConsumer argc = new ArgConsumer(this.manager, args);
|
|
if (argc.hasAtMost(2)) {
|
|
if (argc.hasExactly(1)) {
|
|
return new TabCompleteHelper()
|
|
.addCommands(this.manager)
|
|
.addSettings()
|
|
.filterPrefix(argc.getString())
|
|
.stream();
|
|
}
|
|
Settings.Setting setting = settings.byLowerName.get(argc.getString().toLowerCase(Locale.US));
|
|
if (setting != null) {
|
|
if (setting.getValueClass() == Boolean.class) {
|
|
TabCompleteHelper helper = new TabCompleteHelper();
|
|
if ((Boolean) setting.value) {
|
|
helper.append("true", "false");
|
|
} else {
|
|
helper.append("false", "true");
|
|
}
|
|
return helper.filterPrefix(argc.getString()).stream();
|
|
} else {
|
|
return Stream.of(SettingsUtil.settingValueToString(setting));
|
|
}
|
|
}
|
|
}
|
|
return this.manager.tabComplete(msg);
|
|
} catch (CommandNotEnoughArgumentsException ignored) { // Shouldn't happen, the operation is safe
|
|
return Stream.empty();
|
|
}
|
|
}
|
|
}
|