mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-10 03:52:45 +01:00
SPIGOT-1607: Fix BlockPlaceEvent and BlockMultiPlaceEvent sometimes showing the wrong item used
By: Thinkofdeath <thinkofdeath@spigotmc.org>
This commit is contained in:
parent
8c803cbf66
commit
d0300bb4e0
4 changed files with 24 additions and 10 deletions
|
@ -33,7 +33,7 @@
|
||||||
world.setTypeAndData(blockposition, Blocks.FIRE.getBlockData(), 11);
|
world.setTypeAndData(blockposition, Blocks.FIRE.getBlockData(), 11);
|
||||||
+
|
+
|
||||||
+ // CraftBukkit start
|
+ // CraftBukkit start
|
||||||
+ org.bukkit.event.block.BlockPlaceEvent placeEvent = CraftEventFactory.callBlockPlaceEvent(world, entityhuman, blockState, clicked.getX(), clicked.getY(), clicked.getZ());
|
+ org.bukkit.event.block.BlockPlaceEvent placeEvent = CraftEventFactory.callBlockPlaceEvent(world, entityhuman, enumhand, blockState, clicked.getX(), clicked.getY(), clicked.getZ());
|
||||||
+
|
+
|
||||||
+ if (placeEvent.isCancelled() || !placeEvent.canBuild()) {
|
+ if (placeEvent.isCancelled() || !placeEvent.canBuild()) {
|
||||||
+ placeEvent.getBlockPlaced().setTypeIdAndData(0, (byte) 0, false);
|
+ placeEvent.getBlockPlaced().setTypeIdAndData(0, (byte) 0, false);
|
||||||
|
|
|
@ -97,9 +97,9 @@
|
||||||
+ List<BlockState> blocks = (List<BlockState>) world.capturedBlockStates.clone();
|
+ List<BlockState> blocks = (List<BlockState>) world.capturedBlockStates.clone();
|
||||||
+ world.capturedBlockStates.clear();
|
+ world.capturedBlockStates.clear();
|
||||||
+ if (blocks.size() > 1) {
|
+ if (blocks.size() > 1) {
|
||||||
+ placeEvent = org.bukkit.craftbukkit.event.CraftEventFactory.callBlockMultiPlaceEvent(world, entityhuman, blocks, blockposition.getX(), blockposition.getY(), blockposition.getZ());
|
+ placeEvent = org.bukkit.craftbukkit.event.CraftEventFactory.callBlockMultiPlaceEvent(world, entityhuman, enumhand, blocks, blockposition.getX(), blockposition.getY(), blockposition.getZ());
|
||||||
+ } else if (blocks.size() == 1) {
|
+ } else if (blocks.size() == 1) {
|
||||||
+ placeEvent = org.bukkit.craftbukkit.event.CraftEventFactory.callBlockPlaceEvent(world, entityhuman, blocks.get(0), blockposition.getX(), blockposition.getY(), blockposition.getZ());
|
+ placeEvent = org.bukkit.craftbukkit.event.CraftEventFactory.callBlockPlaceEvent(world, entityhuman, enumhand, blocks.get(0), blockposition.getX(), blockposition.getY(), blockposition.getZ());
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ if (placeEvent != null && (placeEvent.isCancelled() || !placeEvent.canBuild())) {
|
+ if (placeEvent != null && (placeEvent.isCancelled() || !placeEvent.canBuild())) {
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
+ // CraftBukkit start - special case for handling block placement with water lilies
|
+ // CraftBukkit start - special case for handling block placement with water lilies
|
||||||
+ org.bukkit.block.BlockState blockstate = org.bukkit.craftbukkit.block.CraftBlockState.getBlockState(world, blockposition1.getX(), blockposition1.getY(), blockposition1.getZ());
|
+ org.bukkit.block.BlockState blockstate = org.bukkit.craftbukkit.block.CraftBlockState.getBlockState(world, blockposition1.getX(), blockposition1.getY(), blockposition1.getZ());
|
||||||
world.setTypeAndData(blockposition1, Blocks.WATERLILY.getBlockData(), 11);
|
world.setTypeAndData(blockposition1, Blocks.WATERLILY.getBlockData(), 11);
|
||||||
+ org.bukkit.event.block.BlockPlaceEvent placeEvent = org.bukkit.craftbukkit.event.CraftEventFactory.callBlockPlaceEvent(world, entityhuman, blockstate, blockposition.getX(), blockposition.getY(), blockposition.getZ());
|
+ org.bukkit.event.block.BlockPlaceEvent placeEvent = org.bukkit.craftbukkit.event.CraftEventFactory.callBlockPlaceEvent(world, entityhuman, enumhand, blockstate, blockposition.getX(), blockposition.getY(), blockposition.getZ());
|
||||||
+ if (placeEvent != null && (placeEvent.isCancelled() || !placeEvent.canBuild())) {
|
+ if (placeEvent != null && (placeEvent.isCancelled() || !placeEvent.canBuild())) {
|
||||||
+ blockstate.update(true, false);
|
+ blockstate.update(true, false);
|
||||||
+ return new InteractionResultWrapper(EnumInteractionResult.PASS, itemstack);
|
+ return new InteractionResultWrapper(EnumInteractionResult.PASS, itemstack);
|
||||||
|
|
|
@ -91,10 +91,10 @@ public class CraftEventFactory {
|
||||||
/**
|
/**
|
||||||
* Block place methods
|
* Block place methods
|
||||||
*/
|
*/
|
||||||
public static BlockMultiPlaceEvent callBlockMultiPlaceEvent(World world, EntityHuman who, List<BlockState> blockStates, int clickedX, int clickedY, int clickedZ) {
|
public static BlockMultiPlaceEvent callBlockMultiPlaceEvent(World world, EntityHuman who, EnumHand hand, List<BlockState> blockStates, int clickedX, int clickedY, int clickedZ) {
|
||||||
CraftWorld craftWorld = world.getWorld();
|
CraftWorld craftWorld = world.getWorld();
|
||||||
CraftServer craftServer = world.getServer();
|
CraftServer craftServer = world.getServer();
|
||||||
Player player = (who == null) ? null : (Player) who.getBukkitEntity();
|
Player player = (Player) who.getBukkitEntity();
|
||||||
|
|
||||||
Block blockClicked = craftWorld.getBlockAt(clickedX, clickedY, clickedZ);
|
Block blockClicked = craftWorld.getBlockAt(clickedX, clickedY, clickedZ);
|
||||||
|
|
||||||
|
@ -106,24 +106,38 @@ public class CraftEventFactory {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
BlockMultiPlaceEvent event = new BlockMultiPlaceEvent(blockStates, blockClicked, player.getItemInHand(), player, canBuild);
|
org.bukkit.inventory.ItemStack item;
|
||||||
|
if (hand == EnumHand.MAIN_HAND) {
|
||||||
|
item = player.getInventory().getItemInMainHand();
|
||||||
|
} else {
|
||||||
|
item = player.getInventory().getItemInOffHand();
|
||||||
|
}
|
||||||
|
|
||||||
|
BlockMultiPlaceEvent event = new BlockMultiPlaceEvent(blockStates, blockClicked, item, player, canBuild);
|
||||||
craftServer.getPluginManager().callEvent(event);
|
craftServer.getPluginManager().callEvent(event);
|
||||||
|
|
||||||
return event;
|
return event;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static BlockPlaceEvent callBlockPlaceEvent(World world, EntityHuman who, BlockState replacedBlockState, int clickedX, int clickedY, int clickedZ) {
|
public static BlockPlaceEvent callBlockPlaceEvent(World world, EntityHuman who, EnumHand hand, BlockState replacedBlockState, int clickedX, int clickedY, int clickedZ) {
|
||||||
CraftWorld craftWorld = world.getWorld();
|
CraftWorld craftWorld = world.getWorld();
|
||||||
CraftServer craftServer = world.getServer();
|
CraftServer craftServer = world.getServer();
|
||||||
|
|
||||||
Player player = (who == null) ? null : (Player) who.getBukkitEntity();
|
Player player = (Player) who.getBukkitEntity();
|
||||||
|
|
||||||
Block blockClicked = craftWorld.getBlockAt(clickedX, clickedY, clickedZ);
|
Block blockClicked = craftWorld.getBlockAt(clickedX, clickedY, clickedZ);
|
||||||
Block placedBlock = replacedBlockState.getBlock();
|
Block placedBlock = replacedBlockState.getBlock();
|
||||||
|
|
||||||
boolean canBuild = canBuild(craftWorld, player, placedBlock.getX(), placedBlock.getZ());
|
boolean canBuild = canBuild(craftWorld, player, placedBlock.getX(), placedBlock.getZ());
|
||||||
|
|
||||||
BlockPlaceEvent event = new BlockPlaceEvent(placedBlock, replacedBlockState, blockClicked, player.getItemInHand(), player, canBuild);
|
org.bukkit.inventory.ItemStack item;
|
||||||
|
if (hand == EnumHand.MAIN_HAND) {
|
||||||
|
item = player.getInventory().getItemInMainHand();
|
||||||
|
} else {
|
||||||
|
item = player.getInventory().getItemInOffHand();
|
||||||
|
}
|
||||||
|
|
||||||
|
BlockPlaceEvent event = new BlockPlaceEvent(placedBlock, replacedBlockState, blockClicked, item, player, canBuild);
|
||||||
craftServer.getPluginManager().callEvent(event);
|
craftServer.getPluginManager().callEvent(event);
|
||||||
|
|
||||||
return event;
|
return event;
|
||||||
|
|
Loading…
Reference in a new issue