diff --git a/src/main/java/hudson/remoting/DumbClassLoaderBridge.java b/src/main/java/hudson/remoting/DumbClassLoaderBridge.java index 090a60171..4dd43aee9 100644 --- a/src/main/java/hudson/remoting/DumbClassLoaderBridge.java +++ b/src/main/java/hudson/remoting/DumbClassLoaderBridge.java @@ -79,4 +79,10 @@ public ResourceFile[] getResources2(String name) throws IOException { } return res; } + + @Override + public String getName() throws IOException { + return base.getName(); + } + } diff --git a/src/main/java/hudson/remoting/RemoteClassLoader.java b/src/main/java/hudson/remoting/RemoteClassLoader.java index 84518a82c..a5647fc5e 100644 --- a/src/main/java/hudson/remoting/RemoteClassLoader.java +++ b/src/main/java/hudson/remoting/RemoteClassLoader.java @@ -170,11 +170,18 @@ public static ClassLoader create(@CheckForNull ClassLoader parent, @NonNull ICla // actually our classloader that we exported to the other side. return ((ClassLoaderProxy) proxy).cl; } - return new RemoteClassLoader(parent, proxy); + + String name; + try { + name = proxy.getName(); + } catch(IOException ignored) { + name = "unknown-due-to-io-error"; + } + return new RemoteClassLoader(name, parent, proxy); } - private RemoteClassLoader(@CheckForNull ClassLoader parent, @NonNull IClassLoader proxy) { - super(new URL[0], parent); + private RemoteClassLoader(String name, @CheckForNull ClassLoader parent, @NonNull IClassLoader proxy) { + super(name, new URL[0], parent); final Channel channel = RemoteInvocationHandler.unwrap(proxy); this.channel = channel == null ? null : channel.ref(); this.underlyingProxy = proxy; @@ -887,6 +894,11 @@ public interface IClassLoader { */ @NonNull ResourceFile[] getResources2(String name) throws IOException; + + /** + * Name of the classLoader + */ + String getName() throws IOException; } /** @@ -1178,6 +1190,11 @@ public ResourceFile[] getResources2(String name) throws IOException { return r; } + @Override + public String getName() throws IOException { + return cl.getName(); + } + @Override public boolean equals(Object that) { if (this == that) { @@ -1215,6 +1232,7 @@ public String toString() { return "PSEUDO_BOOTSTRAP"; } }; + } /** @@ -1276,6 +1294,11 @@ public ResourceFile[] getResources2(String name) throws IOException { return proxy.getResources2(name); } + @Override + public String getName() throws IOException { + return proxy.getName(); + } + private Object readResolve() throws ObjectStreamException { try { return getChannelForSerialization().getExportedObject(oid); @@ -1285,6 +1308,7 @@ private Object readResolve() throws ObjectStreamException { } private static final long serialVersionUID = 1L; + } private static final class BrokenIClassLoader implements IClassLoader, SerializableOnlyOverRemoting { @@ -1336,6 +1360,11 @@ public ResourceFile[] getResources2(String name) throws IOException { throw new IOException("Cannot get " + name, cause); } + @Override + public String getName() throws IOException { + throw new IOException("Cannot getName", cause); + } + } private static Iterable analyze(InputStream bytecode) {