aa52bf9e33
Mojang made some changes to priorities in 1.17 and it seems that these changes conflict with the changes made in this patch, which in some cases appears to cause excessive rescheduling of tasks. This, however, is not confirmed as such but seems to be the behavior that we're seeing to cause this issue, if mojang has adopted the changes we suggested, then a good chunk of this patch may be unneeded, but, this needs a much better look than I'm currently able to do
50 lines
3.5 KiB
Diff
50 lines
3.5 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: HexedHero <6012891+HexedHero@users.noreply.github.com>
|
|
Date: Mon, 10 May 2021 16:59:05 +0100
|
|
Subject: [PATCH] Add PufferFishStateChangeEvent
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/animal/Pufferfish.java b/src/main/java/net/minecraft/world/entity/animal/Pufferfish.java
|
|
index 284b7c456bf1130359e139f47754357807e7feb0..1b76e267cd36010a57d31852086dec0585d4bce5 100644
|
|
--- a/src/main/java/net/minecraft/world/entity/animal/Pufferfish.java
|
|
+++ b/src/main/java/net/minecraft/world/entity/animal/Pufferfish.java
|
|
@@ -95,25 +95,39 @@ public class Pufferfish extends AbstractFish {
|
|
public void tick() {
|
|
if (!this.level.isClientSide && this.isAlive() && this.isEffectiveAi()) {
|
|
if (this.inflateCounter > 0) {
|
|
+ boolean increase = true; // Paper - Add PufferFishStateChangeEvent
|
|
if (this.getPuffState() == 0) {
|
|
+ if (new io.papermc.paper.event.entity.PufferFishStateChangeEvent((org.bukkit.entity.PufferFish) getBukkitEntity(), 1).callEvent()) { // Paper - Add PufferFishStateChangeEvent
|
|
this.playSound(SoundEvents.PUFFER_FISH_BLOW_UP, this.getSoundVolume(), this.getVoicePitch());
|
|
this.setPuffState(1);
|
|
+ } else { increase = false; } // Paper - Add PufferFishStateChangeEvent
|
|
} else if (this.inflateCounter > 40 && this.getPuffState() == 1) {
|
|
+ if (new io.papermc.paper.event.entity.PufferFishStateChangeEvent((org.bukkit.entity.PufferFish) getBukkitEntity(), 2).callEvent()) { // Paper - Add PufferFishStateChangeEvent
|
|
this.playSound(SoundEvents.PUFFER_FISH_BLOW_UP, this.getSoundVolume(), this.getVoicePitch());
|
|
this.setPuffState(2);
|
|
+ } else { increase = false; } // Paper - Add PufferFishStateChangeEvent
|
|
}
|
|
|
|
+ if (increase) { // Paper - Add PufferFishStateChangeEvent
|
|
++this.inflateCounter;
|
|
+ } // Paper - Add PufferFishStateChangeEvent
|
|
} else if (this.getPuffState() != 0) {
|
|
+ boolean increase = true; // Paper - Add PufferFishStateChangeEvent
|
|
if (this.deflateTimer > 60 && this.getPuffState() == 2) {
|
|
+ if (new io.papermc.paper.event.entity.PufferFishStateChangeEvent((org.bukkit.entity.PufferFish) getBukkitEntity(), 1).callEvent()) { // Paper - Add PufferFishStateChangeEvent
|
|
this.playSound(SoundEvents.PUFFER_FISH_BLOW_OUT, this.getSoundVolume(), this.getVoicePitch());
|
|
this.setPuffState(1);
|
|
+ } else { increase = false; } // Paper - Add PufferFishStateChangeEvent
|
|
} else if (this.deflateTimer > 100 && this.getPuffState() == 1) {
|
|
+ if (new io.papermc.paper.event.entity.PufferFishStateChangeEvent((org.bukkit.entity.PufferFish) getBukkitEntity(), 0).callEvent()) { // Paper - Add PufferFishStateChangeEvent
|
|
this.playSound(SoundEvents.PUFFER_FISH_BLOW_OUT, this.getSoundVolume(), this.getVoicePitch());
|
|
this.setPuffState(0);
|
|
+ } else { increase = false; } // Paper - Add PufferFishStateChangeEvent
|
|
}
|
|
|
|
+ if (increase) { // Paper - Add PufferFishStateChangeEvent
|
|
++this.deflateTimer;
|
|
+ } // Paper - Add PufferFishStateChangeEvent
|
|
}
|
|
}
|
|
|