aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0951-Fix-NPE-in-SculkBloomEvent-world-access.patch
diff options
context:
space:
mode:
authorTonytheMacaroni <[email protected]>2024-03-20 17:33:34 -0400
committerGitHub <[email protected]>2024-03-20 22:33:34 +0100
commit41ffa0cf8c26f6137a0d21d45067fee6d5896edf (patch)
treee69ade6383d83730724af6dff5145093716c9529 /patches/server/0951-Fix-NPE-in-SculkBloomEvent-world-access.patch
parentde620b8480372e2896633f36e04e15dd01443265 (diff)
downloadPaper-41ffa0cf8c26f6137a0d21d45067fee6d5896edf.tar.gz
Paper-41ffa0cf8c26f6137a0d21d45067fee6d5896edf.zip
Expose power on fireballs (#10302)
Diffstat (limited to 'patches/server/0951-Fix-NPE-in-SculkBloomEvent-world-access.patch')
-rw-r--r--patches/server/0951-Fix-NPE-in-SculkBloomEvent-world-access.patch43
1 files changed, 43 insertions, 0 deletions
diff --git a/patches/server/0951-Fix-NPE-in-SculkBloomEvent-world-access.patch b/patches/server/0951-Fix-NPE-in-SculkBloomEvent-world-access.patch
new file mode 100644
index 0000000000..b66e61a522
--- /dev/null
+++ b/patches/server/0951-Fix-NPE-in-SculkBloomEvent-world-access.patch
@@ -0,0 +1,43 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Lulu13022002 <[email protected]>
+Date: Fri, 20 Oct 2023 19:50:22 +0200
+Subject: [PATCH] Fix NPE in SculkBloomEvent world access
+
+
+diff --git a/src/main/java/net/minecraft/world/level/block/entity/SculkCatalystBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/SculkCatalystBlockEntity.java
+index ccb1db9649dfded891b308c346a6aeb870b61ce2..83481539e058e5f428d9951e409fed62ef159e5c 100644
+--- a/src/main/java/net/minecraft/world/level/block/entity/SculkCatalystBlockEntity.java
++++ b/src/main/java/net/minecraft/world/level/block/entity/SculkCatalystBlockEntity.java
+@@ -32,9 +32,16 @@ public class SculkCatalystBlockEntity extends BlockEntity implements GameEventLi
+ public SculkCatalystBlockEntity(BlockPos pos, BlockState state) {
+ super(BlockEntityType.SCULK_CATALYST, pos, state);
+ this.catalystListener = new SculkCatalystBlockEntity.CatalystListener(state, new BlockPositionSource(pos));
+- this.catalystListener.level = this.level; // CraftBukkit
+ }
+
++ // Paper start - Fix NPE in SculkBloomEvent world access
++ @Override
++ public void setLevel(Level level) {
++ super.setLevel(level);
++ this.catalystListener.sculkSpreader.level = level;
++ }
++ // Paper end - Fix NPE in SculkBloomEvent world access
++
+ public static void serverTick(Level world, BlockPos pos, BlockState state, SculkCatalystBlockEntity blockEntity) {
+ org.bukkit.craftbukkit.event.CraftEventFactory.sourceBlockOverride = blockEntity.getBlockPos(); // CraftBukkit - SPIGOT-7068: Add source block override, not the most elegant way but better than passing down a BlockPosition up to five methods deep.
+ blockEntity.catalystListener.getSculkSpreader().updateCursors(world, pos, world.getRandom(), true);
+@@ -64,13 +71,12 @@ public class SculkCatalystBlockEntity extends BlockEntity implements GameEventLi
+ final SculkSpreader sculkSpreader;
+ private final BlockState blockState;
+ private final PositionSource positionSource;
+- private Level level; // CraftBukkit
+
+ public CatalystListener(BlockState state, PositionSource positionSource) {
+ this.blockState = state;
+ this.positionSource = positionSource;
+ this.sculkSpreader = SculkSpreader.createLevelSpreader();
+- this.sculkSpreader.level = this.level; // CraftBukkit
++ // this.sculkSpreader.level = this.level; // CraftBukkit // Paper - Fix NPE in SculkBloomEvent world access
+ }
+
+ @Override