From 96e8a799b4cf312d11fc1e7a08ef4601439962dd Mon Sep 17 00:00:00 2001
From: Zach Brown <1254957+zachbr@users.noreply.github.com>
Date: Fri, 22 Jul 2016 18:54:48 -0500
Subject: [PATCH] Push based hoppers cleanup

---
 .../Make-entities-look-for-hoppers.patch       | 18 +++++++++++++++---
 scripts/importmcdev.sh                         |  1 +
 2 files changed, 16 insertions(+), 3 deletions(-)

diff --git a/Spigot-Server-Patches/Make-entities-look-for-hoppers.patch b/Spigot-Server-Patches/Make-entities-look-for-hoppers.patch
index 6d493cf408..f1250e38ac 100644
--- a/Spigot-Server-Patches/Make-entities-look-for-hoppers.patch
+++ b/Spigot-Server-Patches/Make-entities-look-for-hoppers.patch
@@ -49,7 +49,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
 +                     * This operation doesn't work both ways!
 +                     * Make sure you check if the entity's box intersects the hopper's box, not vice versa!
 +                     */
-+                    if (this.getBoundingBox().b(hopperBoundingBox)) {
++                    if (this.getBoundingBox().intersects(hopperBoundingBox)) {
 +                        return hopper;
 +                    }
 +                }
@@ -91,6 +91,18 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
 +        isHopperPushBased = getBoolean("hopper.push-based", true);
 +    }
  }
+diff --git a/src/main/java/net/minecraft/server/AxisAlignedBB.java b/src/main/java/net/minecraft/server/AxisAlignedBB.java
+index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
+--- a/src/main/java/net/minecraft/server/AxisAlignedBB.java
++++ b/src/main/java/net/minecraft/server/AxisAlignedBB.java
+@@ -0,0 +0,0 @@ public class AxisAlignedBB {
+         }
+     }
+ 
++    public final boolean intersects(AxisAlignedBB intersecting) { return this.b(intersecting); }
+     public boolean b(AxisAlignedBB axisalignedbb) {
+         return this.a(axisalignedbb.a, axisalignedbb.b, axisalignedbb.c, axisalignedbb.d, axisalignedbb.e, axisalignedbb.f);
+     }
 diff --git a/src/main/java/net/minecraft/server/BlockPosition.java b/src/main/java/net/minecraft/server/BlockPosition.java
 index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
 --- a/src/main/java/net/minecraft/server/BlockPosition.java
@@ -261,7 +273,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
      }
  
 +    // Paper start
-+    private boolean mayAcceptItems = true;
++    private boolean mayAcceptItems = false;
 +
 +    public boolean canAcceptItems() {
 +        return mayAcceptItems;
@@ -307,7 +319,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
 +        // Paper start - don't search for entities in push mode
 +        World world = getWorld();
 +        return getInventory(world, this.E() + (double) enumdirection.getAdjacentX(), this.F() + (double) enumdirection.getAdjacentY(), this.G() + (double) enumdirection.getAdjacentZ(), !world.paperConfig.isHopperPushBased);
-+        // Paper endtcon
++        // Paper end
      }
  
 -    public static IInventory b(IHopper ihopper) {
diff --git a/scripts/importmcdev.sh b/scripts/importmcdev.sh
index 6e72cf4bc7..9247bc9d95 100755
--- a/scripts/importmcdev.sh
+++ b/scripts/importmcdev.sh
@@ -35,6 +35,7 @@ function import {
 	fi
 )
 
+import AxisAlignedBB
 import BaseBlockPosition
 import BiomeBase
 import BiomeMesa