2023-12-03 03:41:35 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Owen1212055 <23108066+Owen1212055@users.noreply.github.com>
|
|
|
|
Date: Tue, 27 Jun 2023 21:09:11 -0400
|
|
|
|
Subject: [PATCH] Dont resend blocks on interactions
|
|
|
|
|
|
|
|
In general, the client now has an acknowledgment system which will prevent block changes made by the client to be reverted correctly.
|
|
|
|
|
|
|
|
It should be noted that this system does not yet support block entities, so those still need to resynced when needed.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/level/ServerPlayerGameMode.java b/src/main/java/net/minecraft/server/level/ServerPlayerGameMode.java
|
2024-06-14 08:56:28 +00:00
|
|
|
index d839f8df658c894f144ba4637d290ffbed77e132..415d9802ae4dd75b44055b8faf19672fa50c585f 100644
|
2023-12-03 03:41:35 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/level/ServerPlayerGameMode.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/level/ServerPlayerGameMode.java
|
2024-06-14 08:56:28 +00:00
|
|
|
@@ -204,7 +204,7 @@ public class ServerPlayerGameMode {
|
2023-12-03 03:41:35 +00:00
|
|
|
PlayerInteractEvent event = CraftEventFactory.callPlayerInteractEvent(this.player, Action.LEFT_CLICK_BLOCK, pos, direction, this.player.getInventory().getSelected(), InteractionHand.MAIN_HAND);
|
|
|
|
if (event.isCancelled()) {
|
|
|
|
// Let the client know the block still exists
|
|
|
|
- this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, pos));
|
|
|
|
+ // this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, pos)); // Paper - Don't resync blocks
|
|
|
|
// Update any tile entity data for this block
|
2024-01-18 14:56:25 +00:00
|
|
|
capturedBlockEntity = true; // Paper - Send block entities after destroy prediction
|
2023-12-03 03:41:35 +00:00
|
|
|
return;
|
2024-06-14 08:56:28 +00:00
|
|
|
@@ -219,7 +219,7 @@ public class ServerPlayerGameMode {
|
2023-12-03 03:41:35 +00:00
|
|
|
// Spigot start - handle debug stick left click for non-creative
|
|
|
|
if (this.player.getMainHandItem().is(net.minecraft.world.item.Items.DEBUG_STICK)
|
|
|
|
&& ((net.minecraft.world.item.DebugStickItem) net.minecraft.world.item.Items.DEBUG_STICK).handleInteraction(this.player, this.level.getBlockState(pos), this.level, pos, false, this.player.getMainHandItem())) {
|
|
|
|
- this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, pos));
|
|
|
|
+ // this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, pos)); // Paper - Don't resync block
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
// Spigot end
|
2024-06-14 08:56:28 +00:00
|
|
|
@@ -237,15 +237,17 @@ public class ServerPlayerGameMode {
|
2023-12-03 03:41:35 +00:00
|
|
|
// CraftBukkit start - Swings at air do *NOT* exist.
|
|
|
|
if (event.useInteractedBlock() == Event.Result.DENY) {
|
|
|
|
// If we denied a door from opening, we need to send a correcting update to the client, as it already opened the door.
|
|
|
|
- BlockState data = this.level.getBlockState(pos);
|
|
|
|
- if (data.getBlock() instanceof DoorBlock) {
|
|
|
|
- // For some reason *BOTH* the bottom/top part have to be marked updated.
|
|
|
|
- boolean bottom = data.getValue(DoorBlock.HALF) == DoubleBlockHalf.LOWER;
|
|
|
|
- this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, pos));
|
|
|
|
- this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, bottom ? pos.above() : pos.below()));
|
|
|
|
- } else if (data.getBlock() instanceof TrapDoorBlock) {
|
|
|
|
- this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, pos));
|
|
|
|
- }
|
|
|
|
+ // Paper start - Don't resync blocks
|
|
|
|
+ //BlockState data = this.level.getBlockState(pos);
|
|
|
|
+ //if (data.getBlock() instanceof DoorBlock) {
|
|
|
|
+ // // For some reason *BOTH* the bottom/top part have to be marked updated.
|
|
|
|
+ // boolean bottom = data.getValue(DoorBlock.HALF) == DoubleBlockHalf.LOWER;
|
|
|
|
+ // this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, pos));
|
|
|
|
+ // this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, bottom ? pos.above() : pos.below()));
|
|
|
|
+ //} else if (data.getBlock() instanceof TrapDoorBlock) {
|
|
|
|
+ // this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, pos));
|
|
|
|
+ //}
|
2024-01-13 15:35:59 +00:00
|
|
|
+ // Paper end - Don't resync blocks
|
2023-12-03 03:41:35 +00:00
|
|
|
} else if (!iblockdata.isAir()) {
|
2024-06-14 08:56:28 +00:00
|
|
|
EnchantmentHelper.onHitBlock(this.level, this.player.getMainHandItem(), this.player, this.player, EquipmentSlot.MAINHAND, Vec3.atCenterOf(pos), iblockdata, (item) -> {
|
|
|
|
this.player.onEquippedItemBroken(item, EquipmentSlot.MAINHAND);
|
|
|
|
@@ -257,7 +259,7 @@ public class ServerPlayerGameMode {
|
2023-12-03 03:41:35 +00:00
|
|
|
if (event.useItemInHand() == Event.Result.DENY) {
|
|
|
|
// If we 'insta destroyed' then the client needs to be informed.
|
|
|
|
if (f > 1.0f) {
|
|
|
|
- this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, pos));
|
|
|
|
+ // this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, pos)); // Paper - Don't resync blocks
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
2024-06-14 08:56:28 +00:00
|
|
|
@@ -265,7 +267,7 @@ public class ServerPlayerGameMode {
|
2023-12-03 03:41:35 +00:00
|
|
|
|
|
|
|
if (blockEvent.isCancelled()) {
|
|
|
|
// Let the client know the block still exists
|
|
|
|
- this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, pos));
|
|
|
|
+ // this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, pos)); // Paper - Don't resync block
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2024-06-14 08:56:28 +00:00
|
|
|
@@ -356,7 +358,7 @@ public class ServerPlayerGameMode {
|
2023-12-03 03:41:35 +00:00
|
|
|
|
|
|
|
// Tell client the block is gone immediately then process events
|
|
|
|
// Don't tell the client if its a creative sword break because its not broken!
|
|
|
|
- if (this.level.getBlockEntity(pos) == null && !isSwordNoBreak) {
|
|
|
|
+ if (false && this.level.getBlockEntity(pos) == null && !isSwordNoBreak) { // Paper - Don't resync block
|
|
|
|
ClientboundBlockUpdatePacket packet = new ClientboundBlockUpdatePacket(pos, Blocks.AIR.defaultBlockState());
|
|
|
|
this.player.connection.send(packet);
|
|
|
|
}
|
2024-06-14 08:56:28 +00:00
|
|
|
@@ -382,13 +384,15 @@ public class ServerPlayerGameMode {
|
2023-12-03 03:41:35 +00:00
|
|
|
if (isSwordNoBreak) {
|
|
|
|
return false;
|
|
|
|
}
|
2024-01-13 15:35:59 +00:00
|
|
|
+ // Paper start - Don't resync blocks
|
2023-12-03 03:41:35 +00:00
|
|
|
// Let the client know the block still exists
|
|
|
|
- this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, pos));
|
|
|
|
+ //this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, pos));
|
|
|
|
|
|
|
|
// Brute force all possible updates
|
|
|
|
- for (Direction dir : Direction.values()) {
|
|
|
|
- this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, pos.relative(dir)));
|
|
|
|
- }
|
|
|
|
+ //for (Direction dir : Direction.values()) {
|
|
|
|
+ // this.player.connection.send(new ClientboundBlockUpdatePacket(this.level, pos.relative(dir)));
|
|
|
|
+ //}
|
2024-01-13 15:35:59 +00:00
|
|
|
+ // Paper end - Don't resync blocks
|
2023-12-03 03:41:35 +00:00
|
|
|
|
|
|
|
// Update any tile entity data for this block
|
2024-01-18 14:56:25 +00:00
|
|
|
if (!captureSentBlockEntities) { // Paper - Send block entities after destroy prediction
|
2024-06-14 08:56:28 +00:00
|
|
|
@@ -537,16 +541,18 @@ public class ServerPlayerGameMode {
|
2023-12-03 03:41:35 +00:00
|
|
|
if (event.useInteractedBlock() == Event.Result.DENY) {
|
|
|
|
// If we denied a door from opening, we need to send a correcting update to the client, as it already opened the door.
|
|
|
|
if (iblockdata.getBlock() instanceof DoorBlock) {
|
|
|
|
- boolean bottom = iblockdata.getValue(DoorBlock.HALF) == DoubleBlockHalf.LOWER;
|
|
|
|
- player.connection.send(new ClientboundBlockUpdatePacket(world, bottom ? blockposition.above() : blockposition.below()));
|
|
|
|
+ // Paper start - Don't resync blocks
|
|
|
|
+ // boolean bottom = iblockdata.getValue(DoorBlock.HALF) == DoubleBlockHalf.LOWER;
|
|
|
|
+ // player.connection.send(new ClientboundBlockUpdatePacket(world, bottom ? blockposition.above() : blockposition.below()));
|
2024-01-13 15:35:59 +00:00
|
|
|
+ // Paper end - Don't resync blocks
|
2023-12-03 03:41:35 +00:00
|
|
|
} else if (iblockdata.getBlock() instanceof CakeBlock) {
|
|
|
|
player.getBukkitEntity().sendHealthUpdate(); // SPIGOT-1341 - reset health for cake
|
|
|
|
} else if (this.interactItemStack.getItem() instanceof DoubleHighBlockItem) {
|
|
|
|
// send a correcting update to the client, as it already placed the upper half of the bisected item
|
|
|
|
- player.connection.send(new ClientboundBlockUpdatePacket(world, blockposition.relative(hitResult.getDirection()).above()));
|
2024-01-13 15:35:59 +00:00
|
|
|
+ //player.connection.send(new ClientboundBlockUpdatePacket(world, blockposition.relative(hitResult.getDirection()).above())); // Paper - Don't resync blocks
|
2023-12-03 03:41:35 +00:00
|
|
|
|
|
|
|
// send a correcting update to the client for the block above as well, this because of replaceable blocks (such as grass, sea grass etc)
|
|
|
|
- player.connection.send(new ClientboundBlockUpdatePacket(world, blockposition.above()));
|
2024-01-13 15:35:59 +00:00
|
|
|
+ //player.connection.send(new ClientboundBlockUpdatePacket(world, blockposition.above())); // Paper - Don't resync blocks
|
2024-01-22 17:04:55 +00:00
|
|
|
// Paper start - extend Player Interact cancellation // TODO: consider merging this into the extracted method
|
2024-05-26 20:54:55 +00:00
|
|
|
} else if (iblockdata.is(Blocks.JIGSAW) || iblockdata.is(Blocks.STRUCTURE_BLOCK) || iblockdata.getBlock() instanceof net.minecraft.world.level.block.CommandBlock) {
|
2023-12-03 03:41:35 +00:00
|
|
|
player.connection.send(new net.minecraft.network.protocol.game.ClientboundContainerClosePacket(this.player.containerMenu.containerId));
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/item/BucketItem.java b/src/main/java/net/minecraft/world/item/BucketItem.java
|
2024-06-14 08:56:28 +00:00
|
|
|
index 6caed156ed0cfe0017d578f58cb963ee68272d78..321188173918d0d60858a258400dfd682ccdb21c 100644
|
2023-12-03 03:41:35 +00:00
|
|
|
--- a/src/main/java/net/minecraft/world/item/BucketItem.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/item/BucketItem.java
|
2024-06-14 08:56:28 +00:00
|
|
|
@@ -79,7 +79,7 @@ public class BucketItem extends Item implements DispensibleContainerItem {
|
2023-12-03 03:41:35 +00:00
|
|
|
PlayerBucketFillEvent event = CraftEventFactory.callPlayerBucketFillEvent((ServerLevel) world, user, blockposition, blockposition, movingobjectpositionblock.getDirection(), itemstack, dummyFluid.getItem(), hand);
|
|
|
|
|
|
|
|
if (event.isCancelled()) {
|
|
|
|
- ((ServerPlayer) user).connection.send(new ClientboundBlockUpdatePacket(world, blockposition)); // SPIGOT-5163 (see PlayerInteractManager)
|
|
|
|
+ // ((ServerPlayer) user).connection.send(new ClientboundBlockUpdatePacket(world, blockposition)); // SPIGOT-5163 (see PlayerInteractManager) // Paper - Don't resend blocks
|
|
|
|
((ServerPlayer) user).getBukkitEntity().updateInventory(); // SPIGOT-4541
|
|
|
|
return InteractionResultHolder.fail(itemstack);
|
|
|
|
}
|
2024-06-14 08:56:28 +00:00
|
|
|
@@ -187,7 +187,7 @@ public class BucketItem extends Item implements DispensibleContainerItem {
|
2023-12-03 03:41:35 +00:00
|
|
|
if (flag2 && entityhuman != null) {
|
|
|
|
PlayerBucketEmptyEvent event = CraftEventFactory.callPlayerBucketEmptyEvent((ServerLevel) world, entityhuman, blockposition, clicked, enumdirection, itemstack, enumhand);
|
|
|
|
if (event.isCancelled()) {
|
|
|
|
- ((ServerPlayer) entityhuman).connection.send(new ClientboundBlockUpdatePacket(world, blockposition)); // SPIGOT-4238: needed when looking through entity
|
|
|
|
+ // ((ServerPlayer) entityhuman).connection.send(new ClientboundBlockUpdatePacket(world, blockposition)); // SPIGOT-4238: needed when looking through entity // Paper - Don't resend blocks
|
|
|
|
((ServerPlayer) entityhuman).getBukkitEntity().updateInventory(); // SPIGOT-4541
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/item/ItemStack.java b/src/main/java/net/minecraft/world/item/ItemStack.java
|
2024-06-14 08:56:28 +00:00
|
|
|
index 1f2e6f57ffb827ef9bf3623bfdde07db21edf6ee..486c3769a0e6a1ecb5530a35e2591f78776619b9 100644
|
2023-12-03 03:41:35 +00:00
|
|
|
--- a/src/main/java/net/minecraft/world/item/ItemStack.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/item/ItemStack.java
|
2024-06-14 08:56:28 +00:00
|
|
|
@@ -500,10 +500,12 @@ public final class ItemStack implements DataComponentHolder {
|
2023-12-03 03:41:35 +00:00
|
|
|
world.preventPoiUpdated = false;
|
|
|
|
|
|
|
|
// Brute force all possible updates
|
|
|
|
- BlockPos placedPos = ((CraftBlock) placeEvent.getBlock()).getPosition();
|
|
|
|
- for (Direction dir : Direction.values()) {
|
|
|
|
- ((ServerPlayer) entityhuman).connection.send(new ClientboundBlockUpdatePacket(world, placedPos.relative(dir)));
|
|
|
|
- }
|
2024-01-13 15:35:59 +00:00
|
|
|
+ // Paper start - Don't resync blocks
|
2023-12-03 03:41:35 +00:00
|
|
|
+ // BlockPos placedPos = ((CraftBlock) placeEvent.getBlock()).getPosition();
|
|
|
|
+ // for (Direction dir : Direction.values()) {
|
|
|
|
+ // ((ServerPlayer) entityhuman).connection.send(new ClientboundBlockUpdatePacket(world, placedPos.relative(dir)));
|
|
|
|
+ // }
|
2024-01-13 15:35:59 +00:00
|
|
|
+ // Paper end - Don't resync blocks
|
2023-12-03 03:41:35 +00:00
|
|
|
SignItem.openSign = null; // SPIGOT-6758 - Reset on early return
|
|
|
|
} else {
|
|
|
|
// Change the stack to its new contents if it hasn't been tampered with.
|