Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Unicode C) Append Files to Existing Zip w/out Rewriting Entire ZipDemonstrates how to use the QuickAppend method to append files to an existing .zip archive. This method works by editing the existing .zip -- it does not rewrite or recompress the contents of the existing .zip. It is the fastest way to append additional files to a pre-existing large .zip archive. Note: The QuickAppend method is new and available in the pre-release downloads, or in official releases dated after 6-October-2007.
#include <C_CkZipW.h> void ChilkatSample(void) { HCkZipW zip; BOOL success; BOOL saveExtraPath; // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. zip = CkZipW_Create(); // The NewZip method only initializes the Zip object -- it does // not create or write a .zip file. success = CkZipW_NewZip(zip,L"notUsed.zip"); if (success != TRUE) { wprintf(L"%s\n",CkZipW_lastErrorText(zip)); CkZipW_Dispose(zip); return; } // Add a reference to a file. This is the file that will // be added to a pre-existing .zip archive. // Note: this does not read or compress the file contents -- // it simply adds a reference to the zip object. saveExtraPath = FALSE; success = CkZipW_AppendOneFileOrDir(zip,L"something.dat",saveExtraPath); if (success != TRUE) { wprintf(L"%s\n",CkZipW_lastErrorText(zip)); CkZipW_Dispose(zip); return; } // Appends the contents of the zip object to the preExisting.zip // zip archive. preExisting.zip is opened, and the files // referenced by this zip object are streamed in, compressed, // and appended to the end of the archive. success = CkZipW_QuickAppend(zip,L"preExisting.zip"); if (success != TRUE) { wprintf(L"%s\n",CkZipW_lastErrorText(zip)); CkZipW_Dispose(zip); return; } wprintf(L"Success!\n"); // Note: Additional files, directory trees, or in-memory data // can be appended by calling AppendOneFileOrDir, AppendFiles, // AppendString, AppendData, etc. multiple times. // Whatever files and/or in-memory data that are referenced by // this zip object will be appended to preExisting.zip when // QuickAppend is called CkZipW_Dispose(zip); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.