mirror of
https://github.com/PurpurMC/Purpur.git
synced 2026-02-17 16:37:43 +01:00
Upstream has released updates that appear to apply and compile correctly Paper Changes: PaperMC/Paper@26734e8 Updated Upstream (Bukkit/CraftBukkit/Spigot) (#7454) PaperMC/Paper@4a745f9 Optimize Util#sequence (#7115) PaperMC/Paper@2c8d48c Make Panda implement Sittable (#7414) PaperMC/Paper@2c4a589 Fix issues with LimitedRegion (#7343) PaperMC/Paper@3d91eca Fix cancelled snow bucket placement (#6751) PaperMC/Paper@9567753 Don't load plugins prefixed with a dot (#7392) PaperMC/Paper@92c777d Fix PlayerProfile BukkitObject serialization, deprecate setName and setId for removal (#7471) PaperMC/Paper@e6898ff Fix IllegalArgumentException for /paper mobcaps command (#7472) PaperMC/Paper@a8f2d67 - properly fix IllegalArgumentException in `/paper mobcaps` command Pufferfish Changes: pufferfish-gg/Pufferfish@22f20b2 Fix sentry bug
164 lines
6.8 KiB
Diff
164 lines
6.8 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: William Blake Galbreath <blake.galbreath@gmail.com>
|
|
Date: Tue, 29 Jun 2021 21:37:40 -0500
|
|
Subject: [PATCH] Component related conveniences
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/level/ServerPlayer.java b/src/main/java/net/minecraft/server/level/ServerPlayer.java
|
|
index a261fd5f0709bd9891189d538f762aa8786d19d2..20548a1e7a4d56162ec906646cff3159fc98c817 100644
|
|
--- a/src/main/java/net/minecraft/server/level/ServerPlayer.java
|
|
+++ b/src/main/java/net/minecraft/server/level/ServerPlayer.java
|
|
@@ -1693,6 +1693,26 @@ public class ServerPlayer extends Player {
|
|
}
|
|
// CraftBukkit end
|
|
|
|
+ // Purpur start
|
|
+ public void sendActionBarMessage(@Nullable String message) {
|
|
+ if (message != null) {
|
|
+ sendActionBarMessage(net.kyori.adventure.text.minimessage.MiniMessage.get().parse(message));
|
|
+ }
|
|
+ }
|
|
+
|
|
+ public void sendActionBarMessage(@Nullable net.kyori.adventure.text.Component message) {
|
|
+ if (message != null) {
|
|
+ sendActionBarMessage(io.papermc.paper.adventure.PaperAdventure.asVanilla(message));
|
|
+ }
|
|
+ }
|
|
+
|
|
+ public void sendActionBarMessage(@Nullable Component message) {
|
|
+ if (message != null) {
|
|
+ displayClientMessage(message, true);
|
|
+ }
|
|
+ }
|
|
+ // Purpur end
|
|
+
|
|
@Override
|
|
public void displayClientMessage(Component message, boolean actionBar) {
|
|
this.sendMessage(message, actionBar ? ChatType.GAME_INFO : ChatType.CHAT, Util.NIL_UUID);
|
|
diff --git a/src/main/java/net/minecraft/server/players/PlayerList.java b/src/main/java/net/minecraft/server/players/PlayerList.java
|
|
index 7a0c1ba40156df69bbbf36d96bed0950130d2351..6b4cb3a94dc998e7a087c888876a15c36763bfd0 100644
|
|
--- a/src/main/java/net/minecraft/server/players/PlayerList.java
|
|
+++ b/src/main/java/net/minecraft/server/players/PlayerList.java
|
|
@@ -1377,6 +1377,62 @@ public abstract class PlayerList {
|
|
}
|
|
// CraftBukkit end
|
|
|
|
+ // Purpur start
|
|
+ public void broadcast(@Nullable String message) {
|
|
+ broadcast(message, Util.NIL_UUID);
|
|
+ }
|
|
+
|
|
+ public void broadcast(@Nullable String message, ChatType type) {
|
|
+ broadcast(message, type, Util.NIL_UUID);
|
|
+ }
|
|
+
|
|
+ public void broadcast(@Nullable String message, UUID sender) {
|
|
+ broadcast(message, ChatType.SYSTEM, sender);
|
|
+ }
|
|
+
|
|
+ public void broadcast(@Nullable String message, ChatType type, UUID sender) {
|
|
+ if (message != null) {
|
|
+ broadcast(net.kyori.adventure.text.minimessage.MiniMessage.get().parse(message), type, sender);
|
|
+ }
|
|
+ }
|
|
+
|
|
+ public void broadcast(@Nullable net.kyori.adventure.text.Component message) {
|
|
+ broadcast(message, Util.NIL_UUID);
|
|
+ }
|
|
+
|
|
+ public void broadcast(@Nullable net.kyori.adventure.text.Component message, ChatType type) {
|
|
+ broadcast(message, type, Util.NIL_UUID);
|
|
+ }
|
|
+
|
|
+ public void broadcast(@Nullable net.kyori.adventure.text.Component message, UUID sender) {
|
|
+ broadcast(message, ChatType.SYSTEM, sender);
|
|
+ }
|
|
+
|
|
+ public void broadcast(@Nullable net.kyori.adventure.text.Component message, ChatType type, UUID sender) {
|
|
+ if (message != null) {
|
|
+ broadcast(io.papermc.paper.adventure.PaperAdventure.asVanilla(message), type, sender);
|
|
+ }
|
|
+ }
|
|
+
|
|
+ public void broadcast(@Nullable Component message) {
|
|
+ broadcast(message, Util.NIL_UUID);
|
|
+ }
|
|
+
|
|
+ public void broadcast(@Nullable Component message, ChatType type) {
|
|
+ broadcast(message, type, Util.NIL_UUID);
|
|
+ }
|
|
+
|
|
+ public void broadcast(@Nullable Component message, UUID sender) {
|
|
+ broadcast(message, ChatType.SYSTEM, sender);
|
|
+ }
|
|
+
|
|
+ public void broadcast(@Nullable Component message, ChatType type, UUID sender) {
|
|
+ if (message != null) {
|
|
+ broadcastMessage(message, type, sender);
|
|
+ }
|
|
+ }
|
|
+ // Purpur end
|
|
+
|
|
public void broadcastMessage(Component message, ChatType type, UUID sender) {
|
|
this.server.sendMessage(message, sender);
|
|
Iterator iterator = this.players.iterator();
|
|
diff --git a/src/main/java/net/minecraft/world/damagesource/DamageSource.java b/src/main/java/net/minecraft/world/damagesource/DamageSource.java
|
|
index a828cad27fcd39f8bfbaefa97052a2a3b6650ee7..19d6165f266fcc39bc3533042109ef1b725ecb77 100644
|
|
--- a/src/main/java/net/minecraft/world/damagesource/DamageSource.java
|
|
+++ b/src/main/java/net/minecraft/world/damagesource/DamageSource.java
|
|
@@ -234,6 +234,15 @@ public class DamageSource {
|
|
return entityliving1 != null ? new TranslatableComponent(s1, new Object[]{entity.getDisplayName(), entityliving1.getDisplayName()}) : new TranslatableComponent(s, new Object[]{entity.getDisplayName()});
|
|
}
|
|
|
|
+ // Purpur start
|
|
+ public Component getLocalizedDeathMessage(String str, LivingEntity entity) {
|
|
+ net.kyori.adventure.text.Component name = io.papermc.paper.adventure.PaperAdventure.asAdventure(entity.getDisplayName());
|
|
+ net.kyori.adventure.text.minimessage.Template template = net.kyori.adventure.text.minimessage.Template.of("player", name);
|
|
+ net.kyori.adventure.text.Component component = net.kyori.adventure.text.minimessage.MiniMessage.get().parse(str, template);
|
|
+ return io.papermc.paper.adventure.PaperAdventure.asVanilla(component);
|
|
+ }
|
|
+ // Purpur end
|
|
+
|
|
public boolean isFire() {
|
|
return this.isFireSource;
|
|
}
|
|
diff --git a/src/main/java/net/minecraft/world/entity/Entity.java b/src/main/java/net/minecraft/world/entity/Entity.java
|
|
index fd6e42d3df429aaf753102258b8e65a61ff4d296..12357be999e5e0f684e24f6ea611f7cbfc29e986 100644
|
|
--- a/src/main/java/net/minecraft/world/entity/Entity.java
|
|
+++ b/src/main/java/net/minecraft/world/entity/Entity.java
|
|
@@ -3661,6 +3661,34 @@ public abstract class Entity implements Nameable, EntityAccess, CommandSource, i
|
|
return SlotAccess.NULL;
|
|
}
|
|
|
|
+ // Purpur Start
|
|
+ public void sendMessage(@Nullable String message) {
|
|
+ sendMessage(message, Util.NIL_UUID);
|
|
+ }
|
|
+
|
|
+ public void sendMessage(@Nullable String message, UUID sender) {
|
|
+ if (org.apache.commons.lang3.StringUtils.isNotEmpty(message)) {
|
|
+ sendMessage(net.kyori.adventure.text.minimessage.MiniMessage.get().parse(message), sender);
|
|
+ }
|
|
+ }
|
|
+
|
|
+ public void sendMessage(@Nullable net.kyori.adventure.text.Component message) {
|
|
+ sendMessage(message, Util.NIL_UUID);
|
|
+ }
|
|
+
|
|
+ public void sendMessage(@Nullable net.kyori.adventure.text.Component message, UUID sender) {
|
|
+ if (message != null) {
|
|
+ sendMessage(io.papermc.paper.adventure.PaperAdventure.asVanilla(message), sender);
|
|
+ }
|
|
+ }
|
|
+
|
|
+ public void sendMessage(@Nullable Component message) {
|
|
+ if (message != null) {
|
|
+ sendMessage(message, Util.NIL_UUID);
|
|
+ }
|
|
+ }
|
|
+ // Purpur end
|
|
+
|
|
@Override
|
|
public void sendMessage(Component message, UUID sender) {}
|
|
|