mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-01 05:47:45 +01:00
Add and fix missing BlockFadeEvents
Beyond calling the BlockFadeEvent in more places, this patch also aims to pass the proper replacement state to the event, specifically for potentially waterlogged block states fading. Co-authored-by: Lulu13022002 <41980282+Lulu13022002@users.noreply.github.com>
This commit is contained in:
parent
44f8b39a2c
commit
dede55eaad
@ -8,7 +8,19 @@
|
|||||||
if (entity.getType().equals(EntityType.FALLING_BLOCK)) {
|
if (entity.getType().equals(EntityType.FALLING_BLOCK)) {
|
||||||
this.destroyBlock(world, pos);
|
this.destroyBlock(world, pos);
|
||||||
}
|
}
|
||||||
@@ -121,7 +122,7 @@
|
@@ -101,6 +102,11 @@
|
||||||
|
}
|
||||||
|
|
||||||
|
private void hatchFrogspawn(ServerLevel world, BlockPos pos, RandomSource random) {
|
||||||
|
+ // Paper start - Call BlockFadeEvent
|
||||||
|
+ if (org.bukkit.craftbukkit.event.CraftEventFactory.callBlockFadeEvent(world, pos, Blocks.AIR.defaultBlockState()).isCancelled()) {
|
||||||
|
+ return;
|
||||||
|
+ }
|
||||||
|
+ // Paper end - Call BlockFadeEvent
|
||||||
|
this.destroyBlock(world, pos);
|
||||||
|
world.playSound(null, pos, SoundEvents.FROGSPAWN_HATCH, SoundSource.BLOCKS, 1.0F, 1.0F);
|
||||||
|
this.spawnTadpoles(world, pos, random);
|
||||||
|
@@ -121,7 +127,7 @@
|
||||||
int k = random.nextInt(1, 361);
|
int k = random.nextInt(1, 361);
|
||||||
tadpole.moveTo(d, (double)pos.getY() - 0.5, e, (float)k, 0.0F);
|
tadpole.moveTo(d, (double)pos.getY() - 0.5, e, (float)k, 0.0F);
|
||||||
tadpole.setPersistenceRequired();
|
tadpole.setPersistenceRequired();
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
BlockState iblockdata1 = (BlockState) ((BlockState) state.setValue(ScaffoldingBlock.DISTANCE, i)).setValue(ScaffoldingBlock.BOTTOM, this.isBottom(world, pos, i));
|
BlockState iblockdata1 = (BlockState) ((BlockState) state.setValue(ScaffoldingBlock.DISTANCE, i)).setValue(ScaffoldingBlock.BOTTOM, this.isBottom(world, pos, i));
|
||||||
|
|
||||||
- if ((Integer) iblockdata1.getValue(ScaffoldingBlock.DISTANCE) == 7) {
|
- if ((Integer) iblockdata1.getValue(ScaffoldingBlock.DISTANCE) == 7) {
|
||||||
+ if ((Integer) iblockdata1.getValue(ScaffoldingBlock.DISTANCE) == 7 && !org.bukkit.craftbukkit.event.CraftEventFactory.callBlockFadeEvent(world, pos, Blocks.AIR.defaultBlockState()).isCancelled()) { // CraftBukkit - BlockFadeEvent
|
+ if ((Integer) iblockdata1.getValue(ScaffoldingBlock.DISTANCE) == 7 && !org.bukkit.craftbukkit.event.CraftEventFactory.callBlockFadeEvent(world, pos, iblockdata1.getFluidState().createLegacyBlock()).isCancelled()) { // CraftBukkit - BlockFadeEvent // Paper - fix wrong block state
|
||||||
if ((Integer) state.getValue(ScaffoldingBlock.DISTANCE) == 7) {
|
if ((Integer) state.getValue(ScaffoldingBlock.DISTANCE) == 7) {
|
||||||
FallingBlockEntity.fall(world, pos, iblockdata1);
|
FallingBlockEntity.fall(world, pos, iblockdata1);
|
||||||
} else {
|
} else {
|
||||||
|
@ -1,6 +1,33 @@
|
|||||||
--- a/net/minecraft/world/level/block/SnifferEggBlock.java
|
--- a/net/minecraft/world/level/block/SnifferEggBlock.java
|
||||||
+++ b/net/minecraft/world/level/block/SnifferEggBlock.java
|
+++ b/net/minecraft/world/level/block/SnifferEggBlock.java
|
||||||
@@ -74,7 +74,7 @@
|
@@ -61,12 +61,26 @@
|
||||||
|
return this.getHatchLevel(state) == 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ // Paper start - Call BlockFadeEvent
|
||||||
|
+ private void rescheduleTick(ServerLevel world, BlockPos pos) {
|
||||||
|
+ int baseDelay = hatchBoost(world, pos) ? BOOSTED_HATCH_TIME_TICKS : REGULAR_HATCH_TIME_TICKS;
|
||||||
|
+ world.scheduleTick(pos, this, (baseDelay / 3) + world.random.nextInt(RANDOM_HATCH_OFFSET_TICKS));
|
||||||
|
+ // reschedule to avoid being stuck here and behave like the other calls (see #onPlace)
|
||||||
|
+ }
|
||||||
|
+ // Paper end - Call BlockFadeEvent
|
||||||
|
+
|
||||||
|
@Override
|
||||||
|
public void tick(BlockState state, ServerLevel world, BlockPos pos, RandomSource random) {
|
||||||
|
if (!this.isReadyToHatch(state)) {
|
||||||
|
world.playSound(null, pos, SoundEvents.SNIFFER_EGG_CRACK, SoundSource.BLOCKS, 0.7F, 0.9F + random.nextFloat() * 0.2F);
|
||||||
|
world.setBlock(pos, state.setValue(HATCH, Integer.valueOf(this.getHatchLevel(state) + 1)), 2);
|
||||||
|
} else {
|
||||||
|
+ // Paper start - Call BlockFadeEvent
|
||||||
|
+ if (org.bukkit.craftbukkit.event.CraftEventFactory.callBlockFadeEvent(world, pos, state.getFluidState().createLegacyBlock()).isCancelled()) {
|
||||||
|
+ this.rescheduleTick(world, pos);
|
||||||
|
+ return;
|
||||||
|
+ }
|
||||||
|
+ // Paper end - Call BlockFadeEvent
|
||||||
|
world.playSound(null, pos, SoundEvents.SNIFFER_EGG_HATCH, SoundSource.BLOCKS, 0.7F, 0.9F + random.nextFloat() * 0.2F);
|
||||||
|
world.destroyBlock(pos, false);
|
||||||
|
Sniffer sniffer = EntityType.SNIFFER.create(world, EntitySpawnReason.BREEDING);
|
||||||
|
@@ -74,7 +88,7 @@
|
||||||
Vec3 vec3 = pos.getCenter();
|
Vec3 vec3 = pos.getCenter();
|
||||||
sniffer.setBaby(true);
|
sniffer.setBaby(true);
|
||||||
sniffer.moveTo(vec3.x(), vec3.y(), vec3.z(), Mth.wrapDegrees(world.random.nextFloat() * 360.0F), 0.0F);
|
sniffer.moveTo(vec3.x(), vec3.y(), vec3.z(), Mth.wrapDegrees(world.random.nextFloat() * 360.0F), 0.0F);
|
||||||
|
Loading…
Reference in New Issue
Block a user