From 6ea05f15418644c5ba38fbeec29808dc0f3995d3 Mon Sep 17 00:00:00 2001 From: Bukkit/Spigot Date: Wed, 29 Aug 2018 19:26:58 +1000 Subject: [PATCH] Make matchMaterial accept the minecraft: namespace By: md_5 --- .../src/main/java/org/bukkit/Material.java | 19 +++++++++++------- .../test/java/org/bukkit/MaterialTest.java | 20 +++++++++++++++++++ 2 files changed, 32 insertions(+), 7 deletions(-) diff --git a/paper-api/src/main/java/org/bukkit/Material.java b/paper-api/src/main/java/org/bukkit/Material.java index 90a01e03ec..83f8eca154 100644 --- a/paper-api/src/main/java/org/bukkit/Material.java +++ b/paper-api/src/main/java/org/bukkit/Material.java @@ -2781,9 +2781,9 @@ public enum Material implements Keyed { /** * Attempts to match the Material with the given name. *

- * This is a match lookup; names will be converted to uppercase, then - * stripped of special characters in an attempt to format it like the - * enum. + * This is a match lookup; names will be stripped of the "minecraft:" + * namespace, converted to uppercase, then stripped of special characters in + * an attempt to format it like the enum. * * @param name Name of the material to get * @return Material if found, or null @@ -2795,9 +2795,9 @@ public enum Material implements Keyed { /** * Attempts to match the Material with the given name. *

- * This is a match lookup; names will be converted to uppercase, then - * stripped of special characters in an attempt to format it like the - * enum. + * This is a match lookup; names will be stripped of the "minecraft:" + * namespace, converted to uppercase, then stripped of special characters in + * an attempt to format it like the enum. * * @param name Name of the material to get * @param legacyName whether this is a legacy name @@ -2806,7 +2806,12 @@ public enum Material implements Keyed { public static Material matchMaterial(final String name, boolean legacyName) { Validate.notNull(name, "Name cannot be null"); - String filtered = name.toUpperCase(java.util.Locale.ENGLISH); + String filtered = name; + if (filtered.startsWith(NamespacedKey.MINECRAFT + ":")) { + filtered = filtered.substring((NamespacedKey.MINECRAFT + ":").length()); + } + + filtered = filtered.toUpperCase(java.util.Locale.ENGLISH); filtered = filtered.replaceAll("\\s+", "_").replaceAll("\\W", ""); return getMaterial(filtered, legacyName); diff --git a/paper-api/src/test/java/org/bukkit/MaterialTest.java b/paper-api/src/test/java/org/bukkit/MaterialTest.java index 692bb920cf..66f4603a22 100644 --- a/paper-api/src/test/java/org/bukkit/MaterialTest.java +++ b/paper-api/src/test/java/org/bukkit/MaterialTest.java @@ -43,6 +43,26 @@ public class MaterialTest { } } + @Test + public void matchMaterialByKey() { + for (Material material : Material.values()) { + if (material.isLegacy()) { + continue; + } + assertThat(Material.matchMaterial(material.getKey().toString()), is(material)); + } + } + + @Test + public void matchMaterialByWrongNamespace() { + for (Material material : Material.values()) { + if (material.isLegacy()) { + continue; + } + assertNull(Material.matchMaterial("bogus:" + material.getKey().getKey())); + } + } + @Test public void matchMaterialByLowerCaseAndSpaces() { for (Material material : Material.values()) {