From da77e72dce16886d82258a2bf03b32e54fee2a73 Mon Sep 17 00:00:00 2001 From: Brody Beckwith Date: Fri, 14 Jan 2022 00:40:42 -0500 Subject: [PATCH] Multi Block Change API --- .../main/java/org/bukkit/entity/Player.java | 23 +++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/paper-api/src/main/java/org/bukkit/entity/Player.java b/paper-api/src/main/java/org/bukkit/entity/Player.java index 68c470b950..db3a1e9170 100644 --- a/paper-api/src/main/java/org/bukkit/entity/Player.java +++ b/paper-api/src/main/java/org/bukkit/entity/Player.java @@ -977,6 +977,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 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 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