mirror of
https://github.com/PaperMC/Paper.git
synced 2024-12-12 09:51:12 +01:00
96 lines
5 KiB
Diff
96 lines
5 KiB
Diff
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||
|
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
||
|
Date: Thu, 2 Jan 2020 12:25:07 -0600
|
||
|
Subject: [PATCH] Improve Block#breakNaturally API
|
||
|
|
||
|
Adds bool parameter to play world effect on block break
|
||
|
|
||
|
Adds bool parameter to drop xp from blocks
|
||
|
|
||
|
Fixes fluid-logged blocks not leaving fluid behind if
|
||
|
broken
|
||
|
|
||
|
Handles special cases for ice and turtle eggs
|
||
|
|
||
|
== AT ==
|
||
|
public net.minecraft.world.level.block.TurtleEggBlock decreaseEggs(Lnet/minecraft/world/level/Level;Lnet/minecraft/core/BlockPos;Lnet/minecraft/world/level/block/state/BlockState;)V
|
||
|
|
||
|
Co-authored-by: William Blake Galbreath <Blake.Galbreath@GMail.com>
|
||
|
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/IceBlock.java b/src/main/java/net/minecraft/world/level/block/IceBlock.java
|
||
|
index 0afadbc8515d448b0ef817f4f0f53b1bb0abde43..64206d94a5bf210116d208f9678618b905a61428 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/IceBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/IceBlock.java
|
||
|
@@ -25,6 +25,11 @@ public class IceBlock extends HalfTransparentBlock {
|
||
|
@Override
|
||
|
public void playerDestroy(Level world, Player player, BlockPos pos, BlockState state, @Nullable BlockEntity blockEntity, ItemStack stack) {
|
||
|
super.playerDestroy(world, player, pos, state, blockEntity, stack);
|
||
|
+ // Paper start
|
||
|
+ this.afterDestroy(world, pos, stack);
|
||
|
+ }
|
||
|
+ public void afterDestroy(Level world, BlockPos pos, ItemStack stack) {
|
||
|
+ // Paper end
|
||
|
if (EnchantmentHelper.getItemEnchantmentLevel(Enchantments.SILK_TOUCH, stack) == 0) {
|
||
|
if (world.dimensionType().ultraWarm()) {
|
||
|
world.removeBlock(pos, false);
|
||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java b/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java
|
||
|
index 2e3b675dca8cec906d533141e158e5db6ae87042..3123a8d52236757c3e7ca3b099cc664485cb3c72 100644
|
||
|
--- a/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java
|
||
|
+++ b/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java
|
||
|
@@ -477,6 +477,18 @@ public class CraftBlock implements Block {
|
||
|
|
||
|
@Override
|
||
|
public boolean breakNaturally(ItemStack item) {
|
||
|
+ // Paper start
|
||
|
+ return this.breakNaturally(item, false);
|
||
|
+ }
|
||
|
+
|
||
|
+ @Override
|
||
|
+ public boolean breakNaturally(boolean triggerEffect, boolean dropExperience) {
|
||
|
+ return this.breakNaturally(null, triggerEffect, dropExperience);
|
||
|
+ }
|
||
|
+
|
||
|
+ @Override
|
||
|
+ public boolean breakNaturally(ItemStack item, boolean triggerEffect, boolean dropExperience) {
|
||
|
+ // Paper end
|
||
|
// Order matters here, need to drop before setting to air so skulls can get their data
|
||
|
net.minecraft.world.level.block.state.BlockState iblockdata = this.getNMS();
|
||
|
net.minecraft.world.level.block.Block block = iblockdata.getBlock();
|
||
|
@@ -486,11 +498,35 @@ public class CraftBlock implements Block {
|
||
|
// Modelled off EntityHuman#hasBlock
|
||
|
if (block != Blocks.AIR && (item == null || !iblockdata.requiresCorrectToolForDrops() || nmsItem.isCorrectToolForDrops(iblockdata))) {
|
||
|
net.minecraft.world.level.block.Block.dropResources(iblockdata, this.world.getMinecraftWorld(), position, this.world.getBlockEntity(position), null, nmsItem);
|
||
|
+ // Paper start - improve Block#breanNaturally
|
||
|
+ if (triggerEffect) {
|
||
|
+ if (iblockdata.getBlock() instanceof net.minecraft.world.level.block.BaseFireBlock) {
|
||
|
+ this.world.levelEvent(net.minecraft.world.level.block.LevelEvent.SOUND_EXTINGUISH_FIRE, this.position, 0);
|
||
|
+ } else {
|
||
|
+ this.world.levelEvent(net.minecraft.world.level.block.LevelEvent.PARTICLES_DESTROY_BLOCK, this.position, net.minecraft.world.level.block.Block.getId(iblockdata));
|
||
|
+ }
|
||
|
+ }
|
||
|
+ if (dropExperience) block.popExperience(this.world.getMinecraftWorld(), this.position, block.getExpDrop(iblockdata, this.world.getMinecraftWorld(), this.position, nmsItem, true));
|
||
|
+ // Paper end
|
||
|
result = true;
|
||
|
}
|
||
|
|
||
|
// SPIGOT-6778: Directly call setBlock instead of setTypeAndData, so that the tile entiy is not removed and custom remove logic is run.
|
||
|
- return this.world.setBlock(position, Blocks.AIR.defaultBlockState(), 3) && result;
|
||
|
+ // Paper start - improve breakNaturally
|
||
|
+ boolean destroyed = this.world.removeBlock(this.position, false);
|
||
|
+ if (destroyed) {
|
||
|
+ block.destroy(this.world, this.position, iblockdata);
|
||
|
+ }
|
||
|
+ if (result) {
|
||
|
+ // special cases
|
||
|
+ if (block instanceof net.minecraft.world.level.block.IceBlock iceBlock) {
|
||
|
+ iceBlock.afterDestroy(this.world.getMinecraftWorld(), this.position, nmsItem);
|
||
|
+ } else if (block instanceof net.minecraft.world.level.block.TurtleEggBlock turtleEggBlock) {
|
||
|
+ turtleEggBlock.decreaseEggs(this.world.getMinecraftWorld(), this.position, iblockdata);
|
||
|
+ }
|
||
|
+ }
|
||
|
+ return destroyed && result;
|
||
|
+ // Paper end
|
||
|
}
|
||
|
|
||
|
@Override
|