2021-06-15 00:49:10 +02:00
|
|
|
--- a/net/minecraft/world/level/block/BigDripleafBlock.java
|
|
|
|
+++ b/net/minecraft/world/level/block/BigDripleafBlock.java
|
2024-04-23 17:15:00 +02:00
|
|
|
@@ -43,6 +43,11 @@
|
2021-06-15 00:49:10 +02:00
|
|
|
import net.minecraft.world.phys.shapes.VoxelShapeCollision;
|
|
|
|
import net.minecraft.world.phys.shapes.VoxelShapes;
|
|
|
|
|
|
|
|
+// CraftBukkit start
|
|
|
|
+import org.bukkit.craftbukkit.event.CraftEventFactory;
|
|
|
|
+import org.bukkit.event.entity.EntityInteractEvent;
|
|
|
|
+// CraftBukkit end
|
|
|
|
+
|
|
|
|
public class BigDripleafBlock extends BlockFacingHorizontal implements IBlockFragilePlantElement, IBlockWaterlogged {
|
|
|
|
|
2023-12-05 17:40:00 +01:00
|
|
|
public static final MapCodec<BigDripleafBlock> CODEC = simpleCodec(BigDripleafBlock::new);
|
2024-04-23 17:15:00 +02:00
|
|
|
@@ -117,7 +122,7 @@
|
2021-06-15 00:49:10 +02:00
|
|
|
|
|
|
|
@Override
|
2024-04-23 17:15:00 +02:00
|
|
|
protected void onProjectileHit(World world, IBlockData iblockdata, MovingObjectPositionBlock movingobjectpositionblock, IProjectile iprojectile) {
|
2021-11-21 23:00:00 +01:00
|
|
|
- this.setTiltAndScheduleTick(iblockdata, world, movingobjectpositionblock.getBlockPos(), Tilt.FULL, SoundEffects.BIG_DRIPLEAF_TILT_DOWN);
|
|
|
|
+ this.setTiltAndScheduleTick(iblockdata, world, movingobjectpositionblock.getBlockPos(), Tilt.FULL, SoundEffects.BIG_DRIPLEAF_TILT_DOWN, iprojectile); // CraftBukkit
|
2021-06-15 00:49:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2024-04-23 17:15:00 +02:00
|
|
|
@@ -176,7 +181,20 @@
|
|
|
|
protected void entityInside(IBlockData iblockdata, World world, BlockPosition blockposition, Entity entity) {
|
2021-06-15 00:49:10 +02:00
|
|
|
if (!world.isClientSide) {
|
2021-11-21 23:00:00 +01:00
|
|
|
if (iblockdata.getValue(BigDripleafBlock.TILT) == Tilt.NONE && canEntityTilt(blockposition, entity) && !world.hasNeighborSignal(blockposition)) {
|
|
|
|
- this.setTiltAndScheduleTick(iblockdata, world, blockposition, Tilt.UNSTABLE, (SoundEffect) null);
|
2021-06-15 00:49:10 +02:00
|
|
|
+ // CraftBukkit start - tilt dripleaf
|
|
|
|
+ org.bukkit.event.Cancellable cancellable;
|
|
|
|
+ if (entity instanceof EntityHuman) {
|
|
|
|
+ cancellable = CraftEventFactory.callPlayerInteractEvent((EntityHuman) entity, org.bukkit.event.block.Action.PHYSICAL, blockposition, null, null, null);
|
|
|
|
+ } else {
|
|
|
|
+ cancellable = new EntityInteractEvent(entity.getBukkitEntity(), world.getWorld().getBlockAt(blockposition.getX(), blockposition.getY(), blockposition.getZ()));
|
|
|
|
+ world.getCraftServer().getPluginManager().callEvent((EntityInteractEvent) cancellable);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (cancellable.isCancelled()) {
|
|
|
|
+ return;
|
|
|
|
+ }
|
2021-11-21 23:00:00 +01:00
|
|
|
+ this.setTiltAndScheduleTick(iblockdata, world, blockposition, Tilt.UNSTABLE, (SoundEffect) null, entity);
|
2021-06-15 00:49:10 +02:00
|
|
|
+ // CraftBukkit end
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2024-04-23 17:15:00 +02:00
|
|
|
@@ -190,9 +208,9 @@
|
2021-11-21 23:00:00 +01:00
|
|
|
Tilt tilt = (Tilt) iblockdata.getValue(BigDripleafBlock.TILT);
|
2021-06-15 00:49:10 +02:00
|
|
|
|
|
|
|
if (tilt == Tilt.UNSTABLE) {
|
2021-11-21 23:00:00 +01:00
|
|
|
- this.setTiltAndScheduleTick(iblockdata, worldserver, blockposition, Tilt.PARTIAL, SoundEffects.BIG_DRIPLEAF_TILT_DOWN);
|
|
|
|
+ this.setTiltAndScheduleTick(iblockdata, worldserver, blockposition, Tilt.PARTIAL, SoundEffects.BIG_DRIPLEAF_TILT_DOWN, null); // CraftBukkit
|
2021-06-15 00:49:10 +02:00
|
|
|
} else if (tilt == Tilt.PARTIAL) {
|
2021-11-21 23:00:00 +01:00
|
|
|
- this.setTiltAndScheduleTick(iblockdata, worldserver, blockposition, Tilt.FULL, SoundEffects.BIG_DRIPLEAF_TILT_DOWN);
|
|
|
|
+ this.setTiltAndScheduleTick(iblockdata, worldserver, blockposition, Tilt.FULL, SoundEffects.BIG_DRIPLEAF_TILT_DOWN, null); // CraftBukkit
|
2021-06-15 00:49:10 +02:00
|
|
|
} else if (tilt == Tilt.FULL) {
|
2021-11-21 23:00:00 +01:00
|
|
|
resetTilt(iblockdata, worldserver, blockposition);
|
2021-06-15 00:49:10 +02:00
|
|
|
}
|
2024-04-23 17:15:00 +02:00
|
|
|
@@ -218,8 +236,10 @@
|
2023-06-07 17:30:00 +02:00
|
|
|
return entity.onGround() && entity.position().y > (double) ((float) blockposition.getY() + 0.6875F);
|
2021-06-15 00:49:10 +02:00
|
|
|
}
|
|
|
|
|
2021-11-21 23:00:00 +01:00
|
|
|
- private void setTiltAndScheduleTick(IBlockData iblockdata, World world, BlockPosition blockposition, Tilt tilt, @Nullable SoundEffect soundeffect) {
|
|
|
|
- setTilt(iblockdata, world, blockposition, tilt);
|
2021-06-15 00:49:10 +02:00
|
|
|
+ // CraftBukkit start
|
2021-11-21 23:00:00 +01:00
|
|
|
+ private void setTiltAndScheduleTick(IBlockData iblockdata, World world, BlockPosition blockposition, Tilt tilt, @Nullable SoundEffect soundeffect, @Nullable Entity entity) {
|
|
|
|
+ if (!setTilt(iblockdata, world, blockposition, tilt, entity)) return;
|
2021-06-15 00:49:10 +02:00
|
|
|
+ // CraftBukkit end
|
|
|
|
if (soundeffect != null) {
|
2021-11-21 23:00:00 +01:00
|
|
|
playTiltSound(world, blockposition, soundeffect);
|
2021-06-15 00:49:10 +02:00
|
|
|
}
|
2024-04-23 17:15:00 +02:00
|
|
|
@@ -233,14 +253,21 @@
|
2021-06-15 00:49:10 +02:00
|
|
|
}
|
|
|
|
|
2021-11-21 23:00:00 +01:00
|
|
|
private static void resetTilt(IBlockData iblockdata, World world, BlockPosition blockposition) {
|
|
|
|
- setTilt(iblockdata, world, blockposition, Tilt.NONE);
|
|
|
|
+ setTilt(iblockdata, world, blockposition, Tilt.NONE, null); // CraftBukkit
|
|
|
|
if (iblockdata.getValue(BigDripleafBlock.TILT) != Tilt.NONE) {
|
|
|
|
playTiltSound(world, blockposition, SoundEffects.BIG_DRIPLEAF_TILT_UP);
|
2021-06-15 00:49:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2021-11-21 23:00:00 +01:00
|
|
|
- private static void setTilt(IBlockData iblockdata, World world, BlockPosition blockposition, Tilt tilt) {
|
2021-06-15 00:49:10 +02:00
|
|
|
+ // CraftBukkit start
|
2021-11-21 23:00:00 +01:00
|
|
|
+ private static boolean setTilt(IBlockData iblockdata, World world, BlockPosition blockposition, Tilt tilt, @Nullable Entity entity) {
|
2021-06-15 00:49:10 +02:00
|
|
|
+ if (entity != null) {
|
2023-06-24 09:15:05 +02:00
|
|
|
+ if (!CraftEventFactory.callEntityChangeBlockEvent(entity, blockposition, iblockdata.setValue(BigDripleafBlock.TILT, tilt))) {
|
2021-06-15 00:49:10 +02:00
|
|
|
+ return false;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ // CraftBukkit end
|
2022-06-07 18:00:00 +02:00
|
|
|
Tilt tilt1 = (Tilt) iblockdata.getValue(BigDripleafBlock.TILT);
|
|
|
|
|
2021-11-21 23:00:00 +01:00
|
|
|
world.setBlock(blockposition, (IBlockData) iblockdata.setValue(BigDripleafBlock.TILT, tilt), 2);
|
2024-04-23 17:15:00 +02:00
|
|
|
@@ -248,6 +275,7 @@
|
|
|
|
world.gameEvent((Entity) null, (Holder) GameEvent.BLOCK_CHANGE, blockposition);
|
2021-06-15 00:49:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
+ return true; // CraftBukkit
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|