2021-03-15 23:00:00 +01:00
|
|
|
--- a/net/minecraft/world/item/ItemBlock.java
|
|
|
|
+++ b/net/minecraft/world/item/ItemBlock.java
|
2021-11-21 23:00:00 +01:00
|
|
|
@@ -33,6 +33,13 @@
|
2021-06-11 07:00:00 +02:00
|
|
|
import net.minecraft.world.level.gameevent.GameEvent;
|
2021-03-15 23:00:00 +01:00
|
|
|
import net.minecraft.world.phys.shapes.VoxelShapeCollision;
|
2021-03-08 22:47:33 +01:00
|
|
|
|
2018-07-15 02:00:00 +02:00
|
|
|
+// CraftBukkit start
|
2021-03-15 23:00:00 +01:00
|
|
|
+import net.minecraft.server.level.WorldServer;
|
2018-07-15 02:00:00 +02:00
|
|
|
+import org.bukkit.craftbukkit.block.CraftBlock;
|
|
|
|
+import org.bukkit.craftbukkit.block.data.CraftBlockData;
|
|
|
|
+import org.bukkit.event.block.BlockCanBuildEvent;
|
|
|
|
+// CraftBukkit end
|
2021-03-08 22:47:33 +01:00
|
|
|
+
|
2018-07-15 02:00:00 +02:00
|
|
|
public class ItemBlock extends Item {
|
|
|
|
|
2021-11-21 23:00:00 +01:00
|
|
|
private static final String BLOCK_ENTITY_TAG = "BlockEntityTag";
|
|
|
|
@@ -68,6 +75,12 @@
|
2020-07-04 01:02:19 +02:00
|
|
|
return EnumInteractionResult.FAIL;
|
|
|
|
} else {
|
2021-11-21 23:00:00 +01:00
|
|
|
IBlockData iblockdata = this.getPlacementState(blockactioncontext1);
|
2021-07-18 02:06:38 +02:00
|
|
|
+ // CraftBukkit start - special case for handling block placement with water lilies and snow buckets
|
2020-07-04 01:02:19 +02:00
|
|
|
+ org.bukkit.block.BlockState blockstate = null;
|
2021-07-18 02:06:38 +02:00
|
|
|
+ if (this instanceof ItemWaterLily || this instanceof SolidBucketItem) {
|
2021-11-21 23:00:00 +01:00
|
|
|
+ blockstate = org.bukkit.craftbukkit.block.CraftBlockStates.getBlockState(blockactioncontext1.getLevel(), blockactioncontext1.getClickedPos());
|
2020-07-04 01:02:19 +02:00
|
|
|
+ }
|
|
|
|
+ // CraftBukkit end
|
|
|
|
|
|
|
|
if (iblockdata == null) {
|
|
|
|
return EnumInteractionResult.FAIL;
|
2021-11-21 23:00:00 +01:00
|
|
|
@@ -84,6 +97,19 @@
|
|
|
|
iblockdata1 = this.updateBlockStateFromTag(blockposition, world, itemstack, iblockdata1);
|
|
|
|
this.updateCustomBlockEntityTag(blockposition, world, entityhuman, itemstack, iblockdata1);
|
|
|
|
iblockdata1.getBlock().setPlacedBy(world, blockposition, iblockdata1, entityhuman, itemstack);
|
2020-07-04 01:02:19 +02:00
|
|
|
+ // CraftBukkit start
|
|
|
|
+ if (blockstate != null) {
|
|
|
|
+ org.bukkit.event.block.BlockPlaceEvent placeEvent = org.bukkit.craftbukkit.event.CraftEventFactory.callBlockPlaceEvent((WorldServer) world, entityhuman, blockactioncontext1.getHand(), blockstate, blockposition.getX(), blockposition.getY(), blockposition.getZ());
|
|
|
|
+ if (placeEvent != null && (placeEvent.isCancelled() || !placeEvent.canBuild())) {
|
|
|
|
+ blockstate.update(true, false);
|
2021-07-18 02:06:38 +02:00
|
|
|
+
|
|
|
|
+ if (this instanceof SolidBucketItem) {
|
|
|
|
+ ((EntityPlayer) entityhuman).getBukkitEntity().updateInventory(); // SPIGOT-4541
|
|
|
|
+ }
|
2020-07-04 01:02:19 +02:00
|
|
|
+ return EnumInteractionResult.FAIL;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ // CraftBukkit end
|
|
|
|
if (entityhuman instanceof EntityPlayer) {
|
2021-11-21 23:00:00 +01:00
|
|
|
CriterionTriggers.PLACED_BLOCK.trigger((EntityPlayer) entityhuman, blockposition, itemstack);
|
2020-07-04 01:02:19 +02:00
|
|
|
}
|
2021-11-21 23:00:00 +01:00
|
|
|
@@ -91,9 +117,9 @@
|
2016-06-30 07:39:58 +02:00
|
|
|
|
2021-11-21 23:00:00 +01:00
|
|
|
SoundEffectType soundeffecttype = iblockdata1.getSoundType();
|
2018-07-15 02:00:00 +02:00
|
|
|
|
2021-11-21 23:00:00 +01:00
|
|
|
- world.playSound(entityhuman, blockposition, this.getPlaceSound(iblockdata1), SoundCategory.BLOCKS, (soundeffecttype.getVolume() + 1.0F) / 2.0F, soundeffecttype.getPitch() * 0.8F);
|
|
|
|
+ // world.playSound(entityhuman, blockposition, this.getPlaceSound(iblockdata1), SoundCategory.BLOCKS, (soundeffecttype.getVolume() + 1.0F) / 2.0F, soundeffecttype.getPitch() * 0.8F);
|
|
|
|
world.gameEvent(entityhuman, GameEvent.BLOCK_PLACE, blockposition);
|
2021-06-11 07:00:00 +02:00
|
|
|
- if (entityhuman == null || !entityhuman.getAbilities().instabuild) {
|
|
|
|
+ if ((entityhuman == null || !entityhuman.getAbilities().instabuild) && itemstack != ItemStack.EMPTY) { // CraftBukkit
|
2021-11-21 23:00:00 +01:00
|
|
|
itemstack.shrink(1);
|
2020-06-25 02:00:00 +02:00
|
|
|
}
|
2020-08-09 10:42:07 +02:00
|
|
|
|
2021-11-21 23:00:00 +01:00
|
|
|
@@ -129,6 +155,21 @@
|
2019-07-09 02:47:07 +02:00
|
|
|
|
|
|
|
if (nbttagcompound != null) {
|
|
|
|
NBTTagCompound nbttagcompound1 = nbttagcompound.getCompound("BlockStateTag");
|
|
|
|
+ // CraftBukkit start
|
|
|
|
+ iblockdata1 = getBlockState(iblockdata1, nbttagcompound1);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (iblockdata1 != iblockdata) {
|
2021-11-21 23:00:00 +01:00
|
|
|
+ world.setBlock(blockposition, iblockdata1, 2);
|
2019-07-09 02:47:07 +02:00
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return iblockdata1;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public static IBlockData getBlockState(IBlockData iblockdata, NBTTagCompound nbttagcompound1) {
|
|
|
|
+ IBlockData iblockdata1 = iblockdata;
|
|
|
|
+ {
|
|
|
|
+ // CraftBukkit end
|
2021-11-21 23:00:00 +01:00
|
|
|
BlockStateList<Block, IBlockData> blockstatelist = iblockdata.getBlock().getStateDefinition();
|
|
|
|
Iterator iterator = nbttagcompound1.getAllKeys().iterator();
|
2019-07-09 02:47:07 +02:00
|
|
|
|
2021-11-21 23:00:00 +01:00
|
|
|
@@ -143,11 +184,6 @@
|
2019-07-09 02:47:07 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
-
|
|
|
|
- if (iblockdata1 != iblockdata) {
|
2021-11-21 23:00:00 +01:00
|
|
|
- world.setBlock(blockposition, iblockdata1, 2);
|
2019-07-09 02:47:07 +02:00
|
|
|
- }
|
|
|
|
-
|
|
|
|
return iblockdata1;
|
|
|
|
}
|
|
|
|
|
2021-11-21 23:00:00 +01:00
|
|
|
@@ -160,8 +196,15 @@
|
|
|
|
protected boolean canPlace(BlockActionContext blockactioncontext, IBlockData iblockdata) {
|
|
|
|
EntityHuman entityhuman = blockactioncontext.getPlayer();
|
|
|
|
VoxelShapeCollision voxelshapecollision = entityhuman == null ? VoxelShapeCollision.empty() : VoxelShapeCollision.of(entityhuman);
|
2018-07-15 02:00:00 +02:00
|
|
|
+ // CraftBukkit start - store default return
|
2021-11-21 23:00:00 +01:00
|
|
|
+ boolean defaultReturn = (!this.mustSurvive() || iblockdata.canSurvive(blockactioncontext.getLevel(), blockactioncontext.getClickedPos())) && blockactioncontext.getLevel().isUnobstructed(iblockdata, blockactioncontext.getClickedPos(), voxelshapecollision);
|
|
|
|
+ org.bukkit.entity.Player player = (blockactioncontext.getPlayer() instanceof EntityPlayer) ? (org.bukkit.entity.Player) blockactioncontext.getPlayer().getBukkitEntity() : null;
|
2019-07-09 02:47:07 +02:00
|
|
|
+
|
2021-11-21 23:00:00 +01:00
|
|
|
+ BlockCanBuildEvent event = new BlockCanBuildEvent(CraftBlock.at(blockactioncontext.getLevel(), blockactioncontext.getClickedPos()), player, CraftBlockData.fromData(iblockdata), defaultReturn);
|
|
|
|
+ blockactioncontext.getLevel().getCraftServer().getPluginManager().callEvent(event);
|
2019-07-09 02:47:07 +02:00
|
|
|
|
2021-11-21 23:00:00 +01:00
|
|
|
- return (!this.mustSurvive() || iblockdata.canSurvive(blockactioncontext.getLevel(), blockactioncontext.getClickedPos())) && blockactioncontext.getLevel().isUnobstructed(iblockdata, blockactioncontext.getClickedPos(), voxelshapecollision);
|
2018-07-15 02:00:00 +02:00
|
|
|
+ return event.isBuildable();
|
|
|
|
+ // CraftBukkit end
|
|
|
|
}
|
2016-06-30 07:39:58 +02:00
|
|
|
|
2021-11-21 23:00:00 +01:00
|
|
|
protected boolean mustSurvive() {
|
|
|
|
@@ -244,7 +287,7 @@
|
2021-06-11 07:00:00 +02:00
|
|
|
|
2021-11-21 23:00:00 +01:00
|
|
|
if (nbttagcompound != null && nbttagcompound.contains("Items", 9)) {
|
|
|
|
NBTTagList nbttaglist = nbttagcompound.getList("Items", 10);
|
2021-06-11 07:00:00 +02:00
|
|
|
- Stream stream = nbttaglist.stream();
|
|
|
|
+ Stream<net.minecraft.nbt.NBTBase> stream = nbttaglist.stream(); // CraftBukkit - decompile error
|
|
|
|
|
|
|
|
Objects.requireNonNull(NBTTagCompound.class);
|
2021-11-21 23:00:00 +01:00
|
|
|
ItemLiquidUtil.onContainerDestroyed(entityitem, stream.map(NBTTagCompound.class::cast).map(ItemStack::of));
|