mirror of
https://github.com/PaperMC/Folia.git
synced 2024-11-21 11:55:11 +01:00
Fix off region raid heroes
This commit is contained in:
parent
f15f1ceab5
commit
be3c9e596e
43
patches/server/0032-Fix-off-region-raid-heroes.patch
Normal file
43
patches/server/0032-Fix-off-region-raid-heroes.patch
Normal file
@ -0,0 +1,43 @@
|
||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||
From: WillQi <williamqipizza@gmail.com>
|
||||
Date: Mon, 15 May 2023 23:45:09 -0600
|
||||
Subject: [PATCH] Fix off region raid heroes
|
||||
|
||||
This patch aims to solve a potential incorrect thread call when completing a raid.
|
||||
If a player is a hero of the village but proceeds to leave the region of the
|
||||
raid before it's completion, it would throw an exception due to not being on the
|
||||
same region thread anymore.
|
||||
|
||||
diff --git a/src/main/java/net/minecraft/world/entity/raid/Raid.java b/src/main/java/net/minecraft/world/entity/raid/Raid.java
|
||||
index 359f1690497eac00899eb26c17308e0a6fe943ad..66af0e067abdcea8b4116c23c6adb45aeeec0273 100644
|
||||
--- a/src/main/java/net/minecraft/world/entity/raid/Raid.java
|
||||
+++ b/src/main/java/net/minecraft/world/entity/raid/Raid.java
|
||||
@@ -407,12 +407,25 @@ public class Raid {
|
||||
if (entity instanceof LivingEntity && !entity.isSpectator()) {
|
||||
LivingEntity entityliving = (LivingEntity) entity;
|
||||
|
||||
- entityliving.addEffect(new MobEffectInstance(MobEffects.HERO_OF_THE_VILLAGE, 48000, this.badOmenLevel - 1, false, false, true));
|
||||
+ // Folia start - Fix off region raid heroes
|
||||
+ entityliving.getBukkitLivingEntity().taskScheduler.schedule(task -> {
|
||||
+ entityliving.addEffect(new MobEffectInstance(MobEffects.HERO_OF_THE_VILLAGE, 48000, this.badOmenLevel - 1, false, false, true));
|
||||
+
|
||||
+ if (entityliving instanceof ServerPlayer) {
|
||||
+ ServerPlayer entityplayer = (ServerPlayer) entityliving;
|
||||
+
|
||||
+ entityplayer.awardStat(Stats.RAID_WIN);
|
||||
+ CriteriaTriggers.RAID_WIN.trigger(entityplayer);
|
||||
+ }
|
||||
+ }, null, 0);
|
||||
+ // Folia end
|
||||
if (entityliving instanceof ServerPlayer) {
|
||||
ServerPlayer entityplayer = (ServerPlayer) entityliving;
|
||||
|
||||
- entityplayer.awardStat(Stats.RAID_WIN);
|
||||
- CriteriaTriggers.RAID_WIN.trigger(entityplayer);
|
||||
+ // Folia start - Fix off region raid heroes
|
||||
+ // entityplayer.awardStat(Stats.RAID_WIN);
|
||||
+ // CriteriaTriggers.RAID_WIN.trigger(entityplayer);
|
||||
+ // Folia end
|
||||
winners.add(entityplayer.getBukkitEntity()); // CraftBukkit
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user