2017-07-28 03:39:31 +00:00
|
|
|
From 4e9b597d5c6e078739e0662f73de519766c3926c Mon Sep 17 00:00:00 2001
|
2017-07-27 01:12:40 +00:00
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Wed, 26 Jul 2017 21:12:15 -0400
|
|
|
|
Subject: [PATCH] Fix Recipe Books
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/PlayerConnection.java b/src/main/java/net/minecraft/server/PlayerConnection.java
|
2017-07-28 03:39:31 +00:00
|
|
|
index 682211cdd..0f7e82d27 100644
|
2017-07-27 01:12:40 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/PlayerConnection.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/PlayerConnection.java
|
|
|
|
@@ -2027,12 +2027,6 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
|
|
|
public void a(PacketPlayInAutoRecipe packetplayinautorecipe) {
|
|
|
|
PlayerConnectionUtils.ensureMainThread(packetplayinautorecipe, this, this.player.x());
|
|
|
|
this.player.resetIdleTimer();
|
|
|
|
- // CraftBukkit start
|
|
|
|
- if (!player.getBukkitEntity().hasPermission("minecraft.autocraft")) {
|
|
|
|
- player.getBukkitEntity().updateInventory();
|
|
|
|
- return;
|
|
|
|
- }
|
|
|
|
- // CraftBukkit end
|
|
|
|
if (this.player.activeContainer.windowId == packetplayinautorecipe.a() && this.player.activeContainer.c(this.player)) {
|
|
|
|
this.player.playerConnection.sendPacket(new PacketPlayOutTransaction(packetplayinautorecipe.a(), packetplayinautorecipe.b(), true));
|
|
|
|
Iterator iterator;
|
2017-07-27 07:13:13 +00:00
|
|
|
@@ -2046,7 +2040,11 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
2017-07-27 01:12:40 +00:00
|
|
|
while (iterator.hasNext()) {
|
|
|
|
packetplayinautorecipe_a = (PacketPlayInAutoRecipe.a) iterator.next();
|
|
|
|
itemstack = this.player.activeContainer.getSlot(packetplayinautorecipe_a.b).getItem();
|
|
|
|
- if (this.a(packetplayinautorecipe_a.a, itemstack)) {
|
|
|
|
+ // Paper start - improve validation
|
2017-07-27 07:13:13 +00:00
|
|
|
+ ItemStack to = this.player.inventory.getItem(packetplayinautorecipe_a.c);
|
|
|
|
+ ItemStack ref = packetplayinautorecipe_a.a;
|
|
|
|
+ if (this.a(ref, itemstack) && (to.isEmpty() || this.a(ref, to)) && (ref.getCount() + to.getCount() <= ref.getMaxStackSize())) {
|
2017-07-27 01:12:40 +00:00
|
|
|
+ // Paper end
|
|
|
|
i = packetplayinautorecipe_a.a.getCount();
|
|
|
|
if (packetplayinautorecipe_a.c == -1) {
|
|
|
|
this.player.drop(packetplayinautorecipe_a.a, true);
|
2017-07-27 07:13:13 +00:00
|
|
|
@@ -2066,6 +2064,12 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
2017-07-27 01:12:40 +00:00
|
|
|
itemstack.subtract(i);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
+ // Paper start
|
|
|
|
+ else {
|
|
|
|
+ this.player.getBukkitEntity().updateInventory();
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-07-28 03:39:31 +00:00
|
|
|
@@ -2075,7 +2079,7 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
|
|
|
while (iterator.hasNext()) {
|
|
|
|
packetplayinautorecipe_a = (PacketPlayInAutoRecipe.a) iterator.next();
|
|
|
|
itemstack = this.player.inventory.getItem(packetplayinautorecipe_a.c);
|
|
|
|
- if (this.a(packetplayinautorecipe_a.a, itemstack)) {
|
|
|
|
+ if (this.a(packetplayinautorecipe_a.a, itemstack) && itemstack.getCount() >= packetplayinautorecipe_a.a.getCount()) { // Paper
|
|
|
|
i = packetplayinautorecipe_a.a.getCount();
|
|
|
|
if (itemstack.getCount() == i) {
|
|
|
|
this.player.inventory.splitWithoutUpdate(packetplayinautorecipe_a.c);
|
|
|
|
@@ -2085,6 +2089,12 @@ public class PlayerConnection implements PacketListenerPlayIn, ITickable {
|
|
|
|
|
|
|
|
this.player.activeContainer.b(packetplayinautorecipe_a.b, packetplayinautorecipe_a.a);
|
|
|
|
}
|
|
|
|
+ // Paper start
|
|
|
|
+ else {
|
|
|
|
+ this.player.getBukkitEntity().updateInventory();
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-07-27 01:12:40 +00:00
|
|
|
--
|
|
|
|
2.13.0
|
|
|
|
|