aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0962-Don-t-lose-removed-data-components-in-ItemMeta.patch
diff options
context:
space:
mode:
authorJakub Zacek <[email protected]>2024-07-15 23:35:51 +0200
committerGitHub <[email protected]>2024-07-15 17:35:51 -0400
commit2cd8c461af74f0a524878dcdffba86cd105c48c6 (patch)
treeac107a76fe3d6cdd2e6ef5804ef3cba152957e4c /patches/server/0962-Don-t-lose-removed-data-components-in-ItemMeta.patch
parentb57b24d549c65ddc5eb3edcc1ecc6aad2826dbd8 (diff)
downloadPaper-2cd8c461af74f0a524878dcdffba86cd105c48c6.tar.gz
Paper-2cd8c461af74f0a524878dcdffba86cd105c48c6.zip
Add OMINOUS_ITEM_SPAWNER SpawnReason (#10897)
Diffstat (limited to 'patches/server/0962-Don-t-lose-removed-data-components-in-ItemMeta.patch')
-rw-r--r--patches/server/0962-Don-t-lose-removed-data-components-in-ItemMeta.patch49
1 files changed, 49 insertions, 0 deletions
diff --git a/patches/server/0962-Don-t-lose-removed-data-components-in-ItemMeta.patch b/patches/server/0962-Don-t-lose-removed-data-components-in-ItemMeta.patch
new file mode 100644
index 0000000000..04001583fc
--- /dev/null
+++ b/patches/server/0962-Don-t-lose-removed-data-components-in-ItemMeta.patch
@@ -0,0 +1,49 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Jake Potrebic <[email protected]>
+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
+index 2cf89147025066f34c12b9956d18451487fb2799..bc5adcb7638d6672cad33ef4adf73e475bc16b7d 100644
+--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
++++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
+@@ -198,6 +198,13 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
+ 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();
+ }
+@@ -428,7 +435,11 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
+
+ Set<Map.Entry<DataComponentType<?>, Optional<?>>> keys = tag.entrySet();
+ for (Map.Entry<DataComponentType<?>, Optional<?>> key : keys) {
+- if (!CraftMetaItem.getHandledTags().contains(key.getKey())) {
++ // Paper start - don't lose unhandled tags
++ if (key.getValue().isEmpty()) {
++ this.unhandledTags.remove(key.getKey());
++ } else if (!CraftMetaItem.getHandledTags().contains(key.getKey())) {
++ // Paper end - don't lose unhandled tags
+ key.getValue().ifPresent((value) -> {
+ this.unhandledTags.set((DataComponentType) key.getKey(), value);
+ });
+@@ -864,9 +875,9 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
+ }
+
+ 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()));
+ }
+
+ for (DataComponentType<?> removed : this.removedTags) {