geforkt von Mirrors/Paper
Correctly handle ElderGuardianAppearanceEvent canceling (#7902)
Dieser Commit ist enthalten in:
Ursprung
44548b8544
Commit
d68c295dc1
@ -4,17 +4,45 @@ Date: Fri, 19 Mar 2021 23:39:09 -0400
|
|||||||
Subject: [PATCH] Add ElderGuardianAppearanceEvent
|
Subject: [PATCH] Add ElderGuardianAppearanceEvent
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/effect/MobEffectUtil.java b/src/main/java/net/minecraft/world/effect/MobEffectUtil.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/effect/MobEffectUtil.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/effect/MobEffectUtil.java
|
||||||
|
@@ -0,0 +0,0 @@ public final class MobEffectUtil {
|
||||||
|
}
|
||||||
|
|
||||||
|
public static List<ServerPlayer> addEffectToPlayersAround(ServerLevel worldserver, @Nullable Entity entity, Vec3 vec3d, double d0, MobEffectInstance mobeffect, int i, org.bukkit.event.entity.EntityPotionEffectEvent.Cause cause) {
|
||||||
|
+ // Paper start
|
||||||
|
+ return addEffectToPlayersAround(worldserver, entity, vec3d, d0, mobeffect, i, cause, null);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public static List<ServerPlayer> addEffectToPlayersAround(ServerLevel worldserver, @Nullable Entity entity, Vec3 vec3d, double d0, MobEffectInstance mobeffect, int i, org.bukkit.event.entity.EntityPotionEffectEvent.Cause cause, @Nullable java.util.function.Predicate<ServerPlayer> playerPredicate) {
|
||||||
|
+ // Paper end
|
||||||
|
// CraftBukkit end
|
||||||
|
MobEffect mobeffectlist = mobeffect.getEffect();
|
||||||
|
List<ServerPlayer> list = worldserver.getPlayers((entityplayer) -> {
|
||||||
|
- return entityplayer.gameMode.isSurvival() && (entity == null || !entity.isAlliedTo((Entity) entityplayer)) && vec3d.closerThan(entityplayer.position(), d0) && (!entityplayer.hasEffect(mobeffectlist) || entityplayer.getEffect(mobeffectlist).getAmplifier() < mobeffect.getAmplifier() || entityplayer.getEffect(mobeffectlist).getDuration() < i);
|
||||||
|
+ // Paper start
|
||||||
|
+ boolean condition = entityplayer.gameMode.isSurvival() && (entity == null || !entity.isAlliedTo((Entity) entityplayer)) && vec3d.closerThan(entityplayer.position(), d0) && (!entityplayer.hasEffect(mobeffectlist) || entityplayer.getEffect(mobeffectlist).getAmplifier() < mobeffect.getAmplifier() || entityplayer.getEffect(mobeffectlist).getDuration() < i);
|
||||||
|
+ if (condition) {
|
||||||
|
+ return playerPredicate == null || playerPredicate.test(entityplayer); // Only test the player AFTER it is true
|
||||||
|
+ } else {
|
||||||
|
+ return false;
|
||||||
|
+ }
|
||||||
|
+ // Paper ned
|
||||||
|
});
|
||||||
|
|
||||||
|
list.forEach((entityplayer) -> {
|
||||||
diff --git a/src/main/java/net/minecraft/world/entity/monster/ElderGuardian.java b/src/main/java/net/minecraft/world/entity/monster/ElderGuardian.java
|
diff --git a/src/main/java/net/minecraft/world/entity/monster/ElderGuardian.java b/src/main/java/net/minecraft/world/entity/monster/ElderGuardian.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/world/entity/monster/ElderGuardian.java
|
--- a/src/main/java/net/minecraft/world/entity/monster/ElderGuardian.java
|
||||||
+++ b/src/main/java/net/minecraft/world/entity/monster/ElderGuardian.java
|
+++ b/src/main/java/net/minecraft/world/entity/monster/ElderGuardian.java
|
||||||
@@ -0,0 +0,0 @@ public class ElderGuardian extends Guardian {
|
@@ -0,0 +0,0 @@ public class ElderGuardian extends Guardian {
|
||||||
List<ServerPlayer> list = MobEffectUtil.addEffectToPlayersAround((ServerLevel) this.level, this, this.position(), 50.0D, mobeffect, 1200, org.bukkit.event.entity.EntityPotionEffectEvent.Cause.ATTACK); // CraftBukkit
|
super.customServerAiStep();
|
||||||
|
if ((this.tickCount + this.getId()) % 1200 == 0) {
|
||||||
|
MobEffectInstance mobeffect = new MobEffectInstance(MobEffects.DIG_SLOWDOWN, 6000, 2);
|
||||||
|
- List<ServerPlayer> list = MobEffectUtil.addEffectToPlayersAround((ServerLevel) this.level, this, this.position(), 50.0D, mobeffect, 1200, org.bukkit.event.entity.EntityPotionEffectEvent.Cause.ATTACK); // CraftBukkit
|
||||||
|
+ List<ServerPlayer> list = MobEffectUtil.addEffectToPlayersAround((ServerLevel) this.level, this, this.position(), 50.0D, mobeffect, 1200, org.bukkit.event.entity.EntityPotionEffectEvent.Cause.ATTACK, (player) -> new io.papermc.paper.event.entity.ElderGuardianAppearanceEvent(getBukkitEntity(), player.getBukkitEntity()).callEvent()); // CraftBukkit // Paper
|
||||||
|
|
||||||
list.forEach((entityplayer) -> {
|
list.forEach((entityplayer) -> {
|
||||||
+ if (new io.papermc.paper.event.entity.ElderGuardianAppearanceEvent(getBukkitEntity(), entityplayer.getBukkitEntity()).callEvent()) { // Paper - Add Guardian Appearance Event
|
|
||||||
entityplayer.connection.send(new ClientboundGameEventPacket(ClientboundGameEventPacket.GUARDIAN_ELDER_EFFECT, this.isSilent() ? 0.0F : 1.0F));
|
entityplayer.connection.send(new ClientboundGameEventPacket(ClientboundGameEventPacket.GUARDIAN_ELDER_EFFECT, this.isSilent() ? 0.0F : 1.0F));
|
||||||
+ } // Paper
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren