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-04-25 00:36:49 +02:00
|
|
|
index d544a4e4d88b51cf6ca53e048c411aa23c64d78f..97e1bd56de2c7f6d606e3a4968b2f55cd4689b91 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-04-25 00:36:49 +02:00
|
|
|
@@ -36,12 +36,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;
|
|
|
|
}
|
|
|
|
|