mirror of
https://github.com/PaperMC/Paper.git
synced 2024-12-31 16:40:51 +01:00
Implement methods to convert between Component and Brigadier's Message (#5542)
This commit is contained in:
parent
4047cffca8
commit
db464b099e
3 changed files with 127 additions and 0 deletions
|
@ -0,0 +1,42 @@
|
||||||
|
package io.papermc.paper.brigadier;
|
||||||
|
|
||||||
|
import com.mojang.brigadier.Message;
|
||||||
|
import net.kyori.adventure.text.Component;
|
||||||
|
import net.kyori.adventure.text.ComponentLike;
|
||||||
|
import net.kyori.adventure.text.TextComponent;
|
||||||
|
import org.checkerframework.checker.nullness.qual.NonNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Helper methods to bridge the gaps between Brigadier and Paper-MojangAPI.
|
||||||
|
*/
|
||||||
|
public final class PaperBrigadier {
|
||||||
|
private PaperBrigadier() {
|
||||||
|
throw new RuntimeException("PaperBrigadier is not to be instantiated!");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new Brigadier {@link Message} from a {@link ComponentLike}.
|
||||||
|
*
|
||||||
|
* <p>Mostly useful for creating rich suggestion tooltips in combination with other Paper-MojangAPI APIs.</p>
|
||||||
|
*
|
||||||
|
* @param componentLike The {@link ComponentLike} to use for the {@link Message} contents
|
||||||
|
* @return A new Brigadier {@link Message}
|
||||||
|
*/
|
||||||
|
public static @NonNull Message message(final @NonNull ComponentLike componentLike) {
|
||||||
|
return PaperBrigadierProvider.instance().message(componentLike);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new {@link Component} from a Brigadier {@link Message}.
|
||||||
|
*
|
||||||
|
* <p>If the {@link Message} was created from a {@link Component}, it will simply be
|
||||||
|
* converted back, otherwise a new {@link TextComponent} will be created with the
|
||||||
|
* content of {@link Message#getString()}</p>
|
||||||
|
*
|
||||||
|
* @param message The {@link Message} to create a {@link Component} from
|
||||||
|
* @return The created {@link Component}
|
||||||
|
*/
|
||||||
|
public static @NonNull Component componentFromMessage(final @NonNull Message message) {
|
||||||
|
return PaperBrigadierProvider.instance().componentFromMessage(message);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,30 @@
|
||||||
|
package io.papermc.paper.brigadier;
|
||||||
|
|
||||||
|
import com.mojang.brigadier.Message;
|
||||||
|
import net.kyori.adventure.text.Component;
|
||||||
|
import net.kyori.adventure.text.ComponentLike;
|
||||||
|
import org.checkerframework.checker.nullness.qual.MonotonicNonNull;
|
||||||
|
import org.checkerframework.checker.nullness.qual.NonNull;
|
||||||
|
|
||||||
|
import static java.util.Objects.requireNonNull;
|
||||||
|
|
||||||
|
interface PaperBrigadierProvider {
|
||||||
|
final class Holder {
|
||||||
|
private static @MonotonicNonNull PaperBrigadierProvider INSTANCE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static @NonNull PaperBrigadierProvider instance() {
|
||||||
|
return requireNonNull(Holder.INSTANCE, "PaperBrigadierProvider has not yet been initialized!");
|
||||||
|
}
|
||||||
|
|
||||||
|
static void initialize(final @NonNull PaperBrigadierProvider instance) {
|
||||||
|
if (Holder.INSTANCE != null) {
|
||||||
|
throw new IllegalStateException("PaperBrigadierProvider has already been initialized!");
|
||||||
|
}
|
||||||
|
Holder.INSTANCE = instance;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NonNull Message message(@NonNull ComponentLike componentLike);
|
||||||
|
|
||||||
|
@NonNull Component componentFromMessage(@NonNull Message message);
|
||||||
|
}
|
|
@ -0,0 +1,55 @@
|
||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: jmp <jasonpenilla2@me.com>
|
||||||
|
Date: Sat, 24 Apr 2021 02:09:32 -0700
|
||||||
|
Subject: [PATCH] Implement methods to convert between Component and
|
||||||
|
Brigadier's Message
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/src/main/java/io/papermc/paper/brigadier/PaperBrigadierProviderImpl.java b/src/main/java/io/papermc/paper/brigadier/PaperBrigadierProviderImpl.java
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000000000000000000000000000000000000..fb1d6632788ae886b7a0e56fb490920c6ba2ce22
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/src/main/java/io/papermc/paper/brigadier/PaperBrigadierProviderImpl.java
|
||||||
|
@@ -0,0 +1,30 @@
|
||||||
|
+package io.papermc.paper.brigadier;
|
||||||
|
+
|
||||||
|
+import com.mojang.brigadier.Message;
|
||||||
|
+import io.papermc.paper.adventure.PaperAdventure;
|
||||||
|
+import net.kyori.adventure.text.Component;
|
||||||
|
+import net.kyori.adventure.text.ComponentLike;
|
||||||
|
+import net.minecraft.network.chat.ChatComponentUtils;
|
||||||
|
+import org.checkerframework.checker.nullness.qual.NonNull;
|
||||||
|
+
|
||||||
|
+import static java.util.Objects.requireNonNull;
|
||||||
|
+
|
||||||
|
+public enum PaperBrigadierProviderImpl implements PaperBrigadierProvider {
|
||||||
|
+ INSTANCE;
|
||||||
|
+
|
||||||
|
+ PaperBrigadierProviderImpl() {
|
||||||
|
+ PaperBrigadierProvider.initialize(this);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public @NonNull Message message(final @NonNull ComponentLike componentLike) {
|
||||||
|
+ requireNonNull(componentLike, "componentLike");
|
||||||
|
+ return PaperAdventure.asVanilla(componentLike.asComponent());
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public @NonNull Component componentFromMessage(final @NonNull Message message) {
|
||||||
|
+ requireNonNull(message, "message");
|
||||||
|
+ return PaperAdventure.asAdventure(ChatComponentUtils.fromMessage(message));
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
diff --git a/src/main/java/net/minecraft/server/dedicated/DedicatedServer.java b/src/main/java/net/minecraft/server/dedicated/DedicatedServer.java
|
||||||
|
index 52bb528e75eb43156ee2bf19877bc051a35bb6e3..df8270c40ed7ce6f628686ff6f4fa4cf96af6738 100644
|
||||||
|
--- a/src/main/java/net/minecraft/server/dedicated/DedicatedServer.java
|
||||||
|
+++ b/src/main/java/net/minecraft/server/dedicated/DedicatedServer.java
|
||||||
|
@@ -213,6 +213,7 @@ public class DedicatedServer extends MinecraftServer implements IMinecraftServer
|
||||||
|
}
|
||||||
|
com.destroystokyo.paper.PaperConfig.registerCommands();
|
||||||
|
com.destroystokyo.paper.VersionHistoryManager.INSTANCE.getClass(); // load version history now
|
||||||
|
+ io.papermc.paper.brigadier.PaperBrigadierProviderImpl.INSTANCE.getClass(); // init PaperBrigadierProvider
|
||||||
|
// Paper end
|
||||||
|
|
||||||
|
this.setPVP(dedicatedserverproperties.pvp);
|
Loading…
Reference in a new issue