From a3a9180c517ebb878a8211bdcad4a8cf655b961a Mon Sep 17 00:00:00 2001 From: Trigary Date: Tue, 14 Apr 2020 12:06:14 +0200 Subject: [PATCH] Player elytra boost API --- .../main/java/org/bukkit/entity/Player.java | 19 +++++++++++++++++++ 1 file changed, 19 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 644c20bcf6..30d209eb19 100644 --- a/paper-api/src/main/java/org/bukkit/entity/Player.java +++ b/paper-api/src/main/java/org/bukkit/entity/Player.java @@ -3382,6 +3382,25 @@ public interface Player extends HumanEntity, Conversable, OfflinePlayer, PluginM @NotNull T getClientOption(com.destroystokyo.paper.@NotNull ClientOption option); // Paper end - client option API + // Paper start - elytra boost API + /** + * Boost a Player that's {@link #isGliding()} using a {@link Firework}. + * If the creation of the entity is cancelled, no boosting is done. + * This method does not fire {@link com.destroystokyo.paper.event.player.PlayerElytraBoostEvent}. + * + * @param firework The {@link Material#FIREWORK_ROCKET} to boost the player with + * @return The {@link Firework} boosting the Player or null if the spawning of the entity was cancelled + * @throws IllegalArgumentException if {@link #isGliding()} is false + * or if the {@code firework} isn't a {@link Material#FIREWORK_ROCKET} + * @deprecated use {@link HumanEntity#fireworkBoost(ItemStack)} instead. Note that this method does not + * check if the player is gliding or not. + */ + default @Nullable Firework boostElytra(final @NotNull ItemStack firework) { + com.google.common.base.Preconditions.checkState(this.isGliding(), "Player must be gliding"); + return this.fireworkBoost(firework); + } + // Paper end - elytra boost API + // Spigot start public class Spigot extends Entity.Spigot {