Private helper class for ZipFileSystem to hold per-Zip-archive data.
Uses the zlib and the minizip lib for zip file access.
Multithreading: access to zlib archives needs to be serialized. A ZipArchive objects contains a critical section which it will hand down to ZipFileEntry objects.
- Copyright
- (C) 2006 Radon Labs GmbH (C) 2013-2020 Individual contributors, see AUTHORS file
|
| ZipArchive () |
| constructor
|
|
virtual | ~ZipArchive () |
| destructor
|
|
bool | Setup (const URI &uri, const Util::String &rootPath="") |
| setup the archive from an URI
|
|
void | Discard () |
| discard the archive
|
|
Util::Array< Util::String > | ListFiles (const Util::String &dirPathInArchive, const Util::String &pattern) const |
| list all files in a directory in the archive
|
|
Util::Array< Util::String > | ListDirectories (const Util::String &dirPathInArchive, const Util::String &pattern) const |
| list all subdirectories in a directory in the archive
|
|
URI | ConvertToArchiveURI (const URI &fileURI) const |
| convert a "file:" URI into a "zip:" URI pointing into this archive
|
|
Util::String | ConvertToPathInArchive (const Util::String &absPath) const |
| convert an absolute path to local path inside archive, returns empty string if absPath doesn't point into this archive
|
|
| ArchiveBase () |
| constructor
|
|
virtual | ~ArchiveBase () |
| destructor
|
|
bool | Setup (const URI &archiveURI, const Util::String &rootPath) |
| setup the archive from an URI (without file extension)
|
|
void | Discard () |
| discard the archive
|
|
bool | IsValid () const |
| return true if archive is valid
|
|
const URI & | GetURI () const |
| get the URI of the archive
|
|
Util::Array< Util::String > | ListFiles (const Util::String &dirPathInArchive, const Util::String &pattern) const |
| list all files in a directory in the archive
|
|
Util::Array< Util::String > | ListDirectories (const Util::String &dirPathInArchive, const Util::String &pattern) const |
| list all subdirectories in a directory in the archive
|
|
URI | ConvertToArchiveURI (const URI &fileURI) const |
| convert a "file:" URI into a archive-specific URI pointing into this archive
|
|
Util::String | ConvertToPathInArchive (const Util::String &absPath) const |
| convert an absolute path to local path inside archive, returns empty string if absPath doesn't point into this archive
|
|
| RefCounted () |
| constructor
|
|
int | GetRefCount () const |
| get the current refcount
|
|
void | AddRef () |
| increment refcount by one
|
|
void | Release () |
| decrement refcount and destroy object if refcount is zero
|
|
bool | IsInstanceOf (const Rtti &rtti) const |
| return true if this object is instance of given class
|
|
bool | IsInstanceOf (const Util::String &className) const |
| return true if this object is instance of given class by string
|
|
bool | IsInstanceOf (const Util::FourCC &classFourCC) const |
| return true if this object is instance of given class by fourcc
|
|
bool | IsA (const Rtti &rtti) const |
| return true if this object is instance of given class, or a derived class
|
|
bool | IsA (const Util::String &rttiName) const |
| return true if this object is instance of given class, or a derived class, by string
|
|
bool | IsA (const Util::FourCC &rttiFourCC) const |
| return true if this object is instance of given class, or a derived class, by fourcc
|
|
const Util::String & | GetClassName () const |
| get the class name
|
|
Util::FourCC | GetClassFourCC () const |
| get the class FourCC code
|
|
convert an absolute path to local path inside archive, returns empty string if absPath doesn't point into this archive
Test if an absolute path points into the zip archive and return a locale path into the zip archive.
This will not test, whether the file or directory inside the zip archive actually exists, only if the path points INTO the zip archive by checking against the location directory of the zip archive.