2021-06-11 12:02:28 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
2021-11-27 08:11:43 +00:00
|
|
|
From: MiniDigger <admin@benndorf.dev>
|
2021-06-11 12:02:28 +00:00
|
|
|
Date: Mon, 20 Jan 2020 21:38:15 +0100
|
|
|
|
Subject: [PATCH] Implement Player Client Options API
|
|
|
|
|
2022-11-19 23:53:20 +00:00
|
|
|
== AT ==
|
|
|
|
public net.minecraft.world.entity.player.Player DATA_PLAYER_MODE_CUSTOMISATION
|
2021-06-11 12:02:28 +00:00
|
|
|
|
|
|
|
diff --git a/src/main/java/com/destroystokyo/paper/PaperSkinParts.java b/src/main/java/com/destroystokyo/paper/PaperSkinParts.java
|
|
|
|
new file mode 100644
|
|
|
|
index 0000000000000000000000000000000000000000..b6f4400df3d8ec7e06a996de54f8cabba57885e1
|
|
|
|
--- /dev/null
|
|
|
|
+++ b/src/main/java/com/destroystokyo/paper/PaperSkinParts.java
|
|
|
|
@@ -0,0 +1,74 @@
|
|
|
|
+package com.destroystokyo.paper;
|
|
|
|
+
|
|
|
|
+import com.google.common.base.Objects;
|
|
|
|
+
|
|
|
|
+import java.util.StringJoiner;
|
|
|
|
+
|
|
|
|
+public class PaperSkinParts implements SkinParts {
|
|
|
|
+
|
|
|
|
+ private final int raw;
|
|
|
|
+
|
|
|
|
+ public PaperSkinParts(int raw) {
|
|
|
|
+ this.raw = raw;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public boolean hasCapeEnabled() {
|
|
|
|
+ return (raw & 1) == 1;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public boolean hasJacketEnabled() {
|
|
|
|
+ return (raw >> 1 & 1) == 1;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public boolean hasLeftSleeveEnabled() {
|
|
|
|
+ return (raw >> 2 & 1) == 1;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public boolean hasRightSleeveEnabled() {
|
|
|
|
+ return (raw >> 3 & 1) == 1;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public boolean hasLeftPantsEnabled() {
|
|
|
|
+ return (raw >> 4 & 1) == 1;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public boolean hasRightPantsEnabled() {
|
|
|
|
+ return (raw >> 5 & 1) == 1;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public boolean hasHatsEnabled() {
|
|
|
|
+ return (raw >> 6 & 1) == 1;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public int getRaw() {
|
|
|
|
+ return raw;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public boolean equals(Object o) {
|
|
|
|
+ if (this == o) return true;
|
|
|
|
+ if (o == null || getClass() != o.getClass()) return false;
|
|
|
|
+ PaperSkinParts that = (PaperSkinParts) o;
|
|
|
|
+ return raw == that.raw;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public int hashCode() {
|
|
|
|
+ return Objects.hashCode(raw);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public String toString() {
|
|
|
|
+ return new StringJoiner(", ", PaperSkinParts.class.getSimpleName() + "[", "]")
|
|
|
|
+ .add("raw=" + raw)
|
|
|
|
+ .add("cape=" + hasCapeEnabled())
|
|
|
|
+ .add("jacket=" + hasJacketEnabled())
|
|
|
|
+ .add("leftSleeve=" + hasLeftSleeveEnabled())
|
|
|
|
+ .add("rightSleeve=" + hasRightSleeveEnabled())
|
|
|
|
+ .add("leftPants=" + hasLeftPantsEnabled())
|
|
|
|
+ .add("rightPants=" + hasRightPantsEnabled())
|
|
|
|
+ .add("hats=" + hasHatsEnabled())
|
|
|
|
+ .toString();
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/level/ServerPlayer.java b/src/main/java/net/minecraft/server/level/ServerPlayer.java
|
2023-06-12 23:51:45 +00:00
|
|
|
index 65d17836785774d0f196321ba741ffd05a9db36e..fd34a2ace2efc819b06674ceab44ff78ec11f805 100644
|
2021-06-11 12:02:28 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/level/ServerPlayer.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/level/ServerPlayer.java
|
2023-06-08 05:21:04 +00:00
|
|
|
@@ -1949,9 +1949,24 @@ public class ServerPlayer extends Player {
|
2023-03-14 19:54:57 +00:00
|
|
|
}
|
2022-10-26 23:09:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
+ // Paper start - Client option API
|
|
|
|
+ private java.util.Map<com.destroystokyo.paper.ClientOption<?>, ?> getClientOptionMap(String locale, int viewDistance, com.destroystokyo.paper.ClientOption.ChatVisibility chatVisibility, boolean chatColors, com.destroystokyo.paper.PaperSkinParts skinParts, org.bukkit.inventory.MainHand mainHand, boolean allowsServerListing, boolean textFilteringEnabled) {
|
|
|
|
+ java.util.Map<com.destroystokyo.paper.ClientOption<?>, Object> map = new java.util.HashMap<>();
|
|
|
|
+ map.put(com.destroystokyo.paper.ClientOption.LOCALE, locale);
|
|
|
|
+ map.put(com.destroystokyo.paper.ClientOption.VIEW_DISTANCE, viewDistance);
|
|
|
|
+ map.put(com.destroystokyo.paper.ClientOption.CHAT_VISIBILITY, chatVisibility);
|
|
|
|
+ map.put(com.destroystokyo.paper.ClientOption.CHAT_COLORS_ENABLED, chatColors);
|
|
|
|
+ map.put(com.destroystokyo.paper.ClientOption.SKIN_PARTS, skinParts);
|
|
|
|
+ map.put(com.destroystokyo.paper.ClientOption.MAIN_HAND, mainHand);
|
|
|
|
+ map.put(com.destroystokyo.paper.ClientOption.ALLOW_SERVER_LISTINGS, allowsServerListing);
|
|
|
|
+ map.put(com.destroystokyo.paper.ClientOption.TEXT_FILTERING_ENABLED, textFilteringEnabled);
|
|
|
|
+ return map;
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
2021-06-11 12:02:28 +00:00
|
|
|
public String locale = null; // CraftBukkit - add, lowercase // Paper - default to null
|
|
|
|
public java.util.Locale adventure$locale = java.util.Locale.US; // Paper
|
|
|
|
public void updateOptions(ServerboundClientInformationPacket packet) {
|
2022-10-26 23:09:03 +00:00
|
|
|
+ new com.destroystokyo.paper.event.player.PlayerClientOptionsChangeEvent(getBukkitEntity(), getClientOptionMap(packet.language, packet.viewDistance, com.destroystokyo.paper.ClientOption.ChatVisibility.valueOf(packet.chatVisibility().name()), packet.chatColors(), new com.destroystokyo.paper.PaperSkinParts(packet.modelCustomisation()), packet.mainHand() == HumanoidArm.LEFT ? MainHand.LEFT : MainHand.RIGHT, packet.allowsListing(), packet.textFilteringEnabled())).callEvent(); // Paper - settings event
|
2021-06-11 12:02:28 +00:00
|
|
|
// CraftBukkit start
|
2021-11-24 11:06:34 +00:00
|
|
|
if (getMainArm() != packet.mainHand()) {
|
2021-06-14 01:06:38 +00:00
|
|
|
PlayerChangedMainHandEvent event = new PlayerChangedMainHandEvent(this.getBukkitEntity(), getMainArm() == HumanoidArm.LEFT ? MainHand.LEFT : MainHand.RIGHT);
|
2021-06-11 12:02:28 +00:00
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
2023-06-12 23:51:45 +00:00
|
|
|
index dd99a5ad2212fb228e766a0e0a90a68a3f4b515e..ef2476afc452c83be28c97d9860e27368ded5254 100644
|
2021-06-11 12:02:28 +00:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
2023-06-12 23:51:45 +00:00
|
|
|
@@ -591,6 +591,28 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
|
2022-09-26 08:02:51 +00:00
|
|
|
connection.disconnect(message == null ? net.kyori.adventure.text.Component.empty() : message);
|
|
|
|
}
|
2021-06-11 12:02:28 +00:00
|
|
|
}
|
|
|
|
+
|
|
|
|
+ @Override
|
2021-06-14 01:06:38 +00:00
|
|
|
+ public <T> T getClientOption(com.destroystokyo.paper.ClientOption<T> type) {
|
2022-10-26 23:09:03 +00:00
|
|
|
+ if (com.destroystokyo.paper.ClientOption.SKIN_PARTS == type) {
|
2021-06-14 01:06:38 +00:00
|
|
|
+ return type.getType().cast(new com.destroystokyo.paper.PaperSkinParts(getHandle().getEntityData().get(net.minecraft.world.entity.player.Player.DATA_PLAYER_MODE_CUSTOMISATION)));
|
2022-10-26 23:09:03 +00:00
|
|
|
+ } else if (com.destroystokyo.paper.ClientOption.CHAT_COLORS_ENABLED == type) {
|
2021-06-14 01:06:38 +00:00
|
|
|
+ return type.getType().cast(getHandle().canChatInColor());
|
2022-10-26 23:09:03 +00:00
|
|
|
+ } else if (com.destroystokyo.paper.ClientOption.CHAT_VISIBILITY == type) {
|
2021-06-14 01:06:38 +00:00
|
|
|
+ return type.getType().cast(getHandle().getChatVisibility() == null ? com.destroystokyo.paper.ClientOption.ChatVisibility.UNKNOWN : com.destroystokyo.paper.ClientOption.ChatVisibility.valueOf(getHandle().getChatVisibility().name()));
|
2022-10-26 23:09:03 +00:00
|
|
|
+ } else if (com.destroystokyo.paper.ClientOption.LOCALE == type) {
|
2021-06-11 12:02:28 +00:00
|
|
|
+ return type.getType().cast(getLocale());
|
2022-10-26 23:09:03 +00:00
|
|
|
+ } else if (com.destroystokyo.paper.ClientOption.MAIN_HAND == type) {
|
2021-06-11 12:02:28 +00:00
|
|
|
+ return type.getType().cast(getMainHand());
|
2022-10-26 23:09:03 +00:00
|
|
|
+ } else if (com.destroystokyo.paper.ClientOption.VIEW_DISTANCE == type) {
|
2021-06-11 12:02:28 +00:00
|
|
|
+ return type.getType().cast(getClientViewDistance());
|
2022-10-26 23:09:03 +00:00
|
|
|
+ } else if (com.destroystokyo.paper.ClientOption.ALLOW_SERVER_LISTINGS == type) {
|
|
|
|
+ return type.getType().cast(getHandle().allowsListing());
|
|
|
|
+ } else if (com.destroystokyo.paper.ClientOption.TEXT_FILTERING_ENABLED == type) {
|
|
|
|
+ return type.getType().cast(getHandle().isTextFilteringEnabled());
|
2021-06-11 12:02:28 +00:00
|
|
|
+ }
|
|
|
|
+ throw new RuntimeException("Unknown settings type");
|
|
|
|
+ }
|
|
|
|
// Paper end
|
|
|
|
|
2021-06-14 01:06:38 +00:00
|
|
|
@Override
|
2021-08-14 04:11:12 +00:00
|
|
|
diff --git a/src/test/java/io/papermc/paper/world/TranslationKeyTest.java b/src/test/java/io/papermc/paper/world/TranslationKeyTest.java
|
|
|
|
new file mode 100644
|
2022-06-08 15:31:27 +00:00
|
|
|
index 0000000000000000000000000000000000000000..fab3063fffa959ac7f0eb5937f2fae94d11b6591
|
2021-08-14 04:11:12 +00:00
|
|
|
--- /dev/null
|
|
|
|
+++ b/src/test/java/io/papermc/paper/world/TranslationKeyTest.java
|
2022-06-08 15:31:27 +00:00
|
|
|
@@ -0,0 +1,18 @@
|
2021-08-14 04:11:12 +00:00
|
|
|
+package io.papermc.paper.world;
|
|
|
|
+
|
|
|
|
+import com.destroystokyo.paper.ClientOption;
|
|
|
|
+import net.minecraft.world.entity.player.ChatVisiblity;
|
|
|
|
+import org.bukkit.Difficulty;
|
|
|
|
+import org.junit.Assert;
|
|
|
|
+import org.junit.Test;
|
|
|
|
+
|
|
|
|
+public class TranslationKeyTest {
|
|
|
|
+
|
|
|
|
+ @Test
|
|
|
|
+ public void testChatVisibilityKeys() {
|
|
|
|
+ for (ClientOption.ChatVisibility chatVisibility : ClientOption.ChatVisibility.values()) {
|
|
|
|
+ if (chatVisibility == ClientOption.ChatVisibility.UNKNOWN) continue;
|
|
|
|
+ Assert.assertEquals(chatVisibility + "'s translation key doesn't match", ChatVisiblity.valueOf(chatVisibility.name()).getKey(), chatVisibility.translationKey());
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+}
|