mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-07 16:57:42 +01:00
Provide warnings for spaces in plugin names. Addresses BUKKIT-5419
By: Wesley Wolfe <weswolf@aol.com>
This commit is contained in:
parent
edd5dc6155
commit
bc562b3f5b
@ -166,6 +166,7 @@ import com.google.common.collect.ImmutableMap;
|
||||
*/
|
||||
public final class PluginDescriptionFile {
|
||||
private static final Yaml yaml = new Yaml(new SafeConstructor());
|
||||
String rawName = null;
|
||||
private String name = null;
|
||||
private String main = null;
|
||||
private String classLoaderOf = null;
|
||||
@ -228,6 +229,7 @@ public final class PluginDescriptionFile {
|
||||
* <li>Case sensitive.
|
||||
* <li>The is the token referenced in {@link #getDepend()}, {@link
|
||||
* #getSoftDepend()}, and {@link #getLoadBefore()}.
|
||||
* <li>Using spaces in the plugin's name is deprecated.
|
||||
* </ul>
|
||||
* <p>
|
||||
* In the plugin.yml, this entry is named <code>name</code>.
|
||||
@ -799,7 +801,7 @@ public final class PluginDescriptionFile {
|
||||
|
||||
private void loadMap(Map<?, ?> map) throws InvalidDescriptionException {
|
||||
try {
|
||||
name = map.get("name").toString();
|
||||
name = rawName = map.get("name").toString();
|
||||
|
||||
if (!name.matches("^[A-Za-z0-9 _.-]+$")) {
|
||||
throw new InvalidDescriptionException("name '" + name + "' contains invalid characters.");
|
||||
|
@ -135,13 +135,28 @@ public final class SimplePluginManager implements PluginManager {
|
||||
if (name.equalsIgnoreCase("bukkit") || name.equalsIgnoreCase("minecraft") || name.equalsIgnoreCase("mojang")) {
|
||||
server.getLogger().log(Level.SEVERE, "Could not load '" + file.getPath() + "' in folder '" + directory.getPath() + "': Restricted Name");
|
||||
continue;
|
||||
} else if (description.rawName.indexOf(' ') != -1) {
|
||||
server.getLogger().warning(String.format(
|
||||
"Plugin `%s' uses the space-character (0x20) in its name `%s' - this is discouraged",
|
||||
description.getFullName(),
|
||||
description.rawName
|
||||
));
|
||||
}
|
||||
} catch (InvalidDescriptionException ex) {
|
||||
server.getLogger().log(Level.SEVERE, "Could not load '" + file.getPath() + "' in folder '" + directory.getPath() + "'", ex);
|
||||
continue;
|
||||
}
|
||||
|
||||
plugins.put(description.getName(), file);
|
||||
File replacedFile = plugins.put(description.getName(), file);
|
||||
if (replacedFile != null) {
|
||||
server.getLogger().severe(String.format(
|
||||
"Ambiguous plugin name `%s' for files `%s' and `%s' in `%s'",
|
||||
description.getName(),
|
||||
file.getPath(),
|
||||
replacedFile.getPath(),
|
||||
directory.getPath()
|
||||
));
|
||||
}
|
||||
|
||||
Collection<String> softDependencySet = description.getSoftDepend();
|
||||
if (softDependencySet != null && !softDependencySet.isEmpty()) {
|
||||
|
Loading…
Reference in New Issue
Block a user