mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2025-01-25 00:16:54 +00:00
Fallback to the current side when getting fluid cap
We did this for item caps in 9af1aa1ecf
,
but makes sense to do this for fluid methods too.
This commit is contained in:
parent
9af1aa1ecf
commit
63580b4acb
@ -8,7 +8,9 @@ import dan200.computercraft.api.detail.ForgeDetailRegistries;
|
|||||||
import dan200.computercraft.api.lua.LuaException;
|
import dan200.computercraft.api.lua.LuaException;
|
||||||
import dan200.computercraft.api.lua.LuaFunction;
|
import dan200.computercraft.api.lua.LuaFunction;
|
||||||
import dan200.computercraft.api.peripheral.IComputerAccess;
|
import dan200.computercraft.api.peripheral.IComputerAccess;
|
||||||
|
import dan200.computercraft.api.peripheral.IPeripheral;
|
||||||
import dan200.computercraft.shared.platform.RegistryWrappers;
|
import dan200.computercraft.shared.platform.RegistryWrappers;
|
||||||
|
import dan200.computercraft.shared.util.CapabilityUtil;
|
||||||
import net.minecraft.world.level.block.entity.BlockEntity;
|
import net.minecraft.world.level.block.entity.BlockEntity;
|
||||||
import net.minecraftforge.common.capabilities.ForgeCapabilities;
|
import net.minecraftforge.common.capabilities.ForgeCapabilities;
|
||||||
import net.minecraftforge.common.capabilities.ICapabilityProvider;
|
import net.minecraftforge.common.capabilities.ICapabilityProvider;
|
||||||
@ -53,7 +55,7 @@ public final class FluidMethods extends AbstractFluidMethods<IFluidHandler> {
|
|||||||
var location = computer.getAvailablePeripheral(toName);
|
var location = computer.getAvailablePeripheral(toName);
|
||||||
if (location == null) throw new LuaException("Target '" + toName + "' does not exist");
|
if (location == null) throw new LuaException("Target '" + toName + "' does not exist");
|
||||||
|
|
||||||
var to = extractHandler(location.getTarget());
|
var to = extractHandler(location);
|
||||||
if (to == null) throw new LuaException("Target '" + toName + "' is not an tank");
|
if (to == null) throw new LuaException("Target '" + toName + "' is not an tank");
|
||||||
|
|
||||||
int actualLimit = limit.orElse(Integer.MAX_VALUE);
|
int actualLimit = limit.orElse(Integer.MAX_VALUE);
|
||||||
@ -78,7 +80,7 @@ public final class FluidMethods extends AbstractFluidMethods<IFluidHandler> {
|
|||||||
var location = computer.getAvailablePeripheral(fromName);
|
var location = computer.getAvailablePeripheral(fromName);
|
||||||
if (location == null) throw new LuaException("Target '" + fromName + "' does not exist");
|
if (location == null) throw new LuaException("Target '" + fromName + "' does not exist");
|
||||||
|
|
||||||
var from = extractHandler(location.getTarget());
|
var from = extractHandler(location);
|
||||||
if (from == null) throw new LuaException("Target '" + fromName + "' is not an tank");
|
if (from == null) throw new LuaException("Target '" + fromName + "' is not an tank");
|
||||||
|
|
||||||
int actualLimit = limit.orElse(Integer.MAX_VALUE);
|
int actualLimit = limit.orElse(Integer.MAX_VALUE);
|
||||||
@ -90,11 +92,14 @@ public final class FluidMethods extends AbstractFluidMethods<IFluidHandler> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
private static IFluidHandler extractHandler(@Nullable Object object) {
|
private static IFluidHandler extractHandler(IPeripheral peripheral) {
|
||||||
|
var object = peripheral.getTarget();
|
||||||
|
var direction = peripheral instanceof dan200.computercraft.shared.peripheral.generic.GenericPeripheral sided ? sided.side() : null;
|
||||||
|
|
||||||
if (object instanceof BlockEntity blockEntity && blockEntity.isRemoved()) return null;
|
if (object instanceof BlockEntity blockEntity && blockEntity.isRemoved()) return null;
|
||||||
|
|
||||||
if (object instanceof ICapabilityProvider provider) {
|
if (object instanceof ICapabilityProvider provider) {
|
||||||
var cap = provider.getCapability(ForgeCapabilities.FLUID_HANDLER);
|
var cap = CapabilityUtil.getCapability(provider, ForgeCapabilities.FLUID_HANDLER, direction);
|
||||||
if (cap.isPresent()) return cap.orElseThrow(NullPointerException::new);
|
if (cap.isPresent()) return cap.orElseThrow(NullPointerException::new);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user