Decodes a ZIP file from a stream. More...
#include <juce_ZipFile.h>
Classes | |
class | Builder |
Used to create a new zip file. More... | |
struct | OpenStreamCounter |
struct | ZipEntry |
Contains information about one of the entries in a ZipFile. More... | |
Public Types | |
enum | FollowSymlinks { FollowSymlinks::no, FollowSymlinks::yes } |
enum | OverwriteFiles { OverwriteFiles::no, OverwriteFiles::yes } |
Public Member Functions | |
ZipFile (const File &file) | |
Creates a ZipFile to read a specific file. More... | |
ZipFile (InputSource *inputSource) | |
Creates a ZipFile for an input source. More... | |
ZipFile (InputStream &inputStream) | |
Creates a ZipFile for a given stream. More... | |
ZipFile (InputStream *inputStream, bool deleteStreamWhenDestroyed) | |
Creates a ZipFile for a given stream. More... | |
~ZipFile () | |
Destructor. More... | |
InputStream * | createStreamForEntry (const ZipEntry &entry) |
Creates a stream that can read from one of the zip file's entries. More... | |
InputStream * | createStreamForEntry (int index) |
Creates a stream that can read from one of the zip file's entries. More... | |
const ZipEntry * | getEntry (const String &fileName, bool ignoreCase=false) const noexcept |
Returns a structure that describes one of the entries in the zip file. More... | |
const ZipEntry * | getEntry (int index) const noexcept |
Returns a structure that describes one of the entries in the zip file. More... | |
int | getIndexOfFileName (const String &fileName, bool ignoreCase=false) const noexcept |
Returns the index of the first entry with a given filename. More... | |
int | getNumEntries () const noexcept |
Returns the number of items in the zip file. More... | |
void | sortEntriesByFilename () |
Sorts the list of entries, based on the filename. More... | |
Result | uncompressEntry (int index, const File &targetDirectory, bool shouldOverwriteFiles=true) |
Uncompresses one of the entries from the zip file. More... | |
Result | uncompressEntry (int index, const File &targetDirectory, OverwriteFiles overwriteFiles, FollowSymlinks followSymlinks) |
Uncompresses one of the entries from the zip file. More... | |
Result | uncompressTo (const File &targetDirectory, bool shouldOverwriteFiles=true) |
Uncompresses all of the files in the zip file. More... | |
Private Member Functions | |
void | init () |
Private Attributes | |
OwnedArray< ZipEntryHolder > | entries |
std::unique_ptr< InputSource > | inputSource |
InputStream * | inputStream = nullptr |
CriticalSection | lock |
OpenStreamCounter | streamCounter |
std::unique_ptr< InputStream > | streamToDelete |
Decodes a ZIP file from a stream.
This can enumerate the items in a ZIP file and can create suitable stream objects to read each one.
@tags{Core}
|
strong |
|
strong |
juce::ZipFile::ZipFile | ( | InputStream * | inputStream, |
bool | deleteStreamWhenDestroyed | ||
) |
|
explicit |
|
explicit |
Creates a ZipFile for an input source.
The inputSource object will be owned by the zip file, which will delete it later when not needed.
juce::ZipFile::~ZipFile | ( | ) |
Destructor.
InputStream* juce::ZipFile::createStreamForEntry | ( | const ZipEntry & | entry | ) |
Creates a stream that can read from one of the zip file's entries.
The stream that is returned must be deleted by the caller (and a nullptr might be returned if a stream can't be opened for some reason).
The stream must not be used after the ZipFile object that created has been deleted.
Note that if the ZipFile was created with a user-supplied InputStream object, then all the streams which are created by this method will by trying to share the same source stream, so cannot be safely used on multiple threads! (But if you create the ZipFile from a File or InputSource, then it is safe to do this).
InputStream* juce::ZipFile::createStreamForEntry | ( | int | index | ) |
Creates a stream that can read from one of the zip file's entries.
The stream that is returned must be deleted by the caller (and a nullptr might be returned if a stream can't be opened for some reason).
The stream must not be used after the ZipFile object that created has been deleted.
Note that if the ZipFile was created with a user-supplied InputStream object, then all the streams which are created by this method will by trying to share the same source stream, so cannot be safely used on multiple threads! (But if you create the ZipFile from a File or InputSource, then it is safe to do this).
|
noexcept |
Returns a structure that describes one of the entries in the zip file.
This uses a case-sensitive comparison to look for a filename in the list of entries. It might return 0 if no match is found.
Returns a structure that describes one of the entries in the zip file.
This may return a nullptr if the index is out of range.
|
noexcept |
Returns the index of the first entry with a given filename.
This uses a case-sensitive comparison to look for a filename in the list of entries. It might return -1 if no match is found.
|
noexcept |
Returns the number of items in the zip file.
|
private |
void juce::ZipFile::sortEntriesByFilename | ( | ) |
Sorts the list of entries, based on the filename.
Result juce::ZipFile::uncompressEntry | ( | int | index, |
const File & | targetDirectory, | ||
bool | shouldOverwriteFiles = true |
||
) |
Uncompresses one of the entries from the zip file.
This will expand the entry and write it in a target directory. The entry's path is used to determine which subfolder of the target should contain the new file.
index | the index of the entry to uncompress - this must be a valid index between 0 and (getNumEntries() - 1). |
targetDirectory | the root folder to uncompress into |
shouldOverwriteFiles | whether to overwrite existing files with similarly-named ones |
Result juce::ZipFile::uncompressEntry | ( | int | index, |
const File & | targetDirectory, | ||
OverwriteFiles | overwriteFiles, | ||
FollowSymlinks | followSymlinks | ||
) |
Uncompresses one of the entries from the zip file.
This will expand the entry and write it in a target directory. The entry's path is used to determine which subfolder of the target should contain the new file.
index | the index of the entry to uncompress - this must be a valid index between 0 and (getNumEntries() - 1). |
targetDirectory | the root folder to uncompress into |
overwriteFiles | whether to overwrite existing files with similarly-named ones |
followSymlinks | whether to follow symlinks inside the target directory |
Result juce::ZipFile::uncompressTo | ( | const File & | targetDirectory, |
bool | shouldOverwriteFiles = true |
||
) |
Uncompresses all of the files in the zip file.
This will expand all the entries into a target directory. The relative paths of the entries are used.
targetDirectory | the root folder to uncompress to |
shouldOverwriteFiles | whether to overwrite existing files with similarly-named ones |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |