mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-16 14:33:09 +01:00
223 lines
17 KiB
Diff
223 lines
17 KiB
Diff
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||
|
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
||
|
Date: Sat, 8 May 2021 18:02:36 -0700
|
||
|
Subject: [PATCH] Add EntityInsideBlockEvent
|
||
|
|
||
|
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/BaseFireBlock.java b/src/main/java/net/minecraft/world/level/block/BaseFireBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/BaseFireBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/BaseFireBlock.java
|
||
|
@@ -0,0 +0,0 @@ public abstract class BaseFireBlock extends Block {
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
if (!entity.fireImmune()) {
|
||
|
entity.setRemainingFireTicks(entity.getRemainingFireTicks() + 1);
|
||
|
if (entity.getRemainingFireTicks() == 0) {
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/BasePressurePlateBlock.java b/src/main/java/net/minecraft/world/level/block/BasePressurePlateBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/BasePressurePlateBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/BasePressurePlateBlock.java
|
||
|
@@ -0,0 +0,0 @@ public abstract class BasePressurePlateBlock extends Block {
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
if (!world.isClientSide) {
|
||
|
int i = this.getSignalForState(state);
|
||
|
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/BubbleColumnBlock.java b/src/main/java/net/minecraft/world/level/block/BubbleColumnBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/BubbleColumnBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/BubbleColumnBlock.java
|
||
|
@@ -0,0 +0,0 @@ public class BubbleColumnBlock extends Block implements BucketPickup {
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
BlockState iblockdata1 = world.getBlockState(pos.above());
|
||
|
|
||
|
if (iblockdata1.isAir()) {
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/ButtonBlock.java b/src/main/java/net/minecraft/world/level/block/ButtonBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/ButtonBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/ButtonBlock.java
|
||
|
@@ -0,0 +0,0 @@ public abstract class ButtonBlock extends FaceAttachedHorizontalDirectionalBlock
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
if (!world.isClientSide && this.sensitive && !(Boolean) state.getValue(ButtonBlock.POWERED)) {
|
||
|
this.checkPressed(state, world, pos);
|
||
|
}
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/CactusBlock.java b/src/main/java/net/minecraft/world/level/block/CactusBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/CactusBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/CactusBlock.java
|
||
|
@@ -0,0 +0,0 @@ public class CactusBlock extends Block {
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
CraftEventFactory.blockDamage = world.getWorld().getBlockAt(pos.getX(), pos.getY(), pos.getZ()); // CraftBukkit
|
||
|
entity.hurt(DamageSource.CACTUS, 1.0F);
|
||
|
CraftEventFactory.blockDamage = null; // CraftBukkit
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/CampfireBlock.java b/src/main/java/net/minecraft/world/level/block/CampfireBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/CampfireBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/CampfireBlock.java
|
||
|
@@ -0,0 +0,0 @@ public class CampfireBlock extends BaseEntityBlock implements SimpleWaterloggedB
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
if (!entity.fireImmune() && (Boolean) state.getValue(CampfireBlock.LIT) && entity instanceof LivingEntity && !EnchantmentHelper.hasFrostWalker((LivingEntity) entity)) {
|
||
|
entity.hurt(DamageSource.IN_FIRE, (float) this.fireDamage);
|
||
|
}
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/CauldronBlock.java b/src/main/java/net/minecraft/world/level/block/CauldronBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/CauldronBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/CauldronBlock.java
|
||
|
@@ -0,0 +0,0 @@ public class CauldronBlock extends Block {
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
int i = (Integer) state.getValue(CauldronBlock.LEVEL);
|
||
|
float f = (float) pos.getY() + (6.0F + (float) (3 * i)) / 16.0F;
|
||
|
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/CropBlock.java b/src/main/java/net/minecraft/world/level/block/CropBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/CropBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/CropBlock.java
|
||
|
@@ -0,0 +0,0 @@ public class CropBlock extends BushBlock implements BonemealableBlock {
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
if (entity instanceof Ravager && !CraftEventFactory.callEntityChangeBlockEvent(entity, pos, Blocks.AIR.defaultBlockState(), !world.getGameRules().getBoolean(GameRules.RULE_MOBGRIEFING)).isCancelled()) { // CraftBukkit
|
||
|
world.destroyBlock(pos, true, entity);
|
||
|
}
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/DetectorRailBlock.java b/src/main/java/net/minecraft/world/level/block/DetectorRailBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/DetectorRailBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/DetectorRailBlock.java
|
||
|
@@ -0,0 +0,0 @@ public class DetectorRailBlock extends BaseRailBlock {
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
if (!world.isClientSide) {
|
||
|
if (!(Boolean) state.getValue(DetectorRailBlock.POWERED)) {
|
||
|
this.checkPressed(world, pos, state);
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/EndPortalBlock.java b/src/main/java/net/minecraft/world/level/block/EndPortalBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/EndPortalBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/EndPortalBlock.java
|
||
|
@@ -0,0 +0,0 @@ public class EndPortalBlock extends BaseEntityBlock {
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
if (world instanceof ServerLevel && !entity.isPassenger() && !entity.isVehicle() && entity.canChangeDimensions() && Shapes.joinIsNotEmpty(Shapes.create(entity.getBoundingBox().move((double) (-pos.getX()), (double) (-pos.getY()), (double) (-pos.getZ()))), state.getShape(world, pos), BooleanOp.AND)) {
|
||
|
ResourceKey<Level> resourcekey = world.getTypeKey() == DimensionType.END_LOCATION ? Level.OVERWORLD : Level.END; // CraftBukkit - SPIGOT-6152: send back to main overworld in custom ends
|
||
|
ServerLevel worldserver = ((ServerLevel) world).getServer().getLevel(resourcekey);
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/HoneyBlock.java b/src/main/java/net/minecraft/world/level/block/HoneyBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/HoneyBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/HoneyBlock.java
|
||
|
@@ -0,0 +0,0 @@ public class HoneyBlock extends HalfTransparentBlock {
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
if (this.isSlidingDown(pos, entity)) {
|
||
|
this.maybeDoSlideAchievement(entity, pos);
|
||
|
this.doSlideMovement(entity);
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/HopperBlock.java b/src/main/java/net/minecraft/world/level/block/HopperBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/HopperBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/HopperBlock.java
|
||
|
@@ -0,0 +0,0 @@ public class HopperBlock extends BaseEntityBlock {
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
BlockEntity tileentity = world.getBlockEntity(pos);
|
||
|
|
||
|
if (tileentity instanceof HopperBlockEntity) {
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/NetherPortalBlock.java b/src/main/java/net/minecraft/world/level/block/NetherPortalBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/NetherPortalBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/NetherPortalBlock.java
|
||
|
@@ -0,0 +0,0 @@ public class NetherPortalBlock extends Block {
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
if (!entity.isPassenger() && !entity.isVehicle() && entity.canChangeDimensions()) {
|
||
|
// CraftBukkit start - Entity in portal
|
||
|
EntityPortalEnterEvent event = new EntityPortalEnterEvent(entity.getBukkitEntity(), new org.bukkit.Location(world.getWorld(), pos.getX(), pos.getY(), pos.getZ()));
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/SweetBerryBushBlock.java b/src/main/java/net/minecraft/world/level/block/SweetBerryBushBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/SweetBerryBushBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/SweetBerryBushBlock.java
|
||
|
@@ -0,0 +0,0 @@ public class SweetBerryBushBlock extends BushBlock implements BonemealableBlock
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
if (entity instanceof LivingEntity && entity.getType() != EntityType.FOX && entity.getType() != EntityType.BEE) {
|
||
|
entity.makeStuckInBlock(state, new Vec3(0.800000011920929D, 0.75D, 0.800000011920929D));
|
||
|
if (!world.isClientSide && (Integer) state.getValue(SweetBerryBushBlock.AGE) > 0 && (entity.xOld != entity.getX() || entity.zOld != entity.getZ())) {
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/TripWireBlock.java b/src/main/java/net/minecraft/world/level/block/TripWireBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/TripWireBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/TripWireBlock.java
|
||
|
@@ -0,0 +0,0 @@ public class TripWireBlock extends Block {
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
if (!world.isClientSide) {
|
||
|
if (!(Boolean) state.getValue(TripWireBlock.POWERED)) {
|
||
|
this.checkPressed(world, pos);
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/WaterlilyBlock.java b/src/main/java/net/minecraft/world/level/block/WaterlilyBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/WaterlilyBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/WaterlilyBlock.java
|
||
|
@@ -0,0 +0,0 @@ public class WaterlilyBlock extends BushBlock {
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
super.entityInside(state, world, pos, entity);
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
if (world instanceof ServerLevel && entity instanceof Boat && !org.bukkit.craftbukkit.event.CraftEventFactory.callEntityChangeBlockEvent(entity, pos, Blocks.AIR.defaultBlockState()).isCancelled()) { // CraftBukkit
|
||
|
world.destroyBlock(new BlockPos(pos), true, entity);
|
||
|
}
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/WebBlock.java b/src/main/java/net/minecraft/world/level/block/WebBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/WebBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/WebBlock.java
|
||
|
@@ -0,0 +0,0 @@ public class WebBlock extends Block {
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
entity.makeStuckInBlock(state, new Vec3(0.25D, 0.05000000074505806D, 0.25D));
|
||
|
}
|
||
|
}
|
||
|
diff --git a/src/main/java/net/minecraft/world/level/block/WitherRoseBlock.java b/src/main/java/net/minecraft/world/level/block/WitherRoseBlock.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/net/minecraft/world/level/block/WitherRoseBlock.java
|
||
|
+++ b/src/main/java/net/minecraft/world/level/block/WitherRoseBlock.java
|
||
|
@@ -0,0 +0,0 @@ public class WitherRoseBlock extends FlowerBlock {
|
||
|
|
||
|
@Override
|
||
|
public void entityInside(BlockState state, Level world, BlockPos pos, Entity entity) {
|
||
|
+ if (!new io.papermc.paper.event.entity.EntityInsideBlockEvent(entity.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(world, pos)).callEvent()) { return; } // Paper
|
||
|
if (!world.isClientSide && world.getDifficulty() != Difficulty.PEACEFUL) {
|
||
|
if (entity instanceof LivingEntity) {
|
||
|
LivingEntity entityliving = (LivingEntity) entity;
|