SPIGOT-3981: Make custom inventories return specialised types where practical.

By: Senmori <thesenmori@gmail.com>
This commit is contained in:
CraftBukkit/Spigot 2018-07-25 18:03:26 +10:00
parent 8ee6f8cd25
commit 64f2fdae29
5 changed files with 202 additions and 5 deletions

View file

@ -145,6 +145,7 @@ import org.bukkit.craftbukkit.block.data.CraftBlockData;
import org.bukkit.craftbukkit.command.BukkitCommandWrapper;
import org.bukkit.craftbukkit.command.CraftCommandMap;
import org.bukkit.craftbukkit.command.VanillaCommandWrapper;
import org.bukkit.craftbukkit.inventory.util.CraftInventoryCreator;
import org.bukkit.craftbukkit.tag.CraftBlockTag;
import org.bukkit.craftbukkit.tag.CraftItemTag;
import org.bukkit.craftbukkit.util.CraftNamespacedKey;
@ -1474,25 +1475,26 @@ public final class CraftServer implements Server {
@Override
public Inventory createInventory(InventoryHolder owner, InventoryType type) {
// TODO: Create the appropriate type, rather than Custom?
return new CraftInventoryCustom(owner, type);
Validate.isTrue(type.isCreatable(), "Cannot open an inventory of type ", type);
return CraftInventoryCreator.INSTANCE.createInventory(owner, type);
}
@Override
public Inventory createInventory(InventoryHolder owner, InventoryType type, String title) {
return new CraftInventoryCustom(owner, type, title);
Validate.isTrue(type.isCreatable(), "Cannot open an inventory of type ", type);
return CraftInventoryCreator.INSTANCE.createInventory(owner, type, title);
}
@Override
public Inventory createInventory(InventoryHolder owner, int size) throws IllegalArgumentException {
Validate.isTrue(size % 9 == 0, "Chests must have a size that is a multiple of 9!");
return new CraftInventoryCustom(owner, size);
return CraftInventoryCreator.INSTANCE.createInventory(owner, size);
}
@Override
public Inventory createInventory(InventoryHolder owner, int size, String title) throws IllegalArgumentException {
Validate.isTrue(size % 9 == 0, "Chests must have a size that is a multiple of 9!");
return new CraftInventoryCustom(owner, size, title);
return CraftInventoryCreator.INSTANCE.createInventory(owner, size, title);
}
@Override

View file

@ -189,6 +189,15 @@ public class CraftHumanEntity extends CraftLivingEntity implements HumanEntity {
IInventory iinventory = (inventory instanceof CraftInventory) ? ((CraftInventory) inventory).getInventory() : new org.bukkit.craftbukkit.inventory.InventoryWrapper(inventory);
if (iinventory instanceof ITileInventory) {
if (iinventory instanceof TileEntity) {
TileEntity te = (TileEntity) iinventory;
if (!te.u()) { // PAIL rename hasWorld
te.setWorld(getHandle().world);
}
}
}
switch (type) {
case PLAYER:
case CHEST:

View file

@ -0,0 +1,27 @@
package org.bukkit.craftbukkit.inventory.util;
import org.bukkit.craftbukkit.inventory.CraftInventoryCustom;
import org.bukkit.event.inventory.InventoryType;
import org.bukkit.inventory.Inventory;
import org.bukkit.inventory.InventoryHolder;
public class CraftCustomInventoryConverter implements CraftInventoryCreator.InventoryConverter {
@Override
public Inventory createInventory(InventoryHolder holder, InventoryType type) {
return new CraftInventoryCustom(holder, type);
}
@Override
public Inventory createInventory(InventoryHolder owner, InventoryType type, String title) {
return new CraftInventoryCustom(owner, type, title);
}
public Inventory createInventory(InventoryHolder owner, int size) {
return new CraftInventoryCustom(owner, size);
}
public Inventory createInventory(InventoryHolder owner, int size, String title) {
return new CraftInventoryCustom(owner, size, title);
}
}

View file

@ -0,0 +1,59 @@
package org.bukkit.craftbukkit.inventory.util;
import java.util.HashMap;
import java.util.Map;
import net.minecraft.server.TileEntityDispenser;
import net.minecraft.server.TileEntityDropper;
import net.minecraft.server.TileEntityHopper;
import org.bukkit.event.inventory.InventoryType;
import org.bukkit.inventory.Inventory;
import org.bukkit.inventory.InventoryHolder;
public final class CraftInventoryCreator {
public static final CraftInventoryCreator INSTANCE = new CraftInventoryCreator();
//
private final CraftCustomInventoryConverter DEFAULT_CONVERTER = new CraftCustomInventoryConverter();
private final Map<InventoryType, InventoryConverter> converterMap = new HashMap<>();
private CraftInventoryCreator() {
converterMap.put(InventoryType.CHEST, DEFAULT_CONVERTER);
converterMap.put(InventoryType.DISPENSER, new CraftTileInventoryConverter(new TileEntityDispenser()));
converterMap.put(InventoryType.DROPPER, new CraftTileInventoryConverter(new TileEntityDropper()));
// furnace needs a world
converterMap.put(InventoryType.FURNACE, new CraftTileInventoryConverter.Furnace());
converterMap.put(InventoryType.WORKBENCH, DEFAULT_CONVERTER);
converterMap.put(InventoryType.ENCHANTING, DEFAULT_CONVERTER);
converterMap.put(InventoryType.BREWING, new CraftTileInventoryConverter.BrewingStand());
converterMap.put(InventoryType.PLAYER, DEFAULT_CONVERTER);
converterMap.put(InventoryType.MERCHANT, DEFAULT_CONVERTER);
converterMap.put(InventoryType.ENDER_CHEST, DEFAULT_CONVERTER);
converterMap.put(InventoryType.ANVIL, DEFAULT_CONVERTER);
converterMap.put(InventoryType.BEACON, new CraftTileInventoryConverter.Beacon());
converterMap.put(InventoryType.HOPPER, new CraftTileInventoryConverter(new TileEntityHopper()));
converterMap.put(InventoryType.SHULKER_BOX, DEFAULT_CONVERTER);
}
public Inventory createInventory(InventoryHolder holder, InventoryType type) {
return converterMap.get(type).createInventory(holder, type);
}
public Inventory createInventory(InventoryHolder holder, InventoryType type, String title) {
return converterMap.get(type).createInventory(holder, type, title);
}
public Inventory createInventory(InventoryHolder holder, int size) {
return DEFAULT_CONVERTER.createInventory(holder, size);
}
public Inventory createInventory(InventoryHolder holder, int size, String title) {
return DEFAULT_CONVERTER.createInventory(holder, size, title);
}
public interface InventoryConverter {
Inventory createInventory(InventoryHolder holder, InventoryType type);
Inventory createInventory(InventoryHolder holder, InventoryType type, String title);
}
}

View file

@ -0,0 +1,100 @@
package org.bukkit.craftbukkit.inventory.util;
import net.minecraft.server.ITileInventory;
import net.minecraft.server.MinecraftServer;
import net.minecraft.server.TileEntityBeacon;
import net.minecraft.server.TileEntityBrewingStand;
import net.minecraft.server.TileEntityFurnace;
import net.minecraft.server.TileEntityLootable;
import org.bukkit.craftbukkit.inventory.CraftInventory;
import org.bukkit.craftbukkit.inventory.CraftInventoryBeacon;
import org.bukkit.craftbukkit.inventory.CraftInventoryBrewer;
import org.bukkit.craftbukkit.inventory.CraftInventoryFurnace;
import org.bukkit.craftbukkit.util.CraftChatMessage;
import org.bukkit.event.inventory.InventoryType;
import org.bukkit.inventory.Inventory;
import org.bukkit.inventory.InventoryHolder;
public class CraftTileInventoryConverter implements CraftInventoryCreator.InventoryConverter {
protected final ITileInventory tileEntity;
public CraftTileInventoryConverter(ITileInventory tileEntity) {
this.tileEntity = tileEntity;
}
@Override
public Inventory createInventory(InventoryHolder holder, InventoryType type) {
return getInventory(tileEntity);
}
@Override
public Inventory createInventory(InventoryHolder holder, InventoryType type, String title) {
if (tileEntity instanceof TileEntityLootable) {
((TileEntityLootable) tileEntity).setCustomName(CraftChatMessage.fromStringOrNull(title));
}
return getInventory(tileEntity);
}
public Inventory getInventory(ITileInventory tileEntity) {
return new CraftInventory(tileEntity);
}
public static class Furnace extends CraftTileInventoryConverter {
public Furnace() {
super(new TileEntityFurnace());
}
@Override
public Inventory createInventory(InventoryHolder owner, InventoryType type) {
return getInventory(tileEntity);
}
@Override
public Inventory createInventory(InventoryHolder owner, InventoryType type, String title) {
((TileEntityFurnace) tileEntity).setCustomName(CraftChatMessage.fromStringOrNull(title));
return getInventory(tileEntity);
}
@Override
public Inventory getInventory(ITileInventory tileEntity) {
((TileEntityFurnace) tileEntity).setWorld(MinecraftServer.getServer().getWorldServer(0)); // TODO: customize this if required
return new CraftInventoryFurnace((TileEntityFurnace) tileEntity);
}
}
public static class BrewingStand extends CraftTileInventoryConverter {
public BrewingStand() {
super(new TileEntityBrewingStand());
}
@Override
public Inventory createInventory(InventoryHolder holder, InventoryType type, String title) {
// BrewingStand does not extend TileEntityLootable
if (tileEntity instanceof TileEntityBrewingStand) {
((TileEntityBrewingStand) tileEntity).setCustomName(CraftChatMessage.fromStringOrNull(title));
}
return getInventory(tileEntity);
}
@Override
public Inventory getInventory(ITileInventory tileEntity) {
return new CraftInventoryBrewer(tileEntity);
}
}
public static class Beacon extends CraftTileInventoryConverter {
public Beacon() {
super(new TileEntityBeacon());
}
@Override
public Inventory getInventory(ITileInventory tileInventory) {
return new CraftInventoryBeacon((TileEntityBeacon) tileInventory);
}
}
}