2021-06-11 07:00:00 +02:00
|
|
|
--- a/net/minecraft/world/level/block/LightningRodBlock.java
|
|
|
|
+++ b/net/minecraft/world/level/block/LightningRodBlock.java
|
2023-12-05 17:40:00 +01:00
|
|
|
@@ -33,6 +33,11 @@
|
2021-06-11 07:00:00 +02:00
|
|
|
import net.minecraft.world.phys.MovingObjectPositionBlock;
|
|
|
|
import net.minecraft.world.phys.Vec3D;
|
|
|
|
|
|
|
|
+// CraftBukkit start
|
|
|
|
+import org.bukkit.craftbukkit.block.CraftBlock;
|
|
|
|
+import org.bukkit.event.block.BlockRedstoneEvent;
|
|
|
|
+// CraftBukkit end
|
|
|
|
+
|
|
|
|
public class LightningRodBlock extends RodBlock implements IBlockWaterlogged {
|
|
|
|
|
2023-12-05 17:40:00 +01:00
|
|
|
public static final MapCodec<LightningRodBlock> CODEC = simpleCodec(LightningRodBlock::new);
|
|
|
|
@@ -85,6 +90,18 @@
|
2021-06-11 07:00:00 +02:00
|
|
|
}
|
|
|
|
|
2021-11-21 23:00:00 +01:00
|
|
|
public void onLightningStrike(IBlockData iblockdata, World world, BlockPosition blockposition) {
|
2021-06-11 07:00:00 +02:00
|
|
|
+ // CraftBukkit start
|
2021-11-21 23:00:00 +01:00
|
|
|
+ boolean powered = iblockdata.getValue(LightningRodBlock.POWERED);
|
2021-06-11 07:00:00 +02:00
|
|
|
+ int old = (powered) ? 15 : 0;
|
|
|
|
+ int current = (!powered) ? 15 : 0;
|
|
|
|
+
|
|
|
|
+ BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(CraftBlock.at(world, blockposition), old, current);
|
2021-06-11 13:33:49 +02:00
|
|
|
+ world.getCraftServer().getPluginManager().callEvent(eventRedstone);
|
2021-06-11 07:00:00 +02:00
|
|
|
+
|
|
|
|
+ if (eventRedstone.getNewCurrent() <= 0) {
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ // CraftBukkit end
|
2021-11-21 23:00:00 +01:00
|
|
|
world.setBlock(blockposition, (IBlockData) iblockdata.setValue(LightningRodBlock.POWERED, true), 3);
|
|
|
|
this.updateNeighbours(iblockdata, world, blockposition);
|
|
|
|
world.scheduleTick(blockposition, (Block) this, 8);
|
2023-12-05 17:40:00 +01:00
|
|
|
@@ -142,7 +159,7 @@
|
2022-12-07 17:00:00 +01:00
|
|
|
Entity entity = iprojectile.getOwner();
|
|
|
|
|
|
|
|
entitylightning.setCause(entity instanceof EntityPlayer ? (EntityPlayer) entity : null);
|
|
|
|
- world.addFreshEntity(entitylightning);
|
|
|
|
+ ((WorldServer) world).strikeLightning(entitylightning, org.bukkit.event.weather.LightningStrikeEvent.Cause.TRIDENT); // CraftBukkit
|
|
|
|
}
|
2021-06-11 07:00:00 +02:00
|
|
|
|
|
|
|
world.playSound((EntityHuman) null, blockposition, SoundEffects.TRIDENT_THUNDER, SoundCategory.WEATHER, 5.0F, 1.0F);
|