2023-09-16 23:18:09 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Aeltumn <daniel@goossens.ch>
|
|
|
|
Date: Mon, 28 Aug 2023 13:44:09 +0200
|
|
|
|
Subject: [PATCH] Allow proper checking of empty item stacks
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java
|
2024-07-18 10:13:20 +02:00
|
|
|
index 4d29c34e221b749b6972c7ed79ac1f86da999ed7..c5a09f086d35f84c0a30266f78e06e2dfb5603e6 100644
|
2023-09-16 23:18:09 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java
|
2024-07-18 10:13:20 +02:00
|
|
|
@@ -40,12 +40,19 @@ public final class CraftItemStack extends ItemStack {
|
2023-09-16 23:18:09 +02:00
|
|
|
}
|
|
|
|
// Paper end - MC Utils
|
|
|
|
|
|
|
|
+ // Paper start - override isEmpty to use vanilla's impl
|
|
|
|
+ @Override
|
|
|
|
+ public boolean isEmpty() {
|
|
|
|
+ return handle == null || handle.isEmpty();
|
|
|
|
+ }
|
2024-01-13 18:34:33 +01:00
|
|
|
+ // Paper end - override isEmpty to use vanilla's impl
|
2023-09-16 23:18:09 +02:00
|
|
|
+
|
|
|
|
public static net.minecraft.world.item.ItemStack asNMSCopy(ItemStack original) {
|
|
|
|
if (original instanceof CraftItemStack) {
|
|
|
|
CraftItemStack stack = (CraftItemStack) original;
|
|
|
|
return stack.handle == null ? net.minecraft.world.item.ItemStack.EMPTY : stack.handle.copy();
|
|
|
|
}
|
|
|
|
- if (original == null || original.getType() == Material.AIR) {
|
2024-01-13 18:34:33 +01:00
|
|
|
+ if (original == null || original.isEmpty()) { // Paper - override isEmpty to use vanilla's impl; use isEmpty
|
2023-09-16 23:18:09 +02:00
|
|
|
return net.minecraft.world.item.ItemStack.EMPTY;
|
|
|
|
}
|
|
|
|
|