mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-01-26 13:44:34 +08:00
URLClassLoader.java (Resource.getCodeSource): Fix check certs == null.
* java/net/URLClassLoader.java (Resource.getCodeSource): Fix check certs == null. (getCanonicalFileURL): Removed method. (JarURLLoader): Don't call removed method. (FileURLLoader): Likewise. (FileURLLoader.getResource): Don't canonicalize file name. Co-Authored-By: Jeroen Frijters <jeroen@sumatra.nl> From-SVN: r60780
This commit is contained in:
parent
3006ff7f46
commit
27c687cc5b
@ -1,3 +1,13 @@
|
||||
2003-01-02 Mark Wielaard <mark@klomp.org>
|
||||
Jeroen Frijters <jeroen@sumatra.nl>
|
||||
|
||||
* java/net/URLClassLoader.java (Resource.getCodeSource):
|
||||
Fix check certs == null.
|
||||
(getCanonicalFileURL): Removed method.
|
||||
(JarURLLoader): Don't call removed method.
|
||||
(FileURLLoader): Likewise.
|
||||
(FileURLLoader.getResource): Don't canonicalize file name.
|
||||
|
||||
2003-01-01 Tom Tromey <tromey@redhat.com>
|
||||
|
||||
* Makefile.in: Rebuilt.
|
||||
|
@ -238,7 +238,7 @@ public class URLClassLoader extends SecureClassLoader
|
||||
CodeSource getCodeSource()
|
||||
{
|
||||
Certificate[] certs = getCertificates();
|
||||
if (certs != null)
|
||||
if (certs == null)
|
||||
return loader.noCertCodeSource;
|
||||
else
|
||||
return new CodeSource(loader.baseURL, certs);
|
||||
@ -271,34 +271,18 @@ public class URLClassLoader extends SecureClassLoader
|
||||
abstract InputStream getInputStream() throws IOException;
|
||||
}
|
||||
|
||||
static URL getCanonicalFileURL(URL url)
|
||||
{
|
||||
if ("file".equals(url.getProtocol()))
|
||||
{
|
||||
try
|
||||
{
|
||||
File f = new File(url.getFile()).getCanonicalFile();
|
||||
url = new URL("file", "", f.toString());
|
||||
}
|
||||
catch (IOException ignore)
|
||||
{
|
||||
}
|
||||
}
|
||||
return url;
|
||||
}
|
||||
|
||||
/**
|
||||
* A <code>JarURLLoader</code> is a type of <code>URLLoader</code>
|
||||
* only loading from jar url.
|
||||
*/
|
||||
final static class JarURLLoader extends URLLoader
|
||||
{
|
||||
final JarFile jarfile; // The canonical jar file for this url
|
||||
final JarFile jarfile; // The jar file for this url
|
||||
final URL baseJarURL; // Base jar: url for all resources loaded from jar
|
||||
|
||||
public JarURLLoader(URLClassLoader classloader, URL baseURL)
|
||||
{
|
||||
super(classloader, getCanonicalFileURL(baseURL));
|
||||
super(classloader, baseURL);
|
||||
|
||||
// cache url prefix for all resources in this jar url
|
||||
String external = baseURL.toExternalForm();
|
||||
@ -481,11 +465,11 @@ public class URLClassLoader extends SecureClassLoader
|
||||
*/
|
||||
final static class FileURLLoader extends URLLoader
|
||||
{
|
||||
File dir; //the canonical file for this file url
|
||||
File dir; //the file for this file url
|
||||
|
||||
FileURLLoader(URLClassLoader classloader, URL url)
|
||||
{
|
||||
super(classloader, getCanonicalFileURL(url));
|
||||
super(classloader, url);
|
||||
dir = new File(baseURL.getFile());
|
||||
}
|
||||
|
||||
@ -493,13 +477,6 @@ public class URLClassLoader extends SecureClassLoader
|
||||
Resource getResource(String name)
|
||||
{
|
||||
File file = new File(dir, name);
|
||||
try
|
||||
{
|
||||
file = file.getCanonicalFile();
|
||||
}
|
||||
catch (IOException ignore)
|
||||
{
|
||||
}
|
||||
if (file.exists() && !file.isDirectory())
|
||||
return new FileResource(this, name, file);
|
||||
return null;
|
||||
|
Loading…
Reference in New Issue
Block a user