From e9cbd7b668e0a9f8703c5bb2517af8b471d0ebff Mon Sep 17 00:00:00 2001 From: Brokkonaut Date: Mon, 6 Aug 2018 07:24:55 +0200 Subject: [PATCH] [1.13] Skull block profile api (#1308) Adds #1307 --- ...Add-setPlayerProfile-API-for-Skulls.patch} | 36 ++++++++++++++- ...Add-setPlayerProfile-API-for-Skulls.patch} | 45 ++++++++++++++++++- 2 files changed, 78 insertions(+), 3 deletions(-) rename Spigot-API-Patches/{Add-SkullMeta.setPlayerProfile-API.patch => Add-setPlayerProfile-API-for-Skulls.patch} (53%) rename Spigot-Server-Patches/{Add-SkullMeta.setPlayerProfile-API.patch => Add-setPlayerProfile-API-for-Skulls.patch} (52%) diff --git a/Spigot-API-Patches/Add-SkullMeta.setPlayerProfile-API.patch b/Spigot-API-Patches/Add-setPlayerProfile-API-for-Skulls.patch similarity index 53% rename from Spigot-API-Patches/Add-SkullMeta.setPlayerProfile-API.patch rename to Spigot-API-Patches/Add-setPlayerProfile-API-for-Skulls.patch index b5298265f3..65b74e57d2 100644 --- a/Spigot-API-Patches/Add-SkullMeta.setPlayerProfile-API.patch +++ b/Spigot-API-Patches/Add-setPlayerProfile-API-for-Skulls.patch @@ -1,11 +1,45 @@ From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: Aikar Date: Fri, 19 Jan 2018 00:29:28 -0500 -Subject: [PATCH] Add SkullMeta.setPlayerProfile API +Subject: [PATCH] Add setPlayerProfile API for Skulls This allows you to create already filled textures on Skulls to avoid texture lookups which commonly cause rate limit issues with Mojang API +diff --git a/src/main/java/org/bukkit/block/Skull.java b/src/main/java/org/bukkit/block/Skull.java +index 92363d33..b83df2f7 100644 +--- a/src/main/java/org/bukkit/block/Skull.java ++++ b/src/main/java/org/bukkit/block/Skull.java +@@ -0,0 +0,0 @@ import org.bukkit.Material; + import org.bukkit.OfflinePlayer; + import org.bukkit.SkullType; + import org.bukkit.block.data.BlockData; ++import com.destroystokyo.paper.profile.PlayerProfile; ++import javax.annotation.Nullable; + + /** + * Represents a captured state of a skull block. +@@ -0,0 +0,0 @@ public interface Skull extends BlockState { + */ + public void setOwningPlayer(OfflinePlayer player); + ++ // Paper start ++ /** ++ * Sets this skull to use the supplied Player Profile, which can include textures already prefilled. ++ * @param profile The profile to set this Skull to use, may not be null ++ */ ++ void setPlayerProfile(PlayerProfile profile); ++ ++ /** ++ * If the skull has an owner, per {@link #hasOwner()}, return the owners {@link PlayerProfile} ++ * @return The profile of the owner, if set ++ */ ++ @Nullable PlayerProfile getPlayerProfile(); ++ // Paper end ++ + /** + * Gets the rotation of the skull in the world + * diff --git a/src/main/java/org/bukkit/inventory/meta/SkullMeta.java b/src/main/java/org/bukkit/inventory/meta/SkullMeta.java index 15c1dfd9..a458000f 100644 --- a/src/main/java/org/bukkit/inventory/meta/SkullMeta.java diff --git a/Spigot-Server-Patches/Add-SkullMeta.setPlayerProfile-API.patch b/Spigot-Server-Patches/Add-setPlayerProfile-API-for-Skulls.patch similarity index 52% rename from Spigot-Server-Patches/Add-SkullMeta.setPlayerProfile-API.patch rename to Spigot-Server-Patches/Add-setPlayerProfile-API-for-Skulls.patch index 3a5c721e08..dfdb557dc6 100644 --- a/Spigot-Server-Patches/Add-SkullMeta.setPlayerProfile-API.patch +++ b/Spigot-Server-Patches/Add-setPlayerProfile-API-for-Skulls.patch @@ -1,13 +1,54 @@ From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: Aikar Date: Fri, 19 Jan 2018 00:36:25 -0500 -Subject: [PATCH] Add SkullMeta.setPlayerProfile API +Subject: [PATCH] Add setPlayerProfile API for Skulls This allows you to create already filled textures on Skulls to avoid texture lookups which commonly cause rate limit issues with Mojang API +diff --git a/src/main/java/org/bukkit/craftbukkit/block/CraftSkull.java b/src/main/java/org/bukkit/craftbukkit/block/CraftSkull.java +index f113da713..fdfe101ae 100644 +--- a/src/main/java/org/bukkit/craftbukkit/block/CraftSkull.java ++++ b/src/main/java/org/bukkit/craftbukkit/block/CraftSkull.java +@@ -0,0 +0,0 @@ + package org.bukkit.craftbukkit.block; + ++import com.destroystokyo.paper.profile.CraftPlayerProfile; ++import com.destroystokyo.paper.profile.PlayerProfile; + import com.google.common.base.Preconditions; + import com.mojang.authlib.GameProfile; + import net.minecraft.server.MinecraftServer; +@@ -0,0 +0,0 @@ import org.bukkit.block.Block; + import org.bukkit.block.BlockFace; + import org.bukkit.block.Skull; + import org.bukkit.block.data.Rotatable; ++import javax.annotation.Nullable; + + public class CraftSkull extends CraftBlockEntityState implements Skull { + +@@ -0,0 +0,0 @@ public class CraftSkull extends CraftBlockEntityState implement + this.profile = new GameProfile(player.getUniqueId(), player.getName()); + } + ++ // Paper start ++ @Override ++ public void setPlayerProfile(PlayerProfile profile) { ++ Preconditions.checkNotNull(profile, "profile"); ++ this.profile = CraftPlayerProfile.asAuthlibCopy(profile); ++ } ++ ++ @Nullable ++ @Override ++ public PlayerProfile getPlayerProfile() { ++ return profile != null ? CraftPlayerProfile.asBukkitCopy(profile) : null; ++ } ++ // Paper end ++ + @Override + public BlockFace getRotation() { + return ((Rotatable) getBlockData()).getRotation(); diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java -index 7984c68cb0..14d8dd65ac 100644 +index 7984c68cb..14d8dd65a 100644 --- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java +++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java @@ -0,0 +0,0 @@ package org.bukkit.craftbukkit.inventory;