--- a/net/minecraft/core/cauldron/CauldronInteraction.java +++ b/net/minecraft/core/cauldron/CauldronInteraction.java @@ -34,9 +34,15 @@ import net.minecraft.world.level.block.state.IBlockData; import net.minecraft.world.level.gameevent.GameEvent; +// CraftBukkit start +import org.bukkit.event.block.CauldronLevelChangeEvent; +// CraftBukkit end + public interface CauldronInteraction { Map INTERACTIONS = new Object2ObjectArrayMap(); + // CraftBukkit start - decompile error + /* Codec CODEC; CauldronInteraction.a EMPTY; CauldronInteraction.a WATER; @@ -48,6 +54,8 @@ CauldronInteraction SHULKER_BOX; CauldronInteraction BANNER; CauldronInteraction DYED_ITEM; + */ + // CraftBukkit end static CauldronInteraction.a newInteractionMap(String s) { Object2ObjectOpenHashMap object2objectopenhashmap = new Object2ObjectOpenHashMap(); @@ -72,12 +80,17 @@ if (potioncontents != null && potioncontents.is(Potions.WATER)) { if (!world.isClientSide) { + // CraftBukkit start + if (!LayeredCauldronBlock.changeLevel(iblockdata, world, blockposition, Blocks.WATER_CAULDRON.defaultBlockState(), entityhuman, CauldronLevelChangeEvent.ChangeReason.BOTTLE_EMPTY)) { + return ItemInteractionResult.SUCCESS; + } + // CraftBukkit end Item item = itemstack.getItem(); entityhuman.setItemInHand(enumhand, ItemLiquidUtil.createFilledResult(itemstack, entityhuman, new ItemStack(Items.GLASS_BOTTLE))); entityhuman.awardStat(StatisticList.USE_CAULDRON); entityhuman.awardStat(StatisticList.ITEM_USED.get(item)); - world.setBlockAndUpdate(blockposition, Blocks.WATER_CAULDRON.defaultBlockState()); + // world.setBlockAndUpdate(blockposition, Blocks.WATER_CAULDRON.defaultBlockState()); // CraftBukkit world.playSound((EntityHuman) null, blockposition, SoundEffects.BOTTLE_EMPTY, SoundCategory.BLOCKS, 1.0F, 1.0F); world.gameEvent((Entity) null, (Holder) GameEvent.FLUID_PLACE, blockposition); } @@ -97,12 +110,17 @@ }); map1.put(Items.GLASS_BOTTLE, (iblockdata, world, blockposition, entityhuman, enumhand, itemstack) -> { if (!world.isClientSide) { + // CraftBukkit start + if (!LayeredCauldronBlock.lowerFillLevel(iblockdata, world, blockposition, entityhuman, CauldronLevelChangeEvent.ChangeReason.BOTTLE_FILL)) { + return ItemInteractionResult.SUCCESS; + } + // CraftBukkit end Item item = itemstack.getItem(); entityhuman.setItemInHand(enumhand, ItemLiquidUtil.createFilledResult(itemstack, entityhuman, PotionContents.createItemStack(Items.POTION, Potions.WATER))); entityhuman.awardStat(StatisticList.USE_CAULDRON); entityhuman.awardStat(StatisticList.ITEM_USED.get(item)); - LayeredCauldronBlock.lowerFillLevel(iblockdata, world, blockposition); + // LayeredCauldronBlock.lowerFillLevel(iblockdata, world, blockposition); // CraftBukkit world.playSound((EntityHuman) null, blockposition, SoundEffects.BOTTLE_FILL, SoundCategory.BLOCKS, 1.0F, 1.0F); world.gameEvent((Entity) null, (Holder) GameEvent.FLUID_PICKUP, blockposition); } @@ -117,10 +135,15 @@ if (potioncontents != null && potioncontents.is(Potions.WATER)) { if (!world.isClientSide) { + // CraftBukkit start + if (!LayeredCauldronBlock.changeLevel(iblockdata, world, blockposition, iblockdata.cycle(LayeredCauldronBlock.LEVEL), entityhuman, CauldronLevelChangeEvent.ChangeReason.BOTTLE_EMPTY)) { + return ItemInteractionResult.SUCCESS; + } + // CraftBukkit end entityhuman.setItemInHand(enumhand, ItemLiquidUtil.createFilledResult(itemstack, entityhuman, new ItemStack(Items.GLASS_BOTTLE))); entityhuman.awardStat(StatisticList.USE_CAULDRON); entityhuman.awardStat(StatisticList.ITEM_USED.get(itemstack.getItem())); - world.setBlockAndUpdate(blockposition, (IBlockData) iblockdata.cycle(LayeredCauldronBlock.LEVEL)); + // world.setBlockAndUpdate(blockposition, (IBlockData) iblockdata.cycle(LayeredCauldronBlock.LEVEL)); // CraftBukkit world.playSound((EntityHuman) null, blockposition, SoundEffects.BOTTLE_EMPTY, SoundCategory.BLOCKS, 1.0F, 1.0F); world.gameEvent((Entity) null, (Holder) GameEvent.FLUID_PLACE, blockposition); } @@ -198,12 +221,17 @@ return ItemInteractionResult.PASS_TO_DEFAULT_BLOCK_INTERACTION; } else { if (!world.isClientSide) { + // CraftBukkit start + if (!LayeredCauldronBlock.changeLevel(iblockdata, world, blockposition, Blocks.CAULDRON.defaultBlockState(), entityhuman, CauldronLevelChangeEvent.ChangeReason.BUCKET_FILL)) { + return ItemInteractionResult.SUCCESS; + } + // CraftBukkit end Item item = itemstack.getItem(); entityhuman.setItemInHand(enumhand, ItemLiquidUtil.createFilledResult(itemstack, entityhuman, itemstack1)); entityhuman.awardStat(StatisticList.USE_CAULDRON); entityhuman.awardStat(StatisticList.ITEM_USED.get(item)); - world.setBlockAndUpdate(blockposition, Blocks.CAULDRON.defaultBlockState()); + // world.setBlockAndUpdate(blockposition, Blocks.CAULDRON.defaultBlockState()); // CraftBukkit world.playSound((EntityHuman) null, blockposition, soundeffect, SoundCategory.BLOCKS, 1.0F, 1.0F); world.gameEvent((Entity) null, (Holder) GameEvent.FLUID_PICKUP, blockposition); } @@ -214,12 +242,17 @@ static ItemInteractionResult emptyBucket(World world, BlockPosition blockposition, EntityHuman entityhuman, EnumHand enumhand, ItemStack itemstack, IBlockData iblockdata, SoundEffect soundeffect) { if (!world.isClientSide) { + // CraftBukkit start + if (!LayeredCauldronBlock.changeLevel(iblockdata, world, blockposition, iblockdata, entityhuman, CauldronLevelChangeEvent.ChangeReason.BUCKET_EMPTY)) { + return ItemInteractionResult.SUCCESS; + } + // CraftBukkit end Item item = itemstack.getItem(); entityhuman.setItemInHand(enumhand, ItemLiquidUtil.createFilledResult(itemstack, entityhuman, new ItemStack(Items.BUCKET))); entityhuman.awardStat(StatisticList.FILL_CAULDRON); entityhuman.awardStat(StatisticList.ITEM_USED.get(item)); - world.setBlockAndUpdate(blockposition, iblockdata); + // world.setBlockAndUpdate(blockposition, iblockdata); // CraftBukkit world.playSound((EntityHuman) null, blockposition, soundeffect, SoundCategory.BLOCKS, 1.0F, 1.0F); world.gameEvent((Entity) null, (Holder) GameEvent.FLUID_PLACE, blockposition); } @@ -227,76 +260,89 @@ return ItemInteractionResult.sidedSuccess(world.isClientSide); } - static { - Function function = CauldronInteraction.a::name; - Map map = CauldronInteraction.INTERACTIONS; - - Objects.requireNonNull(map); - CODEC = Codec.stringResolver(function, map::get); - EMPTY = newInteractionMap("empty"); - WATER = newInteractionMap("water"); - LAVA = newInteractionMap("lava"); - POWDER_SNOW = newInteractionMap("powder_snow"); - FILL_WATER = (iblockdata, world, blockposition, entityhuman, enumhand, itemstack) -> { + // CraftBukkit start - decompile errors + // static { + Codec CODEC = Codec.stringResolver(CauldronInteraction.a::name, CauldronInteraction.INTERACTIONS::get); + CauldronInteraction.a EMPTY = newInteractionMap("empty"); + CauldronInteraction.a WATER = newInteractionMap("water"); + CauldronInteraction.a LAVA = newInteractionMap("lava"); + CauldronInteraction.a POWDER_SNOW = newInteractionMap("powder_snow"); + CauldronInteraction FILL_WATER = (iblockdata, world, blockposition, entityhuman, enumhand, itemstack) -> { return emptyBucket(world, blockposition, entityhuman, enumhand, itemstack, (IBlockData) Blocks.WATER_CAULDRON.defaultBlockState().setValue(LayeredCauldronBlock.LEVEL, 3), SoundEffects.BUCKET_EMPTY); }; - FILL_LAVA = (iblockdata, world, blockposition, entityhuman, enumhand, itemstack) -> { + CauldronInteraction FILL_LAVA = (iblockdata, world, blockposition, entityhuman, enumhand, itemstack) -> { return emptyBucket(world, blockposition, entityhuman, enumhand, itemstack, Blocks.LAVA_CAULDRON.defaultBlockState(), SoundEffects.BUCKET_EMPTY_LAVA); }; - FILL_POWDER_SNOW = (iblockdata, world, blockposition, entityhuman, enumhand, itemstack) -> { + CauldronInteraction FILL_POWDER_SNOW = (iblockdata, world, blockposition, entityhuman, enumhand, itemstack) -> { return emptyBucket(world, blockposition, entityhuman, enumhand, itemstack, (IBlockData) Blocks.POWDER_SNOW_CAULDRON.defaultBlockState().setValue(LayeredCauldronBlock.LEVEL, 3), SoundEffects.BUCKET_EMPTY_POWDER_SNOW); }; - SHULKER_BOX = (iblockdata, world, blockposition, entityhuman, enumhand, itemstack) -> { + CauldronInteraction SHULKER_BOX = (iblockdata, world, blockposition, entityhuman, enumhand, itemstack) -> { + // CraftBukkit end Block block = Block.byItem(itemstack.getItem()); if (!(block instanceof BlockShulkerBox)) { return ItemInteractionResult.PASS_TO_DEFAULT_BLOCK_INTERACTION; } else { if (!world.isClientSide) { + // CraftBukkit start + if (!LayeredCauldronBlock.lowerFillLevel(iblockdata, world, blockposition, entityhuman, CauldronLevelChangeEvent.ChangeReason.SHULKER_WASH)) { + return ItemInteractionResult.SUCCESS; + } + // CraftBukkit end ItemStack itemstack1 = itemstack.transmuteCopy(Blocks.SHULKER_BOX, 1); entityhuman.setItemInHand(enumhand, ItemLiquidUtil.createFilledResult(itemstack, entityhuman, itemstack1, false)); entityhuman.awardStat(StatisticList.CLEAN_SHULKER_BOX); - LayeredCauldronBlock.lowerFillLevel(iblockdata, world, blockposition); + // LayeredCauldronBlock.lowerFillLevel(iblockdata, world, blockposition); // CraftBukkit } return ItemInteractionResult.sidedSuccess(world.isClientSide); } }; - BANNER = (iblockdata, world, blockposition, entityhuman, enumhand, itemstack) -> { + CauldronInteraction BANNER = (iblockdata, world, blockposition, entityhuman, enumhand, itemstack) -> { // CraftBukkit - decompile error BannerPatternLayers bannerpatternlayers = (BannerPatternLayers) itemstack.getOrDefault(DataComponents.BANNER_PATTERNS, BannerPatternLayers.EMPTY); if (bannerpatternlayers.layers().isEmpty()) { return ItemInteractionResult.PASS_TO_DEFAULT_BLOCK_INTERACTION; } else { if (!world.isClientSide) { + // CraftBukkit start + if (!LayeredCauldronBlock.lowerFillLevel(iblockdata, world, blockposition, entityhuman, CauldronLevelChangeEvent.ChangeReason.BANNER_WASH)) { + return ItemInteractionResult.SUCCESS; + } + // CraftBukkit end ItemStack itemstack1 = itemstack.copyWithCount(1); itemstack1.set(DataComponents.BANNER_PATTERNS, bannerpatternlayers.removeLast()); entityhuman.setItemInHand(enumhand, ItemLiquidUtil.createFilledResult(itemstack, entityhuman, itemstack1, false)); entityhuman.awardStat(StatisticList.CLEAN_BANNER); - LayeredCauldronBlock.lowerFillLevel(iblockdata, world, blockposition); + // LayeredCauldronBlock.lowerFillLevel(iblockdata, world, blockposition); // CraftBukkit } return ItemInteractionResult.sidedSuccess(world.isClientSide); } }; - DYED_ITEM = (iblockdata, world, blockposition, entityhuman, enumhand, itemstack) -> { + CauldronInteraction DYED_ITEM = (iblockdata, world, blockposition, entityhuman, enumhand, itemstack) -> { // CraftBukkit - decompile error if (!itemstack.is(TagsItem.DYEABLE)) { return ItemInteractionResult.PASS_TO_DEFAULT_BLOCK_INTERACTION; } else if (!itemstack.has(DataComponents.DYED_COLOR)) { return ItemInteractionResult.PASS_TO_DEFAULT_BLOCK_INTERACTION; } else { if (!world.isClientSide) { + // CraftBukkit start + if (!LayeredCauldronBlock.lowerFillLevel(iblockdata, world, blockposition, entityhuman, CauldronLevelChangeEvent.ChangeReason.ARMOR_WASH)) { + return ItemInteractionResult.SUCCESS; + } + // CraftBukkit end itemstack.remove(DataComponents.DYED_COLOR); entityhuman.awardStat(StatisticList.CLEAN_ARMOR); - LayeredCauldronBlock.lowerFillLevel(iblockdata, world, blockposition); + // LayeredCauldronBlock.lowerFillLevel(iblockdata, world, blockposition); // CraftBukkit } return ItemInteractionResult.sidedSuccess(world.isClientSide); } }; - } + // } // CraftBukkit - decompile error public static record a(String name, Map map) {