SPIGOT-7127: /say doesn't work from console

By: md_5 <git@md-5.net>
This commit is contained in:
CraftBukkit/Spigot 2022-08-01 22:07:48 +10:00
parent cb4c71bc0d
commit 0b6cdcc0c4

View file

@ -342,11 +342,11 @@
+ this.connection.acceptConnections(); + this.connection.acceptConnections();
+ } + }
+ // CraftBukkit end + // CraftBukkit end
+
+ protected void forceDifficulty() {}
- this.readScoreboard(worldpersistentdata); - this.readScoreboard(worldpersistentdata);
- this.commandStorage = new PersistentCommandStorage(worldpersistentdata); - this.commandStorage = new PersistentCommandStorage(worldpersistentdata);
+ protected void forceDifficulty() {}
+
+ // CraftBukkit start + // CraftBukkit start
+ public void initWorld(WorldServer worldserver, IWorldDataServer iworlddataserver, SaveData saveData, GeneratorSettings generatorsettings) { + public void initWorld(WorldServer worldserver, IWorldDataServer iworlddataserver, SaveData saveData, GeneratorSettings generatorsettings) {
+ boolean flag = generatorsettings.isDebug(); + boolean flag = generatorsettings.isDebug();
@ -712,7 +712,7 @@
private void startMetricsRecordingTick() { private void startMetricsRecordingTick() {
if (this.willStartRecordingMetrics) { if (this.willStartRecordingMetrics) {
this.metricsRecorder = ActiveMetricsRecorder.createStarted(new ServerMetricsSamplersProvider(SystemUtils.timeSource, this.isDedicatedServer()), SystemUtils.timeSource, SystemUtils.ioPool(), new MetricsPersister("server"), this.onMetricsRecordingStopped, (path) -> { this.metricsRecorder = ActiveMetricsRecorder.createStarted(new ServerMetricsSamplersProvider(SystemUtils.timeSource, this.isDedicatedServer()), SystemUtils.timeSource, SystemUtils.ioPool(), new MetricsPersister("server"), this.onMetricsRecordingStopped, (path) -> {
@@ -1912,8 +2223,25 @@ @@ -1912,8 +2223,30 @@
} }
@ -723,6 +723,11 @@
public ChatDecorator getChatDecorator() { public ChatDecorator getChatDecorator() {
- return ChatDecorator.PLAIN; - return ChatDecorator.PLAIN;
+ return (entityplayer, ichatbasecomponent) -> { + return (entityplayer, ichatbasecomponent) -> {
+ // SPIGOT-7127: Console /say and similar
+ if (entityplayer == null) {
+ return CompletableFuture.completedFuture(ichatbasecomponent);
+ }
+
+ return CompletableFuture.supplyAsync(() -> { + return CompletableFuture.supplyAsync(() -> {
+ AsyncPlayerChatPreviewEvent event = new AsyncPlayerChatPreviewEvent(true, entityplayer.getBukkitEntity(), CraftChatMessage.fromComponent(ichatbasecomponent), new LazyPlayerSet(this)); + AsyncPlayerChatPreviewEvent event = new AsyncPlayerChatPreviewEvent(true, entityplayer.getBukkitEntity(), CraftChatMessage.fromComponent(ichatbasecomponent), new LazyPlayerSet(this));
+ String originalFormat = event.getFormat(), originalMessage = event.getMessage(); + String originalFormat = event.getFormat(), originalMessage = event.getMessage();