2021-06-13 01:45:00 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Fri, 3 Aug 2018 00:04:54 -0400
|
2022-10-22 16:16:24 +02:00
|
|
|
Subject: [PATCH] Fix NBT type issues
|
2021-06-13 01:45:00 +02:00
|
|
|
|
2022-10-22 16:16:24 +02:00
|
|
|
Addresses two issues:
|
|
|
|
- MC-135506: Experience should save as Integers
|
|
|
|
- Allay duplication cooldown is saved and exposed as a long, but loaded as an int
|
2021-06-13 01:45:00 +02:00
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/ExperienceOrb.java b/src/main/java/net/minecraft/world/entity/ExperienceOrb.java
|
2024-06-13 21:04:27 +02:00
|
|
|
index 2d438cd3e69503fdc45a706f25c219af6f7a5db3..0916e24271d07ad5db51c5bc68791722b0f69c2b 100644
|
2021-06-13 01:45:00 +02:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/ExperienceOrb.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/ExperienceOrb.java
|
2024-06-13 21:04:27 +02:00
|
|
|
@@ -305,7 +305,7 @@ public class ExperienceOrb extends Entity {
|
2021-06-13 01:45:00 +02:00
|
|
|
public void addAdditionalSaveData(CompoundTag nbt) {
|
|
|
|
nbt.putShort("Health", (short) this.health);
|
|
|
|
nbt.putShort("Age", (short) this.age);
|
|
|
|
- nbt.putShort("Value", (short) this.value);
|
|
|
|
+ nbt.putInt("Value", this.value); // Paper - save as Integer
|
|
|
|
nbt.putInt("Count", this.count);
|
|
|
|
this.savePaperNBT(nbt); // Paper
|
|
|
|
}
|
2024-06-13 21:04:27 +02:00
|
|
|
@@ -314,7 +314,7 @@ public class ExperienceOrb extends Entity {
|
2021-06-13 01:45:00 +02:00
|
|
|
public void readAdditionalSaveData(CompoundTag nbt) {
|
|
|
|
this.health = nbt.getShort("Health");
|
|
|
|
this.age = nbt.getShort("Age");
|
|
|
|
- this.value = nbt.getShort("Value");
|
|
|
|
+ this.value = nbt.getInt("Value"); // Paper - load as Integer
|
|
|
|
this.count = Math.max(nbt.getInt("Count"), 1);
|
|
|
|
this.loadPaperNBT(nbt); // Paper
|
|
|
|
}
|
2022-10-22 16:16:24 +02:00
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/animal/allay/Allay.java b/src/main/java/net/minecraft/world/entity/animal/allay/Allay.java
|
2024-06-13 21:04:27 +02:00
|
|
|
index 56b9123b42d05e0fb20763b8988aa68583a36781..69986f75d3cf729204cca0c7e5428536af31f695 100644
|
2022-10-22 16:16:24 +02:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/animal/allay/Allay.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/animal/allay/Allay.java
|
2024-06-13 21:04:27 +02:00
|
|
|
@@ -489,7 +489,7 @@ public class Allay extends PathfinderMob implements InventoryCarrier, VibrationS
|
2022-10-22 16:16:24 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
- this.duplicationCooldown = (long) nbt.getInt("DuplicationCooldown");
|
|
|
|
+ this.duplicationCooldown = nbt.getLong("DuplicationCooldown"); // Paper - Load as long
|
|
|
|
this.entityData.set(Allay.DATA_CAN_DUPLICATE, nbt.getBoolean("CanDuplicate"));
|
|
|
|
}
|
|
|
|
|