2021-10-20 21:59:13 +02:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
From: syldium <syldium@mailo.com>
Date: Fri, 9 Jul 2021 18:50:40 +0200
2022-11-04 15:59:15 -07:00
Subject: [PATCH] Add more advancement API
2021-10-20 21:59:13 +02:00
2023-09-22 15:15:57 +02:00
== AT ==
public net.minecraft.advancements.Advancement decorateName(Lnet/minecraft/advancements/DisplayInfo;)Lnet/minecraft/network/chat/Component;
2022-11-24 23:05:48 -08:00
Co-authored-by: Jake Potrebic <jake.m.potrebic@gmail.com>
2021-10-20 21:59:13 +02:00
diff --git a/src/main/java/io/papermc/paper/advancement/PaperAdvancementDisplay.java b/src/main/java/io/papermc/paper/advancement/PaperAdvancementDisplay.java
new file mode 100644
2023-12-06 10:07:47 -08:00
index 0000000000000000000000000000000000000000..adac21ce6db3ff7a56dbcd6bffc02143c2db4046
2021-10-20 21:59:13 +02:00
--- /dev/null
+++ b/src/main/java/io/papermc/paper/advancement/PaperAdvancementDisplay.java
2022-11-24 23:05:48 -08:00
@@ -0,0 +1,69 @@
2021-10-20 21:59:13 +02:00
+package io.papermc.paper.advancement;
+
+import io.papermc.paper.adventure.PaperAdventure;
+import net.kyori.adventure.text.Component;
2022-11-24 23:05:48 -08:00
+import net.minecraft.advancements.Advancement;
2023-12-06 10:07:47 -08:00
+import net.minecraft.advancements.AdvancementType;
2021-10-20 21:59:13 +02:00
+import net.minecraft.advancements.DisplayInfo;
+import org.bukkit.NamespacedKey;
+import org.bukkit.craftbukkit.inventory.CraftItemStack;
+import org.bukkit.craftbukkit.util.CraftNamespacedKey;
+import org.bukkit.inventory.ItemStack;
+import org.jetbrains.annotations.NotNull;
+import org.jetbrains.annotations.Nullable;
+
+public record PaperAdvancementDisplay(DisplayInfo handle) implements AdvancementDisplay {
+
+ @Override
+ public @NotNull Frame frame() {
2023-12-06 10:07:47 -08:00
+ return asPaperFrame(this.handle.getType());
2021-10-20 21:59:13 +02:00
+ }
+
+ @Override
+ public @NotNull Component title() {
+ return PaperAdventure.asAdventure(this.handle.getTitle());
+ }
+
+ @Override
+ public @NotNull Component description() {
+ return PaperAdventure.asAdventure(this.handle.getDescription());
+ }
+
+ @Override
+ public @NotNull ItemStack icon() {
+ return CraftItemStack.asBukkitCopy(this.handle.getIcon());
+ }
+
+ @Override
+ public boolean doesShowToast() {
+ return this.handle.shouldShowToast();
+ }
+
+ @Override
+ public boolean doesAnnounceToChat() {
+ return this.handle.shouldAnnounceChat();
+ }
+
+ @Override
+ public boolean isHidden() {
+ return this.handle.isHidden();
+ }
+
+ @Override
+ public @Nullable NamespacedKey backgroundPath() {
2023-12-06 10:07:47 -08:00
+ return this.handle.getBackground().map(CraftNamespacedKey::fromMinecraft).orElse(null);
2021-10-20 21:59:13 +02:00
+ }
+
2022-11-24 23:05:48 -08:00
+ @Override
+ public @NotNull Component displayName() {
2023-09-22 15:19:33 +02:00
+ return PaperAdventure.asAdventure(Advancement.decorateName(java.util.Objects.requireNonNull(this.handle, "cannot build display name for null handle, invalid state")));
2022-11-24 23:05:48 -08:00
+ }
+
2023-12-06 10:07:47 -08:00
+ public static @NotNull Frame asPaperFrame(final @NotNull AdvancementType frameType) {
2021-10-20 21:59:13 +02:00
+ return switch (frameType) {
+ case TASK -> Frame.TASK;
+ case CHALLENGE -> Frame.CHALLENGE;
+ case GOAL -> Frame.GOAL;
+ };
+ }
+}
diff --git a/src/main/java/net/minecraft/advancements/DisplayInfo.java b/src/main/java/net/minecraft/advancements/DisplayInfo.java
2024-04-24 17:27:28 +02:00
index 05de12414a3ad1c8f0f02f7973898dda84b89b82..6581cdbec730d5d184566e7b611369b3c424fecf 100644
2021-10-20 21:59:13 +02:00
--- a/src/main/java/net/minecraft/advancements/DisplayInfo.java
+++ b/src/main/java/net/minecraft/advancements/DisplayInfo.java
2024-04-24 17:27:28 +02:00
@@ -37,6 +37,7 @@ public class DisplayInfo {
2021-10-20 21:59:13 +02:00
private final boolean hidden;
private float x;
private float y;
2024-01-19 12:30:04 +01:00
+ public final io.papermc.paper.advancement.AdvancementDisplay paper = new io.papermc.paper.advancement.PaperAdvancementDisplay(this); // Paper - Add more advancement API
2021-10-20 21:59:13 +02:00
2024-04-12 12:14:06 -07:00
public DisplayInfo(
ItemStack icon,
2021-10-20 21:59:13 +02:00
diff --git a/src/main/java/org/bukkit/craftbukkit/advancement/CraftAdvancement.java b/src/main/java/org/bukkit/craftbukkit/advancement/CraftAdvancement.java
2024-01-19 12:30:04 +01:00
index 52baf818579a6841b77ff80e42f4f1b9f635ea08..8dfaca2efa0b0bdc97b75aaa83158a2e46361e4e 100644
2021-10-20 21:59:13 +02:00
--- a/src/main/java/org/bukkit/craftbukkit/advancement/CraftAdvancement.java
+++ b/src/main/java/org/bukkit/craftbukkit/advancement/CraftAdvancement.java
2023-09-22 16:03:34 -07:00
@@ -29,12 +29,47 @@ public class CraftAdvancement implements org.bukkit.advancement.Advancement {
2023-09-22 15:15:57 +02:00
return Collections.unmodifiableCollection(this.handle.value().criteria().keySet());
2021-10-20 21:59:13 +02:00
}
2022-06-05 10:43:06 +02:00
2024-01-19 12:30:04 +01:00
+ // Paper start - Add more advancement API
2022-06-05 10:43:06 +02:00
@Override
- public AdvancementDisplay getDisplay() {
2023-09-22 15:15:57 +02:00
- if (this.handle.value().display().isEmpty()) {
2022-06-05 10:43:06 +02:00
- return null;
2021-10-20 21:59:13 +02:00
+ public io.papermc.paper.advancement.AdvancementDisplay getDisplay() {
2023-09-22 15:15:57 +02:00
+ return this.handle.value().display().map(d -> d.paper).orElse(null);
2023-03-23 14:57:03 -07:00
+ }
2021-10-20 21:59:13 +02:00
+
2023-09-22 15:15:57 +02:00
+ @Deprecated
+ @io.papermc.paper.annotation.DoNotUse
2022-11-04 15:59:15 -07:00
+ public AdvancementDisplay getDisplay0() { // May be called by plugins via Commodore
2023-09-22 15:15:57 +02:00
+ return this.handle.value().display().map(CraftAdvancementDisplay::new).orElse(null);
2022-11-04 15:59:15 -07:00
+ }
+
2021-10-20 21:59:13 +02:00
+ @Override
2022-11-24 23:05:48 -08:00
+ public net.kyori.adventure.text.Component displayName() {
2023-09-22 16:03:34 -07:00
+ return io.papermc.paper.adventure.PaperAdventure.asAdventure(net.minecraft.advancements.Advancement.name(this.handle));
2022-11-24 23:05:48 -08:00
+ }
+
+ @Override
2021-10-20 21:59:13 +02:00
+ public org.bukkit.advancement.Advancement getParent() {
2023-09-22 15:15:57 +02:00
+ return this.handle.value().parent()
+ .map(net.minecraft.server.MinecraftServer.getServer().getAdvancements()::get)
+ .map(AdvancementHolder::toBukkit)
+ .orElse(null);
2021-10-20 21:59:13 +02:00
+ }
+
+ @Override
+ public Collection<org.bukkit.advancement.Advancement> getChildren() {
2023-09-22 16:03:34 -07:00
+ final com.google.common.collect.ImmutableList.Builder<org.bukkit.advancement.Advancement> children = com.google.common.collect.ImmutableList.<org.bukkit.advancement.Advancement>builder();
+ final net.minecraft.advancements.AdvancementNode advancementNode = net.minecraft.server.MinecraftServer.getServer().getAdvancements().tree().get(this.handle);
2023-09-22 15:15:57 +02:00
+ if (advancementNode != null) {
2023-09-22 16:03:34 -07:00
+ for (final net.minecraft.advancements.AdvancementNode child : advancementNode.children()) {
2023-09-22 15:15:57 +02:00
+ children.add(child.holder().toBukkit());
+ }
2023-03-23 14:57:03 -07:00
}
2021-10-20 21:59:13 +02:00
+ return children.build();
+ }
2023-03-23 14:57:03 -07:00
2023-09-22 15:15:57 +02:00
- return new CraftAdvancementDisplay(this.handle.value().display().get());
2021-10-20 21:59:13 +02:00
+ @Override
+ public org.bukkit.advancement.Advancement getRoot() {
2023-09-22 16:03:34 -07:00
+ final net.minecraft.advancements.AdvancementNode advancementNode = net.minecraft.server.MinecraftServer.getServer().getAdvancements().tree().get(this.handle);
2023-09-22 15:15:57 +02:00
+ return java.util.Objects.requireNonNull(advancementNode, "could not find internal advancement node for advancement " + this.handle.id()).root().holder().toBukkit();
2023-03-23 14:57:03 -07:00
}
2024-01-19 12:30:04 +01:00
+ // Paper end - Add more advancement API
2021-10-20 21:59:13 +02:00
}
2022-11-04 15:59:15 -07:00
diff --git a/src/main/java/org/bukkit/craftbukkit/advancement/CraftAdvancementDisplay.java b/src/main/java/org/bukkit/craftbukkit/advancement/CraftAdvancementDisplay.java
2023-12-05 21:49:31 -07:00
index 8ca86852319d7463f60832bc98b825b0b4325995..62ada73302c6b3ce3fb2dcc8c31a1d9c0ac4fd09 100644
2022-11-04 15:59:15 -07:00
--- a/src/main/java/org/bukkit/craftbukkit/advancement/CraftAdvancementDisplay.java
+++ b/src/main/java/org/bukkit/craftbukkit/advancement/CraftAdvancementDisplay.java
@@ -6,6 +6,7 @@ import org.bukkit.craftbukkit.inventory.CraftItemStack;
import org.bukkit.craftbukkit.util.CraftChatMessage;
import org.bukkit.inventory.ItemStack;
+@Deprecated // Paper
public class CraftAdvancementDisplay implements org.bukkit.advancement.AdvancementDisplay {
private final DisplayInfo handle;
diff --git a/src/main/java/org/bukkit/craftbukkit/util/Commodore.java b/src/main/java/org/bukkit/craftbukkit/util/Commodore.java
2024-06-13 17:08:12 -07:00
index 2d9453498531c99f4fa566a08099b4e5a7af25fa..9d8adc5e281decd61fb3a8cfd78531b0b374e29c 100644
2022-11-04 15:59:15 -07:00
--- a/src/main/java/org/bukkit/craftbukkit/util/Commodore.java
+++ b/src/main/java/org/bukkit/craftbukkit/util/Commodore.java
2024-06-13 17:08:12 -07:00
@@ -384,6 +384,11 @@ public class Commodore {
2022-12-20 10:56:33 -08:00
super.visitMethodInsn(opcode, owner, name, "()Lcom/destroystokyo/paper/profile/PlayerProfile;", itf);
return;
2022-11-04 15:59:15 -07:00
}
+ if (owner.equals("org/bukkit/advancement/Advancement") && name.equals("getDisplay") && desc.endsWith(")Lorg/bukkit/advancement/AdvancementDisplay;")) {
2024-04-25 11:16:53 -07:00
+ super.visitTypeInsn(Opcodes.CHECKCAST, runtimeCbPkgPrefix() + "advancement/CraftAdvancement");
+ super.visitMethodInsn(Opcodes.INVOKEVIRTUAL, runtimeCbPkgPrefix() + "advancement/CraftAdvancement", "getDisplay0", desc, false);
2022-11-04 15:59:15 -07:00
+ return;
+ }
// Paper end
2024-01-14 01:46:04 -08:00
if (modern) {
2021-10-20 21:59:13 +02:00
diff --git a/src/test/java/io/papermc/paper/advancement/AdvancementFrameTest.java b/src/test/java/io/papermc/paper/advancement/AdvancementFrameTest.java
new file mode 100644
2023-12-08 12:07:56 -08:00
index 0000000000000000000000000000000000000000..47535c27d7cffc4b5ee6cc9e145b1087477eef79
2021-10-20 21:59:13 +02:00
--- /dev/null
+++ b/src/test/java/io/papermc/paper/advancement/AdvancementFrameTest.java
2022-10-11 20:05:28 -07:00
@@ -0,0 +1,24 @@
2021-10-20 21:59:13 +02:00
+package io.papermc.paper.advancement;
+
+import io.papermc.paper.adventure.PaperAdventure;
+import net.kyori.adventure.text.format.TextColor;
2023-12-07 11:14:29 -08:00
+import net.minecraft.advancements.AdvancementType;
2022-06-08 17:31:27 +02:00
+import net.minecraft.network.chat.contents.TranslatableContents;
2023-09-24 17:16:58 +10:00
+import org.junit.jupiter.api.Test;
2021-10-20 21:59:13 +02:00
+
2023-09-24 17:16:58 +10:00
+import static org.junit.jupiter.api.Assertions.assertEquals;
2021-10-20 21:59:13 +02:00
+
+public class AdvancementFrameTest {
+
+ @Test
+ public void test() {
2023-12-07 11:14:29 -08:00
+ for (final AdvancementType advancementType : AdvancementType.values()) {
+ final TextColor expectedColor = PaperAdventure.asAdventure(advancementType.getChatColor());
+ final String expectedTranslationKey = ((TranslatableContents) advancementType.getDisplayName().getContents()).getKey();
+ final var frame = PaperAdvancementDisplay.asPaperFrame(advancementType);
2023-09-24 17:16:58 +10:00
+ assertEquals(expectedTranslationKey, frame.translationKey(), "The translation keys should be the same");
+ assertEquals(expectedColor, frame.color(), "The frame colors should be the same");
2023-12-08 12:07:56 -08:00
+ assertEquals(advancementType.getSerializedName(), AdvancementDisplay.Frame.NAMES.key(frame));
2021-10-20 21:59:13 +02:00
+ }
+ }
+}