mirror of
https://github.com/PurpurMC/Purpur.git
synced 2026-02-21 18:37:42 +01:00
Fix chat preview api
This commit is contained in:
@@ -4,26 +4,47 @@ Date: Mon, 11 Jul 2022 20:44:19 -0500
|
|||||||
Subject: [PATCH] Chat Preview API
|
Subject: [PATCH] Chat Preview API
|
||||||
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/network/chat/ChatDecorator.java b/src/main/java/net/minecraft/network/chat/ChatDecorator.java
|
diff --git a/src/main/java/net/minecraft/server/MinecraftServer.java b/src/main/java/net/minecraft/server/MinecraftServer.java
|
||||||
index b9cdd89a3871d934a0449ed70766c2e9d6369ab9..cf415137057a309db0961dcc993cecf33203151e 100644
|
index a5b09ab0171dd100f9bcf81869346b1d11814092..ac8e7323f3ada11fd58a5df6496c7c96efd916be 100644
|
||||||
--- a/src/main/java/net/minecraft/network/chat/ChatDecorator.java
|
--- a/src/main/java/net/minecraft/server/MinecraftServer.java
|
||||||
+++ b/src/main/java/net/minecraft/network/chat/ChatDecorator.java
|
+++ b/src/main/java/net/minecraft/server/MinecraftServer.java
|
||||||
@@ -7,6 +7,18 @@ import net.minecraft.server.level.ServerPlayer;
|
@@ -2628,12 +2628,29 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
||||||
@FunctionalInterface
|
new com.google.common.util.concurrent.ThreadFactoryBuilder().setDaemon(true).setNameFormat("Async Chat Thread - #%d").setUncaughtExceptionHandler(new net.minecraft.DefaultUncaughtExceptionHandlerWithName(net.minecraft.server.MinecraftServer.LOGGER)).build()); // Paper
|
||||||
public interface ChatDecorator {
|
|
||||||
ChatDecorator PLAIN = (sender, message) -> {
|
public ChatDecorator getChatDecorator() {
|
||||||
|
- return (entityplayer, ichatbasecomponent) -> {
|
||||||
+ // Purpur start
|
+ // Purpur start
|
||||||
+ if (sender != null) {
|
+ return this.chatDecorator;
|
||||||
+ net.kyori.adventure.text.Component adventureComponent = io.papermc.paper.adventure.PaperAdventure.asAdventure(message);
|
+ }
|
||||||
+ org.purpurmc.purpur.event.player.PlayerPreviewChatEvent previewEvent = new org.purpurmc.purpur.event.player.PlayerPreviewChatEvent(sender.getBukkitEntity(), "", adventureComponent);
|
+ public void setChatDecorator(ChatDecorator chatDecorator) {
|
||||||
+ if (!previewEvent.callEvent()) {
|
+ this.chatDecorator = chatDecorator;
|
||||||
|
+ }
|
||||||
|
+ private ChatDecorator chatDecorator = (entityplayer, ichatbasecomponent) -> {
|
||||||
|
+ // Purpur end
|
||||||
|
// Paper start - fix non-player sender
|
||||||
|
if (entityplayer == null) {
|
||||||
|
return CompletableFuture.completedFuture(ichatbasecomponent);
|
||||||
|
}
|
||||||
|
// Paper end
|
||||||
|
+ // Purpur start
|
||||||
|
+ net.kyori.adventure.text.Component adventureComponent = io.papermc.paper.adventure.PaperAdventure.asAdventure(ichatbasecomponent);
|
||||||
|
+ org.purpurmc.purpur.event.player.PlayerPreviewChatEvent purpurPreviewEvent = new org.purpurmc.purpur.event.player.PlayerPreviewChatEvent(entityplayer.getBukkitEntity(), "", adventureComponent);
|
||||||
|
+ if (!purpurPreviewEvent.callEvent()) {
|
||||||
+ return CompletableFuture.completedFuture(null);
|
+ return CompletableFuture.completedFuture(null);
|
||||||
+ }
|
+ }
|
||||||
+ if (!previewEvent.getQuery().equals(adventureComponent)) {
|
+ if (!adventureComponent.equals(purpurPreviewEvent.getQuery())) {
|
||||||
+ return CompletableFuture.completedFuture(io.papermc.paper.adventure.PaperAdventure.asVanilla(previewEvent.getQuery()));
|
+ return CompletableFuture.completedFuture(io.papermc.paper.adventure.PaperAdventure.asVanilla(purpurPreviewEvent.getQuery()));
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ // Purpur end
|
||||||
+ // Purpur end
|
return CompletableFuture.supplyAsync(() -> {
|
||||||
return CompletableFuture.completedFuture(message);
|
AsyncPlayerChatPreviewEvent event = new AsyncPlayerChatPreviewEvent(true, entityplayer.getBukkitEntity(), CraftChatMessage.fromComponent(ichatbasecomponent), new LazyPlayerSet(this));
|
||||||
};
|
String originalFormat = event.getFormat(), originalMessage = event.getMessage();
|
||||||
|
@@ -2647,7 +2664,7 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
||||||
|
}, chatExecutor);
|
||||||
|
};
|
||||||
|
// CraftBukkit end
|
||||||
|
- }
|
||||||
|
+ //} // Purpur
|
||||||
|
|
||||||
|
public static record ReloadableResources(CloseableResourceManager resourceManager, ReloadableServerResources managers) implements AutoCloseable {
|
||||||
|
|
||||||
|
|||||||
@@ -82,7 +82,7 @@ index 8bc0cb9ad5bb4e76d962ff54305e2c08e279a17b..e8efbbeece7e866c6c4d7489677d2d9e
|
|||||||
PacketUtils.LOGGER.debug("Ignoring packet due to disconnection: {}", packet);
|
PacketUtils.LOGGER.debug("Ignoring packet due to disconnection: {}", packet);
|
||||||
}
|
}
|
||||||
diff --git a/src/main/java/net/minecraft/server/MinecraftServer.java b/src/main/java/net/minecraft/server/MinecraftServer.java
|
diff --git a/src/main/java/net/minecraft/server/MinecraftServer.java b/src/main/java/net/minecraft/server/MinecraftServer.java
|
||||||
index f31602ece11240f3c1991c1d9dc8fde4f48890fe..ec2c9f2e3bb89be847993205f107089ed8cc05b5 100644
|
index 327ecc7a92671fbdb8e22e19ca30bb0f76a35a8c..d6b0477509ce4fc37f9e3388a014970ec5e04693 100644
|
||||||
--- a/src/main/java/net/minecraft/server/MinecraftServer.java
|
--- a/src/main/java/net/minecraft/server/MinecraftServer.java
|
||||||
+++ b/src/main/java/net/minecraft/server/MinecraftServer.java
|
+++ b/src/main/java/net/minecraft/server/MinecraftServer.java
|
||||||
@@ -1426,15 +1426,15 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
@@ -1426,15 +1426,15 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
||||||
@@ -211,7 +211,7 @@ index f31602ece11240f3c1991c1d9dc8fde4f48890fe..ec2c9f2e3bb89be847993205f107089e
|
|||||||
|
|
||||||
this.profiler.pop();
|
this.profiler.pop();
|
||||||
}
|
}
|
||||||
@@ -2769,7 +2769,7 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
@@ -2786,7 +2786,7 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -220,7 +220,7 @@ index f31602ece11240f3c1991c1d9dc8fde4f48890fe..ec2c9f2e3bb89be847993205f107089e
|
|||||||
try {
|
try {
|
||||||
for (;;) {
|
for (;;) {
|
||||||
boolean moreTasks = this.tickMidTickTasks();
|
boolean moreTasks = this.tickMidTickTasks();
|
||||||
@@ -2796,7 +2796,7 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
@@ -2813,7 +2813,7 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} finally {
|
} finally {
|
||||||
|
|||||||
Reference in New Issue
Block a user