mirror of
https://github.com/PaperMC/Paper.git
synced 2024-12-03 13:36:44 +01:00
possible fix for block breaking bug
This commit is contained in:
parent
13f55ce0c8
commit
e53fd1367c
2 changed files with 32 additions and 26 deletions
|
@ -112,7 +112,8 @@ public class ItemInWorldManager {
|
|||
server.getPluginManager().callEvent(event);
|
||||
|
||||
if (event.isCancelled()) {
|
||||
return true;
|
||||
MinecraftServer.a.info("A plugin cancelled the block break event");
|
||||
return false;
|
||||
}
|
||||
}
|
||||
// CraftBukkit end
|
||||
|
|
|
@ -328,7 +328,7 @@ public class NetServerHandler extends NetHandler implements ICommandListener {
|
|||
if (packet14blockdig.e == 0) {
|
||||
// CraftBukkit start
|
||||
if (i1 > this.d.spawnProtection || flag) {
|
||||
if (blockId > 0) {
|
||||
// if (blockId > 0) {
|
||||
BlockDamageEvent event;
|
||||
// If the amount of damage that the player is going to do to the block
|
||||
// is >= 1, then the block is going to break (eg, flowers, torches)
|
||||
|
@ -347,7 +347,10 @@ public class NetServerHandler extends NetHandler implements ICommandListener {
|
|||
if (!event.isCancelled()) {
|
||||
this.e.c.a(i, j, k);
|
||||
}
|
||||
}
|
||||
else {
|
||||
MinecraftServer.a.info("A plugin cancelled the block start break event");
|
||||
}
|
||||
// }
|
||||
}
|
||||
} else if (packet14blockdig.e == 2) {
|
||||
// CraftBukkit start - Get last block that the player hit
|
||||
|
@ -357,31 +360,33 @@ public class NetServerHandler extends NetHandler implements ICommandListener {
|
|||
server.getPluginManager().callEvent(event);
|
||||
if (!event.isCancelled()) {
|
||||
this.e.c.b(i, j, k);
|
||||
} else {
|
||||
MinecraftServer.a.info("A plugin cancelled the block stop break event");
|
||||
}
|
||||
// CraftBukkit end
|
||||
} else if (packet14blockdig.e == 1) {
|
||||
// CraftBukkit start
|
||||
if (i1 > this.d.spawnProtection || flag) {
|
||||
BlockDamageEvent event;
|
||||
// If the amount of damage going to the block plus the current amount
|
||||
// of damage is greater than 1, the block is going to break.
|
||||
if (this.e.c.c + damage >= 1.0F) {
|
||||
// if we are destroying either a redstone wire with a current greater than 0 or
|
||||
// a redstone torch that is on, then we should notify plugins that this block has
|
||||
// returned to a current value of 0 (since it will once the redstone is destroyed)
|
||||
if ((blockId == Block.REDSTONE_WIRE.id && block.getRawData() > 0) || blockId == Block.REDSTONE_TORCH_ON.id) {
|
||||
server.getPluginManager().callEvent( new BlockRedstoneEvent(block, (blockId == Block.REDSTONE_WIRE.id ? block.getRawData() : 15), 0));
|
||||
}
|
||||
event = new BlockDamageEvent(Type.BLOCK_DAMAGED, block, BlockDamageLevel.BROKEN, player);
|
||||
} else {
|
||||
event = new BlockDamageEvent(Type.BLOCK_DAMAGED, block, BlockDamageLevel.DIGGING, player);
|
||||
}
|
||||
server.getPluginManager().callEvent(event);
|
||||
if (event.isCancelled()) {
|
||||
this.e.c.c = 0; // Reset the amount of damage if stopping break.
|
||||
}
|
||||
}
|
||||
// CraftBukkit end
|
||||
// } else if (packet14blockdig.e == 1) {
|
||||
// // CraftBukkit start
|
||||
// if (i1 > this.d.spawnProtection || flag) {
|
||||
// BlockDamageEvent event;
|
||||
// // If the amount of damage going to the block plus the current amount
|
||||
// // of damage is greater than 1, the block is going to break.
|
||||
// if (this.e.c.c + damage >= 1.0F) {
|
||||
// // if we are destroying either a redstone wire with a current greater than 0 or
|
||||
// // a redstone torch that is on, then we should notify plugins that this block has
|
||||
// // returned to a current value of 0 (since it will once the redstone is destroyed)
|
||||
// if ((blockId == Block.REDSTONE_WIRE.id && block.getRawData() > 0) || blockId == Block.REDSTONE_TORCH_ON.id) {
|
||||
// server.getPluginManager().callEvent( new BlockRedstoneEvent(block, (blockId == Block.REDSTONE_WIRE.id ? block.getRawData() : 15), 0));
|
||||
// }
|
||||
// event = new BlockDamageEvent(Type.BLOCK_DAMAGED, block, BlockDamageLevel.BROKEN, player);
|
||||
// } else {
|
||||
// event = new BlockDamageEvent(Type.BLOCK_DAMAGED, block, BlockDamageLevel.DIGGING, player);
|
||||
// }
|
||||
// server.getPluginManager().callEvent(event);
|
||||
// if (event.isCancelled()) {
|
||||
// this.e.c.c = 0; // Reset the amount of damage if stopping break.
|
||||
// }
|
||||
// }
|
||||
// // CraftBukkit end
|
||||
} else if (packet14blockdig.e == 3) {
|
||||
double d4 = this.e.locX - ((double) i + 0.5D);
|
||||
double d5 = this.e.locY - ((double) j + 0.5D);
|
||||
|
|
Loading…
Reference in a new issue