![]() |
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
(Unicode C) Chunked Compression Using CompressBd2 with FirstChunk and LastChunkSee more Compression ExamplesThis example demonstrates how to compress data in multiple segments using theCompressBd2 method together with the FirstChunk and LastChunk properties. Instead of compressing all data in a single call, the input is divided into smaller chunks and processed sequentially, which is useful when handling streaming data or large inputs.
The example shows how to correctly mark the first, middle, and final chunks so that the compression stream is properly initialized and finalized. The compressed output is accumulated in a separate This approach is ideal for scenarios where data is received incrementally, such as reading from a network stream, processing large files in parts, or handling real-time data feeds.
#include <C_CkCompressionW.h> #include <C_CkBinDataW.h> void ChilkatSample(void) { BOOL success; HCkCompressionW compress; HCkBinDataW bdOut; const wchar_t *part1; const wchar_t *part2; const wchar_t *part3; HCkBinDataW bdIn; const wchar_t *compressedBase64; HCkBinDataW bdDecompressed; const wchar_t *resultText; success = FALSE; // This example assumes the Chilkat API has already been unlocked. // See Global Unlock Sample for sample code. compress = CkCompressionW_Create(); CkCompressionW_putAlgorithm(compress,L"zlib"); // This will accumulate the compressed output. bdOut = CkBinDataW_Create(); // ------------------------------------------------------------------ // Simulate input arriving in chunks. // ------------------------------------------------------------------ part1 = L"The quick brown fox "; part2 = L"jumps over the lazy dog. "; part3 = L"This text is split into chunks."; // ------------------------------------------------------------------ // Compress the first chunk // ------------------------------------------------------------------ CkCompressionW_putFirstChunk(compress,TRUE); CkCompressionW_putLastChunk(compress,FALSE); bdIn = CkBinDataW_Create(); CkBinDataW_AppendString(bdIn,part1,L"utf-8"); success = CkCompressionW_CompressBd2(compress,bdIn,bdOut); if (success == FALSE) { wprintf(L"%s\n",CkCompressionW_lastErrorText(compress)); CkCompressionW_Dispose(compress); CkBinDataW_Dispose(bdOut); CkBinDataW_Dispose(bdIn); return; } // ------------------------------------------------------------------ // Compress a middle chunk // ------------------------------------------------------------------ CkCompressionW_putFirstChunk(compress,FALSE); CkCompressionW_putLastChunk(compress,FALSE); CkBinDataW_Clear(bdIn); CkBinDataW_AppendString(bdIn,part2,L"utf-8"); success = CkCompressionW_CompressBd2(compress,bdIn,bdOut); if (success == FALSE) { wprintf(L"%s\n",CkCompressionW_lastErrorText(compress)); CkCompressionW_Dispose(compress); CkBinDataW_Dispose(bdOut); CkBinDataW_Dispose(bdIn); return; } // ------------------------------------------------------------------ // Compress the final chunk // ------------------------------------------------------------------ CkCompressionW_putFirstChunk(compress,FALSE); CkCompressionW_putLastChunk(compress,TRUE); CkBinDataW_Clear(bdIn); CkBinDataW_AppendString(bdIn,part3,L"utf-8"); success = CkCompressionW_CompressBd2(compress,bdIn,bdOut); if (success == FALSE) { wprintf(L"%s\n",CkCompressionW_lastErrorText(compress)); CkCompressionW_Dispose(compress); CkBinDataW_Dispose(bdOut); CkBinDataW_Dispose(bdIn); return; } // Get the final compressed result as base64 for display compressedBase64 = CkBinDataW_getEncoded(bdOut,L"base64"); wprintf(L"Compressed data (base64):\n"); wprintf(L"%s\n",compressedBase64); // ------------------------------------------------------------------ // Decompress to verify correctness // ------------------------------------------------------------------ bdDecompressed = CkBinDataW_Create(); CkCompressionW_putFirstChunk(compress,TRUE); CkCompressionW_putLastChunk(compress,TRUE); success = CkCompressionW_DecompressBd2(compress,bdOut,bdDecompressed); if (success == FALSE) { wprintf(L"%s\n",CkCompressionW_lastErrorText(compress)); CkCompressionW_Dispose(compress); CkBinDataW_Dispose(bdOut); CkBinDataW_Dispose(bdIn); CkBinDataW_Dispose(bdDecompressed); return; } // Convert decompressed bytes back to a string resultText = CkBinDataW_getString(bdDecompressed,L"utf-8"); wprintf(L"Decompressed text:\n"); wprintf(L"%s\n",resultText); CkCompressionW_Dispose(compress); CkBinDataW_Dispose(bdOut); CkBinDataW_Dispose(bdIn); CkBinDataW_Dispose(bdDecompressed); } |
||||||
© 2000-2026 Chilkat Software, Inc. All Rights Reserved.