/* * This file ("TileEntityInputter.java") is part of the Actually Additions mod for Minecraft. * It is created and owned by Ellpeck and distributed * under the Actually Additions License to be found at * http://ellpeck.de/actaddlicense * View the source code at https://github.com/Ellpeck/ActuallyAdditions * * © 2015-2017 Ellpeck */ package de.ellpeck.actuallyadditions.mod.tile; import de.ellpeck.actuallyadditions.mod.ActuallyAdditions; import de.ellpeck.actuallyadditions.mod.network.gui.IButtonReactor; import de.ellpeck.actuallyadditions.mod.network.gui.INumberReactor; import de.ellpeck.actuallyadditions.mod.util.StackUtil; import de.ellpeck.actuallyadditions.mod.util.WorldUtil; import de.ellpeck.actuallyadditions.mod.util.compat.SlotlessableItemHandlerWrapper; import net.minecraft.entity.player.EntityPlayer; import net.minecraft.item.ItemStack; import net.minecraft.nbt.NBTTagCompound; import net.minecraft.tileentity.TileEntity; import net.minecraft.util.EnumFacing; import net.minecraft.util.math.BlockPos; import net.minecraftforge.items.CapabilityItemHandler; import net.minecraftforge.items.IItemHandler; import org.cyclops.commoncapabilities.capability.itemhandler.SlotlessItemHandlerConfig; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; public class TileEntityInputter extends TileEntityInventoryBase implements IButtonReactor, INumberReactor{ public static final int OKAY_BUTTON_ID = 133; private final SlotlessableItemHandlerWrapper wrapper = new SlotlessableItemHandlerWrapper(this.slots, null); public int sideToPut = -1; public int slotToPutStart; public int slotToPutEnd; public Map placeToPut = new ConcurrentHashMap(); public int sideToPull = -1; public int slotToPullStart; public int slotToPullEnd; public Map placeToPull = new ConcurrentHashMap(); public boolean isAdvanced; public FilterSettings leftFilter = new FilterSettings(12, true, true, false, false, 0, -1000); public FilterSettings rightFilter = new FilterSettings(12, true, true, false, false, 0, -2000); private int lastPutSide; private int lastPutStart; private int lastPutEnd; private int lastPullSide; private int lastPullStart; private int lastPullEnd; public TileEntityInputter(int slots, String name){ super(slots, name); } public TileEntityInputter(){ super(1, "inputter"); this.isAdvanced = false; } @Override public void onNumberReceived(double number, int textID, EntityPlayer player){ int text = (int)number; if(text != -1){ if(textID == 0){ this.slotToPutStart = Math.max(text, 0); } if(textID == 1){ this.slotToPutEnd = Math.max(text, 0); } if(textID == 2){ this.slotToPullStart = Math.max(text, 0); } if(textID == 3){ this.slotToPullEnd = Math.max(text, 0); } } this.markDirty(); } private boolean newPulling(){ for(EnumFacing side : this.placeToPull.keySet()){ WorldUtil.doItemInteraction(this.placeToPull.get(side), this.wrapper, Integer.MAX_VALUE, this.slotToPullStart, this.slotToPullEnd, !this.isAdvanced ? null : this.leftFilter); if(this.placeToPull instanceof TileEntityItemViewer){ break; } } return false; } private boolean newPutting(){ if(!this.isAdvanced || this.rightFilter.check(this.slots.getStackInSlot(0))){ for(EnumFacing side : this.placeToPut.keySet()){ WorldUtil.doItemInteraction(this.wrapper, this.placeToPut.get(side), Integer.MAX_VALUE, this.slotToPutStart, this.slotToPutEnd, null); if(this.placeToPut instanceof TileEntityItemViewer){ break; } } } return false; } @Override public boolean shouldSaveDataOnChangeOrWorldStart(){ return true; } /** * Sets all of the relevant variables */ @Override public void saveDataOnChangeOrWorldStart(){ this.placeToPull.clear(); this.placeToPut.clear(); if(this.sideToPull != -1){ EnumFacing side = WorldUtil.getDirectionBySidesInOrder(this.sideToPull); BlockPos offset = this.pos.offset(side); if(this.world.isBlockLoaded(offset)){ TileEntity tile = this.world.getTileEntity(offset); if(tile != null){ for(EnumFacing facing : EnumFacing.values()){ IItemHandler normal = null; if(tile.hasCapability(CapabilityItemHandler.ITEM_HANDLER_CAPABILITY, facing)){ normal = tile.getCapability(CapabilityItemHandler.ITEM_HANDLER_CAPABILITY, facing); } Object slotless = null; if(ActuallyAdditions.commonCapsLoaded){ if(tile.hasCapability(SlotlessItemHandlerConfig.CAPABILITY, facing)){ slotless = tile.getCapability(SlotlessItemHandlerConfig.CAPABILITY, facing); } } this.placeToPull.put(facing.getOpposite(), new SlotlessableItemHandlerWrapper(normal, slotless)); } if(this.slotToPullEnd <= 0){ if(tile.hasCapability(CapabilityItemHandler.ITEM_HANDLER_CAPABILITY, null)){ IItemHandler cap = tile.getCapability(CapabilityItemHandler.ITEM_HANDLER_CAPABILITY, null); if(cap != null){ this.slotToPullEnd = cap.getSlots(); } } } } } } if(this.sideToPut != -1){ EnumFacing side = WorldUtil.getDirectionBySidesInOrder(this.sideToPut); BlockPos offset = this.pos.offset(side); if(this.world.isBlockLoaded(offset)){ TileEntity tile = this.world.getTileEntity(offset); if(tile != null){ for(EnumFacing facing : EnumFacing.values()){ IItemHandler normal = null; if(tile.hasCapability(CapabilityItemHandler.ITEM_HANDLER_CAPABILITY, facing)){ normal = tile.getCapability(CapabilityItemHandler.ITEM_HANDLER_CAPABILITY, facing); } Object slotless = null; if(ActuallyAdditions.commonCapsLoaded){ if(tile.hasCapability(SlotlessItemHandlerConfig.CAPABILITY, facing)){ slotless = tile.getCapability(SlotlessItemHandlerConfig.CAPABILITY, facing); } } this.placeToPut.put(facing.getOpposite(), new SlotlessableItemHandlerWrapper(normal, slotless)); } if(this.slotToPutEnd <= 0){ if(tile.hasCapability(CapabilityItemHandler.ITEM_HANDLER_CAPABILITY, null)){ IItemHandler cap = tile.getCapability(CapabilityItemHandler.ITEM_HANDLER_CAPABILITY, null); if(cap != null){ this.slotToPutEnd = cap.getSlots(); } } } } } } } @Override public void onButtonPressed(int buttonID, EntityPlayer player){ this.leftFilter.onButtonPressed(buttonID); this.rightFilter.onButtonPressed(buttonID); //Reset the Slots if(buttonID == 0 || buttonID == 1){ this.slotToPutStart = 0; this.slotToPutEnd = 0; } if(buttonID == 2 || buttonID == 3){ this.slotToPullStart = 0; this.slotToPullEnd = 0; } if(buttonID == 0){ this.sideToPut++; } if(buttonID == 1){ this.sideToPut--; } if(buttonID == 2){ this.sideToPull++; } if(buttonID == 3){ this.sideToPull--; } if(this.sideToPut >= 6){ this.sideToPut = -1; } else if(this.sideToPut < -1){ this.sideToPut = 5; } else if(this.sideToPull >= 6){ this.sideToPull = -1; } else if(this.sideToPull < -1){ this.sideToPull = 5; } this.markDirty(); this.saveDataOnChangeOrWorldStart(); } @Override public void writeSyncableNBT(NBTTagCompound compound, NBTType type){ super.writeSyncableNBT(compound, type); if(type != NBTType.SAVE_BLOCK){ compound.setInteger("SideToPut", this.sideToPut); compound.setInteger("SlotToPut", this.slotToPutStart); compound.setInteger("SlotToPutEnd", this.slotToPutEnd); compound.setInteger("SideToPull", this.sideToPull); compound.setInteger("SlotToPull", this.slotToPullStart); compound.setInteger("SlotToPullEnd", this.slotToPullEnd); } this.leftFilter.writeToNBT(compound, "LeftFilter"); this.rightFilter.writeToNBT(compound, "RightFilter"); } @Override public void readSyncableNBT(NBTTagCompound compound, NBTType type){ if(type != NBTType.SAVE_BLOCK){ this.sideToPut = compound.getInteger("SideToPut"); this.slotToPutStart = compound.getInteger("SlotToPut"); this.slotToPutEnd = compound.getInteger("SlotToPutEnd"); this.sideToPull = compound.getInteger("SideToPull"); this.slotToPullStart = compound.getInteger("SlotToPull"); this.slotToPullEnd = compound.getInteger("SlotToPullEnd"); } this.leftFilter.readFromNBT(compound, "LeftFilter"); this.rightFilter.readFromNBT(compound, "RightFilter"); super.readSyncableNBT(compound, type); } @Override public void updateEntity(){ super.updateEntity(); if(!this.world.isRemote){ //Is Block not powered by Redstone? if(!this.isRedstonePowered){ if(this.ticksElapsed%30 == 0){ if(!(this.sideToPull == this.sideToPut && this.slotToPullStart == this.slotToPutStart && this.slotToPullEnd == this.slotToPutEnd)){ if(!StackUtil.isValid(this.slots.getStackInSlot(0)) && this.sideToPull != -1 && this.placeToPull != null){ this.newPulling(); } if(StackUtil.isValid(this.slots.getStackInSlot(0)) && this.sideToPut != -1 && this.placeToPut != null){ this.newPutting(); } } } } //Update the Client if((this.sideToPut != this.lastPutSide || this.sideToPull != this.lastPullSide || this.slotToPullStart != this.lastPullStart || this.slotToPullEnd != this.lastPullEnd || this.slotToPutStart != this.lastPutStart || this.slotToPutEnd != this.lastPutEnd || this.leftFilter.needsUpdateSend() || this.rightFilter.needsUpdateSend()) && this.sendUpdateWithInterval()){ this.lastPutSide = this.sideToPut; this.lastPullSide = this.sideToPull; this.lastPullStart = this.slotToPullStart; this.lastPullEnd = this.slotToPullEnd; this.lastPutStart = this.slotToPutStart; this.lastPutEnd = this.slotToPutEnd; this.leftFilter.updateLasts(); this.rightFilter.updateLasts(); } } } @Override public boolean isItemValidForSlot(int i, ItemStack stack){ return i == 0; } @Override public boolean canExtractItem(int slot, ItemStack stack){ return slot == 0; } }