mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-04 02:01:44 +01:00
2f92d4e00e
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: 01bb6ba7 PR-936: Add new PersistentDataContainer methods and clean up docs bc145b90 PR-940: Create registry for banner pattern and cat type CraftBukkit Changes: cb2ea54de SPIGOT-7440, PR-1292: Fire EntityTeleportEvent for end gateways 4fea66e44 PR-1299: Add new PersistentDataContainer methods and clean up docs b483a20db PR-1303: Create registry for banner pattern and cat type 4642dd526 SPIGOT-7535: Fix maps not having an ID and also call MapInitializeEvent in more places
53 lines
2 KiB
Diff
53 lines
2 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: SoSeDiK <mrsosedik@gmail.com>
|
|
Date: Wed, 11 Jan 2023 20:59:02 +0200
|
|
Subject: [PATCH] Expand Pose API
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/entity/Entity.java b/src/main/java/org/bukkit/entity/Entity.java
|
|
index 82c67193a2dbb7b0bd0d6381cd0e06af49415d18..1d0fd7ff8449f815a7d980af0b378181ea8bf8d8 100644
|
|
--- a/src/main/java/org/bukkit/entity/Entity.java
|
|
+++ b/src/main/java/org/bukkit/entity/Entity.java
|
|
@@ -799,6 +799,42 @@ public interface Entity extends Metadatable, CommandSender, Nameable, Persistent
|
|
* @param sneak true if the entity should be sneaking
|
|
*/
|
|
void setSneaking(boolean sneak);
|
|
+
|
|
+ /**
|
|
+ * Sets the entity's current {@link Pose}.
|
|
+ *
|
|
+ * <p>Note: While poses affect some things like hitboxes, they do not change the entity's state
|
|
+ * (e.g. having {@link Pose#SNEAKING} does not guarantee {@link #isSneaking()} being {@code true}).
|
|
+ *
|
|
+ * <p>If applied to the {@link Player}, they might see a different pose client-side.
|
|
+ *
|
|
+ * @param pose a new {@link Pose}
|
|
+ * @see #setPose(Pose, boolean)
|
|
+ */
|
|
+ default void setPose(@NotNull Pose pose) {
|
|
+ setPose(pose, false);
|
|
+ }
|
|
+
|
|
+ /**
|
|
+ * Sets the entity's current {@link Pose}.
|
|
+ *
|
|
+ * <p>Note: While poses affect some things like hitboxes, they do not change the entity's state
|
|
+ * (e.g. having {@link Pose#SNEAKING} does not guarantee {@link #isSneaking()} being {@code true}).
|
|
+ *
|
|
+ * <p>If applied to the {@link Player}, they might see a different pose client-side.
|
|
+ *
|
|
+ * @param pose a new {@link Pose}
|
|
+ * @param fixed whether the new {@link Pose} should stay until manually changed
|
|
+ */
|
|
+ void setPose(@NotNull Pose pose, boolean fixed);
|
|
+
|
|
+ /**
|
|
+ * Checks whether the entity has a fixed {@link Pose}
|
|
+ *
|
|
+ * @see #setPose(Pose, boolean)
|
|
+ * @return whether the entity has a fixed {@link Pose}
|
|
+ */
|
|
+ boolean hasFixedPose();
|
|
// Paper end
|
|
|
|
/**
|