Zip Delphi ActiveX Reference Documentation
TChilkatZip
Current Version: 11.1.0
Zip compression component.
Importing the Chilkat ActiveX into Delphi
Important: When upgrading to a new version of Chilkat, make sure to re-imported ActiveX DLL into Delphi to regenerate the files described below.
Chilkat v9.5.*: If using Chilkat v9.5.*, then use "Chilkat_v9_5_0_TLB" instead of "Chilkat_TLB", and the DLLs are named ChilkatAx-9.5.0-win32.dll (or ChilkatAx-9.5.0-x64.dll).
Two things are required to use an ActiveX in Delphi:
- The ActiveX DLL needs to be registered via regsvr32 on the system where the Delphi application runs. See How To Register ActiveX DLLs for detailed information.
- See also: ActiveX Registration Tutorial
- The ActiveX component needs to be "imported". Use the Delphi Import Component Wizard to import the Chilkat type library. This creates the following files: Chilkat_TLB.pas and Chilkat_TLB.dcr. The Chilkat_TLB.pas should be added to your project.
To import the Chilkat type library, do the following:
- In the Delphi RAD Studio, select the menu item "Component" --> "Import a Type Library".
- Find "Chilkat ActiveX" in the list and select it. This will only appear in the list if the ChilkatAx-win32.dll (or ChilkatAx-x64.dll) has been registered w/ regsvr32.
- Check the "Generate Component Wrappers" checkbox.
- Select a directory where the unit files (.pas and .dcr) should be generated.
- Select "Create Unit" and then "Finish".
- Add the .pas to your Delphi project.
To use a Chilkat ActiveX object in your Delphi code, add "Chilkat_TLB" to the "uses" statement. For example:
uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB;
Object Creation
var obj: TChilkatZip; ... begin obj := TChilkatZip.Create(Self); ... // When finished, free the object instance. obj.Free();
Properties
AbortCurrent
When set to 1, causes the currently running method to abort.  Methods that always finish quickly (i.e.have no length file operations or network communications) are not affected.  If no method is running, then this property is automatically reset to 0 when the next method is called.  When the abort occurs, this property is reset to 0.  Both synchronous and asynchronous method calls can be aborted.  (A synchronous method call could be aborted by setting this property from a separate thread.)
AppendFromDir
When files are added to a Zip archive, they are appended from this directory.  For example,  to add all the files under c:/abc/123/myAppDir, this property could be set to c:/abc/123, and myAppDir/* would be passed to AppendFiles.  The path that is saved in the .zip would be myAppDir/.   (The value of the AppendFromDir property does not become part of the file path saved in the .zip.)
AutoRun
(Relevant only when running on a Microsoft Windows operating system.)  Optional when creating Windows-based self-extracting EXEs.  This is the name of an executable contained within the to-be-created EXE that will automatically be run after extraction.  (This is typically something like setup.exe)
AutoRunParams
(Relevant only when running on a Microsoft Windows operating system.) Command line parameters that get passed to the AutoRun executable.
topAutoTemp
(Relevant only when running on a Microsoft Windows operating system.) This option applies to creating Windows-based self-extracting EXEs.  If 1, the to-be-created EXE will automatically select and create a temporary directory for unzipping.  This property is often used in conjunction with the AutoRun property to create a self-extracting EXE that automatically unzips to a temp directory and runs a setup.exe without interaction with the user.
Note: To create a self-extracting EXE with no user-interaction, set the following properties to these values:
ExeSilentProgress =0
ExeNoInterface =1
ExeFinishNotifier =0
The default AutoTemp value is 0.
CaseSensitive
If 1 then all methods that get or search for zip entries by name will use case-sensitive filename matching.  If 0 then filename matching will be case insensitive.  Methods affected by this property include GetEntryByName, UnzipMatching, FirstMatchingEntry, etc.
The default value is 0.
ClearArchiveAttribute
Set this to 1 to clear the FILE_ATTRIBUTE_ARCHIVE file attribute of each file (in the local filesystem) during a zipping operation.
The default value is 0.
Note: The archive attribute or bit, is a Windows file attribute that when is set, it indicates that the file has changed since the last backup operation. When this property is 1, Chilkat Zip will clear the archive attribute of each local file after it has been successfully added to the zip.
ClearReadOnlyAttr
If 1, the read-only attribute is automatically cleared when unzipping.  The default value of this property is 0, which leaves the read-only attribute unchanged when unzipping.
Comment
The global Zip file comment.
topDebugLogFilePath
If set to a file path, this property logs the LastErrorText of each Chilkat method or property call to the specified file. This logging helps identify the context and history of Chilkat calls leading up to any crash or hang, aiding in debugging.
Enabling the VerboseLogging property provides more detailed information. This property is mainly used for debugging rare instances where a Chilkat method call causes a hang or crash, which should generally not happen.
Possible causes of hangs include:
- A timeout property set to 0, indicating an infinite timeout.
- A hang occurring within an event callback in the application code.
- An internal bug in the Chilkat code causing the hang.
DecryptPassword
When opening a password-protected or AES encrypted Zip, this is the password to be used for decryption. Encrypted Zips may be opened without setting a password, but the contents cannot be unzipped without setting this password.
Note:The SetPassword method has the effect of setting both this property as well as the EncryptPassword property. The SetPassword method should no longer be used. It has been replaced by the DecryptPassword and EncryptPassword properties to make it possible to open an encrypted zip and re-write it with a new password.
topDiscardPaths
If 1, discards all file path information when zipping.  The default value is 0.
Encryption
Indicate whether the Zip is to be strong encrypted or not. Valid values are 0 (not encrypted) or 4 (AES encrypted). When this property is set to the value 4, WinZip AES compatible encrypted zip archives are produced.
Note: Prior to Chilkat v9.4.1, other possible values for this property were: 1 (blowfish), 2 (twofish), and 3 (rijndael). These settings originally provided a way to produce strong encrypted zips prior to when the AES encrypted Zip standard existed. Using these legacy values (1, 2, or 3) produced encrypted zips that only applications using Chilkat could read. Chilkat no longer supports these custom modes of encryption. If using an older version of Chilkat with one of these deprecated encryption modes, make sure to decrypt using the old Chilkat version and re-encrypt using mode 4 (WinZip compatible AES encryption) prior to updating to the new Chilkat version.
Important:The Encryption and PasswordProtect properties are mutually exclusive.  PasswordProtect corresponds to the older Zip 2.0 encryption, commonly referred to as a password-protected zip.  If the PasswordProtect is set to 1, the Encryption property should be set to 0.  If the Encryption property is set to a non-zero value, then PasswordProtect should be set to 0.  A zip cannot be both password-protected and strong-encrypted.
EncryptKeyLength
The encryption key length if AES, Blowfish, Twofish, or WinZip-compatible AES encryption is used. This value must be 128, 192, or 256. The default value is 128.
topEncryptPassword
The password used when writing a password-protected or strong-encrytped Zip.
Note:The SetPassword method has the effect of setting both this property as well as the DecryptPassword property. The SetPassword method should no longer be used. It has been replaced by the DecryptPassword and EncryptPassword properties to make it possible to open an encrypted zip and re-write it with a new password.
topExeDefaultDir
(Relevant only when running on a Microsoft Windows operating system.) Specifies the default unzip directory path to appear in the user-interface dialog box when the Windows-based self-extracting EXE is run.
topExeFinishNotifier
(Relevant only when running on a Microsoft Windows operating system.)  If set to 1, a Finished dialog box is displayed when the self-extracting EXE is finished extracting.   The caption, title, and button text of the finish notifier dialog may be customized by calling SetExeConfigParam.  The default value is 0.
ExeIconFile
(Relevant only when running on a Microsoft Windows operating system.) Applies to creating self-extracting EXEs. This property can be set to a pre-existing icon filename (.ico) that will be embedded within the to-be-created EXE and set as its default icon.
Note: This property is only possible for 32-bit applications. (Meaning that the application that is creating the self-extracting EXE must be a 32-bit application if an ExeIconFile is to be used.)
topExeNoInterface
(Relevant only when running on a Microsoft Windows operating system.) Applies to creating Windows-based self-extracting EXEs.  When set to 1, the to-be-created EXE will run without a user-interface.  The default value is 0.
Note: The ExeSilentProgress property needs to be set to 1 for the extract to be truly silent.  
Important: If the AutoTemp property = 1 and there is no AutoRun EXE, and there is no ExeUnzipDir set, then the self-extracting EXE will always display a dialog to get the unzip directory.  The reason is that it makes no sense to silently unzip to an auto-selected (and unknown) temp directory without anything happening afterwards.  
Important: If the self-extracting EXE is encrypted, a password dialog will be displayed. The password dialog may be suppressed if the password is provided on the command line via the -pwd command-line option.
topExeSilentProgress
(Relevant only when running on a Microsoft Windows operating system.)  Determines whether a progress dialog is displayed when the self-extracting EXE is run.  If ExeNoInterface = 0 (i.e. there is a main dialog with the ability to select the unzip directory), then the progress dialog is (by default) shown as a progress bar within the main dialog -- and this property has no effect.  If ExeNoInterface = 1, then a progress-only dialog is displayed if ExeSilentProgress = 0.  The default value of ExeSilentProgress is 1.
ExeTitle
(Relevant only when running on a Microsoft Windows operating system.) Applies to creating Windows-based self-extracting EXEs. Sets the title of the main user-interface dialog that appears when the self-extracting EXE runs.
topExeUnzipCaption
(Relevant only when running on a Microsoft Windows operating system.) Applies to creating MS Windows-based self-extracting EXEs. Sets the unzipping caption of the main user-interface dialog that appears when the self-extracting EXE runs.
topExeUnzipDir
(Relevant only when running on a Microsoft Windows operating system.) Applies to creating MS Windows self-extracting EXEs. Stores a pre-defined unzip directory within the self-extracting EXE so that it automatically unzips to this directory without user-intervention.
Environment variables may be included if surrounded by percent characters. For example: %TEMP%. Environment variables are expanded (i.e. resolved) when the self-extracting EXE runs.
Note: UNC paths, such as \\servername\path, are not supported.
Note: To create a self-extracting EXE with no user-interaction, set the following properties to these values:
ExeSilentProgress =top0<br> ExeNoInterface =1<br> ExeFinishNotifier =0
ExeWaitForSetup
(Relevant only when running on a Microsoft Windows operating system.)  If 1, the self-extracting EXE will wait for the AutoRun EXE to complete before it exits.  If 0, the self-extracting EXE dialog (or process if running silently with no user-interface), is allowed to exit prior to the completion of the AutoRun EXE.  The default value is 1.
ExeXmlConfig
(Relevant only when running on a Microsoft Windows operating system.) Allows for an XML config document to be used to specify all possible options for self-extracting EXEs. This property is a string containing the XML config document.
The XML should have this format:
<SfxConfig>
	<ErrPwdTitle>Title for incorrect password dialog</ErrPwdTitle>
	<ErrPwdCaption>Caption for incorrect password dialog</ErrPwdCaption>
	<FinOkBtn>Text on finish notifier button</FinOkBtn>
	<PwdOkBtn>Text on password challenge dialog's "OK" button.</PwdOkBtn>
	<PwdCancelBtn>Text on password challenge dialog's Cancel button.</PwdCancelBtn>
	<ErrInvalidPassword>Incorrect password error message.</ErrInvalidPassword>
	<MainUnzipBtn>Text on main dialog's unzip button</MainUnzipBtn>
	<MainCloseBtn>Text on main dialog's quit/exit button</MainCloseBtn>
	<MainBrowseBtn>Text on main dialog's browse-for-directory button.</MainBrowseBtn>
	<MainUnzipLabel>Caption displayed in main dialog.</MainUnzipLabel>
	<AutoTemp>"1|0 (Maps to the AutoTemp property)"</AutoTemp>
	<Cleanup>"1|0 (Deletes extracted files after the SetupExe is run.)"</Cleanup>
	<Debug>"1|0  (If 1, the EXE will not extract any files.)"</Debug>
	<Verbose>"1|0 (If 1, then verbose information is sent to the log.)"</Verbose>
	<ShowFin>"1|0" Maps to ExeFinishNotifier property.</ShowFin>
	<ShowMain>"1|0" Maps to ExeNoInterface property.</ShowMain>
	<ShowProgress>"1|0" Maps to ExeSilentProgress property.</ShowProgress>
	<WaitForSetup>"1|0" Maps to ExeWaitForSetup property.</WaitForSetup>
	<Encryption>"1|0"  1=Yes, 0=No</Encryption>
	<KeyLength>128|192|256</KeyLength>
	<SetupExe>EXE to run after extracting. (Maps to AutoRun property)</SetupExe>
	<UnzipDir>Pre-defined unzip directory. (Maps to ExeUnzipDir property, 
                                                UNC paths, such as \\servername\path, are not supported.)>
	<DefaultDir>Default unzip directory to appear in the main dialog. 
                                                (Maps to ExeDefaultDir property)</DefaultDir>
	<IconFile>Icon file to be used (Maps to ExeIconFile property)</IconFile>
	<Url>Maps to ExeSourceUrl property.</Url>
	<MainTitle>Maps to ExeTitle property.</MainTitle>
	<MainCaption>Maps to ExeUnzipCaption property.</MainCaption>
	<FinTitle>Title for the finish notifier dialog.</FinTitle>
	<FinCaption>Caption for the finish notifier dialog.</FinTitle>
	<ProgressTitle>Title for the progress dialog.</ProgressTitle>
	<ProgressCaption>Caption for the progress dialog.</ProgressCaption>
	<PwTitle>Title for the password challenge dialog.</PwTitle>
	<PwCaption>Caption for the password challenge dialog.</PwCaption>
</SfxConfig>
A self-extracting EXE can be run from the command line with the -log {logFilePath} option to create a log with information for debugging.
FileCount
The number of files (excluding directories) contained within the Zip.
topFileName
The path (absolute or relative) of the Zip archive. This is the path of the file that is created or overwritten when the zip is saved.
topHasZipFormatErrors
1 if the opened zip contained file format errors (that were not severe enough to prevent the zip from being opened and parsed).
HeartbeatMs
The interval in milliseconds between each AbortCheck event callback, which enables an application to abort certain method calls before they complete. By default, HeartbeatMs is set to 0, meaning no AbortCheck event callbacks will trigger.
IgnoreAccessDenied
If 1, then files that cannot be read due to access denied (i.e. a file permission error) will be ignored and the call to WriteZip, WriteZipAndClose, WriteExe, etc. will return a success status.  If 0, then the access denied filesystem errors are not ignored and any occurrence will cause the zip writing to fail.  The default value is 1.
LastBinaryResult
This property is mainly used in SQL Server stored procedures to retrieve binary data from the last method call that returned binary data. It is only accessible if Chilkat.Global.KeepBinaryResult is set to 1. This feature allows for the retrieval of large varbinary results in an SQL Server environment, which has restrictions on returning large data via method calls, though temp tables can handle binary properties.
LastErrorHtml
Provides HTML-formatted information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
topLastErrorText
Provides plain text information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
LastErrorXml
Provides XML-formatted information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
topLastMethodSuccess
Indicates the success or failure of the most recent method call: 1 means success, 0 means failure. This property remains unchanged by property setters or getters.  This method is present to address challenges in checking for null or Nothing returns in certain programming languages.
LastStringResult
In SQL Server stored procedures, this property holds the string return value of the most recent method call that returns a string. It is accessible only when Chilkat.Global.KeepStringResult is set to TRUE. SQL Server has limitations on string lengths returned from methods and properties, but temp tables can be used to access large strings.
LastStringResultLen
The length, in characters, of the string contained in the LastStringResult property.
topMaxDate
The maximum last-modified date/time of a file to process for either adding to a .zip, or unzipping. This property uses the timestamp date/time string format. Here are some examples:
- YYYY-MM-DD (e.g., 2024-07-31)
- YYYY-MM-DDTHH:MM:SS±HH:MM (e.g., 2024-07-31T12:34:56+02:00)
- 2024-07-31T12:34:56Z (the Zdenotes Zulu time, or UTC)
This property defaults to the empty string, which means there is no maximum.
MaxUncompressSize
An application can set this property to prevent unzipping any files larger than a max size uncompressed. The default value of this property is 0, which means any size file can be unzipped.
topMinDate
The minimum last-modified date/time of a file to process for either adding to a .zip, or unzipping. This property uses the timestamp date/time string format. Here are some examples:
- YYYY-MM-DD (e.g., 2024-07-31)
- YYYY-MM-DDTHH:MM:SS±HH:MM (e.g., 2024-07-31T12:34:56+02:00)
- 2024-07-31T12:34:56Z (the Zdenotes Zulu time, or UTC)
This property defaults to the empty string, which means there is no minimum.
NumEntries
The number of entries in the Zip, including both files and directories.
OemCodePage
Sets the OEM code page to be used for Unicode filenames. This property defaults to the OEM code page of the computer.
topOverwriteExisting
Determines whether existing files are overwritten during unzipping.  The default is 1, which means that already-existing files will be overwritten.  Set this property = 0 to prevent existing files from being overwritten when unzipping.
PasswordProtect
1 if the Zip should be password-protected using older  Zip 2.0 encryption, commonly referred to as password-protection.
This property is set when a zip archive is opened by any of the Open* methods, such as OpenZip, OpenFromMemory, etc.
PathPrefix
A prefix that is added to each filename when zipping.  One might set the PathPrefix to subdir/ so that files are unzipped to a specified subdirectory when unzipping.
PercentDoneScale
This property is only valid in programming environment and languages that allow for event callbacks.
Sets the value to be defined as 100% complete for the purpose of PercentDone event callbacks. The defaut value of 100 means that at most 100 event PercentDone callbacks will occur in a method that (1) is event enabled and (2) is such that it is possible to measure progress as a percentage completed. This property may be set to larger numbers to get more fine-grained PercentDone callbacks. For example, setting this property equal to 1000 will provide callbacks with .1 percent granularity. For example, a value of 453 would indicate 45.3% competed. This property is clamped to a minimum value of 10, and a maximum value of 100000.
topPwdProtCharset
For older password-protected Zip archives (Zip 2.0 encryption), specifies the charset used for the binary representation of the decrypt password.  The default value is ansi.  Other possible choices are cp850, cp437, or any of the code pages listed at the link below.
TempDir
The temporary directory to use when unzipping files or writing a .zip (see the note below). When running in ASP or ASP.NET, the default value of TempDir is set to the directory where the .zip is being written. Set this property to override the default.
Note: When writing a .zip, a temp file is only used if overwriting an existing .zip. The reason is to prevent losing the existing .zip if something fails when writing the new .zip. If the new .zip is successfully written, then the existing .zip is replaced with the new .zip.
topUncommonOptions
This is a catch-all property to be used for uncommon needs. This property defaults to the empty string, and should typically remain empty.
Currently, the only possible option is ForceZip64.
- ForceZip64- Force the zip to be written with the Zip64 file format, even if not necessary.
VerboseLogging
If set to 1, then the contents of LastErrorText (or LastErrorXml, or LastErrorHtml) may contain more verbose information. The default value is 0.  Verbose logging should only be used for debugging.  The potentially large quantity of logged information may adversely affect peformance.
Version
Zipx
Starting in v9.4.1, Chilkat Zip will automatically unzip ZIPX files using any of the following compression methods: BZIP2, PPMd, LZMA, and Deflate64 (Deflate64 is a trademark of PKWare, Inc.)
This property, however, controls whether or not a ZipX is automatically produced where the best compression algorithm for each file is automatically chosen based on file type. This property is for writing zip archives. It does not apply to when unzipping ZIPX archives, Chilkat Zip automatically handles the various compression algorithms when unzipping.
topZipxDefaultAlg
The default compression algorithm to be used when creating ZIPX archives.  The default value is deflate.  Other possible values are ppmd, lzma, bzip2 and deflate64.   When writing a ZIPX archive, if the file extension does not indicate an obvious choice for the appropriate compression algorithm, then the ZipxDefaultAlg is used.
Methods
AddBd
AddEmpty
Adds an empty file or directory entry to this object.  If isDir is 1, then an empty directory entry is added.  Otherwise an empty file entry is added.
Returns 1 for success, 0 for failure.
topAddEncoded
Adds binary data as a new entry to this object. pathInZip specifies the entry's path within the zip. data contains the data encoded using the method specified by encoding, such as base64 or hex.
Returns 1 for success, 0 for failure.
topAddFile
Adds a file or directory to the object. If localPath is an absolute file path and saveExtraPath is true, localPath is converted to a relative file path for the zip entry. Otherwise, only the filename is stored. If localPath is a relative file path, it is stored as-is in the zip, regardless of saveExtraPath.
Returns 1 for success, 0 for failure.
topAddNoCompressExtension
Attempting to compress already-compressed data is usually a waste of CPU cycles with little or no benefit.  In fact, it is possible that attempting to compress already-compressed data results in a slightly increased size.  The Zip file format allows for files to be stored rather than compressed.  This allows the file data to be streamed directly into a .zip without compression.
An instance of the Zip object has an internal list of no compress extensions.  A filename with a no compress extension is stored rather than compressed.  Additional no compress extensions may be added by calling this method (once per file extension).  You should pass the file extension, such as .xyz in fileExtension.  
no compress extensions may be removed by calling RemoveNoCompressExtension.
The default no compress extensions are: .zip, .gif, .jpg, .gz, .rar, .jar, .tgz, .bz2, .z, .rpm, .msi, .png
AddSb
The content of sb is added as a new entry to this object, using its byte representation based on the specified charset.
Returns 1 for success, 0 for failure.
topAddString
Adds a new text entry to this object, using its byte representation based on the specified charset.
Returns 1 for success, 0 for failure.
topAppendFiles
Appends one or more files to the Zip object. The filePattern can use the * wildcard character for 0 or more of any characterSet recurse equal to True to recursively add all subdirectories, or False to only add files in the current directory.
Note: This method only updates the zip object. To update (rewrite) a zip file, either the WriteZip or WriteZipAndClose method would need to be called.
Returns 1 for success, 0 for failure.
AppendFilesAsync (1)
Creates an asynchronous task to call the AppendFiles method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
AppendFilesEx
Appends one or more files to the Zip object. The filePattern can use the * to mean 0 or more of any character.  The recurse controls whether directories are recursively traversed.  Set recurse equal to 1 to append files and subdirectories in the directory tree.  Set recurse equal to 0 to add files only from the indicated directory.
The saveExtraPath only applies when the filePattern is an absolute path pattern, such as C:/temp/abc/*.txt.  If saveExtraPath is 1, then the absolute path will be included in the zip entry filenames as relative paths.  For example, temp/abc/xyz.txt.    
The archiveOnly, includeHidden, and includeSystem flags only apply when on the Windows operating system.  If archiveOnly is 1, then only files that have the archive bit set will be included in the zip.  If includeHidden is 0, then hidden files are not included.  If includeSystem is 0, then files having the System attribute are not included.
Note: This method does not write the zip archive. It simply adds references to the files that will be included in the .zip when the WriteZip or WriteZipAndClose methods are eventually called. Files and/or data may be added to the zip object by calling any combination of the Append* methods before finally writing the zip via one of the Write* methods.
Returns 1 for success, 0 for failure.
AppendFilesExAsync (1)
Creates an asynchronous task to call the AppendFilesEx method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
AppendZip
Adds the contents of another existing Zip file to this Zip object.
Returns 1 for success, 0 for failure.
topCloseZip
Closes an open Zip file. This is identical to calling NewZip. (NewZip closes the current Zip file, if open, and initializes the Zip object to be empty. Zip files are only created when WriteZip is called.)
topDeleteEntry
Removes a Zip entry from the calling Zip object.
Returns 1 for success, 0 for failure.
EntryAt
Returns the entry at index in entry. The 1st entry is at index 0.
Returns 1 for success, 0 for failure.
topEntryById
Finds and returns the entry with the given id.  (Each entry within the zip object has a unique EntryID.)
Returns 1 for success, 0 for failure.
topEntryMatching
Returns in entry the first entry that matches pattern, where pattern may include * as a wildcard character matching any sequence of zero or more characters. The match is made against the full file path stored in the zip.
Returns 1 for success, 0 for failure.
topEntryOf
Returns in entry the entry where the file path stored within the zip equals pathInZip.
Returns 1 for success, 0 for failure.
topExcludeDir
Adds a directory name to be excluded when AppendFiles is called to add an entire directory tree. All directories having a name equal to an excluded directory will not be included when AppendFiles (or AppendFileEx) is called. Multiple directories can be excluded by calling ExcludeDir multiple times. The name comparison is case-insensitive.
topExtractExe
Extracts files from a Chilkat produced self-extracting EXE into the specified directory. Subdirectories are automatically created as needed. If the self-extracting EXE is encrypted, be sure to set the DecryptPassword property prior to calling this method.
Returns 1 for success, 0 for failure.
topExtractExeAsync (1)
Creates an asynchronous task to call the ExtractExe method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
GetDirectoryAsXML
Return the contents of the Zip file directory in an XML formatted string
Returns a zero-length WideString on failure
topGetExeConfigParam
(Relevant only when running on a Microsoft Windows operating system.) Gets the value of an EXE config param as described in the ExeXmlConfig property.
Returns a zero-length WideString on failure
topGetMaxUncompressedSize
Returns the size of the file contained within the Zip that has the largest uncompressed size. The size is returned in string form because it could be larger than what can be held in a 32-bit unsigned integer, and we leave it to the application to convert the string to an integer number. (If necessary. Perhaps your application is only interested in the order of magnitude, which can be known by the length of the string.)
Returns a zero-length WideString on failure
topIsNoCompressExtension
Returns 1 if the fileExtension is contained in the set of no compress extensions, otherwise returns 0.  (See the documentation for the AddNoCompressExtension method.)   The fileExtension may be  passed with or without the ..  For example, both .jpg and jpg are acceptable.
IsPasswordProtected
Return True if a Zip file is password protected
topLoadTaskCaller
NewZip
Clears and initializes the contents of the Zip object. If a Zip file was open, it is closed and all entries are removed from the object. The FileName property is set to the zipFilePath argument.
OpenBd
Open a Zip contained in binData.
When a zip is opened, the PasswordProtect and Encryption properties will be appropriately set.  If the zip is password protected (i.e. uses older Zip 2.0 encrypion), then the PasswordProtect property will be set to 1.  If the zip is strong encrypted, the Encryption property will be set to a value 1 through 4, where 4 indicates WinZip compatible AES encryption.
Returns 1 for success, 0 for failure.
OpenEmbedded
(Relevant only when running on a Microsoft Windows operating system.) Opens a Zip embedded in an MS Windows EXE
Returns 1 for success, 0 for failure.
topOpenFromByteData
Same as OpenFromMemory.
When a zip is opened, the PasswordProtect and Encryption properties will be appropriately set.  If the zip is password protected (i.e. uses older Zip 2.0 encrypion), then the PasswordProtect property will be set to 1.  If the zip is strong encrypted, the Encryption property will be set to a value 1 through 4, where 4 indicates WinZip compatible AES encryption.
Returns 1 for success, 0 for failure.
topOpenFromMemory
Open a Zip that is completely in-memory. This allows for Zip files to be opened from non-filesystem sources, such as a database.
When a zip is opened, the PasswordProtect and Encryption properties will be appropriately set.  If the zip is password protected (i.e. uses older Zip 2.0 encrypion), then the PasswordProtect property will be set to 1.  If the zip is strong encrypted, the Encryption property will be set to a value 1 through 4, where 4 indicates WinZip compatible AES encryption.
Returns 1 for success, 0 for failure.
OpenZip
Opens a Zip archive. Encrypted and password-protected zips may be opened without providing the password, but their contents may not be unzipped unless the correct password is provided via the DecryptPassword proprety, or the SetPassword method.
When a zip is opened, the PasswordProtect and Encryption properties will be appropriately set.  If the zip is password protected (i.e. uses older Zip 2.0 encrypion), then the PasswordProtect property will be set to 1.  If the zip is strong encrypted, the Encryption property will be set to a value 1 through 4, where 4 indicates WinZip compatible AES encryption.
Returns 1 for success, 0 for failure.
OpenZipAsync (1)
Creates an asynchronous task to call the OpenZip method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
QuickAppend
Efficiently appends additional files to an existing zip archive.  QuickAppend leaves all entries in the existing .zip untouched. It operates by appending new files and updating the internal central directory of the zip archive.
Returns 1 for success, 0 for failure.
QuickAppendAsync (1)
Creates an asynchronous task to call the QuickAppend method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
RemoveNoCompressExtension
Removes a file extension from the zip object's internal list of no compress extensions.  (For more information, see AddNoCompressExtension.)
SetCompressionLevel
Sets the compression level for all file and data entries. The compression level for a mapped entry (i.e. an entry that is contained within an opened .zip, cannot be changed.) The default compression level is 6. A compression level of 0 is equivalent to no compression. The maximum compression level is 9.
The zip.SetCompressionLevel method must be called after appending the files (i.e. after the calls to AppendFile*, AppendData, or AppendOneFileOrDir).
A single call to SetCompressionLevel will set the compression level for all existing file and data entries.
topSetExclusions
Specify a collection of exclusion patterns to be used when adding files to a Zip. Each pattern in the collection can use the * wildcard character, where * indicates 0 or more occurrences of any character.
SetExeConfigParam
Sets a self-extractor property that is embedded in the resultant EXE created by the WriteExe or WriteExe2 methods. The paramName is one of the XML tags listed in the ExeXmlConfig property.
For example, to specify the text for the self-extractor's main dialog unzip button, paramName would be MainUnzipBtn.
SetPassword
Set the password for an encrypted or password-protected Zip.
Note: The SetPassword method has the effect of setting both the EncryptPassword property as well as the DecryptPassword property. The SetPassword method should no longer be used. It has been replaced by the DecryptPassword and EncryptPassword properties to make it possible to open an encrypted zip and re-write it with a new password.
topUnzip
Unzips and returns the number of files unzipped, or -1 if a failure occurs. Subdirectories are automatically created during the unzipping process.
UnzipAsync (1)
Creates an asynchronous task to call the Unzip method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
UnzipInto
Unzips and returns the number of files unzipped, or -1 if a failure occurs. All files in the Zip are unzipped into the specfied dirPath regardless of the directory path information contained in the Zip. This has the effect of collapsing all files into a single directory. If several files in the Zip have the same name, the files unzipped last will overwrite the files already unzipped.
UnzipIntoAsync (1)
Creates an asynchronous task to call the UnzipInto method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
UnzipMatching
Same as Unzip, but only unzips files matching a pattern.  If no wildcard characters ('*') are used, then only files that exactly match the pattern will be unzipped.  The * characters matches 0 or more of any character.
UnzipMatchingAsync (1)
Creates an asynchronous task to call the UnzipMatching method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
UnzipMatchingInto
Unzips matching files into a single directory, ignoring all path information stored in the Zip.
topUnzipMatchingIntoAsync (1)
Creates an asynchronous task to call the UnzipMatchingInto method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
UnzipNewer
Same as Unzip, but only files that don't already exist on disk, or have later file modification dates are unzipped.
topUnzipNewerAsync (1)
Creates an asynchronous task to call the UnzipNewer method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
VerifyPassword
Tests the current DecryptPassword setting against the currently opened zip.  Returns 1 if the password is valid, otherwise returns 0.
WriteBd
Same as WriteZip, but instead of writing the Zip to a file, it writes to binData. Zips that are written to binData can be opened by calling OpenBd. Note: Both WriteBd and OpenBd are added in Chilkat v9.5.0.66
Returns 1 for success, 0 for failure.
WriteBdAsync (1)
Creates an asynchronous task to call the WriteBd method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
WriteExe
(Relevant only when running on a Microsoft Windows operating system.) Writes an MS-Windows self-extracting executable. There are no limitations on the total size, individual file size, or number of files that can be added to a self-extracting EXE.
If the resultant EXE will automatically accept these command-line arguments when run:
- -log logFileName
- Creates a log file that lists the settings embedded within the EXE and logs the errors, warnings, and other information about the self-extraction.
- -unzipDir unzipDirectoryPath
- Unzips to this directory path without user intervention. (UNC paths, such as \\servername\path, are not supported.)
- -pwd password
- Specifies the password for an encrypted EXE
- -ap autoRunParams
- Specifies the command line parameters to be passed to the AutoRun executable (embedded within the EXE).
Returns 1 for success, 0 for failure.
WriteExeAsync (1)
Creates an asynchronous task to call the WriteExe method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
WriteExeToMemory
(Relevant only when running on a Microsoft Windows operating system.) Same as WriteExe, but instead of writing a file, the MS-Windows EXE is written to memory.
Returns a zero-length byte array (as an OleVariant) on failure.
An empty array will have a VarArrayHighBound of -1 meaning 0 elements.
WriteExeToMemoryAsync (1)
Creates an asynchronous task to call the WriteExeToMemory method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
WriteToMemory
Same as WriteZip, but instead of writing the Zip to a file, it writes to memory. Zips that are written to memory can also be opened from memory by calling OpenFromMemory.
Returns a zero-length byte array (as an OleVariant) on failure.
An empty array will have a VarArrayHighBound of -1 meaning 0 elements.
WriteToMemoryAsync (1)
Creates an asynchronous task to call the WriteToMemory method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
WriteZip
Saves the Zip to a file and implictly re-opens it so further operations can continue. Use WriteZipAndClose to write and close the Zip. There is no limitation on the size of files that may be contained within a .zip, the total number of files in a .zip, or the total size of a .zip. If necessary, WriteZip will use the ZIP64 file format extensions when 4GB or file count limitations of the old zip file format are exceeded.
Returns 1 for success, 0 for failure.
WriteZipAsync (1)
Creates an asynchronous task to call the WriteZip method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
WriteZipAndClose
Saves the Zip to a file and closes it. On return, the Zip object will be in the state as if NewZip had been called. There is no limitation on the size of files that may be contained within a .zip, the total number of files in a .zip, or the total size of a .zip. If necessary, WriteZip will use the ZIP64 file format extensions when 4GB or file count limitations of the old zip file format are exceeded.
Returns 1 for success, 0 for failure.
WriteZipAndCloseAsync (1)
Creates an asynchronous task to call the WriteZipAndClose method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
Events
AbortCheck
Enables a method call to be aborted by triggering the AbortCheck event at intervals defined by the HeartbeatMs property. If HeartbeatMs is set to its default value of 0, no events will occur. For instance, set HeartbeatMs to 200 to trigger 5 AbortCheck events per second. 
Delphi ActiveX Event callback implementation:
procedure TForm1.zipAbortCheck(ASender: TObject;  out abort: Integer);
begin
    // Application code goes here...
end;
procedure TForm1.Button1Click(Sender: TObject);
var
  zip: TChilkatZip;
begin
  zip := TChilkatZip.Create(Self);
  zip.OnAbortCheck := zipAbortCheck;
  // ...PercentDone
This provides the percentage completion for any method involving network communications or time-consuming processing, assuming the progress can be measured as a percentage. This event is triggered only when it's possible and logical to express the operation's progress as a percentage. The pctDone argument will range from 1 to 100. For methods that finish quickly, the number of PercentDone callbacks may vary, but the final callback will have pctDone equal to 100. For longer operations, callbacks will not exceed one per percentage point (e.g., 1, 2, 3, ..., 98, 99, 100).
The PercentDone callback also acts as an AbortCheck event. For fast methods where PercentDone fires, an AbortCheck event may not trigger since the PercentDone callback already provides an opportunity to abort. For longer operations, where time between PercentDone callbacks is extended, AbortCheck callbacks enable more responsive operation termination.
        To abort the operation, set the abort output argument to 1. This will cause the method to terminate and return a failure status or corresponding failure value.
Delphi ActiveX Event callback implementation:
procedure TForm1.zipPercentDone(ASender: TObject;  pctDone: Integer; out abort: Integer);
begin
    // Application code goes here...
end;
procedure TForm1.Button1Click(Sender: TObject);
var
  zip: TChilkatZip;
begin
  zip := TChilkatZip.Create(Self);
  zip.OnPercentDone := zipPercentDone;
  // ...ProgressInfo
This event callback provides tag name/value pairs that detail what occurs during a method call. To discover existing tag names, create code to handle the event, emit the pairs, and review them. Most tag names are self-explanatory.
Delphi ActiveX Event callback implementation:
procedure TForm1.zipProgressInfo(ASender: TObject;  const name: WideString; const value: WideString);
begin
    // Application code goes here...
end;
procedure TForm1.Button1Click(Sender: TObject);
var
  zip: TChilkatZip;
begin
  zip := TChilkatZip.Create(Self);
  zip.OnProgressInfo := zipProgressInfo;
  // ...TaskCompleted
Called from the background thread when an asynchronous task completes.
Delphi ActiveX Event callback implementation:
procedure TForm1.zipTaskCompleted(ASender: TObject; const task: IChilkatTask); begin // Application code goes here... end; procedure TForm1.Button1Click(Sender: TObject); var zip: TChilkatZip; begin zip := TChilkatZip.Create(Self); zip.OnTaskCompleted := zipTaskCompleted; // ...
Deprecated
AppendBd
This method is deprecated.  Applications should instead call AddBd.
Appends the contents of byteData as a new entry to this zip object. The zip entry object containing the data is returned.
Returns nil on failure
AppendData
This method is deprecated.  Applications should instead call AddData.
Appends in-memory data as a new entry to a Zip object. The ZipEntry object containing the data is returned.
Note: This method only updates the zip object. To update (rewrite) a zip file, either the WriteZip or WriteZipAndClose method would need to be called.
Returns nil on failure
AppendDataEncoded
This method is deprecated.  Applications should instead call AddEncoded.
Appends in-memory data as a new entry to a Zip object.  The filename is the filename of the entry as it will appear within the zip.  The encoding is the encoding of the data, such as base64, hex, etc.  The full list of encodings is listed at the web page linked below.  
Returns the zip entry object.
Note: This method only updates the zip object. To update (rewrite) a zip file, either the WriteZip or WriteZipAndClose method would need to be called.
Returns nil on failure
AppendNew
This method is deprecated.  Applications should instead call AddEmpty.
Appends a new and empty entry to the Zip object and returns the ZipEntry object. Data can be appended to the entry by calling ZipEntry.AppendData.
Important: To append an already-existing file, call the AppendOneFileOrDir method. The AppendNew method inserts a new and empty file entry within the Zip object. The purpose of AppendNew is to either create an empty file within the Zip, or to create a new file entry which can then be filled with data by calling the entry's AppendData method.
Note: This method only updates the zip object. To update (rewrite) a zip file, either the WriteZip or WriteZipAndClose method would need to be called.
Returns nil on failure
AppendNewDir
This method is deprecated.  Applications should instead call AddEmpty.
Adds an entry to the zip so that when it unzips, a new directory (with no files) is created. The directory does not need to exist on the local filesystem when calling this method. The dirName is simply a string that is used as the directory path for the entry added to the zip. The zip entry object is returned.
Note: This method only updates the zip object. To update (rewrite) a zip file, either the WriteZip or WriteZipAndClose method would need to be called.
Returns nil on failure
AppendOneFileOrDir
This method is deprecated.  Applications should instead call AddFile.
Adds a file or directory to the object. If fileOrDirPath is an absolute file path and saveExtraPath is true, fileOrDirPath is converted to a relative file path for the zip entry. Otherwise, only the filename is stored. If fileOrDirPath is a relative file path, it is stored as-is in the zip, regardless of saveExtraPath.
Returns 1 for success, 0 for failure.
AppendOneFileOrDirAsync (1)
Creates an asynchronous task to call the AppendOneFileOrDir method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
AppendSb
This method is deprecated.  Applications should instead call AddSb.
Same as AppendString, but append the contents of of the sb, and allow the charset to be specified. The contents of sb is converted to charset before being added to the zip. The pathInZip is the path of the file that will be stored within the zip.
Note: This method only updates the zip object. To update (rewrite) a zip file, either the WriteZip or WriteZipAndClose method would need to be called.
Returns 1 for success, 0 for failure.
AppendString
This method is deprecated.  Applications should instead call AddString.
Adds an in-memory string to the Zip object. The textData argument is converted to the ANSI charset before being added to the Zip. If the Zip were written to disk by calling WriteZip, and later unzipped, the entry would unzip to an ANSI text file.
Note: This method only updates the zip object. To update (rewrite) a zip file, either the WriteZip or WriteZipAndClose method would need to be called.
Returns nil on failure
AppendString2
This method is deprecated.  Applications should instead call AddString.
Same as AppendString, but allows the charset to be specified. The textData is converted to charset before being added to the zip. The internalZipFilepath is the path of the file that will be stored within the zip.
Note: This method only updates the zip object. To update (rewrite) a zip file, either the WriteZip or WriteZipAndClose method would need to be called.
Returns nil on failure
FirstEntry
This method is deprecated.  Applications should instead call EntryAt.
Return the first entry in the Zip. Call ZipEntry.NextEntry to iterate over the entries in a Zip until a NULL is returned.
Returns nil on failure
FirstMatchingEntry
This method is deprecated.  Applications should instead call EntryMatching.
Returns the first entry having a filename matching a pattern.  The * characters matches 0 or more of any character.  The full filename, including path, is used when matching against the pattern. A NULL is returned if nothing matches.
Returns nil on failure
GetEntryByID
This method is deprecated.  Applications should instead call EntryById.
Finds and returns the entry with the given entryID.  (Each entry within the zip object has a unique EntryID.)
Returns nil on failure
GetEntryByIndex
This method is deprecated.  Applications should instead call EntryAt.
Retrieves a ZipEntry by index. The first entry is at index 0. This will return directory entries as well as files.
Returns nil on failure
GetEntryByName
This method is deprecated.  Applications should instead call EntryOf.
Returns the entry where the file path stored within the zip equals entryName.
Returns nil on failure
GetExclusions
This method is deprecated and will removed in a future version of Chilkat.
Returns the current collection of exclusion patterns that have been set by SetExclusions.
Returns nil on failure