aboutsummaryrefslogtreecommitdiff
path: root/libjava/gnu/java/net/protocol/jar
diff options
context:
space:
mode:
authorAndrew Haley <aph@redhat.com>2005-07-14 18:20:10 +0000
committerAndrew Haley <aph@gcc.gnu.org>2005-07-14 18:20:10 +0000
commit3fefd0193cc8dcd50fe626a9d81719ba3c845a2f (patch)
tree8de981c27b99e5f3550c9d6ebf969b8edaec99fa /libjava/gnu/java/net/protocol/jar
parentb11e14262e1381cc7e7322aec4d5be27bb15529b (diff)
downloadgcc-3fefd0193cc8dcd50fe626a9d81719ba3c845a2f.zip
gcc-3fefd0193cc8dcd50fe626a9d81719ba3c845a2f.tar.gz
gcc-3fefd0193cc8dcd50fe626a9d81719ba3c845a2f.tar.bz2
Connection.java (unquote): New method.
2005-07-13 Andrew Haley <aph@redhat.com> * gnu/java/net/protocol/file/Connection.java (unquote): New method. (connect): Unquote filename. gnu/java/net/protocol/jar/Connection.java (getInputStream): Likewise. (getJarFile): Likewise. * java/net/URLConnection.java (getContentHandler): Guard cast with instaceof. * java/net/URL.java (URL): If the file part of a spec is absolute, ignore the file part of its context. From-SVN: r102029
Diffstat (limited to 'libjava/gnu/java/net/protocol/jar')
-rw-r--r--libjava/gnu/java/net/protocol/jar/Connection.java13
1 files changed, 9 insertions, 4 deletions
diff --git a/libjava/gnu/java/net/protocol/jar/Connection.java b/libjava/gnu/java/net/protocol/jar/Connection.java
index 8ec35cc..34df183 100644
--- a/libjava/gnu/java/net/protocol/jar/Connection.java
+++ b/libjava/gnu/java/net/protocol/jar/Connection.java
@@ -151,7 +151,8 @@ public final class Connection extends JarURLConnection
if (jarfile != null)
{
// this is the easy way...
- ZipEntry entry = jarfile.getEntry(getEntryName());
+ ZipEntry entry = jarfile.getEntry
+ (gnu.java.net.protocol.file.Connection.unquote(getEntryName()));
if (entry != null)
return jarfile.getInputStream (entry);
@@ -164,12 +165,14 @@ public final class Connection extends JarURLConnection
JarInputStream zis = new JarInputStream(
jarFileURLConnection.getInputStream ());
+ String entryName = gnu.java.net.protocol.file.Connection.unquote(getEntryName());
+
// This is hideous, we're doing a linear search...
for (ZipEntry entry = zis.getNextEntry();
entry != null;
entry = zis.getNextEntry())
{
- if (getEntryName().equals(entry.getName()))
+ if (entryName.equals(entry.getName()))
{
int size = (int) entry.getSize();
byte[] data = new byte[size];
@@ -203,12 +206,14 @@ public final class Connection extends JarURLConnection
jar_file = (JarFile) file_cache.get (jarFileURL);
if (jar_file == null)
{
- jar_file = new JarFile (jarFileURL.getFile());
+ jar_file = new JarFile
+ (gnu.java.net.protocol.file.Connection.unquote(jarFileURL.getFile()));
file_cache.put (jarFileURL, jar_file);
}
}
else
- jar_file = new JarFile (jarFileURL.getFile());
+ jar_file = new JarFile
+ (gnu.java.net.protocol.file.Connection.unquote(jarFileURL.getFile()));
}
else
{