0b20f94297
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: 96340858 PR-938: Various Sound API improvements cbfe0ff0 PR-937: Minor improvements to World#rayTrace documentation e979ee95 PR-935: Change Consumer and Predicates to super 27ae46dc SPIGOT-3641, SPIGOT-7479, PR-931: Add missing values to EntityEffect 0616ec8b Add eclipse .factorypath file to .gitignore CraftBukkit Changes: 8e162d008 PR-1301: Various Sound API improvements eeb7dfc2d SPIGOT-7520: Attribute LootTableSeed missing for generated containers with attached LootTable d433f086d PR-1297: Change Consumer and Predicates to super 864f616da SPIGOT-7518: Fix NullPointerException when calling Block#applyBoneMeal() 5a2d905af Add eclipse .factorypath file to .gitignore 7c6bf15d4 Fix SkullMeta configuration serialization / deserialization with note block sound Spigot Changes: 7de1049b Rebuild patches
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 6d8e4f23095716eeaea16206c3a4bb36f794f29f..0e42cd429a75d10f8628acad319ee3dd2cdf02c3 100644
|
|
--- a/src/main/java/org/bukkit/entity/Player.java
|
|
+++ b/src/main/java/org/bukkit/entity/Player.java
|
|
@@ -851,6 +851,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
|