From 5b81cbe85e5f6b1cb0a1d315f0eab86ba2dc8f13 Mon Sep 17 00:00:00 2001 From: sh4dow Date: Fri, 27 Dec 2024 05:29:04 +0100 Subject: [PATCH] backported item filter for Rannuncarpus (#60) Co-authored-by: Martin Robertz Co-authored-by: Maya <10861407+serenibyss@users.noreply.github.com> --- .../subtile/functional/SubTileHopperhock.java | 17 +++++++++-------- .../subtile/functional/SubTileRannuncarpus.java | 1 + 2 files changed, 10 insertions(+), 8 deletions(-) diff --git a/src/main/java/vazkii/botania/common/block/subtile/functional/SubTileHopperhock.java b/src/main/java/vazkii/botania/common/block/subtile/functional/SubTileHopperhock.java index 84aea3c2ca..29c8dd5261 100644 --- a/src/main/java/vazkii/botania/common/block/subtile/functional/SubTileHopperhock.java +++ b/src/main/java/vazkii/botania/common/block/subtile/functional/SubTileHopperhock.java @@ -29,6 +29,7 @@ import net.minecraft.tileentity.TileEntityChest; import net.minecraft.util.AxisAlignedBB; import net.minecraft.util.StatCollector; +import net.minecraft.world.World; import net.minecraftforge.common.util.ForgeDirection; import org.lwjgl.opengl.GL11; @@ -90,7 +91,7 @@ public void onUpdate() { IInventory inv = InventoryHelper.getInventory(supertile.getWorldObj(), x_, y_, z_); if(inv != null) { - List filter = getFilterForInventory(inv, x_, y_, z_, true); + List filter = getFilterForInventory(supertile.getWorldObj(), inv, x_, y_, z_, true); boolean canAccept = canAcceptItem(stack, filter, filterType); int availablePut = supertile.getWorldObj().isRemote ? 1 : InventoryHelper.testInventoryInsertion(inv, stack, dir); canAccept &= availablePut > 0; @@ -133,7 +134,7 @@ public void onUpdate() { mana--; } - public boolean canAcceptItem(ItemStack stack, List filter, int filterType) { + public static boolean canAcceptItem(ItemStack stack, List filter, int filterType) { if(stack == null) return false; @@ -169,17 +170,17 @@ public boolean canAcceptItem(ItemStack stack, List filter, int filter } } - public List getFilterForInventory(IInventory inv, int x, int y, int z, boolean recursiveForDoubleChests) { + public static List getFilterForInventory(World world, IInventory inv, int x, int y, int z, boolean recursiveForDoubleChests) { List filter = new ArrayList(); if(recursiveForDoubleChests) { - TileEntity tileEntity = supertile.getWorldObj().getTileEntity(x, y, z); - Block chest = supertile.getWorldObj().getBlock(x, y, z); + TileEntity tileEntity = world.getTileEntity(x, y, z); + Block chest = world.getBlock(x, y, z); if(tileEntity instanceof TileEntityChest) for(ForgeDirection dir : LibMisc.CARDINAL_DIRECTIONS) - if(supertile.getWorldObj().getBlock(x + dir.offsetX, y, z + dir.offsetZ) == chest) { - filter.addAll(getFilterForInventory((IInventory) supertile.getWorldObj().getTileEntity(x + dir.offsetX, y, z + dir.offsetZ), x + dir.offsetX, y, z + dir.offsetZ, false)); + if(world.getBlock(x + dir.offsetX, y, z + dir.offsetZ) == chest) { + filter.addAll(getFilterForInventory(world, (IInventory) world.getTileEntity(x + dir.offsetX, y, z + dir.offsetZ), x + dir.offsetX, y, z + dir.offsetZ, false)); break; } } @@ -190,7 +191,7 @@ public List getFilterForInventory(IInventory inv, int x, int y, int z for(ForgeDirection dir : LibMisc.CARDINAL_DIRECTIONS) { AxisAlignedBB aabb = AxisAlignedBB.getBoundingBox(x + dir.offsetX, y + dir.offsetY, z + dir.offsetZ, x + dir.offsetX + 1, y + dir.offsetY + 1, z + dir.offsetZ + 1); - List frames = supertile.getWorldObj().getEntitiesWithinAABB(EntityItemFrame.class, aabb); + List frames = world.getEntitiesWithinAABB(EntityItemFrame.class, aabb); for(EntityItemFrame frame : frames) { int orientation = frame.hangingDirection; if(orientationToDir[orientation] == dir.ordinal()) diff --git a/src/main/java/vazkii/botania/common/block/subtile/functional/SubTileRannuncarpus.java b/src/main/java/vazkii/botania/common/block/subtile/functional/SubTileRannuncarpus.java index f890fd7783..37702488a0 100644 --- a/src/main/java/vazkii/botania/common/block/subtile/functional/SubTileRannuncarpus.java +++ b/src/main/java/vazkii/botania/common/block/subtile/functional/SubTileRannuncarpus.java @@ -78,6 +78,7 @@ public void onUpdate() { int z = supertile.zCoord; List items = supertile.getWorldObj().getEntitiesWithinAABB(EntityItem.class, AxisAlignedBB.getBoundingBox(x - RANGE, y - RANGE_Y, z - RANGE, x + RANGE + 1, y + RANGE_Y, z + RANGE + 1)); + List itemFilter = SubTileHopperhock.getFilterForInventory(supertile.getWorldObj(), null,x,y-(supertile instanceof IFloatingFlower?1:2),z, false); int slowdown = getSlowdownFactor(); for(EntityItem item : items) { if(item.age < (60 + slowdown) || item.isDead)