From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: nostalgic853 Date: Sun, 20 Nov 2022 00:20:00 +0800 Subject: [PATCH] KeYi: Player Skull API Original license: MIT Original project: https://github.com/KeYiMC/KeYi diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java index e3100e65fea02374d4393bab48d63ddeaecef0ab..1f70d832b0287f446722745a65062813e84be566 100644 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java @@ -3649,4 +3649,31 @@ public class CraftPlayer extends CraftHumanEntity implements Player { this.getHandle().connection.send(new net.minecraft.network.protocol.game.ClientboundPlayerCombatKillPacket(getEntityId(), io.papermc.paper.adventure.PaperAdventure.asVanilla(message))); } // Purpur end + + // Leaf start - KeYi - Player Skull API + @Override + public ItemStack getSkull() { + ItemStack skull = new ItemStack(Material.PLAYER_HEAD, 1); + org.bukkit.inventory.meta.SkullMeta meta = (org.bukkit.inventory.meta.SkullMeta) skull.getItemMeta(); + + meta.setOwningPlayer(this); + skull.setItemMeta(meta); + + return skull; + } + + @Override + @Deprecated(forRemoval = true) + public CompletableFuture getSkullAsynchronously() { + org.apache.logging.log4j.LogManager.getLogger("Leaf") + .warn("You should not use this method: Player#getSkullAsynchronously(), cause low performance, " + + "and will be removed in the future."); + java.util.concurrent.ExecutorService executorService = java.util.concurrent.Executors.newCachedThreadPool(); + + CompletableFuture future = (CompletableFuture) executorService.submit(this::getSkull); + executorService.shutdown(); + + return future; + } + // Leaf end - KeYi - Player Skull API }