Improve dependency tracker

By: md_5 <git@md-5.net>
This commit is contained in:
Bukkit/Spigot 2020-01-28 13:36:39 +11:00
parent 99378a8c91
commit d962970177
2 changed files with 8 additions and 11 deletions

View file

@ -796,11 +796,11 @@ public final class SimplePluginManager implements PluginManager {
return new HashSet<Permission>(permissions.values()); return new HashSet<Permission>(permissions.values());
} }
public boolean isTransitiveDepend(@NotNull PluginDescriptionFile plugin, @NotNull Plugin depend) { public boolean isTransitiveDepend(@NotNull PluginDescriptionFile plugin, @NotNull PluginDescriptionFile depend) {
Preconditions.checkArgument(plugin != null, "plugin"); Preconditions.checkArgument(plugin != null, "plugin");
Preconditions.checkArgument(depend != null, "depend"); Preconditions.checkArgument(depend != null, "depend");
return Graphs.reachableNodes(dependencyGraph, plugin.getName()).contains(depend.getName()); return dependencyGraph.nodes().contains(plugin.getName()) && Graphs.reachableNodes(dependencyGraph, plugin.getName()).contains(depend.getName());
} }
@Override @Override

View file

@ -1,6 +1,5 @@
package org.bukkit.plugin.java; package org.bukkit.plugin.java;
import com.google.common.base.Preconditions;
import com.google.common.io.ByteStreams; import com.google.common.io.ByteStreams;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
@ -108,20 +107,18 @@ final class PluginClassLoader extends URLClassLoader {
result = loader.getClassByName(name); result = loader.getClassByName(name);
if (result != null) { if (result != null) {
JavaPlugin provider = ((PluginClassLoader) result.getClassLoader()).plugin; PluginDescriptionFile provider = ((PluginClassLoader) result.getClassLoader()).description;
Preconditions.checkState(provider != null, "Globally provided class %s has no plugin. Perhaps broken reflection is in use.", name);
String providerName = provider.getName();
if (provider != plugin if (provider != description
&& !seenIllegalAccess.contains(providerName) && !seenIllegalAccess.contains(provider.getName())
&& !((SimplePluginManager) loader.server.getPluginManager()).isTransitiveDepend(description, provider)) { && !((SimplePluginManager) loader.server.getPluginManager()).isTransitiveDepend(description, provider)) {
seenIllegalAccess.add(providerName); seenIllegalAccess.add(provider.getName());
if (plugin != null) { if (plugin != null) {
plugin.getLogger().log(Level.WARNING, "Loaded class {0} from {1} which is not a depend, softdepend or loadbefore of this plugin.", new Object[]{name, provider.getDescription().getFullName()}); plugin.getLogger().log(Level.WARNING, "Loaded class {0} from {1} which is not a depend, softdepend or loadbefore of this plugin.", new Object[]{name, provider.getFullName()});
} else { } else {
// In case the bad access occurs on construction // In case the bad access occurs on construction
loader.server.getLogger().log(Level.WARNING, "[{0}] Loaded class {1} from {2} which is not a depend, softdepend or loadbefore of this plugin.", new Object[]{description.getName(), name, provider.getDescription().getFullName()}); loader.server.getLogger().log(Level.WARNING, "[{0}] Loaded class {1} from {2} which is not a depend, softdepend or loadbefore of this plugin.", new Object[]{description.getName(), name, provider.getFullName()});
} }
} }
} }