Class ZipArchive
- java.lang.Object
-
- org.apache.jackrabbit.vault.fs.io.ZipArchive
-
- All Implemented Interfaces:
Closeable,AutoCloseable,Archive
public class ZipArchive extends Object
Implements an archive that is based on a zip file.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.apache.jackrabbit.vault.fs.io.Archive
Archive.Entry
-
-
Constructor Summary
Constructors Constructor Description ZipArchive(File zipFile)Creates a new archive that is based on the given zip file.ZipArchive(File zipFile, boolean isTempFile)Creates a new archive that is based on the given zip file.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()closes the archiveArchive.EntrygetEntry(String path)Returns the entry specified by path.FilegetFile()Returns the underlying file ornullif it does not exist.longgetFileSize()Returns the size of the underlying file or -1 if it does not exist.VaultInputSourcegetInputSource(Archive.Entry entry)Returns an input source for the given entryArchive.EntrygetJcrRoot()Returns the entry that specifies the "jcr_root".MetaInfgetMetaInf()Returns the meta inf.Archive.EntrygetRoot()Returns the root entry.ArchivegetSubArchive(String rootPath, boolean asJcrRoot)Returns a sub archive that is rooted at the given path.voidopen(boolean strict)Opens the archive.InputStreamopenInputStream(Archive.Entry entry)Opens an input stream for the given entryStringtoString()
-
-
-
Method Detail
-
open
public void open(boolean strict) throws IOExceptionDescription copied from interface:ArchiveOpens the archive.- Parameters:
strict- iftrueopen will fail if there was an internal error while parsing meta data.- Throws:
IOException- if an error occurs
-
openInputStream
@Nullable public InputStream openInputStream(@Nullable Archive.Entry entry) throws IOException
Description copied from interface:ArchiveOpens an input stream for the given entry- Parameters:
entry- the entry- Returns:
- the input stream or
nullif the entry can't be read - Throws:
IOException- if an error occurs
-
getInputSource
@Nullable public VaultInputSource getInputSource(@Nullable Archive.Entry entry) throws IOException
Description copied from interface:ArchiveReturns an input source for the given entry- Parameters:
entry- the entry- Returns:
- the input source or
nullif the entry can't be read - Throws:
IOException- if an error occurs
-
close
public void close()
Description copied from interface:Archivecloses the archive
-
getRoot
@Nonnull public Archive.Entry getRoot() throws IOException
Description copied from interface:ArchiveReturns the root entry.- Returns:
- the root entry.
- Throws:
IOException- if an error occurs
-
getMetaInf
@Nonnull public MetaInf getMetaInf()
Description copied from interface:ArchiveReturns the meta inf. If the archive provides no specific meta data, a default, empty meta inf is returned.- Returns:
- the meta inf.
-
getFile
@Nullable public File getFile()
Returns the underlying file ornullif it does not exist.- Returns:
- the file or null.
-
getFileSize
public long getFileSize()
Returns the size of the underlying file or -1 if it does not exist.- Returns:
- the file size
-
getEntry
public Archive.Entry getEntry(String path) throws IOException
Description copied from interface:ArchiveReturns the entry specified by path.- Specified by:
getEntryin interfaceArchive- Parameters:
path- the path- Returns:
- the entry or
nullif not found. - Throws:
IOException- if an error occurs
-
getJcrRoot
public Archive.Entry getJcrRoot() throws IOException
Description copied from interface:ArchiveReturns the entry that specifies the "jcr_root". if no such entry exists,nullis returned.- Specified by:
getJcrRootin interfaceArchive- Returns:
- the jcr_root entry or
null - Throws:
IOException- if an error occurs
-
getSubArchive
public Archive getSubArchive(String rootPath, boolean asJcrRoot) throws IOException
Description copied from interface:ArchiveReturns a sub archive that is rooted at the given path. Note that sub archives currently can't have they own meta inf and are closed automatically if they base is closed.- Specified by:
getSubArchivein interfaceArchive- Parameters:
rootPath- root pathasJcrRoot- iftruethe given root is the jcr_root- Returns:
- the archive or
nullif entry specified by root does not exist. - Throws:
IOException- if an error occurs
-
-