b977ee89ee
* Implemented an adapter for IItemHandler so it can be used by the Storage Bus. * Added update hook for inject/extract to ItemHandlerAdapter. * Implemented ItemHandler and FluidHandler capabilities for the condenser, as replacement for the Void Inventories. * Removed external storage handler, added capability-based way of accessing a monitorable ME network via the storage bus. Removed special case inventories for the matter condenser. * Implemented InventoryAdaptor for IItemHandler. This also now fixes molecular assemblers interaction with part interfaces.
266 lines
6.1 KiB
Java
266 lines
6.1 KiB
Java
/*
|
|
* This file is part of Applied Energistics 2.
|
|
* Copyright (c) 2013 - 2014, AlgorithmX2, All rights reserved.
|
|
*
|
|
* Applied Energistics 2 is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Applied Energistics 2 is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with Applied Energistics 2. If not, see <http://www.gnu.org/licenses/lgpl>.
|
|
*/
|
|
|
|
package appeng.util.inv;
|
|
|
|
|
|
import java.util.Iterator;
|
|
|
|
import net.minecraft.item.ItemStack;
|
|
import net.minecraftforge.items.IItemHandler;
|
|
|
|
import appeng.api.config.FuzzyMode;
|
|
import appeng.util.InventoryAdaptor;
|
|
import appeng.util.Platform;
|
|
|
|
|
|
public class AdaptorItemHandler extends InventoryAdaptor
|
|
{
|
|
private final IItemHandler itemHandler;
|
|
|
|
public AdaptorItemHandler( IItemHandler itemHandler )
|
|
{
|
|
this.itemHandler = itemHandler;
|
|
}
|
|
|
|
@Override
|
|
public ItemStack removeItems( int amount, ItemStack filter, IInventoryDestination destination )
|
|
{
|
|
int slots = itemHandler.getSlots();
|
|
ItemStack rv = null;
|
|
|
|
for( int slot = 0; slot < slots && amount > 0; slot++ )
|
|
{
|
|
final ItemStack is = itemHandler.getStackInSlot( slot );
|
|
if( is == null || ( filter != null && !Platform.isSameItemPrecise( is, filter ) ) )
|
|
{
|
|
continue;
|
|
}
|
|
|
|
if( destination != null )
|
|
{
|
|
ItemStack extracted = itemHandler.extractItem( slot, amount, true );
|
|
if( extracted == null )
|
|
{
|
|
continue;
|
|
}
|
|
|
|
if( !destination.canInsert( extracted ) )
|
|
{
|
|
continue;
|
|
}
|
|
}
|
|
|
|
// Attempt extracting it
|
|
ItemStack extracted = itemHandler.extractItem( slot, amount, false );
|
|
|
|
if( extracted == null )
|
|
{
|
|
continue;
|
|
}
|
|
|
|
if( rv == null )
|
|
{
|
|
// Use the first stack as a template for the result
|
|
rv = extracted;
|
|
filter = extracted;
|
|
amount -= extracted.stackSize;
|
|
}
|
|
else
|
|
{
|
|
// Subsequent stacks will just increase the extracted size
|
|
rv.stackSize += extracted.stackSize;
|
|
amount -= extracted.stackSize;
|
|
}
|
|
}
|
|
|
|
return rv;
|
|
}
|
|
|
|
@Override
|
|
public ItemStack simulateRemove( int amount, ItemStack filter, IInventoryDestination destination )
|
|
{
|
|
int slots = itemHandler.getSlots();
|
|
ItemStack rv = null;
|
|
|
|
for( int slot = 0; slot < slots && amount > 0; slot++ )
|
|
{
|
|
final ItemStack is = itemHandler.getStackInSlot( slot );
|
|
if( is != null && ( filter == null || Platform.isSameItemPrecise( is, filter ) ) )
|
|
{
|
|
ItemStack extracted = itemHandler.extractItem( slot, amount, true );
|
|
|
|
if( extracted == null )
|
|
{
|
|
continue;
|
|
}
|
|
|
|
if( destination != null )
|
|
{
|
|
if( !destination.canInsert( extracted ) )
|
|
{
|
|
continue;
|
|
}
|
|
}
|
|
|
|
if( rv == null )
|
|
{
|
|
// Use the first stack as a template for the result
|
|
rv = extracted.copy();
|
|
filter = extracted;
|
|
amount -= extracted.stackSize;
|
|
}
|
|
else
|
|
{
|
|
// Subsequent stacks will just increase the extracted size
|
|
rv.stackSize += extracted.stackSize;
|
|
amount -= extracted.stackSize;
|
|
}
|
|
}
|
|
}
|
|
|
|
return rv;
|
|
}
|
|
|
|
/**
|
|
* For fuzzy extract, we will only ever extract one slot, since we're afraid of merging two item stacks with different damage values.
|
|
*/
|
|
@Override
|
|
public ItemStack removeSimilarItems( int amount, ItemStack filter, FuzzyMode fuzzyMode, IInventoryDestination destination )
|
|
{
|
|
int slots = itemHandler.getSlots();
|
|
ItemStack extracted = null;
|
|
|
|
for( int slot = 0; slot < slots && extracted == null; slot++ )
|
|
{
|
|
final ItemStack is = itemHandler.getStackInSlot( slot );
|
|
if( is == null || ( filter != null && !Platform.isSameItemFuzzy( is, filter, fuzzyMode ) ) )
|
|
{
|
|
continue;
|
|
}
|
|
|
|
if( destination != null )
|
|
{
|
|
ItemStack simulated = itemHandler.extractItem( slot, amount, true );
|
|
if( simulated == null )
|
|
{
|
|
continue;
|
|
}
|
|
|
|
if( !destination.canInsert( simulated ) )
|
|
{
|
|
continue;
|
|
}
|
|
}
|
|
|
|
// Attempt extracting it
|
|
extracted = itemHandler.extractItem( slot, amount, false );
|
|
}
|
|
|
|
return extracted;
|
|
}
|
|
|
|
@Override
|
|
public ItemStack simulateSimilarRemove( int amount, ItemStack filter, FuzzyMode fuzzyMode, IInventoryDestination destination )
|
|
{
|
|
int slots = itemHandler.getSlots();
|
|
ItemStack extracted = null;
|
|
|
|
for( int slot = 0; slot < slots && extracted == null; slot++ )
|
|
{
|
|
final ItemStack is = itemHandler.getStackInSlot( slot );
|
|
if( is == null || ( filter != null && !Platform.isSameItemFuzzy( is, filter, fuzzyMode ) ) )
|
|
{
|
|
continue;
|
|
}
|
|
|
|
// Attempt extracting it
|
|
extracted = itemHandler.extractItem( slot, amount, true );
|
|
|
|
if( extracted != null && destination != null )
|
|
{
|
|
if( !destination.canInsert( extracted ) )
|
|
{
|
|
extracted = null; // Keep on looking...
|
|
}
|
|
}
|
|
}
|
|
|
|
return extracted;
|
|
}
|
|
|
|
@Override
|
|
public ItemStack addItems( ItemStack toBeAdded )
|
|
{
|
|
return addItems( toBeAdded, false );
|
|
}
|
|
|
|
@Override
|
|
public ItemStack simulateAdd( ItemStack toBeSimulated )
|
|
{
|
|
return addItems( toBeSimulated, true );
|
|
}
|
|
|
|
private ItemStack addItems( final ItemStack itemsToAdd, final boolean simulate )
|
|
{
|
|
if( itemsToAdd == null || itemsToAdd.stackSize == 0 )
|
|
{
|
|
return null;
|
|
}
|
|
|
|
ItemStack left = itemsToAdd.copy();
|
|
|
|
for( int slot = 0; slot < itemHandler.getSlots(); slot++ )
|
|
{
|
|
ItemStack is = itemHandler.getStackInSlot( slot );
|
|
|
|
if( is == null || Platform.isSameItemPrecise( is, left ) )
|
|
{
|
|
left = itemHandler.insertItem( slot, left, simulate );
|
|
|
|
if( left == null || left.stackSize <= 0 )
|
|
{
|
|
return null;
|
|
}
|
|
}
|
|
}
|
|
|
|
return left;
|
|
}
|
|
|
|
@Override
|
|
public boolean containsItems()
|
|
{
|
|
int slots = itemHandler.getSlots();
|
|
for( int slot = 0; slot < slots; slot++ )
|
|
{
|
|
if( itemHandler.getStackInSlot( slot ) != null )
|
|
{
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public Iterator<ItemSlot> iterator()
|
|
{
|
|
return new ItemHandlerIterator( itemHandler );
|
|
}
|
|
}
|