![]() |
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 ActiveX) 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, Chilkat_TLB; ... procedure TForm1.Button1Click(Sender: TObject); var success: Integer; zip: TChilkatZip; recurse: Integer; saveExtraPath: Integer; archiveOnly: Integer; includeHidden: Integer; includeSystem: Integer; begin success := 0; zip := TChilkatZip.Create(Self); success := zip.NewZip('appendFilesEx.zip'); if (success = 0) then begin Memo1.Lines.Add(zip.LastErrorText); Exit; end; // Recursively include all files beneath c:/project/files. recurse := 1; // // 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 = 1, 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 = 0, 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 := 1; // Do not require the Windows archive attribute. archiveOnly := 0; // Include hidden files. includeHidden := 1; // Exclude files having the Windows System attribute. includeSystem := 0; success := zip.AppendFilesEx('c:/project/files',recurse,saveExtraPath,archiveOnly,includeHidden,includeSystem); if (success = 0) then begin Memo1.Lines.Add(zip.LastErrorText); Exit; end; // Write the ZIP archive to disk. success := zip.WriteZipAndClose(); if (success = 0) then begin Memo1.Lines.Add(zip.LastErrorText); Exit; end; Memo1.Lines.Add('ZIP archive created successfully.'); end; |
||||
© 2000-2026 Chilkat Software, Inc. All Rights Reserved.