2020-05-06 17:48:49 +08:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
2020-02-07 09:32:49 +08:00
|
|
|
From: Zach Brown <zach@zachbr.io>
|
|
|
|
Date: Thu, 6 Feb 2020 19:20:27 -0600
|
|
|
|
Subject: [PATCH] Be more tolerant of invalid attributes
|
|
|
|
|
|
|
|
Prior to this commit, the player would be disconnected if they ever encountered an attribute with a name that did
|
|
|
|
not match Bukkit's expected vanilla scheme. It appears that datapacks can set whatever attribute name they want,
|
|
|
|
ignoring vanilla's typical scheme.
|
|
|
|
|
|
|
|
In a more perfect world the API would expose some way to interact with these attributes, however Bukkit is not
|
|
|
|
particularly flexible in this area. Perhaps this is an area for future expansion at a later time.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/attribute/CraftAttributeMap.java b/src/main/java/org/bukkit/craftbukkit/attribute/CraftAttributeMap.java
|
2020-05-06 17:48:49 +08:00
|
|
|
index 77e584b129ab21959b7c33ac45e5841935e86ac8..007d28b16ce16295c7d398c09557b8c0777657c6 100644
|
2020-02-07 09:32:49 +08:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/attribute/CraftAttributeMap.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/attribute/CraftAttributeMap.java
|
|
|
|
@@ -47,6 +47,12 @@ public class CraftAttributeMap implements Attributable {
|
|
|
|
public static Attribute fromMinecraft(String nms) {
|
|
|
|
String[] split = nms.split("\\.", 2);
|
|
|
|
|
|
|
|
+ // Paper start - Datapacks can set their own attributes that may not match our expectations, ignore them
|
|
|
|
+ if (split.length != 2) {
|
|
|
|
+ return null;
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
+
|
|
|
|
String generic = split[0];
|
|
|
|
String descriptor = CaseFormat.LOWER_CAMEL.to(CaseFormat.UPPER_UNDERSCORE, split[1]); // movementSpeed -> MOVEMENT_SPEED
|
|
|
|
String fin = generic + "_" + descriptor;
|