2024-12-11 22:26:55 +01:00
|
|
|
--- a/net/minecraft/world/entity/AgeableMob.java
|
|
|
|
+++ b/net/minecraft/world/entity/AgeableMob.java
|
2024-12-16 14:08:25 +01:00
|
|
|
@@ -20,6 +_,7 @@
|
2024-12-11 22:26:55 +01:00
|
|
|
protected int age;
|
|
|
|
protected int forcedAge;
|
|
|
|
protected int forcedAgeTimer;
|
|
|
|
+ public boolean ageLocked; // CraftBukkit
|
|
|
|
|
2024-12-14 13:05:27 +01:00
|
|
|
protected AgeableMob(EntityType<? extends AgeableMob> entityType, Level level) {
|
|
|
|
super(entityType, level);
|
|
|
|
@@ -66,6 +_,7 @@
|
2018-09-23 20:59:53 -05:00
|
|
|
}
|
|
|
|
|
2024-12-14 13:05:27 +01:00
|
|
|
public void ageUp(int amount, boolean forced) {
|
2018-09-23 20:59:53 -05:00
|
|
|
+ if (this.ageLocked) return; // Paper - Honor ageLock
|
2024-12-14 13:05:27 +01:00
|
|
|
int age = this.getAge();
|
|
|
|
age += amount * 20;
|
|
|
|
if (age > 0) {
|
|
|
|
@@ -104,6 +_,7 @@
|
2024-12-14 16:08:25 +01:00
|
|
|
super.addAdditionalSaveData(compound);
|
|
|
|
compound.putInt("Age", this.getAge());
|
|
|
|
compound.putInt("ForcedAge", this.forcedAge);
|
|
|
|
+ compound.putBoolean("AgeLocked", this.ageLocked); // CraftBukkit
|
2024-12-11 22:26:55 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2024-12-14 13:05:27 +01:00
|
|
|
@@ -111,6 +_,7 @@
|
2024-12-14 16:08:25 +01:00
|
|
|
super.readAdditionalSaveData(compound);
|
|
|
|
this.setAge(compound.getInt("Age"));
|
|
|
|
this.forcedAge = compound.getInt("ForcedAge");
|
|
|
|
+ this.ageLocked = compound.getBoolean("AgeLocked"); // CraftBukkit
|
2024-12-11 22:26:55 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2024-12-14 13:05:27 +01:00
|
|
|
@@ -125,7 +_,7 @@
|
2024-12-11 22:26:55 +01:00
|
|
|
@Override
|
|
|
|
public void aiStep() {
|
|
|
|
super.aiStep();
|
|
|
|
- if (this.level().isClientSide) {
|
|
|
|
+ if (this.level().isClientSide || this.ageLocked) { // CraftBukkit
|
|
|
|
if (this.forcedAgeTimer > 0) {
|
|
|
|
if (this.forcedAgeTimer % 4 == 0) {
|
2024-12-14 13:05:27 +01:00
|
|
|
this.level().addParticle(ParticleTypes.HAPPY_VILLAGER, this.getRandomX(1.0), this.getRandomY() + 0.5, this.getRandomZ(1.0), 0.0, 0.0, 0.0);
|