mirror of
https://github.com/Winds-Studio/Leaf.git
synced 2025-12-19 15:09:25 +00:00
74 lines
3.5 KiB
Diff
74 lines
3.5 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Martijn Muijsers <martijnmuijsers@live.nl>
|
|
Date: Fri, 23 Dec 2022 16:42:04 +0100
|
|
Subject: [PATCH] Fix MC-26304
|
|
|
|
Removed since Gale 1.21.3, Mojang fixed it in 1.21 24w19a
|
|
|
|
License: GPL-3.0 (https://www.gnu.org/licenses/gpl-3.0.html)
|
|
Gale - https://galemc.org
|
|
|
|
This patch is based on the following patch:
|
|
"Fix brewing stands resetting their brewTime when being unloaded"
|
|
By: etil2jz <81570777+etil2jz@users.noreply.github.com>
|
|
As part of: Mirai (https://github.com/etil2jz/Mirai)
|
|
Licensed under: GPL-3.0 (https://www.gnu.org/licenses/gpl-3.0.html)
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/level/block/entity/BrewingStandBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/BrewingStandBlockEntity.java
|
|
index 02fc9ce21c7d367055da350d21be4870d4242f3a..cd64464f68311f61b687257fe5fdacec98e0146d 100644
|
|
--- a/src/main/java/net/minecraft/world/level/block/entity/BrewingStandBlockEntity.java
|
|
+++ b/src/main/java/net/minecraft/world/level/block/entity/BrewingStandBlockEntity.java
|
|
@@ -48,6 +48,7 @@ public class BrewingStandBlockEntity extends BaseContainerBlockEntity implements
|
|
public static final int DATA_BREW_TIME = 0;
|
|
public static final int DATA_FUEL_USES = 1;
|
|
public static final int NUM_DATA_VALUES = 2;
|
|
+ private static final String[] INGREDIENT_NBT_KEYS = {"Gale.Ingredient", "Mirai.ingredient"}; // Gale - Mirai - fix MC-26304
|
|
private NonNullList<ItemStack> items;
|
|
public int brewTime;
|
|
public int recipeBrewTime = 400; // Paper - Add recipeBrewTime
|
|
@@ -314,6 +315,25 @@ public class BrewingStandBlockEntity extends BaseContainerBlockEntity implements
|
|
}
|
|
|
|
this.fuel = nbt.getByte("Fuel");
|
|
+ // Gale start - Mirai - fix MC-26304
|
|
+ if (this.ingredient == null || this.ingredient == Items.AIR) {
|
|
+ for (String nbtKey : INGREDIENT_NBT_KEYS) {
|
|
+ try {
|
|
+ if (nbt.contains(nbtKey)) {
|
|
+ java.util.Optional<net.minecraft.core.Holder.Reference<Item>> opt = net.minecraft.core.registries.BuiltInRegistries.ITEM.get(net.minecraft.resources.ResourceLocation.parse(nbt.getString(nbtKey)));
|
|
+ if (opt.isPresent()) {
|
|
+ this.ingredient = opt.get().value();
|
|
+ if (this.ingredient != null && this.ingredient != Items.AIR) {
|
|
+ break;
|
|
+ }
|
|
+ }
|
|
+ }
|
|
+ } catch (Throwable ignored) {
|
|
+ // Cannot be helped
|
|
+ }
|
|
+ }
|
|
+ }
|
|
+ // Gale end - Mirai - fix MC-26304
|
|
}
|
|
|
|
@Override
|
|
@@ -322,6 +342,18 @@ public class BrewingStandBlockEntity extends BaseContainerBlockEntity implements
|
|
nbt.putShort("BrewTime", (short) this.brewTime);
|
|
ContainerHelper.saveAllItems(nbt, this.items, registries);
|
|
nbt.putByte("Fuel", (byte) this.fuel);
|
|
+ // Gale start - Mirai - fix MC-26304
|
|
+ if (this.ingredient != null && this.ingredient != Items.AIR) {
|
|
+ try {
|
|
+ String value = net.minecraft.core.registries.BuiltInRegistries.ITEM.getKey(this.ingredient).toString();
|
|
+ for (String nbtKey : INGREDIENT_NBT_KEYS) {
|
|
+ nbt.putString(nbtKey, value);
|
|
+ }
|
|
+ } catch (Throwable ignored) {
|
|
+ // Cannot be helped
|
|
+ }
|
|
+ }
|
|
+ // Gale end - Mirai - fix MC-26304
|
|
}
|
|
|
|
@Override
|