mirror of
https://github.com/Ellpeck/ActuallyAdditions.git
synced 2024-11-22 23:28:35 +01:00
no.
no again.
This commit is contained in:
parent
a90b980d57
commit
58b959c593
1 changed files with 13 additions and 6 deletions
|
@ -15,11 +15,12 @@ import cofh.api.energy.IEnergyProvider;
|
||||||
import cofh.api.energy.IEnergyReceiver;
|
import cofh.api.energy.IEnergyReceiver;
|
||||||
import de.ellpeck.actuallyadditions.mod.tile.TileEntityBase;
|
import de.ellpeck.actuallyadditions.mod.tile.TileEntityBase;
|
||||||
import net.darkhax.tesla.api.ITeslaConsumer;
|
import net.darkhax.tesla.api.ITeslaConsumer;
|
||||||
|
import net.darkhax.tesla.api.ITeslaHolder;
|
||||||
import net.darkhax.tesla.api.ITeslaProducer;
|
import net.darkhax.tesla.api.ITeslaProducer;
|
||||||
import net.darkhax.tesla.capability.TeslaCapabilities;
|
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraftforge.common.capabilities.Capability;
|
import net.minecraftforge.common.capabilities.Capability;
|
||||||
|
import net.minecraftforge.common.capabilities.CapabilityInject;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
@ -27,11 +28,17 @@ import java.util.Map;
|
||||||
public final class TeslaUtil{
|
public final class TeslaUtil{
|
||||||
|
|
||||||
private static final Map<TileEntityBase, TeslaHandler[]> TESLA_MAP = new HashMap<TileEntityBase, TeslaHandler[]>();
|
private static final Map<TileEntityBase, TeslaHandler[]> TESLA_MAP = new HashMap<TileEntityBase, TeslaHandler[]>();
|
||||||
|
@CapabilityInject(ITeslaConsumer.class)
|
||||||
|
public static Capability<ITeslaConsumer> teslaConsumer;
|
||||||
|
@CapabilityInject(ITeslaProducer.class)
|
||||||
|
public static Capability<ITeslaProducer> teslaProducer;
|
||||||
|
@CapabilityInject(ITeslaHolder.class)
|
||||||
|
public static Capability<ITeslaHolder> teslaHolder;
|
||||||
|
|
||||||
public static <T> T getTeslaCapability(TileEntityBase tile, Capability<T> capability, EnumFacing facing){
|
public static <T> T getTeslaCapability(TileEntityBase tile, Capability<T> capability, EnumFacing facing){
|
||||||
boolean receive = tile instanceof IEnergyReceiver && capability == TeslaCapabilities.CAPABILITY_CONSUMER;
|
boolean receive = tile instanceof IEnergyReceiver && capability == teslaConsumer;
|
||||||
boolean provide = tile instanceof IEnergyProvider && capability == TeslaCapabilities.CAPABILITY_PRODUCER;
|
boolean provide = tile instanceof IEnergyProvider && capability == teslaProducer;
|
||||||
boolean hold = tile instanceof IEnergyHandler && capability == TeslaCapabilities.CAPABILITY_HOLDER;
|
boolean hold = tile instanceof IEnergyHandler && capability == teslaHolder;
|
||||||
if(receive || provide || hold){
|
if(receive || provide || hold){
|
||||||
return (T)getHandler(tile, facing);
|
return (T)getHandler(tile, facing);
|
||||||
}
|
}
|
||||||
|
@ -46,8 +53,8 @@ public final class TeslaUtil{
|
||||||
|
|
||||||
for(int i = 0; i < 2; i++){
|
for(int i = 0; i < 2; i++){
|
||||||
if(handlerFrom == null && handlerTo == null){
|
if(handlerFrom == null && handlerTo == null){
|
||||||
handlerFrom = (i == 0 ? tile : otherTile).getCapability(TeslaCapabilities.CAPABILITY_PRODUCER, i == 0 ? side : side.getOpposite());
|
handlerFrom = (i == 0 ? tile : otherTile).getCapability(teslaProducer, i == 0 ? side : side.getOpposite());
|
||||||
handlerTo = (i == 0 ? otherTile : tile).getCapability(TeslaCapabilities.CAPABILITY_CONSUMER, i == 0 ? side.getOpposite() : side);
|
handlerTo = (i == 0 ? otherTile : tile).getCapability(teslaConsumer, i == 0 ? side.getOpposite() : side);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue