mirror of
https://github.com/PaperMC/Paper.git
synced 2024-12-22 22:45:31 +01:00
readd fix bee aging patch
This commit is contained in:
parent
ccf158a817
commit
653f0432b5
2 changed files with 41 additions and 51 deletions
41
patches/server/1037-Fix-bees-aging-inside-hives.patch
Normal file
41
patches/server/1037-Fix-bees-aging-inside-hives.patch
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
||||||
|
Date: Sat, 21 Aug 2021 21:54:16 -0700
|
||||||
|
Subject: [PATCH] Fix bees aging inside hives
|
||||||
|
|
||||||
|
Fixes bees incorrectly being aged up due to upstream's
|
||||||
|
resetting the ticks inside hive on a failed release
|
||||||
|
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/level/block/entity/BeehiveBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/BeehiveBlockEntity.java
|
||||||
|
index 6fb7ec36f6f7a3021fac4b9e31fd333dfd5ea5e5..7b263fab4f0014400b3b8e7e33db32f9a125f6ba 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/level/block/entity/BeehiveBlockEntity.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/level/block/entity/BeehiveBlockEntity.java
|
||||||
|
@@ -314,7 +314,7 @@ public class BeehiveBlockEntity extends BlockEntity {
|
||||||
|
iterator.remove();
|
||||||
|
// CraftBukkit start
|
||||||
|
} else {
|
||||||
|
- tileentitybeehive_hivebee.ticksInHive = tileentitybeehive_hivebee.occupant.minTicksInHive / 2; // Not strictly Vanilla behaviour in cases where bees cannot spawn but still reasonable
|
||||||
|
+ tileentitybeehive_hivebee.exitTickCounter = tileentitybeehive_hivebee.occupant.minTicksInHive / 2; // Not strictly Vanilla behaviour in cases where bees cannot spawn but still reasonable // Paper - Fix bees aging inside hives; use exitTickCounter to keep actual bee life
|
||||||
|
// CraftBukkit end
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@@ -474,15 +474,18 @@ public class BeehiveBlockEntity extends BlockEntity {
|
||||||
|
private static class BeeData {
|
||||||
|
|
||||||
|
private final BeehiveBlockEntity.Occupant occupant;
|
||||||
|
+ private int exitTickCounter; // Paper - Fix bees aging inside hives; separate counter for checking if bee should exit to reduce exit attempts
|
||||||
|
private int ticksInHive;
|
||||||
|
|
||||||
|
BeeData(BeehiveBlockEntity.Occupant data) {
|
||||||
|
this.occupant = data;
|
||||||
|
this.ticksInHive = data.ticksInHive();
|
||||||
|
+ this.exitTickCounter = this.ticksInHive; // Paper - Fix bees aging inside hives
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean tick() {
|
||||||
|
- return this.ticksInHive++ > this.occupant.minTicksInHive;
|
||||||
|
+ this.ticksInHive++; // Paper - Fix bees aging inside hives
|
||||||
|
+ return this.exitTickCounter++ > this.occupant.minTicksInHive; // Paper - Fix bees aging inside hives
|
||||||
|
}
|
||||||
|
|
||||||
|
public BeehiveBlockEntity.Occupant toOccupant() {
|
|
@ -1,51 +0,0 @@
|
||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
|
||||||
Date: Sat, 21 Aug 2021 21:54:16 -0700
|
|
||||||
Subject: [PATCH] Fix bees aging inside hives
|
|
||||||
|
|
||||||
Fixes bees incorrectly being aged up due to upstream's
|
|
||||||
resetting the ticks inside hive on a failed release
|
|
||||||
|
|
||||||
TODO: Test if still needed
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/world/level/block/entity/BeehiveBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/BeehiveBlockEntity.java
|
|
||||||
index a69a81ba6a2b65978b5cf00810ed12156a5f89e6..55b0e2bf98a285cdcd30e40d94192b7a1802efd8 100644
|
|
||||||
--- a/src/main/java/net/minecraft/world/level/block/entity/BeehiveBlockEntity.java
|
|
||||||
+++ b/src/main/java/net/minecraft/world/level/block/entity/BeehiveBlockEntity.java
|
|
||||||
@@ -332,7 +332,7 @@ public class BeehiveBlockEntity extends BlockEntity {
|
|
||||||
|
|
||||||
for (Iterator iterator = bees.iterator(); iterator.hasNext(); ++tileentitybeehive_hivebee.ticksInHive) {
|
|
||||||
tileentitybeehive_hivebee = (BeehiveBlockEntity.BeeData) iterator.next();
|
|
||||||
- if (tileentitybeehive_hivebee.ticksInHive > tileentitybeehive_hivebee.minOccupationTicks) {
|
|
||||||
+ if (tileentitybeehive_hivebee.exitTickCounter > tileentitybeehive_hivebee.minOccupationTicks) { // Paper - Fix bees aging inside hives; use exitTickCounter
|
|
||||||
BeehiveBlockEntity.BeeReleaseStatus tileentitybeehive_releasestatus = tileentitybeehive_hivebee.entityData.getBoolean("HasNectar") ? BeehiveBlockEntity.BeeReleaseStatus.HONEY_DELIVERED : BeehiveBlockEntity.BeeReleaseStatus.BEE_RELEASED;
|
|
||||||
|
|
||||||
if (BeehiveBlockEntity.releaseOccupant(world, pos, state, tileentitybeehive_hivebee, (List) null, tileentitybeehive_releasestatus, flowerPos)) {
|
|
||||||
@@ -340,10 +340,11 @@ public class BeehiveBlockEntity extends BlockEntity {
|
|
||||||
iterator.remove();
|
|
||||||
// CraftBukkit start
|
|
||||||
} else {
|
|
||||||
- tileentitybeehive_hivebee.ticksInHive = tileentitybeehive_hivebee.minOccupationTicks / 2; // Not strictly Vanilla behaviour in cases where bees cannot spawn but still reasonable
|
|
||||||
+ tileentitybeehive_hivebee.exitTickCounter = tileentitybeehive_hivebee.minOccupationTicks / 2; // Not strictly Vanilla behaviour in cases where bees cannot spawn but still reasonable // Paper - Fix bees aging inside hives; use exitTickCounter to keep actual bee life
|
|
||||||
// CraftBukkit end
|
|
||||||
}
|
|
||||||
}
|
|
||||||
+ tileentitybeehive_hivebee.exitTickCounter++; // Paper - Fix bees aging inside hives
|
|
||||||
}
|
|
||||||
|
|
||||||
if (flag) {
|
|
||||||
@@ -432,12 +433,14 @@ public class BeehiveBlockEntity extends BlockEntity {
|
|
||||||
|
|
||||||
final CompoundTag entityData;
|
|
||||||
int ticksInHive;
|
|
||||||
+ int exitTickCounter; // Paper - Fix bees aging inside hives; separate counter for checking if bee should exit to reduce exit attempts
|
|
||||||
final int minOccupationTicks;
|
|
||||||
|
|
||||||
BeeData(CompoundTag entityData, int ticksInHive, int minOccupationTicks) {
|
|
||||||
BeehiveBlockEntity.removeIgnoredBeeTags(entityData);
|
|
||||||
this.entityData = entityData;
|
|
||||||
this.ticksInHive = ticksInHive;
|
|
||||||
+ this.exitTickCounter = ticksInHive; // Paper - Fix bees aging inside hives
|
|
||||||
this.minOccupationTicks = minOccupationTicks;
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in a new issue