aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/me/xmrvizzy/skyblocker/utils/scheduler/MessageScheduler.java
diff options
context:
space:
mode:
authorYasin <a.piri@hotmail.de>2023-10-09 12:58:02 +0200
committerYasin <a.piri@hotmail.de>2023-10-09 12:58:02 +0200
commitbd3f0329d0e391bd84b5f9e3ff207d9dd9815853 (patch)
tree2fd1d1ef625f57acc2e4916c967d8d2393844798 /src/main/java/me/xmrvizzy/skyblocker/utils/scheduler/MessageScheduler.java
parent2315b90da8117f28f66348927afdb621ee4fc815 (diff)
downloadSkyblocker-bd3f0329d0e391bd84b5f9e3ff207d9dd9815853.tar.gz
Skyblocker-bd3f0329d0e391bd84b5f9e3ff207d9dd9815853.tar.bz2
Skyblocker-bd3f0329d0e391bd84b5f9e3ff207d9dd9815853.zip
new pr because fixing merge conflict would take too long
Diffstat (limited to 'src/main/java/me/xmrvizzy/skyblocker/utils/scheduler/MessageScheduler.java')
-rw-r--r--src/main/java/me/xmrvizzy/skyblocker/utils/scheduler/MessageScheduler.java66
1 files changed, 0 insertions, 66 deletions
diff --git a/src/main/java/me/xmrvizzy/skyblocker/utils/scheduler/MessageScheduler.java b/src/main/java/me/xmrvizzy/skyblocker/utils/scheduler/MessageScheduler.java
deleted file mode 100644
index b8ffa548..00000000
--- a/src/main/java/me/xmrvizzy/skyblocker/utils/scheduler/MessageScheduler.java
+++ /dev/null
@@ -1,66 +0,0 @@
-package me.xmrvizzy.skyblocker.utils.scheduler;
-
-import net.minecraft.client.MinecraftClient;
-
-/**
- * A scheduler for sending chat messages or commands. Use the instance in {@link #INSTANCE}. Do not instantiate this class.
- */
-public class MessageScheduler extends Scheduler {
- /**
- * The minimum delay that the server will accept between chat messages.
- */
- private static final int MIN_DELAY = 200;
- public static final MessageScheduler INSTANCE = new MessageScheduler();
- /**
- * The timestamp of the last message send,
- */
- private long lastMessage = 0;
-
- protected MessageScheduler() {
- }
-
- /**
- * Sends a chat message or command after the minimum cooldown. Prefer this method to send messages or commands to the server.
- *
- * @param message the message to send
- */
- public void sendMessageAfterCooldown(String message) {
- if (lastMessage + MIN_DELAY < System.currentTimeMillis()) {
- sendMessage(message);
- lastMessage = System.currentTimeMillis();
- } else {
- queueMessage(message, 0);
- }
- }
-
- private void sendMessage(String message) {
- if (MinecraftClient.getInstance().player != null) {
- if (message.startsWith("/")) {
- MinecraftClient.getInstance().player.networkHandler.sendCommand(message.substring(1));
- } else {
- MinecraftClient.getInstance().inGameHud.getChatHud().addToMessageHistory(message);
- MinecraftClient.getInstance().player.networkHandler.sendChatMessage(message);
- }
- }
- }
-
- /**
- * Queues a chat message or command to send in {@code delay} ticks. Use this method to send messages or commands a set time in the future. The minimum cooldown is still respected.
- *
- * @param message the message to send
- * @param delay the delay before sending the message in ticks
- */
- public void queueMessage(String message, int delay) {
- schedule(() -> sendMessage(message), delay);
- }
-
- @Override
- protected boolean runTask(Runnable task) {
- if (lastMessage + MIN_DELAY < System.currentTimeMillis()) {
- task.run();
- lastMessage = System.currentTimeMillis();
- return true;
- }
- return false;
- }
-}