ZipFile is a FileCollection, where the files are stored in a .zip file. More...
#include <zipfile.h>
Public Member Functions | |
virtual FileCollection * | clone () const |
Create a heap allocated clone of the object this method is called for. More... | |
virtual void | close () |
Closes the FileCollection. More... | |
virtual istream * | getInputStream (const ConstEntryPointer &entry) |
Returns a pointer to an opened istream for the specified FileEntry. More... | |
virtual istream * | getInputStream (const string &entry_name, MatchPath matchpath=MATCH) |
Returns a pointer to an opened istream for the specified entry name. More... | |
ZipFile () | |
Default constructor. More... | |
ZipFile (const string &name, int s_off=0, int e_off=0) | |
Constructor. More... | |
virtual | ~ZipFile () |
Destructor. More... | |
Public Member Functions inherited from zipios::FileCollection | |
virtual FileCollection * | clone () const =0 |
Create a heap allocated clone of the object this method is called for. More... | |
virtual void | close ()=0 |
Closes the FileCollection. More... | |
virtual ConstEntries | entries () const |
Returns a vector of const pointers to the entries in the FileCollection. More... | |
FileCollection () | |
FileCollection constructor. More... | |
FileCollection (const FileCollection &src) | |
Copy constructor. More... | |
virtual ConstEntryPointer | getEntry (const string &name, MatchPath matchpath=MATCH) const |
Returns a ConstEntryPointer to a FileEntry object for the entry with the specified name. More... | |
virtual istream * | getInputStream (const ConstEntryPointer &entry)=0 |
Returns a pointer to an opened istream for the specified FileEntry. More... | |
virtual istream * | getInputStream (const string &entry_name, MatchPath matchpath=MATCH)=0 |
Returns a pointer to an opened istream for the specified entry name. More... | |
virtual string | getName () const |
Returns the name of the FileCollection. More... | |
bool | isValid () const |
The member function returns true if the collection is valid. More... | |
const FileCollection & | operator= (const FileCollection &src) |
Copy assignment operator. More... | |
virtual int | size () const |
Returns the number of entries in the FileCollection. More... | |
virtual | ~FileCollection () |
FileCollection destructor. More... | |
Static Public Member Functions | |
static ZipFile | openEmbeddedZipFile (const string &name) |
Opens a Zip archive embedded in another file, by writing the zip archive to the end of the file followed by the start offset of the zip file. More... | |
Additional Inherited Members | |
Public Types inherited from zipios::FileCollection | |
enum | MatchPath { IGN , MATCH } |
ZipFile is a FileCollection, where the files are stored in a .zip file.
zipios::ZipFile::ZipFile | ( | ) |
Default constructor.
Referenced by clone(), and openEmbeddedZipFile().
Constructor.
Opens the zip file name. If the zip "file" is embedded in a file that contains other data, e.g. a binary program, the offset of the zip file start and end must be specified.
name | The filename of the zip file to open. |
s_off | Offset relative to the start of the file, that indicates the beginning of the zip file. |
e_off | Offset relative to the end of the file, that indicates the end of the zip file. The offset is a positive number, even though the offset is towards the beginning of the file. |
FColException | Thrown if the specified file name is not a valid zip archive. |
IOException | Thrown if an I/O problem is encountered, while the directory of the specified zip archive is being read. |
References Base::FileInfo::toStdWString().
|
virtual |
Destructor.
References close().
|
virtual |
Create a heap allocated clone of the object this method is called for.
The caller is responsible for deallocating the clone when he is done with it.
Implements zipios::FileCollection.
References ZipFile().
Referenced by ArchPanel.CommandPanelSheet::Activated(), ArchStructure.CommandStructuralSystem::Activated(), ArchComponent.Component::execute(), ArchCurtainWall.CurtainWall::execute(), ArchTruss.Truss::execute(), Mod.PartDesign.WizardShaft.SegmentFunction.SegmentFunction::integrated(), and PathTests.TestPathHelix.TestPathHelix::test04().
|
virtual |
Closes the FileCollection.
Implements zipios::FileCollection.
Referenced by femexamples.examplesgui.FemExamples::reject(), and ~ZipFile().
|
virtual |
Returns a pointer to an opened istream for the specified FileEntry.
It is the callers responsibility to delete the stream when he is done with it. Returns 0, if there is no such FileEntry in the FileCollection.
entry | A ConstEntryPointer to the FileEntry to get an istream to. |
InvalidStateException | Thrown if the collection is invalid. |
Implements zipios::FileCollection.
References getInputStream().
Referenced by getInputStream().
|
virtual |
Returns a pointer to an opened istream for the specified entry name.
It is the callers responsibility to delete the stream when he is done with it. Returns 0, if there is no entry with the specified name in the FileCollection.
entry_name | |
matchpath | specify MATCH, if the path should match as well, specify IGNORE, if the path should be ignored. |
InvalidStateException | Thrown if the collection is invalid. |
Implements zipios::FileCollection.
References zipios::SimpleSmartPointer< Type >::get(), and zipios::FileCollection::getEntry().
|
static |
Opens a Zip archive embedded in another file, by writing the zip archive to the end of the file followed by the start offset of the zip file.
The offset must be written in zip-file byte-order (little endian). The program appendzip, which is part of the Zipios++ distribution can be used to append a Zip archive to a file, e.g. a binary program.
FColException | Thrown if the specified file name is not a valid zip archive. |
IOException | Thrown if an I/O problem is encountered, while the directory of the specified zip archive is being read. |
References zipios::readUint32(), and ZipFile().