Prevent desync for poi and pistons (#9270)
This commit is contained in:
parent
a60eeb85f5
commit
1f8ca77bb6
2 changed files with 32 additions and 2 deletions
|
@ -59,7 +59,7 @@ index 4f6b7ed4809086811f0460544ba2ec0606f0f5da..9abae63e06c1dde9b8434d32bac87988
|
||||||
+ }
|
+ }
|
||||||
+ world.setBlockEntity(MovingPistonBlock.newMovingBlockEntity(blockposition3, iblockdata2, allowDesync ? list1.get(k) : iblockdata1, dir, retract, false));
|
+ world.setBlockEntity(MovingPistonBlock.newMovingBlockEntity(blockposition3, iblockdata2, allowDesync ? list1.get(k) : iblockdata1, dir, retract, false));
|
||||||
+ if (!allowDesync) {
|
+ if (!allowDesync) {
|
||||||
+ world.setBlock(oldPos, Blocks.AIR.defaultBlockState(), 2 | 4 | 16 | 1024); // set air to prevent later physics updates from seeing this block
|
+ world.setBlock(oldPos, Blocks.AIR.defaultBlockState(), Block.UPDATE_CLIENTS | Block.UPDATE_KNOWN_SHAPE | Block.UPDATE_MOVE_BY_PISTON | 1024); // set air to prevent later physics updates from seeing this block
|
||||||
+ }
|
+ }
|
||||||
+ // Paper end - fix a variety of piston desync dupes
|
+ // Paper end - fix a variety of piston desync dupes
|
||||||
aiblockdata[j++] = iblockdata1;
|
aiblockdata[j++] = iblockdata1;
|
||||||
|
@ -74,7 +74,7 @@ index 17a6327ab7b26dfab38881bbc0689b0b25f8f025..30fafbb26a347b73c72b9f5c30da3b01
|
||||||
BlockState blockState = Block.updateFromNeighbourShapes(blockEntity.movedState, world, pos);
|
BlockState blockState = Block.updateFromNeighbourShapes(blockEntity.movedState, world, pos);
|
||||||
if (blockState.isAir()) {
|
if (blockState.isAir()) {
|
||||||
- world.setBlock(pos, blockEntity.movedState, 84);
|
- world.setBlock(pos, blockEntity.movedState, 84);
|
||||||
+ world.setBlock(pos, blockEntity.movedState, io.papermc.paper.configuration.GlobalConfiguration.get().unsupportedSettings.allowPistonDuplication ? 84 : (84 | 2)); // Paper - force notify (flag 2), it's possible the set type by the piston block (which doesn't notify) set this block to air
|
+ world.setBlock(pos, blockEntity.movedState, io.papermc.paper.configuration.GlobalConfiguration.get().unsupportedSettings.allowPistonDuplication ? 84 : (84 | Block.UPDATE_CLIENTS)); // Paper - force notify (flag 2), it's possible the set type by the piston block (which doesn't notify) set this block to air
|
||||||
Block.updateOrDestroy(blockEntity.movedState, blockState, world, pos, 3);
|
Block.updateOrDestroy(blockEntity.movedState, blockState, world, pos, 3);
|
||||||
} else {
|
} else {
|
||||||
if (blockState.hasProperty(BlockStateProperties.WATERLOGGED) && blockState.getValue(BlockStateProperties.WATERLOGGED)) {
|
if (blockState.hasProperty(BlockStateProperties.WATERLOGGED) && blockState.getValue(BlockStateProperties.WATERLOGGED)) {
|
||||||
|
|
|
@ -3,6 +3,10 @@ From: Lulu13022002 <41980282+Lulu13022002@users.noreply.github.com>
|
||||||
Date: Mon, 3 Apr 2023 18:46:49 +0200
|
Date: Mon, 3 Apr 2023 18:46:49 +0200
|
||||||
Subject: [PATCH] Fix block place logic
|
Subject: [PATCH] Fix block place logic
|
||||||
|
|
||||||
|
Fix several issues when a player interact with a block:
|
||||||
|
* the place sound isn't played for the dispensed shulker block
|
||||||
|
* desync of the jukebox blocks between bukkit handler and the vanilla interaction
|
||||||
|
* poi can desync when the BlockPhysicsEvent is cancelled
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/world/item/BlockItem.java b/src/main/java/net/minecraft/world/item/BlockItem.java
|
diff --git a/src/main/java/net/minecraft/world/item/BlockItem.java b/src/main/java/net/minecraft/world/item/BlockItem.java
|
||||||
index b0204af850ee182773ad458208cccd946ad148d5..ebee8de2ed831755b6fd154f6cc77ac993839bb9 100644
|
index b0204af850ee182773ad458208cccd946ad148d5..ebee8de2ed831755b6fd154f6cc77ac993839bb9 100644
|
||||||
|
@ -36,3 +40,29 @@ index 6a25b768ea2e99acdda781cdc0ab7bf80b45912c..5f0e01060e1d8716e7514a25cbe68b73
|
||||||
world.gameEvent(GameEvent.BLOCK_CHANGE, blockposition, GameEvent.Context.of(entityhuman, world.getBlockState(blockposition)));
|
world.gameEvent(GameEvent.BLOCK_CHANGE, blockposition, GameEvent.Context.of(entityhuman, world.getBlockState(blockposition)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/level/Level.java b/src/main/java/net/minecraft/world/level/Level.java
|
||||||
|
index 147d802d9207e358fdb2d1c7806fc2f634dcfd98..f39ab10c5b0b8d86b579a5b683491204c51db70b 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/level/Level.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/level/Level.java
|
||||||
|
@@ -646,17 +646,18 @@ public abstract class Level implements LevelAccessor, AutoCloseable {
|
||||||
|
// CraftBukkit start
|
||||||
|
iblockdata1.updateIndirectNeighbourShapes(this, blockposition, k, j - 1); // Don't call an event for the old block to limit event spam
|
||||||
|
CraftWorld world = ((ServerLevel) this).getWorld();
|
||||||
|
+ boolean cancelledUpdates = false; // Paper
|
||||||
|
if (world != null && ((ServerLevel)this).hasPhysicsEvent) { // Paper
|
||||||
|
BlockPhysicsEvent event = new BlockPhysicsEvent(world.getBlockAt(blockposition.getX(), blockposition.getY(), blockposition.getZ()), CraftBlockData.fromData(iblockdata));
|
||||||
|
this.getCraftServer().getPluginManager().callEvent(event);
|
||||||
|
|
||||||
|
- if (event.isCancelled()) {
|
||||||
|
- return;
|
||||||
|
- }
|
||||||
|
+ cancelledUpdates = event.isCancelled(); // Paper
|
||||||
|
}
|
||||||
|
// CraftBukkit end
|
||||||
|
+ if (!cancelledUpdates) { // Paper
|
||||||
|
iblockdata.updateNeighbourShapes(this, blockposition, k, j - 1);
|
||||||
|
iblockdata.updateIndirectNeighbourShapes(this, blockposition, k, j - 1);
|
||||||
|
+ } // Paper
|
||||||
|
}
|
||||||
|
|
||||||
|
// CraftBukkit start - SPIGOT-5710
|
||||||
|
|
Loading…
Reference in a new issue