2014-04-14 10:40:29 +10:00
|
|
|
From 4c545da88ebd04a32e7cbb0be787afcf2ac083ef Mon Sep 17 00:00:00 2001
|
2013-09-09 14:40:16 +10:00
|
|
|
From: erocs <github@erocs.org>
|
|
|
|
Date: Sun, 8 Sep 2013 12:06:15 -0700
|
2013-06-20 19:44:06 +10:00
|
|
|
Subject: [PATCH] Hopper Cooldowns
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/TileEntityHopper.java b/src/main/java/net/minecraft/server/TileEntityHopper.java
|
2014-03-24 20:36:29 +00:00
|
|
|
index 3f1a910..d7a3178 100644
|
2013-06-20 19:44:06 +10:00
|
|
|
--- a/src/main/java/net/minecraft/server/TileEntityHopper.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/TileEntityHopper.java
|
2014-03-23 00:06:43 +00:00
|
|
|
@@ -189,12 +189,18 @@ public class TileEntityHopper extends TileEntity implements IHopper {
|
|
|
|
}
|
2013-06-20 19:44:06 +10:00
|
|
|
|
|
|
|
if (flag) {
|
|
|
|
- this.c(8);
|
|
|
|
+ this.c(world.spigotConfig.hopperTransfer); // Spigot
|
|
|
|
this.update();
|
|
|
|
return true;
|
|
|
|
}
|
2013-09-09 14:40:16 +10:00
|
|
|
}
|
2014-03-23 00:06:43 +00:00
|
|
|
|
2013-09-09 14:40:16 +10:00
|
|
|
+ // Spigot start
|
2013-12-01 16:00:50 +11:00
|
|
|
+ if ( !this.j() )
|
2013-09-09 14:40:16 +10:00
|
|
|
+ {
|
|
|
|
+ this.c( world.spigotConfig.hopperCheck );
|
|
|
|
+ }
|
|
|
|
+ // Spigot end
|
|
|
|
return false;
|
|
|
|
} else {
|
|
|
|
return false;
|
2014-03-23 00:06:43 +00:00
|
|
|
@@ -260,7 +266,7 @@ public class TileEntityHopper extends TileEntity implements IHopper {
|
|
|
|
this.getWorld().getServer().getPluginManager().callEvent(event);
|
|
|
|
if (event.isCancelled()) {
|
2014-03-24 20:36:29 +00:00
|
|
|
this.setItem(j, itemstack);
|
2014-03-23 00:06:43 +00:00
|
|
|
- this.c(8); // Delay hopper checks
|
|
|
|
+ this.c(world.spigotConfig.hopperTransfer); // Spigot
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
ItemStack itemstack1 = addItem(iinventory, CraftItemStack.asNMSCopy(event.getItem()), i);
|
|
|
|
@@ -396,9 +402,9 @@ public class TileEntityHopper extends TileEntity implements IHopper {
|
2013-06-20 19:44:06 +10:00
|
|
|
iinventory.setItem(i, itemstack1);
|
|
|
|
|
|
|
|
if (ihopper instanceof TileEntityHopper) {
|
|
|
|
- ((TileEntityHopper) ihopper).c(8); // Delay hopper checks
|
|
|
|
+ ((TileEntityHopper) ihopper).c(ihopper.getWorld().spigotConfig.hopperTransfer); // Spigot
|
|
|
|
} else if (ihopper instanceof EntityMinecartHopper) {
|
2013-07-02 13:03:56 +10:00
|
|
|
- ((EntityMinecartHopper) ihopper).l(4); // Delay hopper minecart checks
|
2013-07-02 13:45:51 +10:00
|
|
|
+ ((EntityMinecartHopper) ihopper).l(ihopper.getWorld().spigotConfig.hopperTransfer / 2); // Spigot
|
2013-06-20 19:44:06 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
2014-03-23 00:06:43 +00:00
|
|
|
@@ -502,7 +508,7 @@ public class TileEntityHopper extends TileEntity implements IHopper {
|
2013-06-20 19:44:06 +10:00
|
|
|
|
|
|
|
if (flag) {
|
|
|
|
if (iinventory instanceof TileEntityHopper) {
|
|
|
|
- ((TileEntityHopper) iinventory).c(8);
|
|
|
|
+ ((TileEntityHopper) iinventory).c(((TileEntityHopper) iinventory).world.spigotConfig.hopperTransfer); // Spigot
|
2013-07-02 13:03:56 +10:00
|
|
|
iinventory.update();
|
2013-06-20 19:44:06 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
diff --git a/src/main/java/org/spigotmc/SpigotWorldConfig.java b/src/main/java/org/spigotmc/SpigotWorldConfig.java
|
2014-03-10 09:14:45 +11:00
|
|
|
index 6421bf2..827e6f9 100644
|
2013-06-20 19:44:06 +10:00
|
|
|
--- a/src/main/java/org/spigotmc/SpigotWorldConfig.java
|
|
|
|
+++ b/src/main/java/org/spigotmc/SpigotWorldConfig.java
|
2014-01-14 19:16:43 +11:00
|
|
|
@@ -164,4 +164,17 @@ public class SpigotWorldConfig
|
2014-02-17 12:19:44 +00:00
|
|
|
otherTrackingRange = getInt( "entity-tracking-range.other", otherTrackingRange );
|
|
|
|
log( "Entity Tracking Range: Pl " + playerTrackingRange + " / An " + animalTrackingRange + " / Mo " + monsterTrackingRange + " / Mi " + miscTrackingRange + " / Other " + otherTrackingRange );
|
2013-06-20 19:44:06 +10:00
|
|
|
}
|
|
|
|
+
|
|
|
|
+ public int hopperTransfer = 8;
|
2013-09-09 14:40:16 +10:00
|
|
|
+ public int hopperCheck = 8;
|
2013-06-20 19:44:06 +10:00
|
|
|
+ private void hoppers()
|
|
|
|
+ {
|
2013-09-09 14:40:16 +10:00
|
|
|
+ // Set the tick delay between hopper item movements
|
2013-06-20 19:44:06 +10:00
|
|
|
+ hopperTransfer = getInt( "ticks-per.hopper-transfer", hopperTransfer );
|
2013-09-09 14:40:16 +10:00
|
|
|
+ // Set the tick delay between checking for items after the associated
|
|
|
|
+ // container is empty. Default to the hopperTransfer value to prevent
|
|
|
|
+ // hopper sorting machines from becoming out of sync.
|
|
|
|
+ hopperCheck = getInt( "ticks-per.hopper-check", hopperTransfer );
|
|
|
|
+ log( "Hopper Transfer: " + hopperTransfer + " Hopper Check: " + hopperCheck );
|
2013-06-20 19:44:06 +10:00
|
|
|
+ }
|
|
|
|
}
|
|
|
|
--
|
2014-04-14 10:40:29 +10:00
|
|
|
1.8.3.2
|
2013-06-20 19:44:06 +10:00
|
|
|
|