41e6f20420
Upstream has released updates that appear to apply and compile correctly. This update has not been tested by PaperMC and as with ANY update, please do your own testing Bukkit Changes: fdff0cd4 PR-869: Add Enderman#teleport and Enderman#teleportTowards dfd86ee7 Improve sendSignChange and related documentation beced2b2 PR-867: Add Player#sendBlockUpdate to send tile entity updates CraftBukkit Changes: ad6d0cffb SPIGOT-7394: Fix another issue with sendSignChange 66c5ce4c7 SPIGOT-7391: Preserve vanilla sign json where not modified by event ae3824f94 PR-1204: Add Enderman#teleport and Enderman#teleportTowards 5863a2eae Fix sendSignChange not working 4a7eadc97 PR-1201: Add Player#sendBlockUpdate to send tile entity updates 789324e30 Work around issue placing decorated pots
40 lines
2 KiB
Diff
40 lines
2 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Brody Beckwith <brody@beckwith.dev>
|
|
Date: Fri, 14 Jan 2022 00:40:42 -0500
|
|
Subject: [PATCH] Multi Block Change API
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/entity/Player.java b/src/main/java/org/bukkit/entity/Player.java
|
|
index 18e098920193438d171ca57e505e20c6c96742ae..505fdb8885b05be9fb51acda49530f8bf0e120ff 100644
|
|
--- a/src/main/java/org/bukkit/entity/Player.java
|
|
+++ b/src/main/java/org/bukkit/entity/Player.java
|
|
@@ -686,6 +686,29 @@ public interface Player extends HumanEntity, Conversable, OfflinePlayer, PluginM
|
|
*/
|
|
public void sendBlockDamage(@NotNull Location loc, float progress);
|
|
|
|
+ // Paper start
|
|
+ /**
|
|
+ * Send multiple block changes. This fakes a multi block change packet for each
|
|
+ * chunk section that a block change occurs. This will not actually change the world in any way.
|
|
+ *
|
|
+ * @param blockChanges A map of the positions you want to change to their new block data
|
|
+ */
|
|
+ void sendMultiBlockChange(@NotNull Map<? extends io.papermc.paper.math.Position, BlockData> blockChanges);
|
|
+
|
|
+ /**
|
|
+ * Send multiple block changes. This fakes a multi block change packet for each
|
|
+ * chunk section that a block change occurs. This will not actually change the world in any way.
|
|
+ *
|
|
+ * @param blockChanges A map of the positions you want to change to their new block data
|
|
+ * @param suppressLightUpdates Whether to suppress light updates or not
|
|
+ * @deprecated suppressLightUpdates is no longer available in 1.20+, use {@link #sendMultiBlockChange(Map)}
|
|
+ */
|
|
+ @Deprecated
|
|
+ default void sendMultiBlockChange(@NotNull Map<? extends io.papermc.paper.math.Position, BlockData> blockChanges, boolean suppressLightUpdates) {
|
|
+ this.sendMultiBlockChange(blockChanges);
|
|
+ }
|
|
+ // Paper end
|
|
+
|
|
/**
|
|
* Send block damage. This fakes block break progress at a certain location
|
|
* sourced by the provided entity. This will not actually change the block's
|