diff options
Diffstat (limited to 'patches/server/0850-Added-byte-array-serialization-deserialization-for-P.patch')
-rw-r--r-- | patches/server/0850-Added-byte-array-serialization-deserialization-for-P.patch | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/patches/server/0850-Added-byte-array-serialization-deserialization-for-P.patch b/patches/server/0850-Added-byte-array-serialization-deserialization-for-P.patch new file mode 100644 index 0000000000..b3ca268703 --- /dev/null +++ b/patches/server/0850-Added-byte-array-serialization-deserialization-for-P.patch @@ -0,0 +1,38 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: Nex <[email protected]> +Date: Thu, 24 Feb 2022 16:28:07 +0100 +Subject: [PATCH] Added byte array serialization/deserialization for + PersistentDataContainers + + +diff --git a/src/main/java/org/bukkit/craftbukkit/persistence/CraftPersistentDataContainer.java b/src/main/java/org/bukkit/craftbukkit/persistence/CraftPersistentDataContainer.java +index 564e97c6fefb4c8af4b4df70e68951a2157e72cb..8f3769145c3dacc976cc926d896ea9f82332119c 100644 +--- a/src/main/java/org/bukkit/craftbukkit/persistence/CraftPersistentDataContainer.java ++++ b/src/main/java/org/bukkit/craftbukkit/persistence/CraftPersistentDataContainer.java +@@ -168,5 +168,26 @@ public class CraftPersistentDataContainer implements PersistentDataContainer { + + return this.customDataTags.containsKey(key.toString()); + } ++ ++ @Override ++ public byte[] serializeToBytes() throws java.io.IOException { ++ net.minecraft.nbt.CompoundTag root = this.toTagCompound(); ++ java.io.ByteArrayOutputStream byteArrayOutput = new java.io.ByteArrayOutputStream(); ++ try (java.io.DataOutputStream dataOutput = new java.io.DataOutputStream(byteArrayOutput)) { ++ net.minecraft.nbt.NbtIo.write(root, dataOutput); ++ return byteArrayOutput.toByteArray(); ++ } ++ } ++ ++ @Override ++ public void readFromBytes(byte[] bytes, boolean clear) throws java.io.IOException { ++ if (clear) { ++ this.clear(); ++ } ++ try (java.io.DataInputStream dataInput = new java.io.DataInputStream(new java.io.ByteArrayInputStream(bytes))) { ++ net.minecraft.nbt.CompoundTag compound = net.minecraft.nbt.NbtIo.read(dataInput); ++ this.putAll(compound); ++ } ++ } + // Paper end + } |