From a2e8758a92f70e7549cb9ddbd0adb84a73a869f9 Mon Sep 17 00:00:00 2001 From: apple502j <33279053+apple502j@users.noreply.github.com> Date: Fri, 17 Nov 2023 01:11:10 +0900 Subject: [PATCH] 23w45a porting fixes (#3421) --- .../fabric/test/dimension/FabricDimensionTest.java | 6 ++++-- .../api/object/builder/v1/block/FabricBlockSettings.java | 7 ++++++- .../object/builder/v1/block/type/BlockSetTypeBuilder.java | 2 ++ .../fabric-transitive-access-wideners-v1.accesswidener | 1 + .../template.accesswidener | 1 + 5 files changed, 14 insertions(+), 3 deletions(-) diff --git a/fabric-dimensions-v1/src/testmod/java/net/fabricmc/fabric/test/dimension/FabricDimensionTest.java b/fabric-dimensions-v1/src/testmod/java/net/fabricmc/fabric/test/dimension/FabricDimensionTest.java index 10f16e81b1..9c7efe097c 100644 --- a/fabric-dimensions-v1/src/testmod/java/net/fabricmc/fabric/test/dimension/FabricDimensionTest.java +++ b/fabric-dimensions-v1/src/testmod/java/net/fabricmc/fabric/test/dimension/FabricDimensionTest.java @@ -22,6 +22,7 @@ import com.mojang.brigadier.context.CommandContext; import com.mojang.brigadier.exceptions.CommandSyntaxException; +import com.mojang.brigadier.exceptions.SimpleCommandExceptionType; import net.minecraft.block.Blocks; import net.minecraft.command.argument.DimensionArgumentType; @@ -51,6 +52,7 @@ public class FabricDimensionTest implements ModInitializer { // The dimension options refer to the JSON-file in the dimension subfolder of the data pack, // which will always share its ID with the world that is created from it private static final RegistryKey DIMENSION_KEY = RegistryKey.of(RegistryKeys.DIMENSION, new Identifier("fabric_dimension", "void")); + private static final SimpleCommandExceptionType FAILED_EXCEPTION = new SimpleCommandExceptionType(Text.literal("Teleportation failed!")); private static RegistryKey WORLD_KEY = RegistryKey.of(RegistryKeys.WORLD, DIMENSION_KEY.getValue()); @@ -110,7 +112,7 @@ public void onInitialize() { }); } - private int swapTargeted(CommandContext context) { + private int swapTargeted(CommandContext context) throws CommandSyntaxException { ServerPlayerEntity player = context.getSource().getPlayer(); if (player == null) { @@ -126,7 +128,7 @@ private int swapTargeted(CommandContext context) { FabricDimensions.teleport(player, modWorld, target); if (player.getWorld() != modWorld) { - throw new RuntimeException("Teleportation failed!"); + throw FAILED_EXCEPTION.create(); } modWorld.setBlockState(new BlockPos(0, 100, 0), Blocks.DIAMOND_BLOCK.getDefaultState()); diff --git a/fabric-object-builder-api-v1/src/main/java/net/fabricmc/fabric/api/object/builder/v1/block/FabricBlockSettings.java b/fabric-object-builder-api-v1/src/main/java/net/fabricmc/fabric/api/object/builder/v1/block/FabricBlockSettings.java index 5d90b75844..c2a89fb3a4 100644 --- a/fabric-object-builder-api-v1/src/main/java/net/fabricmc/fabric/api/object/builder/v1/block/FabricBlockSettings.java +++ b/fabric-object-builder-api-v1/src/main/java/net/fabricmc/fabric/api/object/builder/v1/block/FabricBlockSettings.java @@ -82,7 +82,12 @@ protected FabricBlockSettings(AbstractBlock.Settings settings) { this.instrument(otherAccessor.getInstrument()); thisAccessor.setReplaceable(otherAccessor.getReplaceable()); - // Not copied in vanilla: field definition order + // Vanilla did not copy those fields until 23w45a, which introduced + // copyShallow method (maintaining the behavior previously used by the copy method) + // and the copy method that copies those fields as well. copyShallow is now + // deprecated. To maintain compatibility and since this behavior seems to be the + // more proper way, this copies all the fields, not just the shallow ones. + // Fields are added by field definition order. this.jumpVelocityMultiplier(otherAccessor.getJumpVelocityMultiplier()); this.drops(otherAccessor.getLootTableId()); this.allowsSpawning(otherAccessor.getAllowsSpawningPredicate()); diff --git a/fabric-object-builder-api-v1/src/main/java/net/fabricmc/fabric/api/object/builder/v1/block/type/BlockSetTypeBuilder.java b/fabric-object-builder-api-v1/src/main/java/net/fabricmc/fabric/api/object/builder/v1/block/type/BlockSetTypeBuilder.java index 37efe77b32..57a1ee6f30 100644 --- a/fabric-object-builder-api-v1/src/main/java/net/fabricmc/fabric/api/object/builder/v1/block/type/BlockSetTypeBuilder.java +++ b/fabric-object-builder-api-v1/src/main/java/net/fabricmc/fabric/api/object/builder/v1/block/type/BlockSetTypeBuilder.java @@ -210,6 +210,7 @@ public BlockSetTypeBuilder buttonClickOnSound(SoundEvent buttonClickOnSound) { public static BlockSetTypeBuilder copyOf(BlockSetTypeBuilder builder) { BlockSetTypeBuilder copy = new BlockSetTypeBuilder(); copy.openableByHand(builder.openableByHand); + copy.openableByWindCharge(builder.openableByWindCharge); copy.buttonActivatedByArrows(builder.buttonActivatedByArrows); copy.pressurePlateActivationRule(builder.pressurePlateActivationRule); copy.soundGroup(builder.soundGroup); @@ -234,6 +235,7 @@ public static BlockSetTypeBuilder copyOf(BlockSetTypeBuilder builder) { public static BlockSetTypeBuilder copyOf(BlockSetType setType) { BlockSetTypeBuilder copy = new BlockSetTypeBuilder(); copy.openableByHand(setType.canOpenByHand()); + copy.openableByWindCharge(setType.canOpenByWindCharge()); copy.buttonActivatedByArrows(setType.canButtonBeActivatedByArrows()); copy.pressurePlateActivationRule(setType.pressurePlateSensitivity()); copy.soundGroup(setType.soundType()); diff --git a/fabric-transitive-access-wideners-v1/src/main/resources/fabric-transitive-access-wideners-v1.accesswidener b/fabric-transitive-access-wideners-v1/src/main/resources/fabric-transitive-access-wideners-v1.accesswidener index 442cc8914a..435d0d8c06 100644 --- a/fabric-transitive-access-wideners-v1/src/main/resources/fabric-transitive-access-wideners-v1.accesswidener +++ b/fabric-transitive-access-wideners-v1/src/main/resources/fabric-transitive-access-wideners-v1.accesswidener @@ -129,6 +129,7 @@ transitive-accessible field net/minecraft/client/MinecraftClient attackCooldown transitive-accessible method net/minecraft/block/Blocks createFlowerPotBlock (Lnet/minecraft/block/Block;)Lnet/minecraft/block/Block; transitive-accessible method net/minecraft/block/Blocks createLeavesBlock (Lnet/minecraft/sound/BlockSoundGroup;)Lnet/minecraft/block/Block; transitive-accessible method net/minecraft/block/Blocks createLogBlock (Lnet/minecraft/block/MapColor;Lnet/minecraft/block/MapColor;)Lnet/minecraft/block/Block; +transitive-accessible method net/minecraft/block/Blocks createLogBlock (Lnet/minecraft/block/MapColor;Lnet/minecraft/block/MapColor;Lnet/minecraft/sound/BlockSoundGroup;)Lnet/minecraft/block/Block; transitive-accessible method net/minecraft/block/Blocks createNetherStemBlock (Lnet/minecraft/block/MapColor;)Lnet/minecraft/block/Block; transitive-accessible method net/minecraft/block/Blocks createStoneButtonBlock ()Lnet/minecraft/block/Block; transitive-accessible method net/minecraft/block/Blocks createWoodenButtonBlock (Lnet/minecraft/block/BlockSetType;)Lnet/minecraft/block/Block; diff --git a/fabric-transitive-access-wideners-v1/template.accesswidener b/fabric-transitive-access-wideners-v1/template.accesswidener index 65815c9453..5ec724596a 100644 --- a/fabric-transitive-access-wideners-v1/template.accesswidener +++ b/fabric-transitive-access-wideners-v1/template.accesswidener @@ -124,6 +124,7 @@ transitive-accessible field net/minecraft/client/MinecraftClient attackCooldown transitive-accessible method net/minecraft/block/Blocks createFlowerPotBlock (Lnet/minecraft/block/Block;)Lnet/minecraft/block/Block; transitive-accessible method net/minecraft/block/Blocks createLeavesBlock (Lnet/minecraft/sound/BlockSoundGroup;)Lnet/minecraft/block/Block; transitive-accessible method net/minecraft/block/Blocks createLogBlock (Lnet/minecraft/block/MapColor;Lnet/minecraft/block/MapColor;)Lnet/minecraft/block/Block; +transitive-accessible method net/minecraft/block/Blocks createLogBlock (Lnet/minecraft/block/MapColor;Lnet/minecraft/block/MapColor;Lnet/minecraft/sound/BlockSoundGroup;)Lnet/minecraft/block/Block; transitive-accessible method net/minecraft/block/Blocks createNetherStemBlock (Lnet/minecraft/block/MapColor;)Lnet/minecraft/block/Block; transitive-accessible method net/minecraft/block/Blocks createStoneButtonBlock ()Lnet/minecraft/block/Block; transitive-accessible method net/minecraft/block/Blocks createWoodenButtonBlock (Lnet/minecraft/block/BlockSetType;)Lnet/minecraft/block/Block;