mirror of
https://github.com/dmulloy2/ProtocolLib.git
synced 2025-01-07 08:58:34 +01:00
Restore ItemStack to CraftItemStack conversion
This commit is contained in:
parent
d175a7655e
commit
33bb12713d
@ -1847,121 +1847,6 @@ public class MinecraftReflection {
|
|||||||
return getMinecraftClass("NonNullList");
|
return getMinecraftClass("NonNullList");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Retrieve a CraftItemStack from a given ItemStack.
|
|
||||||
* @param bukkitItemStack - the Bukkit ItemStack to convert.
|
|
||||||
* @return A CraftItemStack as an ItemStack.
|
|
||||||
*/
|
|
||||||
/* public static ItemStack getBukkitItemStack(ItemStack bukkitItemStack) {
|
|
||||||
// Delegate this task to the method that can execute it
|
|
||||||
if (craftBukkitNMS != null)
|
|
||||||
return getBukkitItemByMethod(bukkitItemStack);
|
|
||||||
|
|
||||||
if (craftBukkitConstructor == null) {
|
|
||||||
try {
|
|
||||||
craftBukkitConstructor = getCraftItemStackClass().getConstructor(ItemStack.class);
|
|
||||||
} catch (Exception e) {
|
|
||||||
// See if this method works
|
|
||||||
if (!craftItemStackFailed)
|
|
||||||
return getBukkitItemByMethod(bukkitItemStack);
|
|
||||||
|
|
||||||
throw new RuntimeException("Cannot find CraftItemStack(org.bukkit.inventory.ItemStack).", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Try to create the CraftItemStack
|
|
||||||
try {
|
|
||||||
return (ItemStack) craftBukkitConstructor.newInstance(bukkitItemStack);
|
|
||||||
} catch (Exception e) {
|
|
||||||
throw new RuntimeException("Cannot construct CraftItemStack.", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static ItemStack getBukkitItemByMethod(ItemStack bukkitItemStack) {
|
|
||||||
if (craftBukkitNMS == null) {
|
|
||||||
try {
|
|
||||||
craftBukkitNMS = getCraftItemStackClass().getMethod("asNMSCopy", ItemStack.class);
|
|
||||||
craftBukkitOBC = getCraftItemStackClass().getMethod("asCraftMirror", MinecraftReflection.getItemStackClass());
|
|
||||||
} catch (Exception e) {
|
|
||||||
craftItemStackFailed = true;
|
|
||||||
throw new RuntimeException("Cannot find CraftItemStack.asCraftCopy(org.bukkit.inventory.ItemStack).", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Next, construct it
|
|
||||||
try {
|
|
||||||
Object nmsItemStack = craftBukkitNMS.invoke(null, bukkitItemStack);
|
|
||||||
return (ItemStack) craftBukkitOBC.invoke(null, nmsItemStack);
|
|
||||||
} catch (Exception e) {
|
|
||||||
throw new RuntimeException("Cannot construct CraftItemStack.", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Retrieve the Bukkit ItemStack from a given net.minecraft.server ItemStack.
|
|
||||||
* @param minecraftItemStack - the NMS ItemStack to wrap.
|
|
||||||
* @return The wrapped ItemStack.
|
|
||||||
*/
|
|
||||||
/* public static ItemStack getBukkitItemStack(Object minecraftItemStack) {
|
|
||||||
// Delegate this task to the method that can execute it
|
|
||||||
if (craftNMSMethod != null)
|
|
||||||
return getBukkitItemByMethod(minecraftItemStack);
|
|
||||||
|
|
||||||
if (craftNMSConstructor == null) {
|
|
||||||
try {
|
|
||||||
craftNMSConstructor = getCraftItemStackClass().getConstructor(minecraftItemStack.getClass());
|
|
||||||
} catch (Exception e) {
|
|
||||||
// Give it a try
|
|
||||||
if (!craftItemStackFailed)
|
|
||||||
return getBukkitItemByMethod(minecraftItemStack);
|
|
||||||
|
|
||||||
throw new RuntimeException("Cannot find CraftItemStack(net.minecraft.server.ItemStack).", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Try to create the CraftItemStack
|
|
||||||
try {
|
|
||||||
return (ItemStack) craftNMSConstructor.newInstance(minecraftItemStack);
|
|
||||||
} catch (Exception e) {
|
|
||||||
throw new RuntimeException("Cannot construct CraftItemStack.", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static ItemStack getBukkitItemByMethod(Object minecraftItemStack) {
|
|
||||||
if (craftNMSMethod == null) {
|
|
||||||
try {
|
|
||||||
craftNMSMethod = getCraftItemStackClass().getMethod("asCraftMirror", minecraftItemStack.getClass());
|
|
||||||
} catch (Exception e) {
|
|
||||||
craftItemStackFailed = true;
|
|
||||||
throw new RuntimeException("Cannot find CraftItemStack.asCraftMirror(net.minecraft.server.ItemStack).", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Next, construct it
|
|
||||||
try {
|
|
||||||
return (ItemStack) craftNMSMethod.invoke(null, minecraftItemStack);
|
|
||||||
} catch (Exception e) {
|
|
||||||
throw new RuntimeException("Cannot construct CraftItemStack.", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Retrieve the net.minecraft.server ItemStack from a Bukkit ItemStack.
|
|
||||||
* <p>
|
|
||||||
* By convention, item stacks that contain air are usually represented as NULL.
|
|
||||||
*
|
|
||||||
* @param stack - the Bukkit ItemStack to convert.
|
|
||||||
* @return The NMS ItemStack, or NULL if the stack represents air.
|
|
||||||
*/
|
|
||||||
/* public static Object getMinecraftItemStack(ItemStack stack) {
|
|
||||||
// Make sure this is a CraftItemStack
|
|
||||||
if (!isCraftItemStack(stack))
|
|
||||||
stack = getBukkitItemStack(stack);
|
|
||||||
|
|
||||||
BukkitUnwrapper unwrapper = new BukkitUnwrapper();
|
|
||||||
return unwrapper.unwrapItem(stack);
|
|
||||||
} */
|
|
||||||
|
|
||||||
// ---- ItemStack conversions
|
// ---- ItemStack conversions
|
||||||
|
|
||||||
private static Method asNMSCopy = null;
|
private static Method asNMSCopy = null;
|
||||||
@ -1973,24 +1858,38 @@ public class MinecraftReflection {
|
|||||||
/**
|
/**
|
||||||
* Retrieves the Bukkit equivalent of a NMS ItemStack. This method should
|
* Retrieves the Bukkit equivalent of a NMS ItemStack. This method should
|
||||||
* preserve NBT data and will never return null when supplied with a valid
|
* preserve NBT data and will never return null when supplied with a valid
|
||||||
* ItemStack. Empty ItemStacks are returned as AIR.
|
* ItemStack. Empty ItemStacks are treated as AIR.
|
||||||
*
|
*
|
||||||
* @param generic NMS ItemStack
|
* @param generic NMS ItemStack
|
||||||
* @return The Bukkit equivalent
|
* @return The Bukkit equivalent
|
||||||
*/
|
*/
|
||||||
public static ItemStack getBukkitItemStack(Object generic) {
|
public static ItemStack getBukkitItemStack(Object generic) {
|
||||||
// Make sure it actually is an ItemStack
|
|
||||||
if (!is(getItemStackClass(), generic)) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Convert null to AIR
|
|
||||||
if (generic == null) {
|
if (generic == null) {
|
||||||
|
// Convert null to AIR - 1.11 behavior
|
||||||
return new ItemStack(Material.AIR);
|
return new ItemStack(Material.AIR);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check null enforcement
|
if (generic instanceof ItemStack) {
|
||||||
|
ItemStack bukkit = (ItemStack) generic;
|
||||||
|
|
||||||
|
// They're probably looking for the CraftItemStack
|
||||||
|
// If it's one already our work is done
|
||||||
|
if (is(getCraftItemStackClass(), generic)) {
|
||||||
|
return bukkit;
|
||||||
|
}
|
||||||
|
|
||||||
|
// If not, convert it to one
|
||||||
|
Object nmsStack = getMinecraftItemStack((ItemStack) generic);
|
||||||
|
return getBukkitItemStack(nmsStack);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!is(getItemStackClass(), generic)) {
|
||||||
|
// We can't do anything with non-ItemStacks
|
||||||
|
throw new IllegalArgumentException(generic + " is not an ItemStack!");
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
// Check null enforcement - 1.11 behavior
|
||||||
if (nullEnforced == null) {
|
if (nullEnforced == null) {
|
||||||
isEmpty = getItemStackClass().getMethod("isEmpty");
|
isEmpty = getItemStackClass().getMethod("isEmpty");
|
||||||
nullEnforced = true;
|
nullEnforced = true;
|
||||||
@ -2005,7 +1904,6 @@ public class MinecraftReflection {
|
|||||||
nullEnforced = false;
|
nullEnforced = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Find asCraftMirror
|
|
||||||
if (asCraftMirror == null) {
|
if (asCraftMirror == null) {
|
||||||
try {
|
try {
|
||||||
asCraftMirror = getCraftItemStackClass().getMethod("asCraftMirror", getItemStackClass());
|
asCraftMirror = getCraftItemStackClass().getMethod("asCraftMirror", getItemStackClass());
|
||||||
@ -2014,8 +1912,8 @@ public class MinecraftReflection {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Convert to a craft mirror to preserve NBT data
|
|
||||||
try {
|
try {
|
||||||
|
// Convert to a craft mirror to preserve NBT data
|
||||||
return (ItemStack) asCraftMirror.invoke(nullEnforced, generic);
|
return (ItemStack) asCraftMirror.invoke(nullEnforced, generic);
|
||||||
} catch (ReflectiveOperationException ex) {
|
} catch (ReflectiveOperationException ex) {
|
||||||
throw new RuntimeException("Failed to obtain craft mirror of " + generic, ex);
|
throw new RuntimeException("Failed to obtain craft mirror of " + generic, ex);
|
||||||
@ -2031,7 +1929,6 @@ public class MinecraftReflection {
|
|||||||
* @return The NMS equivalent
|
* @return The NMS equivalent
|
||||||
*/
|
*/
|
||||||
public static Object getMinecraftItemStack(ItemStack specific) {
|
public static Object getMinecraftItemStack(ItemStack specific) {
|
||||||
// Grab asNMSCopy first
|
|
||||||
if (asNMSCopy == null) {
|
if (asNMSCopy == null) {
|
||||||
try {
|
try {
|
||||||
asNMSCopy = getCraftItemStackClass().getMethod("asNMSCopy", ItemStack.class);
|
asNMSCopy = getCraftItemStackClass().getMethod("asNMSCopy", ItemStack.class);
|
||||||
@ -2040,13 +1937,13 @@ public class MinecraftReflection {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// If it's already a CraftItemStack, use its handle
|
|
||||||
if (is(getCraftItemStackClass(), specific)) {
|
if (is(getCraftItemStackClass(), specific)) {
|
||||||
|
// If it's already a CraftItemStack, use its handle
|
||||||
return new BukkitUnwrapper().unwrapItem(specific);
|
return new BukkitUnwrapper().unwrapItem(specific);
|
||||||
}
|
}
|
||||||
|
|
||||||
// If it's not, grab a NMS copy
|
|
||||||
try {
|
try {
|
||||||
|
// If not, grab a NMS copy
|
||||||
return asNMSCopy.invoke(null, specific);
|
return asNMSCopy.invoke(null, specific);
|
||||||
} catch (ReflectiveOperationException ex) {
|
} catch (ReflectiveOperationException ex) {
|
||||||
throw new RuntimeException("Failed to make NMS copy of " + specific, ex);
|
throw new RuntimeException("Failed to make NMS copy of " + specific, ex);
|
||||||
|
Loading…
Reference in New Issue
Block a user