c43dcbfcf0
If we set a UUID to new format, need to make sure old format doesn't exist anymore. Additionally, ensure if new format exists, we prefer it over old.
49 Zeilen
2.1 KiB
Diff
49 Zeilen
2.1 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Aikar <aikar@aikar.co>
|
|
Date: Mon, 29 Jun 2020 03:26:17 -0400
|
|
Subject: [PATCH] Support old UUID format for NBT
|
|
|
|
We have stored UUID in plenty of places that did not get DFU'd
|
|
|
|
So just look for old format and load it if it exists.
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/NBTTagCompound.java b/src/main/java/net/minecraft/server/NBTTagCompound.java
|
|
index f608b35502890650adfc1df35e0794471f57ecbc..436f40bcd7817bedde4f6570c7c47dba7ff7034f 100644
|
|
--- a/src/main/java/net/minecraft/server/NBTTagCompound.java
|
|
+++ b/src/main/java/net/minecraft/server/NBTTagCompound.java
|
|
@@ -135,6 +135,12 @@ public class NBTTagCompound implements NBTBase {
|
|
|
|
public void setUUID(String prefix, UUID uuid) { a(prefix, uuid); } // Paper - OBFHELPER
|
|
public void a(String s, UUID uuid) {
|
|
+ // Paper start - support old format
|
|
+ if (this.hasKeyOfType(s + "Most", 99) && this.hasKeyOfType(s + "Least", 99)) {
|
|
+ this.map.remove(s + "Most");
|
|
+ this.map.remove(s + "Least");
|
|
+ }
|
|
+ // Paper end
|
|
this.map.put(s, GameProfileSerializer.a(uuid));
|
|
}
|
|
|
|
@@ -142,11 +148,21 @@ public class NBTTagCompound implements NBTBase {
|
|
@Nullable public UUID getUUID(String prefix) { return a(prefix); } // Paper - OBFHELPER
|
|
@Nullable
|
|
public UUID a(String s) {
|
|
+ // Paper start - support old format
|
|
+ if (!hasKeyOfType(s, 11) && this.hasKeyOfType(s + "Most", 99) && this.hasKeyOfType(s + "Least", 99)) {
|
|
+ return new UUID(this.getLong(s + "Most"), this.getLong(s + "Least"));
|
|
+ }
|
|
+ // Paper end
|
|
return GameProfileSerializer.a(this.get(s));
|
|
}
|
|
|
|
public final boolean hasUUID(String s) { return this.b(s); } // Paper - OBFHELPER
|
|
public boolean b(String s) {
|
|
+ // Paper start - support old format
|
|
+ if (this.hasKeyOfType(s + "Most", 99) && this.hasKeyOfType(s + "Least", 99)) {
|
|
+ return true;
|
|
+ }
|
|
+ // Paper end
|
|
NBTBase nbtbase = this.get(s);
|
|
|
|
return nbtbase != null && nbtbase.b() == NBTTagIntArray.a && ((NBTTagIntArray) nbtbase).getInts().length == 4;
|