Files
Objective-Zip/Objective-Zip/OZZipFile+Standard.h
T
Gianluca Bertani 61b0029250 Updated MiniZip to latest version.
Added unit tests for 32/64 bit cross compatibility and encryption.
Fixed reading example (#59).
Fixed script for fat library building (#55).
Bumped version to 1.0.4.
2017-05-13 16:28:35 +02:00

285 lines
12 KiB
Objective-C

//
// OZZipFile+Standard.h
// Objective-Zip v. 1.0.4
//
// Created by Gianluca Bertani on 09/09/15.
// Copyright 2009-2017 Gianluca Bertani. All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions
// are met:
//
// * Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
// * Neither the name of Gianluca Bertani nor the names of its contributors
// may be used to endorse or promote products derived from this software
// without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.
//
#import "OZZipFile.h"
@interface OZZipFile (Standard)
#pragma mark -
#pragma mark Initialization
/**
@brief Creates a OZZipFile with the specified zip file name and access mode.
<p>The access mode specifies if the zip is being created, appended, or
unzipped.</p>
<p>Note: the zip file is opened in 64-bit mode.</p>
@param fileName File name of the zip file.
@param mode Access mode, can be:<ul>
<li>OZZipFileModeUnzip: the zip file is opened for reading.
<li>OZZipFileModeCreate: the zip file is opened for creation.
<br/>Note: if the file already exists the behavior is unspecified.
<li>OZZipFileModeAppend: the zip file is opened for writing.
</ul>
@throws OZZipException If the file can't be opened due to an erroror if the
access mode is invalid.
*/
- (nonnull instancetype) initWithFileName:(nonnull NSString *)fileName mode:(OZZipFileMode)mode;
/**
@brief Creates a OZZipFile with the specified zip file name, access mode and
legacy 32-bit mode compatibility.
<p>The access mode specifies if the zip is being created, appended, or
unzipped.</p>
@param fileName File name of the zip file.
@param mode Access mode, can be:<ul>
<li>OZZipFileModeUnzip: the zip file is opened for reading.
<li>OZZipFileModeCreate: the zip file is opened for creation.
<br/>Note: if the file already exists the behavior is unspecified.
<li>OZZipFileModeAppend: the zip file is opened for writing.
</ul>
@param legacy32BitMode If set, the zip file is opened in 32-bit mode to
provide compatibility with older operating systems (such as some
version of Android).
@throws OZZipException If the file can't be opened due to an error or if the
access mode is invalid.
*/
- (nonnull instancetype) initWithFileName:(nonnull NSString *)fileName mode:(OZZipFileMode)mode legacy32BitMode:(BOOL)legacy32BitMode;
#pragma mark -
#pragma mark File writing
/**
@brief Creates a new OZZipWriteStream for adding a new file in the zip file
content.
<p>The returned write stream can be used to write data to the new file.</p>
<p>Note: the new file is added with the current date/time.</p>
@param fileNameInZip Name of the new file that must be added to the zip file
content.
<br/>Note: to structure the zip file with directories and subdirectories,
ensure to prepend them in the file name, e.g. "docs/html/index.html"
@param compressionLevel The compression level that must be used to compress
the new file added to the zip file content. Can be:<ul>
<li>OZZipCompressionLevelNone: does not compress the new file, it is stored
as is.
<li>OZZipCompressionLevelFastest: uses the fastest compression level, which
also compresses the least.
<li>OZZipCompressionLevelBest: uses the best compression level, which is also
the slowest.
<li>OZZipCompressionLevelDefault: uses the default compression level,
somewhere inbetween OZZipCompressionLevelBest and
OZZipCompressionLevelFastest.
</ul>
@return A new OZZipWriteStream for writing data to the new file in the zip
file content.
@throws OZZipException If the file stream can't be created due to an error or
if the zip file has been opened in unzip mode.
*/
- (nonnull OZZipWriteStream *) writeFileInZipWithName:(nonnull NSString *)fileNameInZip compressionLevel:(OZZipCompressionLevel)compressionLevel;
/**
@brief Creates a new OZZipWriteStream for adding a new file in the zip file
content.
<p>The returned write stream can be used to write data to the new file.</p>
@param fileNameInZip Name of the new file that must be added to the zip file
content.
<br/>Note: to structure the zip file with directories and subdirectories,
ensure to prepend them in the file name, e.g. "docs/html/index.html"
@param fileDate The date/time of the new file that must be added to the zip
file content.
@param compressionLevel The compression level that must be used to compress
the new file added to the zip file content. Can be:<ul>
<li>OZZipCompressionLevelNone: does not compress the new file, it is stored
as is.
<li>OZZipCompressionLevelFastest: uses the fastest compression level, which
also compresses the least.
<li>OZZipCompressionLevelBest: uses the best compression level, which is also
the slowest.
<li>OZZipCompressionLevelDefault: uses the default compression level,
somewhere inbetween OZZipCompressionLevelBest and
OZZipCompressionLevelFastest.
</ul>
@return A new OZZipWriteStream for writing data to the new file in the zip
file content.
@throws OZZipException If the file stream can't be created due to an error or
if the zip file has been opened in unzip mode.
*/
- (nonnull OZZipWriteStream *) writeFileInZipWithName:(nonnull NSString *)fileNameInZip fileDate:(nonnull NSDate *)fileDate compressionLevel:(OZZipCompressionLevel)compressionLevel;
/**
@brief Creates a new OZZipWriteStream for adding a new encrypted file in the
zip file content.
<p>The returned write stream can be used to write data to the new file.</p>
@param fileNameInZip Name of the new file that must be added to the zip file
content.
<br/>Note: to structure the zip file with directories and subdirectories,
ensure to prepend them in the file name, e.g. "docs/html/index.html"
@param fileDate The date/time of the new file that must be added to the zip
file content.
@param compressionLevel The compression level that must be used to compress
the new file added to the zip file content. Can be:<ul>
<li>OZZipCompressionLevelNone: does not compress the new file, it is stored
as is.
<li>OZZipCompressionLevelFastest: uses the fastest compression level, which
also compresses the least.
<li>OZZipCompressionLevelBest: uses the best compression level, which is also
the slowest.
<li>OZZipCompressionLevelDefault: uses the default compression level,
somewhere inbetween OZZipCompressionLevelBest and
OZZipCompressionLevelFastest.
</ul>
@param password The password that must be used to encrypt the new file data.
@param crc32 A precomputed CRC32 of the new file data (needed for crypting).
@return A new OZZipWriteStream for writing data to the new file in the zip
file content.
@throws OZZipException If the file stream can't be created due to an error or
if the zip file has been opened in unzip mode.
*/
- (nonnull OZZipWriteStream *) writeFileInZipWithName:(nonnull NSString *)fileNameInZip fileDate:(nonnull NSDate *)fileDate compressionLevel:(OZZipCompressionLevel)compressionLevel password:(nonnull NSString *)password crc32:(uint32_t)crc32;
#pragma mark -
#pragma mark File seeking and info
/**
@brief Moves selection to the first file contained in the zip file.
<p>The selected file may then be read by obaining a OZZipReadStream with
<code>readCurrentFileInZip</code>.</p>
@throws OZZipException If the first file can't be selected due to an error or
if the zip file has been opened with a mode other than Unzip.
*/
- (void) goToFirstFileInZip;
/**
@brief Moves selection to the next file contained in the zip file.
<p>The selected file may then be read by obaining a OZZipReadStream with
<code>readCurrentFileInZip</code>.</p>
@return <code>YES</code> if the next file has been selected,
<code>NO</code> if there were no more files to select in the zip file.
@throws OZZipException If the next file can't be selected due to an error or
if the zip file has been opened with a mode other than Unzip.
*/
- (BOOL) goToNextFileInZip;
/**
@brief Locates a file by name in the zip file and selects it.
<p>The selected file may then be read by obaining a OZZipReadStream with
<code>readCurrentFileInZip</code>.</p>
@return <code>YES</code> if the file has been located and selected,
<code>NO</code> if the specified file name is not present in the zip file.
<br/>NOTE: return value convention is different in NSError compliant
interface.
@throws OZZipException If the file can't be located due to an error or if the
zip file has been opened with a mode other than Unzip.
*/
- (BOOL) locateFileInZip:(nonnull NSString *)fileNameInZip;
/**
@brief Returns the number of files contained in the zip file.
@return The number of files contained in the zip file.
@throws OZZipException If the number of files could not be obtained due to an
error or if the zip file has been opened with a mode other than Unzip.
*/
- (NSUInteger) numFilesInZip;
/**
@brief Returns a list of OZFileInZipInfo with the information on all the files
contained in the zip file.
@return The list of OZFileInZipInfo with the information on all the files
contained in the zip file.
@throws OZZipException If the list of file info could not be obtained due to
an error or if the zip file has been opened with a mode other than Unzip.
*/
- (nonnull NSArray *) listFileInZipInfos;
/**
@brief Returns an OZFileInZipInfo with the information on the currently
selected file in the zip file.
@return An OZFileInZipInfo with the information on the currently
selected file in the zip file.
@throws OZZipException If the info info could not be obtained due to an error
or if the zip file has been opened with a mode other than Unzip.
*/
- (nonnull OZFileInZipInfo *) getCurrentFileInZipInfo;
#pragma mark -
#pragma mark File reading
/**
@brief Creates a OZZipReadStream for reading the currently selected file in
the zip file.
<p>A file in the zip file can be selected using
<code>goToFirstFileInZip</code>, <code>goToNextFileInZip</code> and
<code>locateFileInZip:</code>.</p>
@return The OZZipReadStream to be used for reading the currently selected file
in the zip file.
@throws OZZipException If the read stream could not be created due to an error
or if the zip file has been opened with a mode other than Unzip.
*/
- (nonnull OZZipReadStream *) readCurrentFileInZip;
/**
@brief Creates a OZZipReadStream for reading the currently selected file in
the zip file, if it is encrypted.
<p>A file in the zip file can be selected using
<code>goToFirstFileInZip</code>, <code>goToNextFileInZip</code> and
<code>locateFileInZip:</code>.</p>
@param password The password that must be used to decrypt the file data.
@return The OZZipReadStream to be used for reading the currently selected file
in the zip file.
@throws OZZipException If the read stream could not be created due to an error
or if the zip file has been opened with a mode other than Unzip.
*/
- (nonnull OZZipReadStream *) readCurrentFileInZipWithPassword:(nonnull NSString *)password;
#pragma mark -
#pragma mark Closing
/**
@brief Closes the zip file and releases its resources.
<p>Once you have finished working with the zip file (e.g. all files have been
unzipped, or all files have been added), it is important to close it so system
resources may be freed.</p>
<p>Note: after the zip file has been closed any subsequent call will result in an
error.</p>
@throws OZZipException If the zip file could not be closed due to an error.
*/
- (void) close;
@end