Package net.minestom.server.inventory
Class AbstractInventory
java.lang.Object
net.minestom.server.inventory.AbstractInventory
- All Implemented Interfaces:
InventoryClickHandler,Taggable,TagReadable,TagWritable
- Direct Known Subclasses:
Inventory,PlayerInventory
public abstract sealed class AbstractInventory
extends Object
implements InventoryClickHandler, Taggable
permits Inventory, PlayerInventory
Represents an inventory where items can be modified/retrieved.
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected final InventoryClickProcessorprotected final List<InventoryCondition> protected final ItemStack[] -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidaddInventoryCondition(@NotNull InventoryCondition inventoryCondition) Adds a newInventoryConditionto this inventory.booleanaddItemStack(@NotNull ItemStack itemStack) <T> TaddItemStack(@NotNull ItemStack itemStack, @NotNull TransactionOption<T> option) Adds anItemStackto the inventory and sends relevant update to the viewer(s).<T> @NotNull List<@NotNull T> addItemStacks(@NotNull List<@NotNull ItemStack> itemStacks, @NotNull TransactionOption<T> option) AddsItemStacks to the inventory and sends relevant updates to the viewer(s).voidclear()Clears the inventory and send relevant update to the viewer(s).voidcopyContents(@NotNull ItemStack[] itemStacks) Places all the items ofitemStacksinto the internal array.intGets the size of the "inner inventory" (which includes only "usable" slots).@NotNull List<@NotNull InventoryCondition> Gets all theInventoryConditionof this inventory.@NotNull ItemStackgetItemStack(int slot) Gets theItemStackat the specified slot.@NotNull ItemStack[]Gets all theItemStackin the inventory.intgetSize()Gets the size of the inventory.<T> TprocessItemStack(@NotNull ItemStack itemStack, @NotNull TransactionType type, @NotNull TransactionOption<T> option) <T> @NotNull List<@NotNull T> processItemStacks(@NotNull List<@NotNull ItemStack> itemStacks, @NotNull TransactionType type, @NotNull TransactionOption<T> option) voidreplaceItemStack(int slot, @NotNull UnaryOperator<@NotNull ItemStack> operator) protected final voidsafeItemInsert(int slot, @NotNull ItemStack itemStack) protected final voidsafeItemInsert(int slot, @NotNull ItemStack itemStack, boolean sendPacket) Inserts safely an item into the inventory.voidsetItemStack(int slot, @NotNull ItemStack itemStack) Sets anItemStackat the specified slot and send relevant update to the viewer(s).@NotNull TagHandler<T> TtakeItemStack(@NotNull ItemStack itemStack, @NotNull TransactionOption<T> option) Takes anItemStackfrom the inventory and sends relevant update to the viewer(s).<T> @NotNull List<@NotNull T> takeItemStacks(@NotNull List<@NotNull ItemStack> itemStacks, @NotNull TransactionOption<T> option) TakesItemStacks from the inventory and sends relevant updates to the viewer(s).protected abstract voidUNSAFE_itemInsert(int slot, @NotNull ItemStack itemStack, boolean sendPacket) abstract voidupdate()Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface net.minestom.server.inventory.InventoryClickHandler
callClickEvent, changeHeld, doubleClick, dragging, drop, leftClick, middleClick, rightClick, shiftClick
-
Field Details
-
itemStacks
-
inventoryConditions
-
clickProcessor
-
-
Constructor Details
-
AbstractInventory
protected AbstractInventory(int size)
-
-
Method Details
-
setItemStack
Sets anItemStackat the specified slot and send relevant update to the viewer(s).- Parameters:
slot- the slot to set the itemitemStack- the item to set
-
safeItemInsert
protected final void safeItemInsert(int slot, @NotNull @NotNull ItemStack itemStack, boolean sendPacket) Inserts safely an item into the inventory.This will update the slot for all viewers and warn the inventory that the window items packet is not up-to-date.
- Parameters:
slot- the internal slot iditemStack- the item to insert (use air instead of null)- Throws:
IllegalArgumentException- if the slotslotdoes not exist
-
safeItemInsert
-
UNSAFE_itemInsert
protected abstract void UNSAFE_itemInsert(int slot, @NotNull @NotNull ItemStack itemStack, boolean sendPacket) -
processItemStack
@NotNull public <T> T processItemStack(@NotNull @NotNull ItemStack itemStack, @NotNull @NotNull TransactionType type, @NotNull @NotNull TransactionOption<T> option) -
processItemStacks
@NotNull public <T> @NotNull List<@NotNull T> processItemStacks(@NotNull @NotNull List<@NotNull ItemStack> itemStacks, @NotNull @NotNull TransactionType type, @NotNull @NotNull TransactionOption<T> option) -
addItemStack
@NotNull public <T> T addItemStack(@NotNull @NotNull ItemStack itemStack, @NotNull @NotNull TransactionOption<T> option) Adds anItemStackto the inventory and sends relevant update to the viewer(s).- Parameters:
itemStack- the item to addoption- the transaction option- Returns:
- true if the item has been successfully added, false otherwise
-
addItemStack
-
addItemStacks
@NotNull public <T> @NotNull List<@NotNull T> addItemStacks(@NotNull @NotNull List<@NotNull ItemStack> itemStacks, @NotNull @NotNull TransactionOption<T> option) AddsItemStacks to the inventory and sends relevant updates to the viewer(s).- Parameters:
itemStacks- items to addoption- the transaction option- Returns:
- the operation results
-
takeItemStack
@NotNull public <T> T takeItemStack(@NotNull @NotNull ItemStack itemStack, @NotNull @NotNull TransactionOption<T> option) Takes anItemStackfrom the inventory and sends relevant update to the viewer(s).- Parameters:
itemStack- the item to take- Returns:
- true if the item has been successfully fully taken, false otherwise
-
takeItemStacks
@NotNull public <T> @NotNull List<@NotNull T> takeItemStacks(@NotNull @NotNull List<@NotNull ItemStack> itemStacks, @NotNull @NotNull TransactionOption<T> option) TakesItemStacks from the inventory and sends relevant updates to the viewer(s).- Parameters:
itemStacks- items to take- Returns:
- the operation results
-
replaceItemStack
public void replaceItemStack(int slot, @NotNull @NotNull UnaryOperator<@NotNull ItemStack> operator) -
clear
public void clear()Clears the inventory and send relevant update to the viewer(s). -
update
public abstract void update() -
getItemStack
Gets theItemStackat the specified slot.- Parameters:
slot- the slot to check- Returns:
- the item in the slot
slot
-
getItemStacks
Gets all theItemStackin the inventory.Be aware that the returned array does not need to be the original one, meaning that modifying it directly may not work.
- Returns:
- an array containing all the inventory's items
-
getSize
public int getSize()Gets the size of the inventory.- Returns:
- the inventory's size
-
getInnerSize
public int getInnerSize()Gets the size of the "inner inventory" (which includes only "usable" slots).- Returns:
- inner inventory's size
-
getInventoryConditions
Gets all theInventoryConditionof this inventory.- Returns:
- a modifiable
Listcontaining all the inventory conditions
-
addInventoryCondition
Adds a newInventoryConditionto this inventory.- Parameters:
inventoryCondition- the inventory condition to add
-
copyContents
Places all the items ofitemStacksinto the internal array.- Parameters:
itemStacks- the array to copy the content from- Throws:
IllegalArgumentException- if the size of the array is not equal togetSize()NullPointerException- ifitemStackscontains one null element or more
-
tagHandler
- Specified by:
tagHandlerin interfaceTaggable
-