diff options
Diffstat (limited to 'libjava/java/util/jar/JarFile.java')
-rw-r--r-- | libjava/java/util/jar/JarFile.java | 428 |
1 files changed, 224 insertions, 204 deletions
diff --git a/libjava/java/util/jar/JarFile.java b/libjava/java/util/jar/JarFile.java index 5e0f73b..588f1f8 100644 --- a/libjava/java/util/jar/JarFile.java +++ b/libjava/java/util/jar/JarFile.java @@ -7,7 +7,7 @@ GNU Classpath is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version. - + GNU Classpath is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU @@ -47,231 +47,251 @@ import java.util.Enumeration; * @since 1.2 * @author Mark Wielaard (mark@klomp.org) */ -public class JarFile extends ZipFile { - - // Fields - - /** The name of the manifest entry: META-INF/MANIFEST.MF */ - public static final String MANIFEST_NAME = "META-INF/MANIFEST.MF"; - - /** - * The manifest of this file, if any, otherwise null. - * Read by the constructor. - */ - private final Manifest manifest; +public class JarFile extends ZipFile +{ + // Fields - /** Wether to verify the manifest and all entries */ - private boolean verify; + /** The name of the manifest entry: META-INF/MANIFEST.MF */ + public static final String MANIFEST_NAME = "META-INF/MANIFEST.MF"; - // Constructors + /** + * The manifest of this file, if any, otherwise null. + * Read by the constructor. + */ + private final Manifest manifest; - /** - * Creates a new JarFile, tries to read the manifest and if the manifest - * exists verifies it. - * - * @param fileName the name of the file to open - * @exception FileNotFoundException if the fileName cannot be found - * @exception IOException if another IO exception occurs while reading - */ - public JarFile(String fileName) throws FileNotFoundException, - IOException { - this (fileName, true); - } + /** Wether to verify the manifest and all entries */ + private boolean verify; - /** - * Creates a new JarFile, tries to read the manifest and if the manifest - * exists and verify is true verfies it. - * - * @param fileName the name of the file to open - * @param verify checks manifest and entries when true and a manifest - * exists, when false no checks are made - * @exception FileNotFoundException if the fileName cannot be found - * @exception IOException if another IO exception occurs while reading - */ - public JarFile(String fileName, boolean verify) throws - FileNotFoundException, - IOException { - super(fileName); - manifest = readManifest(); - if (verify) - verify(); - } + // Constructors - /** - * Creates a new JarFile, tries to read the manifest and if the manifest - * exists verifies it. - * - * @param file the file to open as a jar file - * @exception FileNotFoundException if the file does not exits - * @exception IOException if another IO exception occurs while reading - */ - public JarFile(File file) throws FileNotFoundException, - IOException { - this (file, true); - } + /** + * Creates a new JarFile, tries to read the manifest and if the manifest + * exists verifies it. + * + * @param fileName the name of the file to open + * @exception FileNotFoundException if the fileName cannot be found + * @exception IOException if another IO exception occurs while reading + */ + public JarFile(String fileName) throws FileNotFoundException, IOException + { + this(fileName, true); + } - /** - * Creates a new JarFile, tries to read the manifest and if the manifest - * exists and verify is true verfies it. - * - * @param file the file to open to open as a jar file - * @param verify checks manifest and entries when true and a manifest - * exists, when false no checks are made - * @exception FileNotFoundException if file does not exist - * @exception IOException if another IO exception occurs while reading - */ - public JarFile(File file, boolean verify) throws FileNotFoundException, - IOException { - super(file); - manifest = readManifest(); - if (verify) - verify(); - } + /** + * Creates a new JarFile, tries to read the manifest and if the manifest + * exists and verify is true verfies it. + * + * @param fileName the name of the file to open + * @param verify checks manifest and entries when true and a manifest + * exists, when false no checks are made + * @exception FileNotFoundException if the fileName cannot be found + * @exception IOException if another IO exception occurs while reading + */ + public JarFile(String fileName, boolean verify) throws + FileNotFoundException, IOException + { + super(fileName); + manifest = readManifest(); + if (verify) + verify(); + } - /** - * Creates a new JarFile with the indicated mode, tries to read the - * manifest and if the manifest exists and verify is true verfies it. - * - * @param file the file to open to open as a jar file - * @param verify checks manifest and entries when true and a manifest - * exists, when false no checks are made - * @param mode either ZipFile.OPEN_READ or - * (ZipFile.OPEN_READ | ZipFile.OPEN_DELETE) - * @exception FileNotFoundException if the file does not exist - * @exception IOException if another IO exception occurs while reading - * @exception IllegalArgumentException when given an illegal mode - * - * @since 1.3 - */ - public JarFile(File file, boolean verify, int mode) throws - FileNotFoundException, - IOException, - IllegalArgumentException { - super(file, mode); - manifest = readManifest(); - if (verify) - verify(); - } + /** + * Creates a new JarFile, tries to read the manifest and if the manifest + * exists verifies it. + * + * @param file the file to open as a jar file + * @exception FileNotFoundException if the file does not exits + * @exception IOException if another IO exception occurs while reading + */ + public JarFile(File file) throws FileNotFoundException, IOException + { + this(file, true); + } - // Methods + /** + * Creates a new JarFile, tries to read the manifest and if the manifest + * exists and verify is true verfies it. + * + * @param file the file to open to open as a jar file + * @param verify checks manifest and entries when true and a manifest + * exists, when false no checks are made + * @exception FileNotFoundException if file does not exist + * @exception IOException if another IO exception occurs while reading + */ + public JarFile(File file, boolean verify) throws FileNotFoundException, + IOException + { + super(file); + manifest = readManifest(); + if (verify) + verify(); + } - /** - * XXX - should verify the manifest file - */ - private void verify() { - // only check if manifest is not null - if (manifest == null) { - verify = false; - return; - } + /** + * Creates a new JarFile with the indicated mode, tries to read the + * manifest and if the manifest exists and verify is true verfies it. + * + * @param file the file to open to open as a jar file + * @param verify checks manifest and entries when true and a manifest + * exists, when false no checks are made + * @param mode either ZipFile.OPEN_READ or + * (ZipFile.OPEN_READ | ZipFile.OPEN_DELETE) + * @exception FileNotFoundException if the file does not exist + * @exception IOException if another IO exception occurs while reading + * @exception IllegalArgumentException when given an illegal mode + * + * @since 1.3 + */ + public JarFile(File file, boolean verify, int mode) throws + FileNotFoundException, IOException, IllegalArgumentException + { + super(file, mode); + manifest = readManifest(); + if (verify) + verify(); + } - verify = true; - // XXX - verify manifest - } + // Methods - /** - * Parses and returns the manifest if it exists, otherwise returns null. - */ - private Manifest readManifest() { - try { - ZipEntry manEntry = super.getEntry(MANIFEST_NAME); - if (manEntry != null) { - InputStream in = super.getInputStream(manEntry); - return new Manifest(in); - } else { - return null; - } - } catch (IOException ioe) { - return null; - } - } + /** + * XXX - should verify the manifest file + */ + private void verify() + { + // only check if manifest is not null + if (manifest == null) + { + verify = false; + return; + } - /** - * Returns a enumeration of all the entries in the JarFile. - * Note that also the Jar META-INF entries are returned. - * - * @exception IllegalStateException when the JarFile is already closed - */ - public Enumeration entries() throws IllegalStateException { - return new JarEnumeration(super.entries()); - } + verify = true; + // XXX - verify manifest + } - /** - * Wraps a given Zip Entries Enumeration. For every zip entry a - * JarEntry is created and the corresponding Attributes are looked up. - * XXX - Should also look up the certificates. - */ - private class JarEnumeration implements Enumeration { + /** + * Parses and returns the manifest if it exists, otherwise returns null. + */ + private Manifest readManifest() + { + try + { + ZipEntry manEntry = super.getEntry(MANIFEST_NAME); + if (manEntry != null) + { + InputStream in = super.getInputStream(manEntry); + return new Manifest(in); + } + else + { + return null; + } + } + catch (IOException ioe) + { + return null; + } + } - private final Enumeration entries; + /** + * Returns a enumeration of all the entries in the JarFile. + * Note that also the Jar META-INF entries are returned. + * + * @exception IllegalStateException when the JarFile is already closed + */ + public Enumeration entries() throws IllegalStateException + { + return new JarEnumeration(super.entries()); + } - JarEnumeration(Enumeration e) { - entries = e; - } + /** + * Wraps a given Zip Entries Enumeration. For every zip entry a + * JarEntry is created and the corresponding Attributes are looked up. + * XXX - Should also look up the certificates. + */ + private class JarEnumeration implements Enumeration + { - public boolean hasMoreElements() { - return entries.hasMoreElements(); - } + private final Enumeration entries; - public Object nextElement() { - ZipEntry zip = (ZipEntry) entries.nextElement(); - JarEntry jar = new JarEntry(zip); - if (manifest != null) { - jar.attr = manifest.getAttributes(jar.getName()); - } - // XXX jar.certs - return jar; - } + JarEnumeration(Enumeration e) + { + entries = e; } - /** - * XXX - * It actually returns a JarEntry not a zipEntry - * @param name XXX - */ - public ZipEntry getEntry(String name) { - ZipEntry entry = super.getEntry(name); - if (entry != null) { - JarEntry jarEntry = new JarEntry(entry); - if (manifest != null) { - jarEntry.attr = manifest.getAttributes(name); - // XXX jarEntry.certs - } - return jarEntry; - } - return null; + public boolean hasMoreElements() + { + return entries.hasMoreElements(); } - /** - * XXX should verify the inputstream - * @param entry XXX - * @exception ZipException XXX - * @exception IOException XXX - */ - public synchronized InputStream getInputStream(ZipEntry entry) throws - ZipException, - IOException { - return super.getInputStream(entry); // XXX verify + public Object nextElement() + { + ZipEntry zip = (ZipEntry) entries.nextElement(); + JarEntry jar = new JarEntry(zip); + if (manifest != null) + { + jar.attr = manifest.getAttributes(jar.getName()); + } + // XXX jar.certs + return jar; } + } - /** - * Returns the JarEntry that belongs to the name if such an entry - * exists in the JarFile. Returns null otherwise - * Convenience method that just casts the result from <code>getEntry</code> - * to a JarEntry. - * - * @param name the jar entry name to look up - * @return the JarEntry if it exists, null otherwise - */ - public JarEntry getJarEntry(String name) { - return (JarEntry)getEntry(name); - } + /** + * XXX + * It actually returns a JarEntry not a zipEntry + * @param name XXX + */ + public ZipEntry getEntry(String name) + { + ZipEntry entry = super.getEntry(name); + if (entry != null) + { + JarEntry jarEntry = new JarEntry(entry); + if (manifest != null) + { + jarEntry.attr = manifest.getAttributes(name); + // XXX jarEntry.certs + } + return jarEntry; + } + return null; + } - /** - * Returns the manifest for this JarFile or null when the JarFile does not - * contain a manifest file. - */ - public Manifest getManifest() { - return manifest; - } + /** + * XXX should verify the inputstream + * @param entry XXX + * @exception ZipException XXX + * @exception IOException XXX + */ + public synchronized InputStream getInputStream(ZipEntry entry) throws + ZipException, IOException + { + return super.getInputStream(entry); // XXX verify + } + + /** + * Returns the JarEntry that belongs to the name if such an entry + * exists in the JarFile. Returns null otherwise + * Convenience method that just casts the result from <code>getEntry</code> + * to a JarEntry. + * + * @param name the jar entry name to look up + * @return the JarEntry if it exists, null otherwise + */ + public JarEntry getJarEntry(String name) + { + return (JarEntry) getEntry(name); + } + + /** + * Returns the manifest for this JarFile or null when the JarFile does not + * contain a manifest file. + */ + public Manifest getManifest() + { + return manifest; + } } |