![]() |
Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java JavaScript Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Delphi DLL) Recursively Add Files to a ZIP Using AppendFilesExSee more Zip Examples
This example demonstrates how to use the The example:
The This method is cross-platform and works on Windows, macOS, Linux, Android, iOS, and other supported operating systems. Some arguments are Windows-specific:
On non-Windows operating systems, these Windows-specific options are simply ignored. Suppose the local filesystem contains the following directory tree: c:/project/files/docs/readme.txt And suppose the following call is made:
If project/files/docs/readme.txt In this case, the extra leading path information from the filePattern is preserved in the ZIP.
If docs/readme.txt
In this case, the leading Note: This example requires Chilkat v11.0.0 or greater.
uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Zip; ... procedure TForm1.Button1Click(Sender: TObject); var success: Boolean; zip: HCkZip; recurse: Boolean; saveExtraPath: Boolean; archiveOnly: Boolean; includeHidden: Boolean; includeSystem: Boolean; begin success := False; zip := CkZip_Create(); success := CkZip_NewZip(zip,'appendFilesEx.zip'); if (success = False) then begin Memo1.Lines.Add(CkZip__lastErrorText(zip)); Exit; end; // Recursively include all files beneath c:/project/files. recurse := True; // // The saveExtraPath argument controls whether the extra leading path // information from the filePattern is included in the stored ZIP paths. // // For example, suppose the local filesystem contains: // // c:/project/files/docs/readme.txt // c:/project/files/docs/manual.pdf // c:/project/files/images/logo.png // // And suppose AppendFilesEx is called with: // // "c:/project/files" // // If saveExtraPath = True, the ZIP stores: // // project/files/docs/readme.txt // project/files/docs/manual.pdf // project/files/images/logo.png // // In this case, the extra path information from the filePattern is preserved. // // ---------------------------------------------------------------- // // If saveExtraPath = False, the ZIP stores paths relative to the // directory specified by the filePattern: // // docs/readme.txt // docs/manual.pdf // images/logo.png // // In this case, the leading "project/files" path is not stored in the ZIP. // ---------------------------------------------------------------- // Preserve extra path information within the ZIP archive. saveExtraPath := True; // Do not require the Windows archive attribute. archiveOnly := False; // Include hidden files. includeHidden := True; // Exclude files having the Windows System attribute. includeSystem := False; success := CkZip_AppendFilesEx(zip,'c:/project/files',recurse,saveExtraPath,archiveOnly,includeHidden,includeSystem); if (success = False) then begin Memo1.Lines.Add(CkZip__lastErrorText(zip)); Exit; end; // Write the ZIP archive to disk. success := CkZip_WriteZipAndClose(zip); if (success = False) then begin Memo1.Lines.Add(CkZip__lastErrorText(zip)); Exit; end; Memo1.Lines.Add('ZIP archive created successfully.'); CkZip_Dispose(zip); end; |
||||
© 2000-2026 Chilkat Software, Inc. All Rights Reserved.