2024-04-27 08:17:58 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
|
|
|
Date: Fri, 26 Apr 2024 21:33:20 -0700
|
|
|
|
Subject: [PATCH] Don't lose removed data components in ItemMeta
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
2024-06-15 18:28:18 +02:00
|
|
|
index 64457318250c8ab1dcefdbd1f3373b891d859a7a..b5103f318b685145d10337c833f0026d4785f05f 100644
|
2024-04-27 08:17:58 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
2024-06-15 18:28:18 +02:00
|
|
|
@@ -198,6 +198,13 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
2024-04-27 08:17:58 +02:00
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
|
|
|
+ // Paper start - support removing component types
|
|
|
|
+ <T> Applicator remove(DataComponentType<T> type) {
|
|
|
|
+ this.builder.remove(type);
|
|
|
|
+ return this;
|
|
|
|
+ }
|
|
|
|
+ // Paper end - support removing component types
|
|
|
|
+
|
|
|
|
DataComponentPatch build() {
|
|
|
|
return this.builder.build();
|
|
|
|
}
|
2024-06-15 18:28:18 +02:00
|
|
|
@@ -428,7 +435,11 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
2024-04-27 08:17:58 +02:00
|
|
|
|
|
|
|
Set<Map.Entry<DataComponentType<?>, Optional<?>>> keys = tag.entrySet();
|
|
|
|
for (Map.Entry<DataComponentType<?>, Optional<?>> key : keys) {
|
|
|
|
- if (!CraftMetaItem.getHandledTags().contains(key.getKey())) {
|
2024-06-15 18:28:18 +02:00
|
|
|
+ // Paper start - don't lose unhandled tags
|
2024-04-27 08:17:58 +02:00
|
|
|
+ if (key.getValue().isEmpty()) {
|
|
|
|
+ this.unhandledTags.remove(key.getKey());
|
|
|
|
+ } else if (!CraftMetaItem.getHandledTags().contains(key.getKey())) {
|
2024-06-15 18:28:18 +02:00
|
|
|
+ // Paper end - don't lose unhandled tags
|
|
|
|
key.getValue().ifPresent((value) -> {
|
2024-04-27 08:17:58 +02:00
|
|
|
this.unhandledTags.set((DataComponentType) key.getKey(), value);
|
2024-06-15 18:28:18 +02:00
|
|
|
});
|
|
|
|
@@ -864,9 +875,9 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
2024-04-27 08:17:58 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
for (Map.Entry<DataComponentType<?>, Optional<?>> e : this.unhandledTags.build().entrySet()) {
|
|
|
|
- e.getValue().ifPresent((value) -> {
|
|
|
|
+ e.getValue().ifPresentOrElse((value) -> {
|
|
|
|
itemTag.builder.set((DataComponentType) e.getKey(), value);
|
|
|
|
- });
|
|
|
|
+ }, () -> itemTag.remove(e.getKey()));
|
|
|
|
}
|
|
|
|
|
2024-06-15 18:28:18 +02:00
|
|
|
for (DataComponentType<?> removed : this.removedTags) {
|