1.21.3-update #16
43
patches/server/1068-Always-send-Banner-patterns-to-the-client.patch
Normale Datei
43
patches/server/1068-Always-send-Banner-patterns-to-the-client.patch
Normale Datei
@ -0,0 +1,43 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Shane Freeder <theboyetronic@gmail.com>
|
||||||
|
Date: Sun, 20 Oct 2024 18:23:59 +0100
|
||||||
|
Subject: [PATCH] Always send Banner patterns to the client
|
||||||
|
|
||||||
|
The mojang client will not remove patterns from a Banner when none
|
||||||
|
are sent inside of an update packet, given that this is not an expected
|
||||||
|
flow for them, this is not all too surprising. So, we shall resort to always
|
||||||
|
sending the patterns over the network for update packets.
|
||||||
|
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/level/block/entity/BannerBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/BannerBlockEntity.java
|
||||||
|
index 60c26076e7acf869fa0e20fdc14eeec341387d99..60a9f3c7f007d268f24a4fe9e87029fdbc8360f9 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/level/block/entity/BannerBlockEntity.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/level/block/entity/BannerBlockEntity.java
|
||||||
|
@@ -63,7 +63,7 @@ public class BannerBlockEntity extends BlockEntity implements Nameable {
|
||||||
|
@Override
|
||||||
|
protected void saveAdditional(CompoundTag nbt, HolderLookup.Provider registryLookup) {
|
||||||
|
super.saveAdditional(nbt, registryLookup);
|
||||||
|
- if (!this.patterns.equals(BannerPatternLayers.EMPTY)) {
|
||||||
|
+ if (!this.patterns.equals(BannerPatternLayers.EMPTY) || serialisingForNetwork.get()) { // Paper - always send patterns to client
|
||||||
|
nbt.put("patterns", (Tag) BannerPatternLayers.CODEC.encodeStart(registryLookup.createSerializationContext(NbtOps.INSTANCE), this.patterns).getOrThrow());
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -95,9 +95,18 @@ public class BannerBlockEntity extends BlockEntity implements Nameable {
|
||||||
|
return ClientboundBlockEntityDataPacket.create(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
+ // Paper start - always send patterns to client
|
||||||
|
+ ThreadLocal<Boolean> serialisingForNetwork = ThreadLocal.withInitial(() -> Boolean.FALSE);
|
||||||
|
@Override
|
||||||
|
public CompoundTag getUpdateTag(HolderLookup.Provider registryLookup) {
|
||||||
|
- return this.saveWithoutMetadata(registryLookup);
|
||||||
|
+ final Boolean wasSerialisingForNetwork = serialisingForNetwork.get();
|
||||||
|
+ try {
|
||||||
|
+ serialisingForNetwork.set(Boolean.TRUE);
|
||||||
|
+ return this.saveWithoutMetadata(registryLookup);
|
||||||
|
+ } finally {
|
||||||
|
+ serialisingForNetwork.set(wasSerialisingForNetwork);
|
||||||
|
+ }
|
||||||
|
+ // Paper end - always send patterns to client
|
||||||
|
}
|
||||||
|
|
||||||
|
public BannerPatternLayers getPatterns() {
|
In neuem Issue referenzieren
Einen Benutzer sperren