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
(C) Unzip One File to a StreamDemonstrates how to unzip a particular file contained within a .zip archive to a Chilkat stream.
#include <C_CkZip.h> #include <C_CkZipEntry.h> #include <C_CkStream.h> #include <C_CkTask.h> #include <C_CkStringBuilder.h> void ChilkatSample(void) { HCkZip zip; BOOL success; HCkZipEntry entry; HCkStream streamA; HCkStream streamB; HCkTask unzipTask; HCkStringBuilder sb; HCkStream streamC; const char *s; // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. zip = CkZip_Create(); // First open a .zip. success = CkZip_OpenZip(zip,"qa_data/hamlet.zip"); if (success != TRUE) { printf("%s\n",CkZip_lastErrorText(zip)); CkZip_Dispose(zip); return; } // Find the entry to be unzipped to a stream.. entry = CkZip_FirstMatchingEntry(zip,"*hamlet.xml"); if (CkZip_getLastMethodSuccess(zip) != TRUE) { printf("%s\n",CkZip_lastErrorText(zip)); CkZip_Dispose(zip); return; } // There are three ways we can unzip (inflate) to a stream. // // 1) Set a sink file on the stream object and call UnzipToStream synchronously. // This unzips to the stream's sink (which is to simply unzip to a file in the filesystem). // // 2) Create a stream object and call UnzipToStreamAsync. This starts the unzip in a background // thread (after Task.Run is called). Your application can then read the unzipped (inflated) file // directly from the stream. // // 3) (not shown in this example) Unzip to a stream object that is the source of something else. // // ---------------------------------------------------------------- // Case 1: Unzip to a file by setting the sink of streamA to a file. streamA = CkStream_Create(); CkStream_putSinkFile(streamA,"qa_output/hamletA.xml"); success = CkZipEntry_UnzipToStream(entry,streamA); if (success != TRUE) { printf("%s\n",CkZipEntry_lastErrorText(entry)); CkZipEntry_Dispose(entry); CkZip_Dispose(zip); CkStream_Dispose(streamA); return; } // Close the stream to close the output file. success = CkStream_WriteClose(streamA); // ---------------------------------------------------------------- // Case 2a: Uzip to a stream asynchronously. streamB = CkStream_Create(); unzipTask = CkZipEntry_UnzipToStreamAsync(entry,streamB); if (CkZipEntry_getLastMethodSuccess(entry) != TRUE) { printf("%s\n",CkZipEntry_lastErrorText(entry)); CkZipEntry_Dispose(entry); CkZip_Dispose(zip); CkStream_Dispose(streamA); CkStream_Dispose(streamB); return; } // Start the background unzip thread. CkTask_Run(unzipTask); // Read the stream. (this is reading the unzipped file data) sb = CkStringBuilder_Create(); while (CkStream_getEndOfStream(streamB) != TRUE) { // Each call to ReadSb appends to the contents of sb. CkStream_ReadSb(streamB,sb); } CkStringBuilder_WriteFile(sb,"qa_output/hamletB.xml","utf-8",FALSE); CkTask_Dispose(unzipTask); printf("Success.\n"); // ---------------------------------------------------------------- // Case 2b: Uzip to a stream asynchronously and emit output while reading. streamC = CkStream_Create(); unzipTask = CkZipEntry_UnzipToStreamAsync(entry,streamC); if (CkZipEntry_getLastMethodSuccess(entry) != TRUE) { printf("%s\n",CkZipEntry_lastErrorText(entry)); CkZipEntry_Dispose(entry); CkZip_Dispose(zip); CkStream_Dispose(streamA); CkStream_Dispose(streamB); CkStringBuilder_Dispose(sb); CkStream_Dispose(streamC); return; } CkTask_Run(unzipTask); while (CkStream_getEndOfStream(streamC) != TRUE) { s = CkStream_readString(streamC); printf("%s\n",s); } CkZipEntry_Dispose(entry); CkTask_Dispose(unzipTask); printf("Success.\n"); CkZip_Dispose(zip); CkStream_Dispose(streamA); CkStream_Dispose(streamB); CkStringBuilder_Dispose(sb); CkStream_Dispose(streamC); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.