mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-16 06:30:46 +01:00
parent
2fd081ef17
commit
bd2bbe7bf4
2 changed files with 9 additions and 36 deletions
|
@ -23,9 +23,3 @@ c net/minecraft/world/level/chunk/LevelChunk net/minecraft/world/level/chunk/Chu
|
||||||
# Paper changes type
|
# Paper changes type
|
||||||
c net/minecraft/core/MappedRegistry net/minecraft/core/RegistryMaterials
|
c net/minecraft/core/MappedRegistry net/minecraft/core/RegistryMaterials
|
||||||
f Lit/unimi/dsi/fastutil/objects/Reference2IntOpenHashMap; toId bA
|
f Lit/unimi/dsi/fastutil/objects/Reference2IntOpenHashMap; toId bA
|
||||||
|
|
||||||
# We add the getLevel method back to Hopper since mojang removed it - we need the method for hopper optimization
|
|
||||||
# We add the method with this name to match the mojmap method of the same name in BlockEntity
|
|
||||||
# Since we add the method we need to add the mapping for it so reobf works as expected
|
|
||||||
c net/minecraft/world/level/block/entity/Hopper net/minecraft/world/level/block/entity/IHopper
|
|
||||||
m ()Lnet/minecraft/world/level/Level; getLevel W
|
|
||||||
|
|
|
@ -46,24 +46,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
this.profiler.push(() -> {
|
this.profiler.push(() -> {
|
||||||
return worldserver + " " + worldserver.dimension().location();
|
return worldserver + " " + worldserver.dimension().location();
|
||||||
diff --git a/src/main/java/net/minecraft/world/entity/vehicle/MinecartHopper.java b/src/main/java/net/minecraft/world/entity/vehicle/MinecartHopper.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/net/minecraft/world/entity/vehicle/MinecartHopper.java
|
|
||||||
+++ b/src/main/java/net/minecraft/world/entity/vehicle/MinecartHopper.java
|
|
||||||
@@ -0,0 +0,0 @@ public class MinecartHopper extends AbstractMinecartContainer implements Hopper
|
|
||||||
this.enabled = enabled;
|
|
||||||
}
|
|
||||||
|
|
||||||
+ // Paper start - add back getLevel
|
|
||||||
+ @Override
|
|
||||||
+ public net.minecraft.world.level.Level getLevel() {
|
|
||||||
+ return this.level;
|
|
||||||
+ }
|
|
||||||
+ // Paper end
|
|
||||||
+
|
|
||||||
@Override
|
|
||||||
public double getLevelX() {
|
|
||||||
return this.getX();
|
|
||||||
diff --git a/src/main/java/net/minecraft/world/item/ItemStack.java b/src/main/java/net/minecraft/world/item/ItemStack.java
|
diff --git a/src/main/java/net/minecraft/world/item/ItemStack.java b/src/main/java/net/minecraft/world/item/ItemStack.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/world/item/ItemStack.java
|
--- a/src/main/java/net/minecraft/world/item/ItemStack.java
|
||||||
|
@ -112,8 +94,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
return SUCK;
|
return SUCK;
|
||||||
}
|
}
|
||||||
|
|
||||||
+ net.minecraft.world.level.Level getLevel(); // Paper
|
|
||||||
+
|
|
||||||
+ default net.minecraft.core.BlockPos getBlockPosition() { return new net.minecraft.core.BlockPos(getLevelX(), getLevelY(), getLevelZ()); } // Paper
|
+ default net.minecraft.core.BlockPos getBlockPosition() { return new net.minecraft.core.BlockPos(getLevelX(), getLevelY(), getLevelZ()); } // Paper
|
||||||
+
|
+
|
||||||
double getLevelX();
|
double getLevelX();
|
||||||
|
@ -192,11 +172,10 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ return false;
|
+ return false;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ private static boolean hopperPull(Hopper ihopper, Container iinventory, ItemStack origItemStack, int i) {
|
+ private static boolean hopperPull(Level level, Hopper ihopper, Container iinventory, ItemStack origItemStack, int i) {
|
||||||
+ ItemStack itemstack = origItemStack;
|
+ ItemStack itemstack = origItemStack;
|
||||||
+ final int origCount = origItemStack.getCount();
|
+ final int origCount = origItemStack.getCount();
|
||||||
+ final Level world = ihopper.getLevel();
|
+ final int moved = Math.min(level.spigotConfig.hopperAmount, origCount);
|
||||||
+ final int moved = Math.min(world.spigotConfig.hopperAmount, origCount);
|
|
||||||
+ itemstack.setCount(moved);
|
+ itemstack.setCount(moved);
|
||||||
+
|
+
|
||||||
+ if (!skipPullModeEventFire) {
|
+ if (!skipPullModeEventFire) {
|
||||||
|
@ -226,7 +205,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ }
|
+ }
|
||||||
+ origItemStack.setCount(origCount);
|
+ origItemStack.setCount(origCount);
|
||||||
+
|
+
|
||||||
+ if (world.paperConfig.cooldownHopperWhenFull) {
|
+ if (level.paperConfig.cooldownHopperWhenFull) {
|
||||||
+ cooldownHopper(ihopper);
|
+ cooldownHopper(ihopper);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
|
@ -289,10 +268,10 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ private static void cooldownHopper(Hopper hopper) {
|
+ private static void cooldownHopper(Hopper hopper) {
|
||||||
+ if (hopper instanceof HopperBlockEntity) {
|
+ if (hopper instanceof HopperBlockEntity blockEntity) {
|
||||||
+ ((HopperBlockEntity) hopper).setCooldown(hopper.getLevel().spigotConfig.hopperTransfer);
|
+ blockEntity.setCooldown(blockEntity.getLevel().spigotConfig.hopperTransfer);
|
||||||
+ } else if (hopper instanceof MinecartHopper) {
|
+ } else if (hopper instanceof MinecartHopper blockEntity) {
|
||||||
+ ((MinecartHopper) hopper).setCooldown(hopper.getLevel().spigotConfig.hopperTransfer / 2);
|
+ blockEntity.setCooldown(blockEntity.getLevel().spigotConfig.hopperTransfer / 2);
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
|
@ -387,7 +366,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ return !HopperBlockEntity.isEmptyContainer(iinventory, enumdirection) && anyMatch(iinventory, enumdirection, (item, i) -> {
|
+ return !HopperBlockEntity.isEmptyContainer(iinventory, enumdirection) && anyMatch(iinventory, enumdirection, (item, i) -> {
|
||||||
+ // Logic copied from below to avoid extra getItem calls
|
+ // Logic copied from below to avoid extra getItem calls
|
||||||
+ if (!item.isEmpty() && canTakeItemFromContainer(iinventory, item, i, enumdirection)) {
|
+ if (!item.isEmpty() && canTakeItemFromContainer(iinventory, item, i, enumdirection)) {
|
||||||
+ return hopperPull(hopper, iinventory, item, i);
|
+ return hopperPull(world, hopper, iinventory, item, i);
|
||||||
+ } else {
|
+ } else {
|
||||||
+ return false;
|
+ return false;
|
||||||
+ }
|
+ }
|
||||||
|
@ -405,7 +384,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
- if (!itemstack.isEmpty() && HopperBlockEntity.canTakeItemFromContainer(iinventory, itemstack, i, enumdirection)) {
|
- if (!itemstack.isEmpty() && HopperBlockEntity.canTakeItemFromContainer(iinventory, itemstack, i, enumdirection)) {
|
||||||
+ if (!itemstack.isEmpty() && HopperBlockEntity.canTakeItemFromContainer(iinventory, itemstack, i, enumdirection)) { // If this logic changes, update above. this is left inused incase reflective plugins
|
+ if (!itemstack.isEmpty() && HopperBlockEntity.canTakeItemFromContainer(iinventory, itemstack, i, enumdirection)) { // If this logic changes, update above. this is left inused incase reflective plugins
|
||||||
+ return hopperPull(ihopper, iinventory, itemstack, i); /* // Paper - disable rest
|
+ return hopperPull(world, ihopper, iinventory, itemstack, i); /* // Paper - disable rest
|
||||||
ItemStack itemstack1 = itemstack.copy();
|
ItemStack itemstack1 = itemstack.copy();
|
||||||
// ItemStack itemstack2 = addItem(iinventory, ihopper, iinventory.removeItem(i, 1), (EnumDirection) null);
|
// ItemStack itemstack2 = addItem(iinventory, ihopper, iinventory.removeItem(i, 1), (EnumDirection) null);
|
||||||
// CraftBukkit start - Call event on collection of items from inventories into the hopper
|
// CraftBukkit start - Call event on collection of items from inventories into the hopper
|
||||||
|
|
Loading…
Reference in a new issue