mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-05 15:57:35 +01:00
Fix two beacon bugs (#9675)
This commit is contained in:
parent
ba0e1f54b9
commit
a856073368
@ -60,6 +60,12 @@ https://bugs.mojang.com/browse/MC-225381
|
|||||||
https://bugs.mojang.com/browse/MC-173303
|
https://bugs.mojang.com/browse/MC-173303
|
||||||
Fix leashed pets teleporting to owner when loaded
|
Fix leashed pets teleporting to owner when loaded
|
||||||
|
|
||||||
|
https://bugs.mojang.com/browse/MC-174630
|
||||||
|
Fix secondary beacon effect remaining after switching effect
|
||||||
|
|
||||||
|
https://bugs.mojang.com/browse/MC-153086
|
||||||
|
Fix the beacon deactivation sound always playing when broken
|
||||||
|
|
||||||
== AT ==
|
== AT ==
|
||||||
public net/minecraft/world/entity/Mob leashInfoTag
|
public net/minecraft/world/entity/Mob leashInfoTag
|
||||||
|
|
||||||
@ -338,6 +344,22 @@ index 380afb885e85e4cf80e746d217033345a7514443..41457c9f27b18fa2734a6cca297ec518
|
|||||||
if (!raid.hasFirstWaveSpawned()) {
|
if (!raid.hasFirstWaveSpawned()) {
|
||||||
player.awardStat(Stats.RAID_TRIGGER);
|
player.awardStat(Stats.RAID_TRIGGER);
|
||||||
CriteriaTriggers.BAD_OMEN.trigger(player);
|
CriteriaTriggers.BAD_OMEN.trigger(player);
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/inventory/BeaconMenu.java b/src/main/java/net/minecraft/world/inventory/BeaconMenu.java
|
||||||
|
index 335d0a85378c04dd466fafd42048b2474c815cb9..f984af71fc034e09147fa339bd5f260a7466e127 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/inventory/BeaconMenu.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/inventory/BeaconMenu.java
|
||||||
|
@@ -167,6 +167,11 @@ public class BeaconMenu extends AbstractContainerMenu {
|
||||||
|
// Paper end
|
||||||
|
|
||||||
|
public void updateEffects(Optional<MobEffect> primary, Optional<MobEffect> secondary) {
|
||||||
|
+ // Paper start - fix MC-174630 - validate secondary power
|
||||||
|
+ if (secondary.isPresent() && secondary.get() != net.minecraft.world.effect.MobEffects.REGENERATION && (primary.isPresent() && secondary.get() != primary.get())) {
|
||||||
|
+ secondary = Optional.empty();
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
if (this.paymentSlot.hasItem()) {
|
||||||
|
// Paper start
|
||||||
|
io.papermc.paper.event.player.PlayerChangeBeaconEffectEvent event = new io.papermc.paper.event.player.PlayerChangeBeaconEffectEvent((org.bukkit.entity.Player) this.player.player.getBukkitEntity(), convert(primary), convert(secondary), this.access.getLocation().getBlock());
|
||||||
diff --git a/src/main/java/net/minecraft/world/item/BundleItem.java b/src/main/java/net/minecraft/world/item/BundleItem.java
|
diff --git a/src/main/java/net/minecraft/world/item/BundleItem.java b/src/main/java/net/minecraft/world/item/BundleItem.java
|
||||||
index 10b0720ce7eed58fa3cd8c8051efa6225f7d73e1..ac0bc87f60c4e1562d1301522183e449558d42f8 100644
|
index 10b0720ce7eed58fa3cd8c8051efa6225f7d73e1..ac0bc87f60c4e1562d1301522183e449558d42f8 100644
|
||||||
--- a/src/main/java/net/minecraft/world/item/BundleItem.java
|
--- a/src/main/java/net/minecraft/world/item/BundleItem.java
|
||||||
@ -424,3 +446,19 @@ index 436290eaa0dab05a642b67b265117dbe5eceb8b7..5ccc419b904aec590c5624438da61ca6
|
|||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java
|
||||||
|
index 147e808c7e2b3ed16861c989c1ba4a0b99a5be38..2b3bb4513557e8d81bf2b0a3e10c34cec6a6d43e 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java
|
||||||
|
@@ -282,7 +282,11 @@ public class BeaconBlockEntity extends BlockEntity implements MenuProvider, Name
|
||||||
|
org.bukkit.block.Block block = org.bukkit.craftbukkit.block.CraftBlock.at(level, worldPosition);
|
||||||
|
new io.papermc.paper.event.block.BeaconDeactivatedEvent(block).callEvent();
|
||||||
|
// Paper end
|
||||||
|
+ // Paper start - fix MC-153086
|
||||||
|
+ if (this.levels > 0 && !this.beamSections.isEmpty()) {
|
||||||
|
BeaconBlockEntity.playSound(this.level, this.worldPosition, SoundEvents.BEACON_DEACTIVATE);
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
super.setRemoved();
|
||||||
|
}
|
||||||
|
|
||||||
|
@ -56,10 +56,10 @@ index f1acd19432877a833f0d4339f9de4830a0f7b890..8d38ebfdc976b9695ed367591e58de8c
|
|||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
diff --git a/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java
|
diff --git a/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java
|
||||||
index 147e808c7e2b3ed16861c989c1ba4a0b99a5be38..59246e24558569f7f50b4d4d508616798091c888 100644
|
index 2b3bb4513557e8d81bf2b0a3e10c34cec6a6d43e..c343ae1999672be8be0c982df2fadca8d05ebfa4 100644
|
||||||
--- a/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java
|
--- a/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java
|
||||||
+++ b/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java
|
+++ b/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java
|
||||||
@@ -444,7 +444,7 @@ public class BeaconBlockEntity extends BlockEntity implements MenuProvider, Name
|
@@ -448,7 +448,7 @@ public class BeaconBlockEntity extends BlockEntity implements MenuProvider, Name
|
||||||
@Nullable
|
@Nullable
|
||||||
@Override
|
@Override
|
||||||
public AbstractContainerMenu createMenu(int syncId, Inventory playerInventory, Player player) {
|
public AbstractContainerMenu createMenu(int syncId, Inventory playerInventory, Player player) {
|
||||||
|
@ -7,10 +7,10 @@ For larger ranges, it's better to iterate over the player list
|
|||||||
than the entity slices.
|
than the entity slices.
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java
|
diff --git a/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java
|
||||||
index 59246e24558569f7f50b4d4d508616798091c888..3b866e2c20ee7bfc981ff09b29065530de993778 100644
|
index c343ae1999672be8be0c982df2fadca8d05ebfa4..5c951ef93fe4cf4f085df86b0cefc02bc2610ab9 100644
|
||||||
--- a/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java
|
--- a/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java
|
||||||
+++ b/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java
|
+++ b/src/main/java/net/minecraft/world/level/block/entity/BeaconBlockEntity.java
|
||||||
@@ -316,7 +316,16 @@ public class BeaconBlockEntity extends BlockEntity implements MenuProvider, Name
|
@@ -320,7 +320,16 @@ public class BeaconBlockEntity extends BlockEntity implements MenuProvider, Name
|
||||||
double d0 = blockEntity != null ? blockEntity.getEffectRange() : (i * 10 + 10);// Paper - custom beacon ranges
|
double d0 = blockEntity != null ? blockEntity.getEffectRange() : (i * 10 + 10);// Paper - custom beacon ranges
|
||||||
|
|
||||||
AABB axisalignedbb = (new AABB(blockposition)).inflate(d0).expandTowards(0.0D, (double) world.getHeight(), 0.0D);
|
AABB axisalignedbb = (new AABB(blockposition)).inflate(d0).expandTowards(0.0D, (double) world.getHeight(), 0.0D);
|
||||||
|
Loading…
Reference in New Issue
Block a user