From 5906da794852e9154fadc479cacc4c6bdf169f61 Mon Sep 17 00:00:00 2001 From: Bukkit/Spigot Date: Wed, 29 Feb 2012 08:32:25 -0600 Subject: [PATCH] [Bleeding] Cleaned up unsafe casts. Addresses BUKKIT-844 Removed internal collection leaks from PluginDescriptionFile BREAKING: PluginDescriptionFile.getAuthors() now returns List instead of ArrayList Various places with unsafe generics, notably List getList() in Configurations are now referenced as . This is nonbreaking, but sourcecode will need to be revised when compiled. By: Wesley Wolfe --- .../command/PluginCommandYamlParser.java | 84 +++++++------- .../command/defaults/VersionCommand.java | 5 +- .../configuration/ConfigurationSection.java | 10 +- .../bukkit/configuration/MemorySection.java | 46 ++++---- .../configuration/file/YamlConfiguration.java | 14 +-- .../configuration/file/YamlConstructor.java | 5 +- .../java/org/bukkit/event/HandlerList.java | 2 +- .../java/org/bukkit/inventory/ItemStack.java | 5 +- .../org/bukkit/permissions/Permission.java | 42 +++---- .../bukkit/plugin/PluginDescriptionFile.java | 108 ++++++++++-------- .../bukkit/plugin/SimplePluginManager.java | 5 +- .../bukkit/plugin/java/JavaPluginLoader.java | 23 ++-- .../main/java/org/bukkit/potion/Potion.java | 6 +- .../file/YamlConfigurationTest.java | 2 +- 14 files changed, 174 insertions(+), 183 deletions(-) diff --git a/paper-api/src/main/java/org/bukkit/command/PluginCommandYamlParser.java b/paper-api/src/main/java/org/bukkit/command/PluginCommandYamlParser.java index e7feea4909..2e6fedf1dc 100644 --- a/paper-api/src/main/java/org/bukkit/command/PluginCommandYamlParser.java +++ b/paper-api/src/main/java/org/bukkit/command/PluginCommandYamlParser.java @@ -9,58 +9,54 @@ import org.bukkit.plugin.Plugin; public class PluginCommandYamlParser { - @SuppressWarnings("unchecked") public static List parse(Plugin plugin) { List pluginCmds = new ArrayList(); - Object object = plugin.getDescription().getCommands(); - if (object == null) { + Map> map = plugin.getDescription().getCommands(); + + if (map == null) { return pluginCmds; } - Map> map = (Map>) object; + for (Entry> entry : map.entrySet()) { + Command newCmd = new PluginCommand(entry.getKey(), plugin); + Object description = entry.getValue().get("description"); + Object usage = entry.getValue().get("usage"); + Object aliases = entry.getValue().get("aliases"); + Object permission = entry.getValue().get("permission"); + Object permissionMessage = entry.getValue().get("permission-message"); - if (map != null) { - for (Entry> entry : map.entrySet()) { - Command newCmd = new PluginCommand(entry.getKey(), plugin); - Object description = entry.getValue().get("description"); - Object usage = entry.getValue().get("usage"); - Object aliases = entry.getValue().get("aliases"); - Object permission = entry.getValue().get("permission"); - Object permissionMessage = entry.getValue().get("permission-message"); - - if (description != null) { - newCmd.setDescription(description.toString()); - } - - if (usage != null) { - newCmd.setUsage(usage.toString()); - } - - if (aliases != null) { - List aliasList = new ArrayList(); - - if (aliases instanceof List) { - for (Object o : (List) aliases) { - aliasList.add(o.toString()); - } - } else { - aliasList.add(aliases.toString()); - } - - newCmd.setAliases(aliasList); - } - - if (permission != null) { - newCmd.setPermission(permission.toString()); - } - - if (permissionMessage != null) { - newCmd.setPermissionMessage(permissionMessage.toString()); - } - - pluginCmds.add(newCmd); + if (description != null) { + newCmd.setDescription(description.toString()); } + + if (usage != null) { + newCmd.setUsage(usage.toString()); + } + + if (aliases != null) { + List aliasList = new ArrayList(); + + if (aliases instanceof List) { + for (Object o : (List) aliases) { + aliasList.add(o.toString()); + } + } else { + aliasList.add(aliases.toString()); + } + + newCmd.setAliases(aliasList); + } + + if (permission != null) { + newCmd.setPermission(permission.toString()); + } + + if (permissionMessage != null) { + newCmd.setPermissionMessage(permissionMessage.toString()); + } + + pluginCmds.add(newCmd); } return pluginCmds; } diff --git a/paper-api/src/main/java/org/bukkit/command/defaults/VersionCommand.java b/paper-api/src/main/java/org/bukkit/command/defaults/VersionCommand.java index 3a58235967..0bd5c5af0d 100644 --- a/paper-api/src/main/java/org/bukkit/command/defaults/VersionCommand.java +++ b/paper-api/src/main/java/org/bukkit/command/defaults/VersionCommand.java @@ -1,7 +1,8 @@ package org.bukkit.command.defaults; -import java.util.ArrayList; import java.util.Arrays; +import java.util.List; + import org.bukkit.ChatColor; import org.bukkit.Bukkit; import org.bukkit.command.Command; @@ -67,7 +68,7 @@ public class VersionCommand extends Command { private String getAuthors(final PluginDescriptionFile desc) { StringBuilder result = new StringBuilder(); - ArrayList authors = desc.getAuthors(); + List authors = desc.getAuthors(); for (int i = 0; i < authors.size(); i++) { if (result.length() > 0) { diff --git a/paper-api/src/main/java/org/bukkit/configuration/ConfigurationSection.java b/paper-api/src/main/java/org/bukkit/configuration/ConfigurationSection.java index 7083ccc2d6..90d438491d 100644 --- a/paper-api/src/main/java/org/bukkit/configuration/ConfigurationSection.java +++ b/paper-api/src/main/java/org/bukkit/configuration/ConfigurationSection.java @@ -174,7 +174,7 @@ public interface ConfigurationSection { * @param path Path to create the section at. * @return Newly created section */ - public ConfigurationSection createSection(String path, Map map); + public ConfigurationSection createSection(String path, Map map); // Primitives /** @@ -368,8 +368,7 @@ public interface ConfigurationSection { * @param path Path of the List to get. * @return Requested List. */ - @SuppressWarnings("rawtypes") - public List getList(String path); + public List getList(String path); /** * Gets the requested List by path, returning a default value if not found. @@ -380,8 +379,7 @@ public interface ConfigurationSection { * @param path Path of the List to get. * @return Requested List. */ - @SuppressWarnings("rawtypes") - public List getList(String path, List def); + public List getList(String path, List def); /** * Checks if the specified path is a List. @@ -544,7 +542,7 @@ public interface ConfigurationSection { * @param path Path of the List to get. * @return Requested List of Maps. */ - public List> getMapList(String path); + public List> getMapList(String path); // Bukkit /** diff --git a/paper-api/src/main/java/org/bukkit/configuration/MemorySection.java b/paper-api/src/main/java/org/bukkit/configuration/MemorySection.java index 6d6c3f9d04..549d4a136c 100644 --- a/paper-api/src/main/java/org/bukkit/configuration/MemorySection.java +++ b/paper-api/src/main/java/org/bukkit/configuration/MemorySection.java @@ -261,15 +261,14 @@ public class MemorySection implements ConfigurationSection { } } - @SuppressWarnings("unchecked") - public ConfigurationSection createSection(String path, Map map) { + public ConfigurationSection createSection(String path, Map map) { ConfigurationSection section = createSection(path); - for (Map.Entry entry : map.entrySet()) { + for (Map.Entry entry : map.entrySet()) { if (entry.getValue() instanceof Map) { - section.createSection(entry.getKey(), (Map) entry.getValue()); + section.createSection(entry.getKey().toString(), (Map) entry.getValue()); } else { - section.set(entry.getKey(), entry.getValue()); + section.set(entry.getKey().toString(), entry.getValue()); } } @@ -413,24 +412,22 @@ public class MemorySection implements ConfigurationSection { } // Java - @SuppressWarnings("unchecked") - public List getList(String path) { + public List getList(String path) { if (path == null) { throw new IllegalArgumentException("Path cannot be null"); } Object def = getDefault(path); - return getList(path, (def instanceof List) ? (List) def : null); + return getList(path, (def instanceof List) ? (List) def : null); } - @SuppressWarnings("unchecked") - public List getList(String path, List def) { + public List getList(String path, List def) { if (path == null) { throw new IllegalArgumentException("Path cannot be null"); } Object val = get(path, def); - return (List) ((val instanceof List) ? val : def); + return (List) ((val instanceof List) ? val : def); } public boolean isList(String path) { @@ -447,7 +444,7 @@ public class MemorySection implements ConfigurationSection { throw new IllegalArgumentException("Path cannot be null"); } - List list = getList(path); + List list = getList(path); if (list == null) { return new ArrayList(0); @@ -469,7 +466,7 @@ public class MemorySection implements ConfigurationSection { throw new IllegalArgumentException("Path cannot be null"); } - List list = getList(path); + List list = getList(path); if (list == null) { return new ArrayList(0); @@ -510,7 +507,7 @@ public class MemorySection implements ConfigurationSection { throw new IllegalArgumentException("Path cannot be null"); } - List list = getList(path); + List list = getList(path); if (list == null) { return new ArrayList(0); @@ -538,7 +535,7 @@ public class MemorySection implements ConfigurationSection { throw new IllegalArgumentException("Path cannot be null"); } - List list = getList(path); + List list = getList(path); if (list == null) { return new ArrayList(0); @@ -579,7 +576,7 @@ public class MemorySection implements ConfigurationSection { throw new IllegalArgumentException("Path cannot be null"); } - List list = getList(path); + List list = getList(path); if (list == null) { return new ArrayList(0); @@ -620,7 +617,7 @@ public class MemorySection implements ConfigurationSection { throw new IllegalArgumentException("Path cannot be null"); } - List list = getList(path); + List list = getList(path); if (list == null) { return new ArrayList(0); @@ -661,7 +658,7 @@ public class MemorySection implements ConfigurationSection { throw new IllegalArgumentException("Path cannot be null"); } - List list = getList(path); + List list = getList(path); if (list == null) { return new ArrayList(0); @@ -702,7 +699,7 @@ public class MemorySection implements ConfigurationSection { throw new IllegalArgumentException("Path cannot be null"); } - List list = getList(path); + List list = getList(path); if (list == null) { return new ArrayList(0); @@ -744,7 +741,7 @@ public class MemorySection implements ConfigurationSection { throw new IllegalArgumentException("Path cannot be null"); } - List list = getList(path); + List list = getList(path); if (list == null) { return new ArrayList(0); @@ -780,18 +777,17 @@ public class MemorySection implements ConfigurationSection { return result; } - @SuppressWarnings("unchecked") - public List> getMapList(String path) { + public List> getMapList(String path) { if (path == null) { throw new IllegalArgumentException("Path cannot be null"); } - List list = getList(path); - List> result = new ArrayList>(); + List list = getList(path); + List> result = new ArrayList>(); for (Object object : list) { if (object instanceof Map) { - result.add((Map) object); + result.add((Map) object); } } diff --git a/paper-api/src/main/java/org/bukkit/configuration/file/YamlConfiguration.java b/paper-api/src/main/java/org/bukkit/configuration/file/YamlConfiguration.java index 80842a7011..99bfa1f8e4 100644 --- a/paper-api/src/main/java/org/bukkit/configuration/file/YamlConfiguration.java +++ b/paper-api/src/main/java/org/bukkit/configuration/file/YamlConfiguration.java @@ -42,16 +42,15 @@ public class YamlConfiguration extends FileConfiguration { return header + dump; } - @SuppressWarnings("unchecked") @Override public void loadFromString(String contents) throws InvalidConfigurationException { if (contents == null) { throw new IllegalArgumentException("Contents cannot be null"); } - Map input; + Map input; try { - input = (Map) yaml.load(contents); + input = (Map) yaml.load(contents); } catch (YAMLException e) { throw new InvalidConfigurationException(e); } catch (ClassCastException e) { @@ -68,14 +67,13 @@ public class YamlConfiguration extends FileConfiguration { } } - @SuppressWarnings("unchecked") - protected void convertMapsToSections(Map input, ConfigurationSection section) { - for (Map.Entry entry : input.entrySet()) { + protected void convertMapsToSections(Map input, ConfigurationSection section) { + for (Map.Entry entry : input.entrySet()) { String key = entry.getKey().toString(); Object value = entry.getValue(); - if (value instanceof Map) { - convertMapsToSections((Map) value, section.createSection(key)); + if (value instanceof Map) { + convertMapsToSections((Map) value, section.createSection(key)); } else { section.set(key, value); } diff --git a/paper-api/src/main/java/org/bukkit/configuration/file/YamlConstructor.java b/paper-api/src/main/java/org/bukkit/configuration/file/YamlConstructor.java index 7df59fb260..73ad722a82 100644 --- a/paper-api/src/main/java/org/bukkit/configuration/file/YamlConstructor.java +++ b/paper-api/src/main/java/org/bukkit/configuration/file/YamlConstructor.java @@ -23,12 +23,11 @@ public class YamlConstructor extends SafeConstructor { throw new YAMLException("Unexpected referential mapping structure. Node: " + node); } - @SuppressWarnings("unchecked") - Map raw = (Map) super.construct(node); + Map raw = (Map) super.construct(node); if (raw.containsKey(ConfigurationSerialization.SERIALIZED_TYPE_KEY)) { Map typed = new LinkedHashMap(raw.size()); - for (Map.Entry entry : raw.entrySet()) { + for (Map.Entry entry : raw.entrySet()) { typed.put(entry.getKey().toString(), entry.getValue()); } diff --git a/paper-api/src/main/java/org/bukkit/event/HandlerList.java b/paper-api/src/main/java/org/bukkit/event/HandlerList.java index f25b26fba6..f48d942f55 100644 --- a/paper-api/src/main/java/org/bukkit/event/HandlerList.java +++ b/paper-api/src/main/java/org/bukkit/event/HandlerList.java @@ -9,7 +9,6 @@ import java.util.Map.Entry; /** * A list of event handlers, stored per-event. Based on lahwran's fevents. */ -@SuppressWarnings("unchecked") public class HandlerList { /** * Handler array. This field being an array is the key to this system's speed. @@ -203,6 +202,7 @@ public class HandlerList { * * @return the list of all handler lists */ + @SuppressWarnings("unchecked") public static ArrayList getHandlerLists() { return (ArrayList) allLists.clone(); } diff --git a/paper-api/src/main/java/org/bukkit/inventory/ItemStack.java b/paper-api/src/main/java/org/bukkit/inventory/ItemStack.java index 9118194be2..b814fbec78 100644 --- a/paper-api/src/main/java/org/bukkit/inventory/ItemStack.java +++ b/paper-api/src/main/java/org/bukkit/inventory/ItemStack.java @@ -391,10 +391,9 @@ public class ItemStack implements Cloneable, ConfigurationSerializable { Object raw = args.get("enchantments"); if (raw instanceof Map) { - @SuppressWarnings("unchecked") - Map map = (Map) raw; + Map map = (Map) raw; - for (Map.Entry entry : map.entrySet()) { + for (Map.Entry entry : map.entrySet()) { Enchantment enchantment = Enchantment.getByName(entry.getKey().toString()); if ((enchantment != null) && (entry.getValue() instanceof Integer)) { diff --git a/paper-api/src/main/java/org/bukkit/permissions/Permission.java b/paper-api/src/main/java/org/bukkit/permissions/Permission.java index bfac37ab81..abac6a9ae7 100644 --- a/paper-api/src/main/java/org/bukkit/permissions/Permission.java +++ b/paper-api/src/main/java/org/bukkit/permissions/Permission.java @@ -6,6 +6,8 @@ import java.util.List; import java.util.Map; import java.util.Set; import java.util.logging.Level; + +import org.apache.commons.lang.Validate; import org.bukkit.Bukkit; import org.bukkit.plugin.PluginManager; @@ -204,12 +206,12 @@ public class Permission { * @param def Default permission value to use if missing * @return Permission object */ - public static List loadPermissions(Map> data, String error, PermissionDefault def) { + public static List loadPermissions(Map data, String error, PermissionDefault def) { List result = new ArrayList(); - for (Map.Entry> entry : data.entrySet()) { + for (Map.Entry entry : data.entrySet()) { try { - result.add(Permission.loadPermission(entry.getKey(), entry.getValue(), def, result)); + result.add(Permission.loadPermission(entry.getKey().toString(), (Map) entry.getValue(), def, result)); } catch (Throwable ex) { Bukkit.getServer().getLogger().log(Level.SEVERE, String.format(error, entry.getKey()), ex); } @@ -248,13 +250,10 @@ public class Permission { * @param output A list to append any created child-Permissions to, may be null * @return Permission object */ - public static Permission loadPermission(String name, Map data, PermissionDefault def, List output) { - if (name == null) { - throw new IllegalArgumentException("Name cannot be null"); - } - if (data == null) { - throw new IllegalArgumentException("Data cannot be null"); - } + public static Permission loadPermission(String name, Map data, PermissionDefault def, List output) { + Validate.notNull(name, "Name cannot be null"); + Validate.notNull(data, "Data cannot be null"); + String desc = null; Map children = null; @@ -280,11 +279,7 @@ public class Permission { } if (data.containsKey("description")) { - try { - desc = (String) data.get("description"); - } catch (ClassCastException ex) { - throw new IllegalArgumentException("'description' key is of wrong type", ex); - } + desc = data.get("description").toString(); } Permission result = new Permission(name, desc, def, children); @@ -304,31 +299,30 @@ public class Permission { return result; } - @SuppressWarnings("unchecked") - private static Map extractChildren(Map data, String name, PermissionDefault def, List output) { - Map input = (Map) data.get("children"); + private static Map extractChildren(Map data, String name, PermissionDefault def, List output) { + Map input = (Map) data.get("children"); Map children = new LinkedHashMap(); - for (Map.Entry entry : input.entrySet()) { + for (Map.Entry entry : input.entrySet()) { if ((entry.getValue() instanceof Boolean)) { - children.put(entry.getKey(), (Boolean) entry.getValue()); + children.put(entry.getKey().toString(), (Boolean) entry.getValue()); } else if ((entry.getValue() instanceof Map)) { try { try { - Permission perm = loadPermission((String) entry.getKey(), (Map) entry.getValue(), def, output); + Permission perm = loadPermission(entry.getKey().toString(), (Map) entry.getValue(), def, output); children.put(perm.getName(), Boolean.valueOf(true)); if (output != null) { output.add(perm); } } catch (Throwable ex) { - Bukkit.getServer().getLogger().log(Level.SEVERE, "Permission node '" + (String) entry.getKey() + "' in child of " + name + " is invalid", ex); + Bukkit.getServer().getLogger().log(Level.SEVERE, "Permission node '" + entry.getKey().toString() + "' in child of " + name + " is invalid", ex); } } catch (ClassCastException ex) { - throw new IllegalArgumentException("Child '" + (String) entry.getKey() + "' contains invalid map type"); + throw new IllegalArgumentException("Child '" + entry.getKey().toString() + "' contains invalid map type"); } } else { - throw new IllegalArgumentException("Child '" + (String) entry.getKey() + "' contains invalid value"); + throw new IllegalArgumentException("Child '" + entry.getKey().toString() + "' contains invalid value"); } } diff --git a/paper-api/src/main/java/org/bukkit/plugin/PluginDescriptionFile.java b/paper-api/src/main/java/org/bukkit/plugin/PluginDescriptionFile.java index 69f409681d..34095d52ad 100644 --- a/paper-api/src/main/java/org/bukkit/plugin/PluginDescriptionFile.java +++ b/paper-api/src/main/java/org/bukkit/plugin/PluginDescriptionFile.java @@ -3,15 +3,18 @@ package org.bukkit.plugin; import java.io.InputStream; import java.io.Reader; import java.io.Writer; -import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; + import org.bukkit.permissions.Permission; import org.bukkit.permissions.PermissionDefault; import org.yaml.snakeyaml.Yaml; import org.yaml.snakeyaml.constructor.SafeConstructor; +import com.google.common.collect.ImmutableList; +import com.google.common.collect.ImmutableMap; + /** * Provides access to a Plugins description file, plugin.yaml */ @@ -20,21 +23,20 @@ public final class PluginDescriptionFile { private String name = null; private String main = null; private String classLoaderOf = null; - private ArrayList depend = null; - private ArrayList softDepend = null; + private List depend = null; + private List softDepend = null; private String version = null; - private Object commands = null; + private Map> commands = null; private String description = null; - private ArrayList authors = new ArrayList(); + private List authors = null; private String website = null; private boolean database = false; private PluginLoadOrder order = PluginLoadOrder.POSTWORLD; - private List permissions = new ArrayList(); + private List permissions = null; private PermissionDefault defaultPerm = PermissionDefault.OP; - @SuppressWarnings("unchecked") public PluginDescriptionFile(final InputStream stream) throws InvalidDescriptionException { - loadMap((Map) yaml.load(stream)); + loadMap((Map) yaml.load(stream)); } /** @@ -43,9 +45,8 @@ public final class PluginDescriptionFile { * @param reader The reader * @throws InvalidDescriptionException If the PluginDescriptionFile is invalid */ - @SuppressWarnings("unchecked") public PluginDescriptionFile(final Reader reader) throws InvalidDescriptionException { - loadMap((Map) yaml.load(reader)); + loadMap((Map) yaml.load(reader)); } /** @@ -106,15 +107,15 @@ public final class PluginDescriptionFile { return main; } - public Object getCommands() { + public Map> getCommands() { return commands; } - public Object getDepend() { + public List getDepend() { return depend; } - public Object getSoftDepend() { + public List getSoftDepend() { return softDepend; } @@ -131,7 +132,7 @@ public final class PluginDescriptionFile { return description; } - public ArrayList getAuthors() { + public List getAuthors() { return authors; } @@ -159,8 +160,7 @@ public final class PluginDescriptionFile { return classLoaderOf; } - @SuppressWarnings("unchecked") - private void loadMap(Map map) throws InvalidDescriptionException { + private void loadMap(Map map) throws InvalidDescriptionException { try { name = map.get("name").toString(); @@ -193,11 +193,28 @@ public final class PluginDescriptionFile { } if (map.containsKey("commands")) { + ImmutableMap.Builder> commandsBuilder = ImmutableMap.>builder(); try { - commands = map.get("commands"); + for (Map.Entry command : ((Map) map.get("commands")).entrySet()) { + ImmutableMap.Builder commandBuilder = ImmutableMap.builder(); + for (Map.Entry commandEntry : ((Map) command.getValue()).entrySet()) { + if (commandEntry.getValue() instanceof Iterable) { + // This prevents internal alias list changes + ImmutableList.Builder commandSubList = ImmutableList.builder(); + for (Object commandSubListItem : (Iterable) commandEntry.getValue()) { + commandSubList.add(commandSubListItem); + } + commandBuilder.put(commandEntry.getKey().toString(), commandSubList.build()); + } else { + commandBuilder.put(commandEntry.getKey().toString(), commandEntry.getValue()); + } + } + commandsBuilder.put(command.getKey().toString(), commandBuilder.build()); + } } catch (ClassCastException ex) { throw new InvalidDescriptionException(ex, "commands are of wrong type"); } + commands = commandsBuilder.build(); } if (map.containsKey("class-loader-of")) { @@ -205,19 +222,27 @@ public final class PluginDescriptionFile { } if (map.containsKey("depend")) { + ImmutableList.Builder dependBuilder = ImmutableList.builder(); try { - depend = (ArrayList) map.get("depend"); + for (Object dependency : (Iterable) map.get("depend")) { + dependBuilder.add(dependency.toString()); + } } catch (ClassCastException ex) { throw new InvalidDescriptionException(ex, "depend is of wrong type"); } + depend = dependBuilder.build(); } if (map.containsKey("softdepend")) { + ImmutableList.Builder softDependBuilder = ImmutableList.builder(); try { - softDepend = (ArrayList) map.get("softdepend"); + for (Object dependency : (Iterable) map.get("softdepend")) { + softDependBuilder.add(dependency.toString()); + } } catch (ClassCastException ex) { throw new InvalidDescriptionException(ex, "softdepend is of wrong type"); } + softDepend = softDependBuilder.build(); } if (map.containsKey("database")) { @@ -229,19 +254,11 @@ public final class PluginDescriptionFile { } if (map.containsKey("website")) { - try { - website = (String) map.get("website"); - } catch (ClassCastException ex) { - throw new InvalidDescriptionException(ex, "website is of wrong type"); - } + website = map.get("website").toString(); } if (map.containsKey("description")) { - try { - description = (String) map.get("description"); - } catch (ClassCastException ex) { - throw new InvalidDescriptionException(ex, "description is of wrong type"); - } + description = map.get("description").toString(); } if (map.containsKey("load")) { @@ -254,29 +271,28 @@ public final class PluginDescriptionFile { } } - if (map.containsKey("author")) { - try { - String extra = (String) map.get("author"); - - authors.add(extra); - } catch (ClassCastException ex) { - throw new InvalidDescriptionException(ex, "author is of wrong type"); - } - } - if (map.containsKey("authors")) { + ImmutableList.Builder authorsBuilder = ImmutableList.builder(); + if (map.containsKey("author")) { + authorsBuilder.add(map.get("author").toString()); + } try { - ArrayList extra = (ArrayList) map.get("authors"); - - authors.addAll(extra); + for (Object o : (Iterable) map.get("authors")) { + authorsBuilder.add(o.toString()); + } } catch (ClassCastException ex) { throw new InvalidDescriptionException(ex, "authors are of wrong type"); } + authors = authorsBuilder.build(); + } else if (map.containsKey("author")) { + authors = ImmutableList.of(map.get("author").toString()); + } else { + authors = ImmutableList.of(); } if (map.containsKey("default-permission")) { try { - defaultPerm = PermissionDefault.getByName((String) map.get("default-permission")); + defaultPerm = PermissionDefault.getByName(map.get("default-permission").toString()); } catch (ClassCastException ex) { throw new InvalidDescriptionException(ex, "default-permission is of wrong type"); } catch (IllegalArgumentException ex) { @@ -286,12 +302,14 @@ public final class PluginDescriptionFile { if (map.containsKey("permissions")) { try { - Map> perms = (Map>) map.get("permissions"); + Map perms = (Map) map.get("permissions"); - permissions = Permission.loadPermissions(perms, "Permission node '%s' in plugin description file for " + getFullName() + " is invalid", defaultPerm); + permissions = ImmutableList.copyOf(Permission.loadPermissions(perms, "Permission node '%s' in plugin description file for " + getFullName() + " is invalid", defaultPerm)); } catch (ClassCastException ex) { throw new InvalidDescriptionException(ex, "permissions are of wrong type"); } + } else { + permissions = ImmutableList.of(); } } diff --git a/paper-api/src/main/java/org/bukkit/plugin/SimplePluginManager.java b/paper-api/src/main/java/org/bukkit/plugin/SimplePluginManager.java index 1febcb8cce..f23a59e284 100644 --- a/paper-api/src/main/java/org/bukkit/plugin/SimplePluginManager.java +++ b/paper-api/src/main/java/org/bukkit/plugin/SimplePluginManager.java @@ -99,7 +99,6 @@ public final class SimplePluginManager implements PluginManager { * @param directory Directory to check for plugins * @return A list of all plugins loaded */ - @SuppressWarnings("unchecked") public Plugin[] loadPlugins(File directory) { Validate.notNull(directory, "Directory cannot be null"); Validate.isTrue(directory.isDirectory(), "Directory must be a directory"); @@ -138,12 +137,12 @@ public final class SimplePluginManager implements PluginManager { plugins.put(description.getName(), file); - Collection softDependencySet = (Collection) description.getSoftDepend(); + Collection softDependencySet = description.getSoftDepend(); if (softDependencySet != null) { softDependencies.put(description.getName(), new LinkedList(softDependencySet)); } - Collection dependencySet = (Collection) description.getDepend(); + Collection dependencySet = description.getDepend(); if (dependencySet != null) { dependencies.put(description.getName(), new LinkedList(dependencySet)); } diff --git a/paper-api/src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java b/paper-api/src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java index 2766330d77..cb0055b4fe 100644 --- a/paper-api/src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java +++ b/paper-api/src/main/java/org/bukkit/plugin/java/JavaPluginLoader.java @@ -8,9 +8,9 @@ import java.lang.reflect.Constructor; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import java.net.URL; -import java.util.ArrayList; import java.util.HashMap; import java.util.HashSet; +import java.util.List; import java.util.Map; import java.util.Set; import java.util.jar.JarEntry; @@ -40,6 +40,8 @@ import org.bukkit.plugin.TimedRegisteredListener; import org.bukkit.plugin.UnknownDependencyException; import org.yaml.snakeyaml.error.YAMLException; +import com.google.common.collect.ImmutableList; + /** * Represents a Java plugin loader, allowing plugins in the form of .jar */ @@ -53,7 +55,6 @@ public class JavaPluginLoader implements PluginLoader { server = instance; } - @SuppressWarnings("unchecked") public Plugin loadPlugin(File file) throws InvalidPluginException { Validate.notNull(file, "File cannot be null"); @@ -104,15 +105,9 @@ public class JavaPluginLoader implements PluginLoader { )); } - ArrayList depend; - - try { - depend = (ArrayList) description.getDepend(); - if (depend == null) { - depend = new ArrayList(); - } - } catch (ClassCastException ex) { - throw new InvalidPluginException(ex); + List depend = description.getDepend(); + if (depend == null) { + depend = ImmutableList.of(); } for (String pluginName : depend) { @@ -251,8 +246,7 @@ public class JavaPluginLoader implements PluginLoader { classes.put(name, clazz); if (ConfigurationSerializable.class.isAssignableFrom(clazz)) { - @SuppressWarnings("unchecked") - Class serializable = (Class) clazz; + Class serializable = clazz.asSubclass(ConfigurationSerializable.class); ConfigurationSerialization.registerClass(serializable); } } @@ -263,8 +257,7 @@ public class JavaPluginLoader implements PluginLoader { try { if ((clazz != null) && (ConfigurationSerializable.class.isAssignableFrom(clazz))) { - @SuppressWarnings("unchecked") - Class serializable = (Class) clazz; + Class serializable = clazz.asSubclass(ConfigurationSerializable.class); ConfigurationSerialization.unregisterClass(serializable); } } catch (NullPointerException ex) { diff --git a/paper-api/src/main/java/org/bukkit/potion/Potion.java b/paper-api/src/main/java/org/bukkit/potion/Potion.java index a66d1f9199..e9c8e041aa 100644 --- a/paper-api/src/main/java/org/bukkit/potion/Potion.java +++ b/paper-api/src/main/java/org/bukkit/potion/Potion.java @@ -1,13 +1,14 @@ package org.bukkit.potion; import java.util.Collection; -import java.util.Collections; import org.apache.commons.lang.Validate; import org.bukkit.Material; import org.bukkit.entity.LivingEntity; import org.bukkit.inventory.ItemStack; +import com.google.common.collect.ImmutableList; + /** * Represents a minecraft potion */ @@ -170,9 +171,8 @@ public class Potion { * @see Potion#toDamageValue() * @return The effects that this potion applies */ - @SuppressWarnings("unchecked") public Collection getEffects() { - if(type == null) return Collections.EMPTY_SET; + if (type == null) return ImmutableList.of(); return getBrewer().getEffectsFromDamage(toDamageValue()); } diff --git a/paper-api/src/test/java/org/bukkit/configuration/file/YamlConfigurationTest.java b/paper-api/src/test/java/org/bukkit/configuration/file/YamlConfigurationTest.java index b3c6de9b5b..7c4d7653b3 100644 --- a/paper-api/src/test/java/org/bukkit/configuration/file/YamlConfigurationTest.java +++ b/paper-api/src/test/java/org/bukkit/configuration/file/YamlConfigurationTest.java @@ -93,7 +93,7 @@ public class YamlConfigurationTest extends FileConfigurationTest { YamlConfiguration in = new YamlConfiguration(); in.loadFromString(yaml); - List raw = in.getList("composite-list.abc.def"); + List raw = in.getList("composite-list.abc.def"); assertEquals(stacks.size(), raw.size()); assertEquals(stacks.get(0), raw.get(0));