2022-01-20 12:50:50 -05:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Brody Beckwith <brody@beckwith.dev>
|
|
|
|
Date: Fri, 14 Jan 2022 00:41:11 -0500
|
|
|
|
Subject: [PATCH] Multi Block Change API Implementation
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/network/protocol/game/ClientboundSectionBlocksUpdatePacket.java b/src/main/java/net/minecraft/network/protocol/game/ClientboundSectionBlocksUpdatePacket.java
|
2024-04-24 10:59:51 -07:00
|
|
|
index 926ff9be3d9e3f5d620e4c7ccb22b9f64865ff8c..1a37654aff9a9c86c9f7af10a1cf721371f0c5ec 100644
|
2022-01-20 12:50:50 -05:00
|
|
|
--- a/src/main/java/net/minecraft/network/protocol/game/ClientboundSectionBlocksUpdatePacket.java
|
|
|
|
+++ b/src/main/java/net/minecraft/network/protocol/game/ClientboundSectionBlocksUpdatePacket.java
|
2024-04-24 10:59:51 -07:00
|
|
|
@@ -62,6 +62,14 @@ public class ClientboundSectionBlocksUpdatePacket implements Packet<ClientGamePa
|
2022-01-20 12:50:50 -05:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2024-01-18 22:00:40 +01:00
|
|
|
+ // Paper start - Multi Block Change API
|
2023-06-08 13:56:13 -07:00
|
|
|
+ public ClientboundSectionBlocksUpdatePacket(SectionPos sectionPos, it.unimi.dsi.fastutil.shorts.Short2ObjectMap<BlockState> blockChanges) {
|
2022-01-20 12:50:50 -05:00
|
|
|
+ this.sectionPos = sectionPos;
|
|
|
|
+ this.positions = blockChanges.keySet().toShortArray();
|
|
|
|
+ this.states = blockChanges.values().toArray(new BlockState[0]);
|
|
|
|
+ }
|
2024-01-18 22:00:40 +01:00
|
|
|
+ // Paper end - Multi Block Change API
|
2022-01-20 12:50:50 -05:00
|
|
|
+
|
2024-04-24 10:59:51 -07:00
|
|
|
private void write(FriendlyByteBuf buf) {
|
2022-01-20 12:50:50 -05:00
|
|
|
buf.writeLong(this.sectionPos.asLong());
|
2024-04-24 10:59:51 -07:00
|
|
|
buf.writeVarInt(this.positions.length);
|
2022-01-20 12:50:50 -05:00
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
2024-04-25 18:51:28 -07:00
|
|
|
index cc6d0b713f839d482dfba8a1e83f927923c9c690..ee31c18ae530cb064ae9d1cc3f3d68312c1f854c 100644
|
2022-01-20 12:50:50 -05:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
2024-04-25 23:21:18 +02:00
|
|
|
@@ -928,6 +928,32 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
|
2022-01-20 12:50:50 -05:00
|
|
|
this.getHandle().connection.send(packet);
|
|
|
|
}
|
|
|
|
|
|
|
|
+ // Paper start
|
|
|
|
+ @Override
|
2023-06-08 13:56:13 -07:00
|
|
|
+ public void sendMultiBlockChange(final Map<? extends io.papermc.paper.math.Position, BlockData> blockChanges) {
|
2022-01-20 12:50:50 -05:00
|
|
|
+ if (this.getHandle().connection == null) return;
|
|
|
|
+
|
|
|
|
+ Map<SectionPos, it.unimi.dsi.fastutil.shorts.Short2ObjectMap<net.minecraft.world.level.block.state.BlockState>> sectionMap = new HashMap<>();
|
|
|
|
+
|
2023-04-07 11:39:13 -07:00
|
|
|
+ for (Map.Entry<? extends io.papermc.paper.math.Position, BlockData> entry : blockChanges.entrySet()) {
|
2022-01-20 12:50:50 -05:00
|
|
|
+ BlockData blockData = entry.getValue();
|
2023-04-07 11:39:13 -07:00
|
|
|
+ BlockPos blockPos = io.papermc.paper.util.MCUtil.toBlockPos(entry.getKey());
|
2022-01-20 12:50:50 -05:00
|
|
|
+ SectionPos sectionPos = SectionPos.of(blockPos);
|
|
|
|
+
|
|
|
|
+ it.unimi.dsi.fastutil.shorts.Short2ObjectMap<net.minecraft.world.level.block.state.BlockState> sectionData = sectionMap.computeIfAbsent(sectionPos, key -> new it.unimi.dsi.fastutil.shorts.Short2ObjectArrayMap<>());
|
|
|
|
+ sectionData.put(SectionPos.sectionRelativePos(blockPos), ((CraftBlockData) blockData).getState());
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ for (Map.Entry<SectionPos, it.unimi.dsi.fastutil.shorts.Short2ObjectMap<net.minecraft.world.level.block.state.BlockState>> entry : sectionMap.entrySet()) {
|
|
|
|
+ SectionPos sectionPos = entry.getKey();
|
|
|
|
+ it.unimi.dsi.fastutil.shorts.Short2ObjectMap<net.minecraft.world.level.block.state.BlockState> blockData = entry.getValue();
|
|
|
|
+
|
2023-06-08 13:56:13 -07:00
|
|
|
+ net.minecraft.network.protocol.game.ClientboundSectionBlocksUpdatePacket packet = new net.minecraft.network.protocol.game.ClientboundSectionBlocksUpdatePacket(sectionPos, blockData);
|
2022-01-20 12:50:50 -05:00
|
|
|
+ this.getHandle().connection.send(packet);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
+
|
|
|
|
@Override
|
2023-06-08 04:08:08 -04:00
|
|
|
public void sendBlockChanges(Collection<BlockState> blocks) {
|
2022-09-24 02:38:12 +01:00
|
|
|
Preconditions.checkArgument(blocks != null, "blocks must not be null");
|