Mirror von
https://github.com/PaperMC/Paper.git
synchronisiert 2024-12-18 12:30:06 +01:00
SPIGOT-5606: call BlockRedstoneEvent for fence gates
Dieser Commit ist enthalten in:
Ursprung
fc24934098
Commit
a6f809378c
20
nms-patches/BlockFenceGate.patch
Normale Datei
20
nms-patches/BlockFenceGate.patch
Normale Datei
@ -0,0 +1,20 @@
|
|||||||
|
--- a/net/minecraft/server/BlockFenceGate.java
|
||||||
|
+++ b/net/minecraft/server/BlockFenceGate.java
|
||||||
|
@@ -103,6 +103,17 @@
|
||||||
|
public void doPhysics(IBlockData iblockdata, World world, BlockPosition blockposition, Block block, BlockPosition blockposition1, boolean flag) {
|
||||||
|
if (!world.isClientSide) {
|
||||||
|
boolean flag1 = world.isBlockIndirectlyPowered(blockposition);
|
||||||
|
+ // CraftBukkit start
|
||||||
|
+ boolean oldPowered = iblockdata.get(BlockFenceGate.POWERED);
|
||||||
|
+ if (oldPowered != flag1) {
|
||||||
|
+ int newPower = flag1 ? 15 : 0;
|
||||||
|
+ int oldPower = oldPowered ? 15 : 0;
|
||||||
|
+ org.bukkit.block.Block bukkitBlock = org.bukkit.craftbukkit.block.CraftBlock.at(world, blockposition);
|
||||||
|
+ org.bukkit.event.block.BlockRedstoneEvent eventRedstone = new org.bukkit.event.block.BlockRedstoneEvent(bukkitBlock, oldPower, newPower);
|
||||||
|
+ world.getServer().getPluginManager().callEvent(eventRedstone);
|
||||||
|
+ flag1 = eventRedstone.getNewCurrent() > 0;
|
||||||
|
+ }
|
||||||
|
+ // CraftBukkit end
|
||||||
|
|
||||||
|
if ((Boolean) iblockdata.get(BlockFenceGate.POWERED) != flag1) {
|
||||||
|
world.setTypeAndData(blockposition, (IBlockData) ((IBlockData) iblockdata.set(BlockFenceGate.POWERED, flag1)).set(BlockFenceGate.OPEN, flag1), 2);
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren