Add API to get full list of stacks for an item/fluid type. (#2804)
This commit is contained in:
@@ -118,6 +118,12 @@ public interface IStackList<T> {
|
||||
@Nonnull
|
||||
Collection<StackListEntry<T>> getStacks();
|
||||
|
||||
/**
|
||||
* @return a collection of stacks matching the given type (ignoring NBT)
|
||||
*/
|
||||
@Nonnull
|
||||
Collection<StackListEntry<T>> getStacks(@Nonnull T stack);
|
||||
|
||||
/**
|
||||
* @return a new copy of this list, with the stacks in it copied as well
|
||||
*/
|
||||
|
@@ -6,14 +6,12 @@ import com.refinedmods.refinedstorage.api.util.StackListEntry;
|
||||
import com.refinedmods.refinedstorage.api.util.StackListResult;
|
||||
import com.refinedmods.refinedstorage.apiimpl.API;
|
||||
import net.minecraft.fluid.Fluid;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraftforge.fluids.FluidStack;
|
||||
|
||||
import javax.annotation.Nonnull;
|
||||
import javax.annotation.Nullable;
|
||||
import java.util.Collection;
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.UUID;
|
||||
import java.util.*;
|
||||
|
||||
public class FluidStackList implements IStackList<FluidStack> {
|
||||
private final ArrayListMultimap<Fluid, StackListEntry<FluidStack>> stacks = ArrayListMultimap.create();
|
||||
@@ -143,6 +141,12 @@ public class FluidStackList implements IStackList<FluidStack> {
|
||||
return stacks.values();
|
||||
}
|
||||
|
||||
@Override
|
||||
@Nonnull
|
||||
public Collection<StackListEntry<FluidStack>> getStacks(@Nonnull FluidStack stack) {
|
||||
return stacks.get(stack.getFluid());
|
||||
}
|
||||
|
||||
@Override
|
||||
@Nonnull
|
||||
public IStackList<FluidStack> copy() {
|
||||
|
@@ -11,10 +11,7 @@ import net.minecraftforge.items.ItemHandlerHelper;
|
||||
|
||||
import javax.annotation.Nonnull;
|
||||
import javax.annotation.Nullable;
|
||||
import java.util.Collection;
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.UUID;
|
||||
import java.util.*;
|
||||
|
||||
public class ItemStackList implements IStackList<ItemStack> {
|
||||
private final ArrayListMultimap<Item, StackListEntry<ItemStack>> stacks = ArrayListMultimap.create();
|
||||
@@ -141,6 +138,12 @@ public class ItemStackList implements IStackList<ItemStack> {
|
||||
return stacks.values();
|
||||
}
|
||||
|
||||
@Override
|
||||
@Nonnull
|
||||
public Collection<StackListEntry<ItemStack>> getStacks(@Nonnull ItemStack stack) {
|
||||
return stacks.get(stack.getItem());
|
||||
}
|
||||
|
||||
@Override
|
||||
@Nonnull
|
||||
public IStackList<ItemStack> copy() {
|
||||
|
Reference in New Issue
Block a user