![]() |
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
(Tcl) 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.
load ./chilkat.dll set success 0 set zip [new_CkZip] set success [CkZip_NewZip $zip "appendFilesEx.zip"] if {$success == 0} then { puts [CkZip_lastErrorText $zip] delete_CkZip $zip exit } # Recursively include all files beneath c:/project/files. set 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. set saveExtraPath 1 # Do not require the Windows archive attribute. set archiveOnly 0 # Include hidden files. set includeHidden 1 # Exclude files having the Windows System attribute. set includeSystem 0 set success [CkZip_AppendFilesEx $zip "c:/project/files" $recurse $saveExtraPath $archiveOnly $includeHidden $includeSystem] if {$success == 0} then { puts [CkZip_lastErrorText $zip] delete_CkZip $zip exit } # Write the ZIP archive to disk. set success [CkZip_WriteZipAndClose $zip] if {$success == 0} then { puts [CkZip_lastErrorText $zip] delete_CkZip $zip exit } puts "ZIP archive created successfully." delete_CkZip $zip |
||||
© 2000-2026 Chilkat Software, Inc. All Rights Reserved.