mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-15 14:13:56 +01:00
more fixes for ItemMeta relating to components
This commit is contained in:
parent
c534b3e0ea
commit
c6bdd67d28
2 changed files with 104 additions and 1 deletions
|
@ -4,6 +4,67 @@ Date: Sat, 27 Apr 2024 20:56:17 -0700
|
||||||
Subject: [PATCH] General ItemMeta fixes
|
Subject: [PATCH] General ItemMeta fixes
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java
|
||||||
|
@@ -0,0 +0,0 @@ public final class CraftItemStack extends ItemStack {
|
||||||
|
// Paper end - improve handled tags on type change
|
||||||
|
// Paper start
|
||||||
|
public static void applyMetaToItem(net.minecraft.world.item.ItemStack itemStack, ItemMeta itemMeta) {
|
||||||
|
- final CraftMetaItem.Applicator tag = new CraftMetaItem.Applicator();
|
||||||
|
+ // Paper start - support updating profile after resolving it
|
||||||
|
+ final CraftMetaItem.Applicator tag = new CraftMetaItem.Applicator() {
|
||||||
|
+ @Override
|
||||||
|
+ void skullCallback(final com.mojang.authlib.GameProfile gameProfile) {
|
||||||
|
+ itemStack.set(DataComponents.PROFILE, new net.minecraft.world.item.component.ResolvableProfile(gameProfile));
|
||||||
|
+ }
|
||||||
|
+ };
|
||||||
|
+ // Paper end - support updating profile after resolving it
|
||||||
|
((CraftMetaItem) itemMeta).applyToItem(tag);
|
||||||
|
itemStack.applyComponents(tag.build());
|
||||||
|
}
|
||||||
|
@@ -0,0 +0,0 @@ public final class CraftItemStack extends ItemStack {
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!((CraftMetaItem) itemMeta).isEmpty()) {
|
||||||
|
- CraftMetaItem.Applicator tag = new CraftMetaItem.Applicator();
|
||||||
|
+ // Paper start - support updating profile after resolving it
|
||||||
|
+ CraftMetaItem.Applicator tag = new CraftMetaItem.Applicator() {
|
||||||
|
+ @Override
|
||||||
|
+ void skullCallback(final com.mojang.authlib.GameProfile gameProfile) {
|
||||||
|
+ item.set(DataComponents.PROFILE, new net.minecraft.world.item.component.ResolvableProfile(gameProfile));
|
||||||
|
+ }
|
||||||
|
+ };
|
||||||
|
+ // Paper end - support updating profile after resolving it
|
||||||
|
|
||||||
|
((CraftMetaItem) itemMeta).applyToItem(tag);
|
||||||
|
item.restorePatch(tag.build());
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaBanner extends CraftMetaItem implements BannerMeta {
|
||||||
|
void applyToItem(CraftMetaItem.Applicator tag) {
|
||||||
|
super.applyToItem(tag);
|
||||||
|
|
||||||
|
+ if (this.patterns.isEmpty()) return; // Paper - don't write empty patterns
|
||||||
|
List<BannerPatternLayers.Layer> newPatterns = new ArrayList<>();
|
||||||
|
|
||||||
|
for (Pattern p : this.patterns) {
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBookSigned.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBookSigned.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBookSigned.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBookSigned.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaBookSigned extends CraftMetaItem implements BookMeta {
|
||||||
|
for (Component page : this.pages) {
|
||||||
|
list.add(Filterable.passThrough(page));
|
||||||
|
}
|
||||||
|
- itemData.put(CraftMetaBookSigned.BOOK_CONTENT, new WrittenBookContent(Filterable.from(FilteredText.passThrough(this.title)), this.author, this.generation, list, this.resolved));
|
||||||
|
+ itemData.put(CraftMetaBookSigned.BOOK_CONTENT, new WrittenBookContent(Filterable.from(FilteredText.passThrough(this.title == null ? "" : this.title)), this.author == null ? "" : this.author, this.generation, list, this.resolved));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaFirework.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaFirework.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaFirework.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaFirework.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaFirework.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaFirework.java
|
||||||
|
@ -24,3 +85,46 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
itemTag.put(CraftMetaFirework.FIREWORKS, new Fireworks(this.power, effects));
|
itemTag.put(CraftMetaFirework.FIREWORKS, new Fireworks(this.power, effects));
|
||||||
}
|
}
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
- static final class Applicator {
|
||||||
|
+ static abstract class Applicator { // Paper - support updating profile after resolving it
|
||||||
|
|
||||||
|
final DataComponentPatch.Builder builder = DataComponentPatch.builder();
|
||||||
|
+ void skullCallback(com.mojang.authlib.GameProfile gameProfile) {} // Paper - support updating profile after resolving it
|
||||||
|
|
||||||
|
<T> Applicator put(ItemMetaKeyType<T> key, T value) {
|
||||||
|
this.builder.set(key.TYPE, value);
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getAsString() {
|
||||||
|
- CraftMetaItem.Applicator tag = new CraftMetaItem.Applicator();
|
||||||
|
+ CraftMetaItem.Applicator tag = new CraftMetaItem.Applicator() {}; // Paper - support updating profile after resolving it
|
||||||
|
this.applyToItem(tag);
|
||||||
|
DataComponentPatch patch = tag.build();
|
||||||
|
Tag nbt = DataComponentPatch.CODEC.encodeStart(MinecraftServer.getDefaultRegistryAccess().createSerializationContext(NbtOps.INSTANCE), patch).getOrThrow();
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java
|
||||||
|
@@ -0,0 +0,0 @@ class CraftMetaSkull extends CraftMetaItem implements SkullMeta {
|
||||||
|
// Fill in textures
|
||||||
|
PlayerProfile ownerProfile = new CraftPlayerProfile(this.profile); // getOwnerProfile may return null
|
||||||
|
if (ownerProfile.getTextures().isEmpty()) {
|
||||||
|
- ownerProfile.update().thenAccept((filledProfile) -> {
|
||||||
|
+ ownerProfile.update().thenAcceptAsync((filledProfile) -> { // Paper - run on main thread
|
||||||
|
this.setOwnerProfile(filledProfile);
|
||||||
|
- tag.put(CraftMetaSkull.SKULL_PROFILE, new ResolvableProfile(this.profile));
|
||||||
|
- });
|
||||||
|
+ tag.skullCallback(this.profile); // Paper - actually set profile on itemstack
|
||||||
|
+ }, ((org.bukkit.craftbukkit.CraftServer) org.bukkit.Bukkit.getServer()).getServer()); // Paper - run on main thread
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,6 @@ dependencies {
|
||||||
|
|
||||||
tasks.processResources {
|
tasks.processResources {
|
||||||
val apiVersion = rootProject.providers.gradleProperty("mcVersion").get()
|
val apiVersion = rootProject.providers.gradleProperty("mcVersion").get()
|
||||||
.split(".", "-").take(2).joinToString(".")
|
|
||||||
val props = mapOf(
|
val props = mapOf(
|
||||||
"version" to project.version,
|
"version" to project.version,
|
||||||
"apiversion" to "\"$apiVersion\"",
|
"apiversion" to "\"$apiVersion\"",
|
||||||
|
|
Loading…
Reference in a new issue