Skip to content

Commit dd61319

Browse files
Couple fixes for command blocks (#8004)
1 parent f428887 commit dd61319

File tree

2 files changed

+42
-3
lines changed

2 files changed

+42
-3
lines changed

patches/server/0008-Adventure.patch

Lines changed: 8 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -2012,7 +2012,7 @@ index 40421cc8ef25f1bef32a0a5d2f0f25165efe230a..1357bc97801f892e59fc8e89c3cc2d69
20122012
+ // Paper end
20132013
}
20142014
diff --git a/src/main/java/org/bukkit/craftbukkit/Main.java b/src/main/java/org/bukkit/craftbukkit/Main.java
2015-
index c694c6dfed0b3aa098b1822676e39bd3eb04b45a..0d427758182ebe01d612d5140e4a0d519a96d8c0 100644
2015+
index df98326c49973183e81ccb96d4b1a7a7626dffee..18652607d36a980a4b0956584f8a722be776dad2 100644
20162016
--- a/src/main/java/org/bukkit/craftbukkit/Main.java
20172017
+++ b/src/main/java/org/bukkit/craftbukkit/Main.java
20182018
@@ -19,6 +19,12 @@ public class Main {
@@ -2242,15 +2242,20 @@ index 3f5292deeeddb8a6a5df57aac01f48ba11be6d7c..911843bf38ab750edd4a63417ba7a9de
22422242
Component[] components = new Component[4];
22432243

22442244
diff --git a/src/main/java/org/bukkit/craftbukkit/command/CraftBlockCommandSender.java b/src/main/java/org/bukkit/craftbukkit/command/CraftBlockCommandSender.java
2245-
index 3de88112bdb08d6bd0d28f20582c4090bfd8dbfe..11164a28018be3ba46f898e57a1eefbeb0360426 100644
2245+
index 3de88112bdb08d6bd0d28f20582c4090bfd8dbfe..87f2cea36d852c81fdb0a1bc21162d41377ab2e7 100644
22462246
--- a/src/main/java/org/bukkit/craftbukkit/command/CraftBlockCommandSender.java
22472247
+++ b/src/main/java/org/bukkit/craftbukkit/command/CraftBlockCommandSender.java
2248-
@@ -45,6 +45,13 @@ public class CraftBlockCommandSender extends ServerCommandSender implements Bloc
2248+
@@ -45,6 +45,18 @@ public class CraftBlockCommandSender extends ServerCommandSender implements Bloc
22492249
return this.block.getTextName();
22502250
}
22512251

22522252
+ // Paper start
22532253
+ @Override
2254+
+ public void sendMessage(net.kyori.adventure.identity.Identity identity, net.kyori.adventure.text.Component message, net.kyori.adventure.audience.MessageType type) {
2255+
+ block.source.sendSystemMessage(io.papermc.paper.adventure.PaperAdventure.asVanilla(message));
2256+
+ }
2257+
+
2258+
+ @Override
22542259
+ public net.kyori.adventure.text.Component name() {
22552260
+ return io.papermc.paper.adventure.PaperAdventure.asAdventure(this.block.getDisplayName());
22562261
+ }
Lines changed: 34 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,34 @@
1+
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
2+
From: Jake Potrebic <jake.m.potrebic@gmail.com>
3+
Date: Thu, 16 Jun 2022 14:22:56 -0700
4+
Subject: [PATCH] Don't broadcast messages to command blocks
5+
6+
Previously the broadcast method would update the last output
7+
in command blocks, and if called asynchronously, would throw
8+
an error
9+
10+
diff --git a/src/main/java/net/minecraft/world/level/BaseCommandBlock.java b/src/main/java/net/minecraft/world/level/BaseCommandBlock.java
11+
index c0195f73cd2c8721e882c681eaead65471710081..861b348f73867af3199f1cc0dab1ddd4241d1567 100644
12+
--- a/src/main/java/net/minecraft/world/level/BaseCommandBlock.java
13+
+++ b/src/main/java/net/minecraft/world/level/BaseCommandBlock.java
14+
@@ -172,6 +172,7 @@ public abstract class BaseCommandBlock implements CommandSource {
15+
@Override
16+
public void sendSystemMessage(Component message) {
17+
if (this.trackOutput) {
18+
+ org.spigotmc.AsyncCatcher.catchOp("sendSystemMessage to a command block"); // Paper
19+
SimpleDateFormat simpledateformat = BaseCommandBlock.TIME_FORMAT;
20+
Date date = new Date();
21+
22+
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
23+
index f1e5ccfbcd08a73ac3aba9a1cb7b414faef81f9e..72311b27bb642ee05dba45b76935277d183012eb 100644
24+
--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
25+
+++ b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
26+
@@ -1736,7 +1736,7 @@ public final class CraftServer implements Server {
27+
// Paper end
28+
Set<CommandSender> recipients = new HashSet<>();
29+
for (Permissible permissible : this.getPluginManager().getPermissionSubscriptions(permission)) {
30+
- if (permissible instanceof CommandSender && permissible.hasPermission(permission)) {
31+
+ if (permissible instanceof CommandSender && !(permissible instanceof org.bukkit.command.BlockCommandSender) && permissible.hasPermission(permission)) { // Paper - don't broadcast to BlockCommandSender (specifically Command Blocks)
32+
recipients.add((CommandSender) permissible);
33+
}
34+
}

0 commit comments

Comments
 (0)