/*
* CraftBook Copyright (C) 2010-2017 sk89q <http://www.sk89q.com>
* CraftBook Copyright (C) 2011-2017 me4502 <http://www.me4502.com>
* CraftBook Copyright (C) Contributors
*
* This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public
* License as published by the Free
* Software Foundation, either version 3 of the License, or (at your option) any later version.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License along with this program. If not,
* see <http://www.gnu.org/licenses/>.
*/
package com.sk89q.craftbook.sponge.mechanics.blockbags;
import org.spongepowered.api.item.inventory.ItemStack;
import java.util.List;
/**
* Represents an object that contains an inventory, and can be used as a source of blocks for CraftBook mechanics.
*/
public interface BlockBag {
/**
* Determines if this {@link BlockBag} contains the requested {@link ItemStack}s.
*
* @param itemStacks The requested items
* @return if it contains the items
*/
boolean has(List<ItemStack> itemStacks);
/**
* Adds the given {@link ItemStack}s to this {@link BlockBag}.
*
* @param itemStacks The items to add
* @return All items that could not be added
*/
List<ItemStack> add(List<ItemStack> itemStacks);
/**
* Removes the given {@link ItemStack}s from this {@link BlockBag}.
*
* @param itemStacks The items to remove
* @return All items that could not be removed
*/
List<ItemStack> remove(List<ItemStack> itemStacks);
}