Fix blaze burner consuming buckets, arm no longer inserts lava buckets

This commit is contained in:
tterrag 2020-12-13 15:04:55 -05:00
parent d68d702b3a
commit 4c26627b73
2 changed files with 30 additions and 10 deletions

View file

@ -27,6 +27,7 @@ import net.minecraft.state.EnumProperty;
import net.minecraft.state.IProperty; import net.minecraft.state.IProperty;
import net.minecraft.state.StateContainer.Builder; import net.minecraft.state.StateContainer.Builder;
import net.minecraft.tileentity.TileEntity; import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.ActionResult;
import net.minecraft.util.ActionResultType; import net.minecraft.util.ActionResultType;
import net.minecraft.util.Hand; import net.minecraft.util.Hand;
import net.minecraft.util.IItemProvider; import net.minecraft.util.IItemProvider;
@ -123,29 +124,42 @@ public class BlazeBurnerBlock extends Block implements ITE<BlazeBurnerTileEntity
return ActionResultType.PASS; return ActionResultType.PASS;
} }
if (!tryInsert(state, world, pos, dontConsume ? heldItem.copy() : heldItem, forceOverflow, false)) ActionResult<ItemStack> res = tryInsert(state, world, pos, dontConsume ? heldItem.copy() : heldItem, forceOverflow, false);
return ActionResultType.PASS; ItemStack leftover = res.getResult();
return ActionResultType.SUCCESS; if (!world.isRemote && !dontConsume && !leftover.isEmpty()) {
if (heldItem.isEmpty()) {
player.setHeldItem(hand, leftover);
} else if (!player.inventory.addItemStackToInventory(leftover)) {
player.dropItem(leftover, false);
}
}
return res.getType() == ActionResultType.SUCCESS ? res.getType() : ActionResultType.PASS;
} }
public static boolean tryInsert(BlockState state, World world, BlockPos pos, ItemStack stack, boolean forceOverflow, public static ActionResult<ItemStack> tryInsert(BlockState state, World world, BlockPos pos, ItemStack stack, boolean forceOverflow,
boolean simulate) { boolean simulate) {
if (!state.hasTileEntity()) if (!state.hasTileEntity())
return false; return ActionResult.fail(ItemStack.EMPTY);
TileEntity te = world.getTileEntity(pos); TileEntity te = world.getTileEntity(pos);
if (!(te instanceof BlazeBurnerTileEntity)) if (!(te instanceof BlazeBurnerTileEntity))
return false; return ActionResult.fail(ItemStack.EMPTY);
BlazeBurnerTileEntity burnerTE = (BlazeBurnerTileEntity) te; BlazeBurnerTileEntity burnerTE = (BlazeBurnerTileEntity) te;
if (!burnerTE.tryUpdateFuel(stack, forceOverflow, simulate)) if (!burnerTE.tryUpdateFuel(stack, forceOverflow, simulate))
return false; return ActionResult.fail(ItemStack.EMPTY);
ItemStack container = stack.getContainerItem();
if (!simulate && !world.isRemote) { if (!simulate && !world.isRemote) {
world.playSound(null, pos, SoundEvents.ENTITY_BLAZE_SHOOT, SoundCategory.BLOCKS, world.playSound(null, pos, SoundEvents.ENTITY_BLAZE_SHOOT, SoundCategory.BLOCKS,
.125f + world.rand.nextFloat() * .125f, .75f - world.rand.nextFloat() * .25f); .125f + world.rand.nextFloat() * .125f, .75f - world.rand.nextFloat() * .25f);
stack.shrink(1); stack.shrink(1);
} }
return true; if (!container.isEmpty()) {
return ActionResult.success(container);
}
return ActionResult.success(ItemStack.EMPTY);
} }
@Override @Override

View file

@ -36,6 +36,8 @@ import net.minecraft.nbt.NBTUtil;
import net.minecraft.state.properties.BlockStateProperties; import net.minecraft.state.properties.BlockStateProperties;
import net.minecraft.tileentity.JukeboxTileEntity; import net.minecraft.tileentity.JukeboxTileEntity;
import net.minecraft.tileentity.TileEntity; import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.ActionResult;
import net.minecraft.util.ActionResultType;
import net.minecraft.util.Direction; import net.minecraft.util.Direction;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Vec3d; import net.minecraft.util.math.Vec3d;
@ -277,8 +279,12 @@ public abstract class ArmInteractionPoint {
@Override @Override
ItemStack insert(World world, ItemStack stack, boolean simulate) { ItemStack insert(World world, ItemStack stack, boolean simulate) {
boolean success = BlazeBurnerBlock.tryInsert(state, world, pos, stack.copy(), false, simulate); ItemStack input = stack.copy();
return success ? ItemHandlerHelper.copyStackWithSize(stack, stack.getCount() - 1) : stack; if (!BlazeBurnerBlock.tryInsert(state, world, pos, input, false, true).getResult().isEmpty()) {
return stack;
}
ActionResult<ItemStack> res = BlazeBurnerBlock.tryInsert(state, world, pos, input, false, simulate);
return res.getType() == ActionResultType.SUCCESS ? ItemHandlerHelper.copyStackWithSize(stack, stack.getCount() - 1) : stack;
} }
@Override @Override