From 158c189089c5c07f5821d94449866e7ab282eef5 Mon Sep 17 00:00:00 2001
From: modmuss50 <modmuss50@gmail.com>
Date: Wed, 5 Apr 2023 17:18:33 +0100
Subject: [PATCH] 23w14a

---
 .../test/lookup/FabricApiLookupTest.java      |  6 +-
 .../v1/provider/FabricLootTableProvider.java  |  4 +-
 .../test/entity/event/EntityEventTests.java   |  2 +-
 .../fabric/mixin/item/ItemStackMixin.java     | 22 +----
 .../fabric/mixin/loot/LootManagerMixin.java   | 42 +++++----
 .../client/DisconnectedScreenMixin.java       | 93 -------------------
 ...abric-networking-api-v1.client.mixins.json |  3 +-
 .../v1/block/FabricMaterialBuilder.java       |  6 --
 .../v1/block/type/BlockSetTypeRegistry.java   |  5 +-
 .../test/transfer/ingame/FluidChuteBlock.java |  2 +-
 .../ingame/TransferTestInitializer.java       |  4 +-
 gradle.properties                             | 34 +++----
 12 files changed, 56 insertions(+), 167 deletions(-)
 delete mode 100644 fabric-networking-api-v1/src/client/java/net/fabricmc/fabric/mixin/networking/client/DisconnectedScreenMixin.java

