mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-05 02:22:12 +01:00
SPIGOT-7309: Add API for jukebox inventories
By: Parker Hawke <hawkeboyz2@hotmail.com>
This commit is contained in:
parent
027afe0c44
commit
576f627798
3 changed files with 57 additions and 1 deletions
|
@ -1,14 +1,16 @@
|
||||||
package org.bukkit.block;
|
package org.bukkit.block;
|
||||||
|
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.inventory.BlockInventoryHolder;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.JukeboxInventory;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents a captured state of a jukebox.
|
* Represents a captured state of a jukebox.
|
||||||
*/
|
*/
|
||||||
public interface Jukebox extends TileState {
|
public interface Jukebox extends TileState, BlockInventoryHolder {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the record inserted into the jukebox.
|
* Gets the record inserted into the jukebox.
|
||||||
|
@ -62,4 +64,19 @@ public interface Jukebox extends TileState {
|
||||||
* @throws IllegalStateException if this block state is not placed
|
* @throws IllegalStateException if this block state is not placed
|
||||||
*/
|
*/
|
||||||
public boolean eject();
|
public boolean eject();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return inventory
|
||||||
|
* @see Container#getInventory()
|
||||||
|
*/
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
JukeboxInventory getInventory();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return snapshot inventory
|
||||||
|
* @see Container#getSnapshotInventory()
|
||||||
|
*/
|
||||||
|
@NotNull
|
||||||
|
JukeboxInventory getSnapshotInventory();
|
||||||
}
|
}
|
||||||
|
|
|
@ -138,6 +138,10 @@ public enum InventoryType {
|
||||||
* Pseudo chiseled bookshelf inventory, with 6 slots of undefined type.
|
* Pseudo chiseled bookshelf inventory, with 6 slots of undefined type.
|
||||||
*/
|
*/
|
||||||
CHISELED_BOOKSHELF(6, "Chiseled Bookshelf", false),
|
CHISELED_BOOKSHELF(6, "Chiseled Bookshelf", false),
|
||||||
|
/**
|
||||||
|
* Pseudo jukebox inventory with 1 slot of undefined type.
|
||||||
|
*/
|
||||||
|
JUKEBOX(1, "Jukebox", false),
|
||||||
/**
|
/**
|
||||||
* The new smithing inventory, with 3 CRAFTING slots and 1 RESULT slot.
|
* The new smithing inventory, with 3 CRAFTING slots and 1 RESULT slot.
|
||||||
*
|
*
|
||||||
|
|
|
@ -0,0 +1,35 @@
|
||||||
|
package org.bukkit.inventory;
|
||||||
|
|
||||||
|
import org.bukkit.Tag;
|
||||||
|
import org.bukkit.block.Jukebox;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface to the inventory of a Jukebox.
|
||||||
|
*/
|
||||||
|
public interface JukeboxInventory extends Inventory {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the record in the jukebox.
|
||||||
|
* <p>
|
||||||
|
* This will immediately start playing the inserted item or stop playing if the
|
||||||
|
* item provided is null. If the provided item is not a record (according to
|
||||||
|
* {@link Tag#ITEMS_MUSIC_DISCS}), this method will do nothing and not set the
|
||||||
|
* item in the inventory.
|
||||||
|
*
|
||||||
|
* @param item the new record
|
||||||
|
*/
|
||||||
|
void setRecord(@Nullable ItemStack item);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the record in the jukebox.
|
||||||
|
*
|
||||||
|
* @return the current record
|
||||||
|
*/
|
||||||
|
@Nullable
|
||||||
|
ItemStack getRecord();
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
@Override
|
||||||
|
public Jukebox getHolder();
|
||||||
|
}
|
Loading…
Reference in a new issue