aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0850-Added-byte-array-serialization-deserialization-for-P.patch
diff options
context:
space:
mode:
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.patch38
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
+ }