diff --git a/fabric-api-lookup-api-v1/src/testmod/java/net/fabricmc/fabric/test/lookup/FabricApiLookupTest.java b/fabric-api-lookup-api-v1/src/testmod/java/net/fabricmc/fabric/test/lookup/FabricApiLookupTest.java
index f216a83f9..e581d52c4 100644
--- a/fabric-api-lookup-api-v1/src/testmod/java/net/fabricmc/fabric/test/lookup/FabricApiLookupTest.java
+++ b/fabric-api-lookup-api-v1/src/testmod/java/net/fabricmc/fabric/test/lookup/FabricApiLookupTest.java
@@ -42,17 +42,17 @@ public class FabricApiLookupTest implements ModInitializer {
 	public static final String MOD_ID = "fabric-lookup-api-v1-testmod";
 	// Chute - Block without model that transfers item from the container above to the container below.
 	// It's meant to work with unsided containers: chests, dispensers, droppers and hoppers.
-	public static final ChuteBlock CHUTE_BLOCK = new ChuteBlock(FabricBlockSettings.of(Material.METAL));
+	public static final ChuteBlock CHUTE_BLOCK = new ChuteBlock(FabricBlockSettings.of(Material.field_44489));
 	public static final BlockItem CHUTE_ITEM = new BlockItem(CHUTE_BLOCK, new Item.Settings());
 	public static BlockEntityType<ChuteBlockEntity> CHUTE_BLOCK_ENTITY_TYPE;
 	// Cobble gen - Block without model that can generate infinite cobblestone when placed above a chute.
 	// It's meant to test BlockApiLookup#registerSelf.
-	public static final CobbleGenBlock COBBLE_GEN_BLOCK = new CobbleGenBlock(FabricBlockSettings.of(Material.METAL));
+	public static final CobbleGenBlock COBBLE_GEN_BLOCK = new CobbleGenBlock(FabricBlockSettings.of(Material.field_44489));
 	public static final BlockItem COBBLE_GEN_ITEM = new BlockItem(COBBLE_GEN_BLOCK, new Item.Settings());
 	public static BlockEntityType<CobbleGenBlockEntity> COBBLE_GEN_BLOCK_ENTITY_TYPE;
 	// Testing for item api lookups is done in the `item` package.
 
-	public static final InspectorBlock INSPECTOR_BLOCK = new InspectorBlock(FabricBlockSettings.of(Material.METAL));
+	public static final InspectorBlock INSPECTOR_BLOCK = new InspectorBlock(FabricBlockSettings.of(Material.field_44489));
 	public static final BlockItem INSPECTOR_ITEM = new BlockItem(INSPECTOR_BLOCK, new Item.Settings());
 
 	@Override
diff --git a/fabric-data-generation-api-v1/src/main/java/net/fabricmc/fabric/api/datagen/v1/provider/FabricLootTableProvider.java b/fabric-data-generation-api-v1/src/main/java/net/fabricmc/fabric/api/datagen/v1/provider/FabricLootTableProvider.java
index c9eb1ed91..358f33554 100644
--- a/fabric-data-generation-api-v1/src/main/java/net/fabricmc/fabric/api/datagen/v1/provider/FabricLootTableProvider.java
+++ b/fabric-data-generation-api-v1/src/main/java/net/fabricmc/fabric/api/datagen/v1/provider/FabricLootTableProvider.java
@@ -30,10 +30,10 @@ import com.google.common.collect.Maps;
 import com.google.gson.JsonObject;
 import org.jetbrains.annotations.ApiStatus;
 
+import net.minecraft.class_8490;
 import net.minecraft.data.DataOutput;
 import net.minecraft.data.DataProvider;
 import net.minecraft.data.DataWriter;
-import net.minecraft.loot.LootManager;
 import net.minecraft.loot.LootTable;
 import net.minecraft.loot.context.LootContextType;
 import net.minecraft.util.Identifier;
@@ -87,7 +87,7 @@ public interface FabricLootTableProvider extends Consumer<BiConsumer<Identifier,
 		final List<CompletableFuture<?>> futures = new ArrayList<>();
 
 		for (Map.Entry<Identifier, LootTable> entry : builders.entrySet()) {
-			JsonObject tableJson = (JsonObject) LootManager.toJson(entry.getValue());
+			JsonObject tableJson = (JsonObject) class_8490.LOOT_TABLES.method_51203().toJsonTree(entry.getValue());
 			ConditionJsonProvider.write(tableJson, conditionMap.remove(entry.getKey()));
 
 			futures.add(DataProvider.writeToPath(writer, tableJson, getOutputPath(entry.getKey())));
diff --git a/fabric-entity-events-v1/src/testmod/java/net/fabricmc/fabric/test/entity/event/EntityEventTests.java b/fabric-entity-events-v1/src/testmod/java/net/fabricmc/fabric/test/entity/event/EntityEventTests.java
index 7a141c659..a75fe383e 100644
--- a/fabric-entity-events-v1/src/testmod/java/net/fabricmc/fabric/test/entity/event/EntityEventTests.java
+++ b/fabric-entity-events-v1/src/testmod/java/net/fabricmc/fabric/test/entity/event/EntityEventTests.java
@@ -51,7 +51,7 @@ import net.fabricmc.fabric.api.entity.event.v1.ServerPlayerEvents;
 
 public final class EntityEventTests implements ModInitializer {
 	private static final Logger LOGGER = LoggerFactory.getLogger(EntityEventTests.class);
-	public static final Block TEST_BED = new TestBedBlock(AbstractBlock.Settings.of(Material.WOOL).strength(1, 1));
+	public static final Block TEST_BED = new TestBedBlock(AbstractBlock.Settings.of(Material.field_44489).strength(1, 1));
 	public static final Item DIAMOND_ELYTRA = new DiamondElytraItem();
 
 	@Override
diff --git a/fabric-item-api-v1/src/main/java/net/fabricmc/fabric/mixin/item/ItemStackMixin.java b/fabric-item-api-v1/src/main/java/net/fabricmc/fabric/mixin/item/ItemStackMixin.java
index 1c3a43932..89df9b5c8 100644
--- a/fabric-item-api-v1/src/main/java/net/fabricmc/fabric/mixin/item/ItemStackMixin.java
+++ b/fabric-item-api-v1/src/main/java/net/fabricmc/fabric/mixin/item/ItemStackMixin.java
@@ -20,7 +20,6 @@ import java.util.function.Consumer;
 
 import com.google.common.collect.LinkedHashMultimap;
 import com.google.common.collect.Multimap;
-import org.spongepowered.asm.mixin.Final;
 import org.spongepowered.asm.mixin.Mixin;
 import org.spongepowered.asm.mixin.Shadow;
 import org.spongepowered.asm.mixin.Unique;
@@ -37,10 +36,9 @@ import net.minecraft.entity.attribute.EntityAttribute;
 import net.minecraft.entity.attribute.EntityAttributeModifier;
 import net.minecraft.item.Item;
 import net.minecraft.item.ItemStack;
-import net.minecraft.item.Items;
 
-import net.fabricmc.fabric.api.item.v1.FabricItemStack;
 import net.fabricmc.fabric.api.item.v1.CustomDamageHandler;
+import net.fabricmc.fabric.api.item.v1.FabricItemStack;
 import net.fabricmc.fabric.api.item.v1.ModifyItemAttributeModifiersCallback;
 import net.fabricmc.fabric.impl.item.ItemExtensions;
 
@@ -102,22 +100,4 @@ public abstract class ItemStackMixin implements FabricItemStack {
 	public boolean hookIsSuitableFor(Item item, BlockState state) {
 		return item.isSuitableFor((ItemStack) (Object) this, state);
 	}
-
-	@Final
-	@Shadow
-	private Item item;
-	@Shadow
-	private int count;
-	@Shadow
-	private boolean empty;
-
-	/**
-	 * Soft-overwrite updateEmptyState to fix <a href="https://bugs.mojang.com/projects/MC/issues/MC-258939">MC-258939</a>.
-	 * Cannot hard-overwrite because Lithium contains a similar but insufficient inject.
-	 */
-	@Inject(method = "updateEmptyState", at = @At("HEAD"), cancellable = true)
-	private void updateEmptyState(CallbackInfo ci) {
-		this.empty = this.item == null || this.item == Items.AIR || this.count <= 0;
-		ci.cancel();
-	}
 }
diff --git a/fabric-loot-api-v2/src/main/java/net/fabricmc/fabric/mixin/loot/LootManagerMixin.java b/fabric-loot-api-v2/src/main/java/net/fabricmc/fabric/mixin/loot/LootManagerMixin.java
index 10dc732c4..e86fa257c 100644
--- a/fabric-loot-api-v2/src/main/java/net/fabricmc/fabric/mixin/loot/LootManagerMixin.java
+++ b/fabric-loot-api-v2/src/main/java/net/fabricmc/fabric/mixin/loot/LootManagerMixin.java
@@ -17,20 +17,22 @@
 package net.fabricmc.fabric.mixin.loot;
 
 import java.util.Map;
+import java.util.concurrent.CompletableFuture;
+import java.util.concurrent.Executor;
 
 import com.google.common.collect.ImmutableMap;
-import com.google.gson.JsonObject;
 import org.spongepowered.asm.mixin.Mixin;
 import org.spongepowered.asm.mixin.Shadow;
+import org.spongepowered.asm.mixin.Unique;
 import org.spongepowered.asm.mixin.injection.At;
 import org.spongepowered.asm.mixin.injection.Inject;
-import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
+import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable;
 
+import net.minecraft.class_8488;
 import net.minecraft.loot.LootManager;
 import net.minecraft.loot.LootTable;
-import net.minecraft.loot.LootTables;
 import net.minecraft.resource.ResourceManager;
-import net.minecraft.util.Identifier;
+import net.minecraft.resource.ResourceReloader;
 import net.minecraft.util.profiler.Profiler;
 
 import net.fabricmc.fabric.api.loot.v2.FabricLootTableBuilder;
@@ -44,27 +46,34 @@ import net.fabricmc.fabric.impl.loot.LootUtil;
 @Mixin(LootManager.class)
 abstract class LootManagerMixin {
 	@Shadow
-	private Map<Identifier, LootTable> tables;
+	private Map<class_8488<?>, ?> field_44492;
 
-	@Inject(method = "apply", at = @At("RETURN"))
-	private void apply(Map<Identifier, JsonObject> jsonMap, ResourceManager resourceManager, Profiler profiler, CallbackInfo info) {
+	@Inject(method = "reload", at = @At("RETURN"), cancellable = true)
+	private void reload(ResourceReloader.Synchronizer synchronizer, ResourceManager manager, Profiler prepareProfiler, Profiler applyProfiler, Executor prepareExecutor, Executor applyExecutor, CallbackInfoReturnable<CompletableFuture<Void>> cir) {
+		//noinspection DataFlowIssue
+		LootManager lootManager = (LootManager) (Object) this;
+		cir.setReturnValue(cir.getReturnValue().thenRun(() -> applyLootTableEvents(manager, lootManager)));
+	}
+
+	@Unique
+	private void applyLootTableEvents(ResourceManager resourceManager, LootManager lootManager) {
 		// The builder for the new LootManager.tables map with modified loot tables.
 		// We're using an immutable map to match vanilla.
-		ImmutableMap.Builder<Identifier, LootTable> newTables = ImmutableMap.builder();
+		ImmutableMap.Builder<class_8488<?>, Object> newTables = ImmutableMap.builder();
 
-		tables.forEach((id, table) -> {
-			if (id.equals(LootTables.EMPTY)) {
+		this.field_44492.forEach((id, entry) -> {
+			if (id == LootManager.field_44491) {
 				// This is a special table and cannot be modified.
 				// Vanilla also warns about that.
+				newTables.put(id, entry);
 				return;
 			}
 
-			// noinspection ConstantConditions
-			LootManager lootManager = (LootManager) (Object) this;
-			LootTableSource source = LootUtil.determineSource(id, resourceManager);
+			LootTable table = (LootTable) entry;
 
+			LootTableSource source = LootUtil.determineSource(id.location(), resourceManager);
 			// Invoke the REPLACE event for the current loot table.
-			LootTable replacement = LootTableEvents.REPLACE.invoker().replaceLootTable(resourceManager, lootManager, id, table, source);
+			LootTable replacement = LootTableEvents.REPLACE.invoker().replaceLootTable(resourceManager, lootManager, id.location(), table, source);
 
 			if (replacement != null) {
 				// Set the loot table to MODIFY to be the replacement loot table.
@@ -75,13 +84,12 @@ abstract class LootManagerMixin {
 
 			// Turn the current table into a modifiable builder and invoke the MODIFY event.
 			LootTable.Builder builder = FabricLootTableBuilder.copyOf(table);
-			LootTableEvents.MODIFY.invoker().modifyLootTable(resourceManager, lootManager, id, builder, source);
+			LootTableEvents.MODIFY.invoker().modifyLootTable(resourceManager, lootManager, id.location(), builder, source);
 
 			// Turn the builder back into a loot table and store it in the new table.
 			newTables.put(id, builder.build());
 		});
 
-		// Finally, store the new loot table map in the field.
-		tables = newTables.build();
+		this.field_44492 = newTables.build();
 	}
 }
diff --git a/fabric-networking-api-v1/src/client/java/net/fabricmc/fabric/mixin/networking/client/DisconnectedScreenMixin.java b/fabric-networking-api-v1/src/client/java/net/fabricmc/fabric/mixin/networking/client/DisconnectedScreenMixin.java
deleted file mode 100644
index 76ffd9cbf..000000000
--- a/fabric-networking-api-v1/src/client/java/net/fabricmc/fabric/mixin/networking/client/DisconnectedScreenMixin.java
+++ /dev/null
@@ -1,93 +0,0 @@
-/*
- * Copyright (c) 2016, 2017, 2018, 2019 FabricMC
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- *     http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package net.fabricmc.fabric.mixin.networking.client;
-
-import org.objectweb.asm.Opcodes;
-import org.spongepowered.asm.mixin.Mixin;
-import org.spongepowered.asm.mixin.Shadow;
-import org.spongepowered.asm.mixin.Unique;
-import org.spongepowered.asm.mixin.injection.At;
-import org.spongepowered.asm.mixin.injection.Inject;
-import org.spongepowered.asm.mixin.injection.Redirect;
-import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
-
-import net.minecraft.client.font.MultilineText;
-import net.minecraft.client.gui.DrawableHelper;
-import net.minecraft.client.gui.screen.DisconnectedScreen;
-import net.minecraft.client.gui.screen.Screen;
-import net.minecraft.client.util.math.MatrixStack;
-import net.minecraft.util.math.MathHelper;
-
-/**
- * This mixin makes disconnect reason text scrollable.
- */
-@Mixin(DisconnectedScreen.class)
-public abstract class DisconnectedScreenMixin extends Screen {
-	@Shadow
-	private int reasonHeight;
-
-	@Unique
-	private int actualReasonHeight;
-
-	@Unique
-	private int scroll;
-
-	@Unique
-	private int maxScroll;
-
-	private DisconnectedScreenMixin() {
-		super(null);
-	}
-
-	// Inject to right after reasonHeight is stored, to make sure the back button have correct position.
-	@Inject(method = "init", at = @At(value = "FIELD", target = "Lnet/minecraft/client/gui/screen/DisconnectedScreen;reasonHeight:I", opcode = Opcodes.PUTFIELD, shift = At.Shift.AFTER))
-	private void init(CallbackInfo ci) {
-		actualReasonHeight = reasonHeight;
-		reasonHeight = Math.min(reasonHeight, height - 100);
-		scroll = 0;
-		maxScroll = actualReasonHeight - reasonHeight;
-	}
-
-	@Redirect(method = "render", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/font/MultilineText;drawCenterWithShadow(Lnet/minecraft/client/util/math/MatrixStack;II)I"))
-	private int render(MultilineText instance, MatrixStack matrixStack, int x, int y) {
-		DrawableHelper.enableScissor(0, y, width, y + reasonHeight);
-		instance.drawCenterWithShadow(matrixStack, x, y - scroll);
-		DrawableHelper.disableScissor();
-
-		// Draw gradient at the top/bottom to indicate that the text is scrollable.
-		if (actualReasonHeight > reasonHeight) {
-			int startX = (width - instance.getMaxWidth()) / 2;
-			int endX = (width + instance.getMaxWidth()) / 2;
-
-			if (scroll > 0) {
-				fillGradient(matrixStack, startX, y, endX, y + 10, 0xFF000000, 0);
-			}
-
-			if (scroll < maxScroll) {
-				fillGradient(matrixStack, startX, y + reasonHeight - 10, endX, y + reasonHeight, 0, 0xFF000000);
-			}
-		}
-
-		return y + reasonHeight;
-	}
-
-	@Override
-	public boolean mouseScrolled(double mouseX, double mouseY, double amount) {
-		scroll = MathHelper.clamp(scroll - (MathHelper.sign(amount) * client.textRenderer.fontHeight * 10), 0, maxScroll);
-		return super.mouseScrolled(mouseX, mouseY, amount);
-	}
-}
diff --git a/fabric-networking-api-v1/src/client/resources/fabric-networking-api-v1.client.mixins.json b/fabric-networking-api-v1/src/client/resources/fabric-networking-api-v1.client.mixins.json
index 1ff8a2eb4..2d4b321ab 100644
--- a/fabric-networking-api-v1/src/client/resources/fabric-networking-api-v1.client.mixins.json
+++ b/fabric-networking-api-v1/src/client/resources/fabric-networking-api-v1.client.mixins.json
@@ -7,8 +7,7 @@
     "accessor.ConnectScreenAccessor",
     "accessor.MinecraftClientAccessor",
     "ClientLoginNetworkHandlerMixin",
-    "ClientPlayNetworkHandlerMixin",
-    "DisconnectedScreenMixin"
+    "ClientPlayNetworkHandlerMixin"
   ],
   "injectors": {
     "defaultRequire": 1
diff --git a/fabric-object-builder-api-v1/src/main/java/net/fabricmc/fabric/api/object/builder/v1/block/FabricMaterialBuilder.java b/fabric-object-builder-api-v1/src/main/java/net/fabricmc/fabric/api/object/builder/v1/block/FabricMaterialBuilder.java
index 24ef976e4..5b969b8f4 100644
--- a/fabric-object-builder-api-v1/src/main/java/net/fabricmc/fabric/api/object/builder/v1/block/FabricMaterialBuilder.java
+++ b/fabric-object-builder-api-v1/src/main/java/net/fabricmc/fabric/api/object/builder/v1/block/FabricMaterialBuilder.java
@@ -42,12 +42,6 @@ public class FabricMaterialBuilder extends Material.Builder {
 		return this;
 	}
 
-	@Override
-	public FabricMaterialBuilder liquid() {
-		super.liquid();
-		return this;
-	}
-
 	@Override
 	public FabricMaterialBuilder notSolid() {
 		super.notSolid();
diff --git a/fabric-object-builder-api-v1/src/main/java/net/fabricmc/fabric/api/object/builder/v1/block/type/BlockSetTypeRegistry.java b/fabric-object-builder-api-v1/src/main/java/net/fabricmc/fabric/api/object/builder/v1/block/type/BlockSetTypeRegistry.java
index 2e54c89b6..b92b04e96 100644
--- a/fabric-object-builder-api-v1/src/main/java/net/fabricmc/fabric/api/object/builder/v1/block/type/BlockSetTypeRegistry.java
+++ b/fabric-object-builder-api-v1/src/main/java/net/fabricmc/fabric/api/object/builder/v1/block/type/BlockSetTypeRegistry.java
@@ -46,6 +46,7 @@ public final class BlockSetTypeRegistry {
 	 * Creates and registers a {@link BlockSetType}.
 	 *
 	 * @param id the id of this {@link BlockSetType}
+	 * @param canOpenByHand set to true to allow this block set's door's to be opened by hand
 	 * @param soundType the {@link BlockSoundGroup} for this block set
 	 * @param doorClose the {@link SoundEvent} for when this block set's door closes
 	 * @param doorOpen the {@link SoundEvent} for when this block set's door opens
@@ -57,7 +58,7 @@ public final class BlockSetTypeRegistry {
 	 * @param buttonClickOn the {@link SoundEvent} for when this block set's button is pressed
 	 * @return a new {@link BlockSetType}
 	 */
-	public static BlockSetType register(Identifier id, BlockSoundGroup soundType, SoundEvent doorClose, SoundEvent doorOpen, SoundEvent trapdoorClose, SoundEvent trapdoorOpen, SoundEvent pressurePlateClickOff, SoundEvent pressurePlateClickOn, SoundEvent buttonClickOff, SoundEvent buttonClickOn) {
-		return BlockSetType.register(new BlockSetType(id.toString(), soundType, doorClose, doorOpen, trapdoorClose, trapdoorOpen, pressurePlateClickOff, pressurePlateClickOn, buttonClickOff, buttonClickOn));
+	public static BlockSetType register(Identifier id, boolean canOpenByHand, BlockSoundGroup soundType, SoundEvent doorClose, SoundEvent doorOpen, SoundEvent trapdoorClose, SoundEvent trapdoorOpen, SoundEvent pressurePlateClickOff, SoundEvent pressurePlateClickOn, SoundEvent buttonClickOff, SoundEvent buttonClickOn) {
+		return BlockSetType.register(new BlockSetType(id.toString(), canOpenByHand, soundType, doorClose, doorOpen, trapdoorClose, trapdoorOpen, pressurePlateClickOff, pressurePlateClickOn, buttonClickOff, buttonClickOn));
 	}
 }
diff --git a/fabric-transfer-api-v1/src/testmod/java/net/fabricmc/fabric/test/transfer/ingame/FluidChuteBlock.java b/fabric-transfer-api-v1/src/testmod/java/net/fabricmc/fabric/test/transfer/ingame/FluidChuteBlock.java
index cfde70216..0a061a35d 100644
--- a/fabric-transfer-api-v1/src/testmod/java/net/fabricmc/fabric/test/transfer/ingame/FluidChuteBlock.java
+++ b/fabric-transfer-api-v1/src/testmod/java/net/fabricmc/fabric/test/transfer/ingame/FluidChuteBlock.java
@@ -42,7 +42,7 @@ import net.fabricmc.fabric.api.transfer.v1.fluid.FluidVariantAttributes;
 
 public class FluidChuteBlock extends Block implements BlockEntityProvider {
 	public FluidChuteBlock() {
-		super(Settings.of(Material.METAL));
+		super(Settings.of(Material.field_44489));
 	}
 
 	private static final VoxelShape SHAPE = VoxelShapes.cuboid(
diff --git a/fabric-transfer-api-v1/src/testmod/java/net/fabricmc/fabric/test/transfer/ingame/TransferTestInitializer.java b/fabric-transfer-api-v1/src/testmod/java/net/fabricmc/fabric/test/transfer/ingame/TransferTestInitializer.java
index 5bb534aca..0c4635511 100644
--- a/fabric-transfer-api-v1/src/testmod/java/net/fabricmc/fabric/test/transfer/ingame/TransferTestInitializer.java
+++ b/fabric-transfer-api-v1/src/testmod/java/net/fabricmc/fabric/test/transfer/ingame/TransferTestInitializer.java
@@ -35,8 +35,8 @@ import net.fabricmc.fabric.api.transfer.v1.item.ItemStorage;
 public class TransferTestInitializer implements ModInitializer {
 	public static final String MOD_ID = "fabric-transfer-api-v1-testmod";
 
-	private static final Block INFINITE_WATER_SOURCE = new Block(AbstractBlock.Settings.of(Material.METAL));
-	private static final Block INFINITE_LAVA_SOURCE = new Block(AbstractBlock.Settings.of(Material.METAL));
+	private static final Block INFINITE_WATER_SOURCE = new Block(AbstractBlock.Settings.of(Material.field_44483));
+	private static final Block INFINITE_LAVA_SOURCE = new Block(AbstractBlock.Settings.of(Material.field_44483));
 	private static final Block FLUID_CHUTE = new FluidChuteBlock();
 	private static final Item EXTRACT_STICK = new ExtractStickItem();
 	public static BlockEntityType<FluidChuteBlockEntity> FLUID_CHUTE_TYPE;
diff --git a/gradle.properties b/gradle.properties
index 8ff1cbfcb..c81351969 100644
--- a/gradle.properties
+++ b/gradle.properties
@@ -2,8 +2,8 @@ org.gradle.jvmargs=-Xmx2560M
 org.gradle.parallel=true
 fabric.loom.multiProjectOptimisation=true
 
-version=0.77.0
-minecraft_version=23w13a
+version=0.77.1
+minecraft_version=23w14a
 yarn_version=+build.1
 loader_version=0.14.18
 installer_version=0.11.1
@@ -12,39 +12,39 @@ prerelease=true
 
 # Do not manually update, use the bumpversions task:
 fabric-api-base-version=0.4.23
-fabric-api-lookup-api-v1-version=1.6.24
+fabric-api-lookup-api-v1-version=1.6.25
 fabric-biome-api-v1-version=13.0.6
 fabric-block-api-v1-version=1.0.5
 fabric-blockrenderlayer-v1-version=1.1.33
 fabric-command-api-v1-version=1.2.25
 fabric-command-api-v2-version=2.2.4
 fabric-commands-v0-version=0.2.42
-fabric-containers-v0-version=0.1.53
+fabric-containers-v0-version=0.1.54
 fabric-content-registries-v0-version=3.5.7
 fabric-crash-report-info-v1-version=0.2.14
-fabric-data-generation-api-v1-version=11.3.8
+fabric-data-generation-api-v1-version=11.3.9
 fabric-dimensions-v1-version=2.1.44
-fabric-entity-events-v1-version=1.5.12
+fabric-entity-events-v1-version=1.5.13
 fabric-events-interaction-v0-version=0.4.42
-fabric-events-lifecycle-v0-version=0.2.51
+fabric-events-lifecycle-v0-version=0.2.52
 fabric-game-rule-api-v1-version=1.0.32
 fabric-gametest-api-v1-version=1.2.2
-fabric-item-api-v1-version=2.1.16
+fabric-item-api-v1-version=2.1.17
 fabric-item-group-api-v1-version=3.0.3
 fabric-key-binding-api-v1-version=1.0.32
 fabric-keybindings-v0-version=0.2.30
 fabric-lifecycle-events-v1-version=2.2.14
-fabric-loot-api-v2-version=1.1.25
-fabric-loot-tables-v1-version=1.1.29
+fabric-loot-api-v2-version=1.1.26
+fabric-loot-tables-v1-version=1.1.30
 fabric-message-api-v1-version=5.1.0
 fabric-mining-level-api-v1-version=2.1.37
 fabric-models-v0-version=0.3.29
-fabric-networking-api-v1-version=1.3.0
-fabric-networking-v0-version=0.3.40
-fabric-object-builder-api-v1-version=8.0.0
+fabric-networking-api-v1-version=1.3.1
+fabric-networking-v0-version=0.3.41
+fabric-object-builder-api-v1-version=9.0.0
 fabric-particles-v1-version=1.0.22
-fabric-recipe-api-v1-version=1.0.7
-fabric-registry-sync-v0-version=2.1.3
+fabric-recipe-api-v1-version=1.0.8
+fabric-registry-sync-v0-version=2.1.4
 fabric-renderer-api-v1-version=2.2.4
 fabric-renderer-indigo-version=1.1.0
 fabric-renderer-registries-v1-version=3.2.37
@@ -55,9 +55,9 @@ fabric-rendering-v1-version=2.1.0
 fabric-resource-conditions-api-v1-version=2.3.0
 fabric-resource-loader-v0-version=0.11.0
 fabric-screen-api-v1-version=1.0.44
-fabric-screen-handler-api-v1-version=1.3.19
+fabric-screen-handler-api-v1-version=1.3.20
 fabric-sound-api-v1-version=1.0.8
-fabric-transfer-api-v1-version=3.0.1
+fabric-transfer-api-v1-version=3.0.2
 fabric-transitive-access-wideners-v1-version=4.0.0
 fabric-convention-tags-v1-version=1.4.0
 fabric-client-tags-api-v1-version=1.0.14