mirror of
https://github.com/YatopiaMC/Yatopia.git
synced 2024-09-19 02:53:06 +02:00
141 lines
7.0 KiB
Diff
141 lines
7.0 KiB
Diff
From 416295b54c77bf9093ee4bf3ff60ec168540abb1 Mon Sep 17 00:00:00 2001
|
|
From: willies952002 <admin@domnian.com>
|
|
Date: Fri, 16 Aug 2019 22:18:35 -0400
|
|
Subject: [PATCH] EMC Fix Bukkit.createInventory() with type LECTERN
|
|
|
|
This fixes an issue with Bukkit which makes it possible to open a Lectern interface, but not be able to interact with it (e.g.: change pages). The following changes had to be made:
|
|
|
|
nms.TileEntityLectern:
|
|
- Add `virtual` flag, this is used to stop calls that would attempt to update a block which we do not have, as well as used in the following change.
|
|
|
|
nms.TileEntityLectern$LecternInventory
|
|
- in `a(EntityHuman)`, add `(TileEntityLectern.this.virtual && TileEntityLectern.this.hasBook()) ||` to short-circuit the "can use" logic
|
|
- Add `getLectern()` method for use in the following change.
|
|
|
|
obc.e.CraftHumanEntity#openInventory(Inventory):
|
|
- Check if the wrapped inventory is a TileEntityLectern.LecternInventory, and get the Lectern from that
|
|
|
|
obc.i.u.CraftTileInventoryConverter$Lectern:
|
|
- Mark the created lectern as "virtual"
|
|
- Override `getInventory(IInventory)` to return a CraftInventoryLectern.
|
|
|
|
This patch is licensed under the MIT License.
|
|
License: https://opensource.org/licenses/MIT
|
|
---
|
|
.../net/minecraft/server/TileEntityLectern.java | 14 +++++++++++---
|
|
.../craftbukkit/entity/CraftHumanEntity.java | 5 +++++
|
|
.../util/CraftTileInventoryConverter.java | 13 ++++++++++++-
|
|
3 files changed, 28 insertions(+), 4 deletions(-)
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/TileEntityLectern.java b/src/main/java/net/minecraft/server/TileEntityLectern.java
|
|
index 8aac96ed..89d3608b 100644
|
|
--- a/src/main/java/net/minecraft/server/TileEntityLectern.java
|
|
+++ b/src/main/java/net/minecraft/server/TileEntityLectern.java
|
|
@@ -18,6 +18,11 @@ public class TileEntityLectern extends TileEntity implements Clearable, ITileInv
|
|
// CraftBukkit start - add fields and methods
|
|
public final IInventory inventory = new LecternInventory();
|
|
public class LecternInventory implements IInventory {
|
|
+ // EMC start
|
|
+ public TileEntityLectern getLectern() {
|
|
+ return TileEntityLectern.this;
|
|
+ }
|
|
+ // EMC end
|
|
|
|
public List<HumanEntity> transaction = new ArrayList<>();
|
|
private int maxStack = 1;
|
|
@@ -75,7 +80,7 @@ public class TileEntityLectern extends TileEntity implements Clearable, ITileInv
|
|
|
|
@Override
|
|
public ItemStack splitStack(int i, int j) {
|
|
- if (i == 0) {
|
|
+ if (i == 0 && !TileEntityLectern.this.virtual) { // EMC
|
|
ItemStack itemstack = TileEntityLectern.this.book.cloneAndSubtract(j);
|
|
|
|
if (TileEntityLectern.this.book.isEmpty()) {
|
|
@@ -90,7 +95,7 @@ public class TileEntityLectern extends TileEntity implements Clearable, ITileInv
|
|
|
|
@Override
|
|
public ItemStack splitWithoutUpdate(int i) {
|
|
- if (i == 0) {
|
|
+ if (i == 0 && !TileEntityLectern.this.virtual) { // EMC
|
|
ItemStack itemstack = TileEntityLectern.this.book;
|
|
|
|
TileEntityLectern.this.book = ItemStack.a;
|
|
@@ -125,7 +130,7 @@ public class TileEntityLectern extends TileEntity implements Clearable, ITileInv
|
|
|
|
@Override
|
|
public boolean a(EntityHuman entityhuman) {
|
|
- return TileEntityLectern.this.world.getTileEntity(TileEntityLectern.this.position) != TileEntityLectern.this ? false : (entityhuman.g((double) TileEntityLectern.this.position.getX() + 0.5D, (double) TileEntityLectern.this.position.getY() + 0.5D, (double) TileEntityLectern.this.position.getZ() + 0.5D) > 64.0D ? false : TileEntityLectern.this.hasBook());
|
|
+ return (TileEntityLectern.this.virtual && TileEntityLectern.this.hasBook()) || TileEntityLectern.this.world.getTileEntity(TileEntityLectern.this.position) != TileEntityLectern.this ? false : (entityhuman.g((double) TileEntityLectern.this.position.getX() + 0.5D, (double) TileEntityLectern.this.position.getY() + 0.5D, (double) TileEntityLectern.this.position.getZ() + 0.5D) > 64.0D ? false : TileEntityLectern.this.hasBook());
|
|
}
|
|
|
|
@Override
|
|
@@ -158,6 +163,7 @@ public class TileEntityLectern extends TileEntity implements Clearable, ITileInv
|
|
private ItemStack book;
|
|
private int page;
|
|
private int maxPage;
|
|
+ public boolean virtual = false; // EMC
|
|
|
|
public TileEntityLectern() {
|
|
super(TileEntityTypes.LECTERN);
|
|
@@ -179,6 +185,7 @@ public class TileEntityLectern extends TileEntity implements Clearable, ITileInv
|
|
}
|
|
|
|
private void k() {
|
|
+ if (this.virtual) return; // EMC
|
|
this.page = 0;
|
|
this.maxPage = 0;
|
|
BlockLectern.setHasBook(this.getWorld(), this.getPosition(), this.getBlock(), false);
|
|
@@ -196,6 +203,7 @@ public class TileEntityLectern extends TileEntity implements Clearable, ITileInv
|
|
|
|
if (j != this.page) {
|
|
this.page = j;
|
|
+ if (this.virtual) return; // EMC
|
|
this.update();
|
|
BlockLectern.a(this.getWorld(), this.getPosition(), this.getBlock());
|
|
}
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java
|
|
index 470b3fbe..04c624a2 100644
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftHumanEntity.java
|
|
@@ -331,6 +331,11 @@ public class CraftHumanEntity extends CraftLivingEntity implements HumanEntity {
|
|
if (craft.getInventory() instanceof ITileInventory) {
|
|
iinventory = (ITileInventory) craft.getInventory();
|
|
}
|
|
+ // EMC start
|
|
+ if (craft.getInventory() instanceof TileEntityLectern.LecternInventory) {
|
|
+ iinventory = ((TileEntityLectern.LecternInventory)craft.getInventory()).getLectern();
|
|
+ }
|
|
+ // EMC end
|
|
}
|
|
|
|
if (iinventory instanceof ITileInventory) {
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/util/CraftTileInventoryConverter.java b/src/main/java/org/bukkit/craftbukkit/inventory/util/CraftTileInventoryConverter.java
|
|
index 32b36c70..f0c1d611 100644
|
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/util/CraftTileInventoryConverter.java
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/util/CraftTileInventoryConverter.java
|
|
@@ -126,8 +126,19 @@ public abstract class CraftTileInventoryConverter implements CraftInventoryCreat
|
|
|
|
@Override
|
|
public IInventory getTileEntity() {
|
|
- return new TileEntityLectern().inventory;
|
|
+ // EMC start
|
|
+ TileEntityLectern lectern = new TileEntityLectern();
|
|
+ lectern.virtual = true;
|
|
+ return lectern.inventory;
|
|
+ // EMC end
|
|
}
|
|
+
|
|
+ // EMC start
|
|
+ @Override
|
|
+ public Inventory getInventory(IInventory tileEntity) {
|
|
+ return new org.bukkit.craftbukkit.inventory.CraftInventoryLectern(tileEntity);
|
|
+ }
|
|
+ // EMC end
|
|
}
|
|
|
|
public static class Smoker extends CraftTileInventoryConverter {
|
|
--
|
|
2.25.1.windows.1
|
|
|