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) Decompress Large Text File in BlocksDecompresses a large text file in blocks, and compares the restored (decompressed) file with the original to make sure it's correct.
#include <C_CkCompression.h> #include <C_CkFileAccess.h> #include <C_CkByteData.h> void ChilkatSample(void) { HCkCompression compress; BOOL success; HCkFileAccess fac; const char *originalPath; HCkFileAccess facSrc; HCkFileAccess facDest; int blockSize; int numBlocks; const char *restoredPath; const char *decompressedStr; HCkByteData compressedBytes; int i; BOOL bEqualContents; // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // First, let's compress a text file. // We'll then decompress in blocks, and compare the decompressed with the original file. // Compress a text file: compress = CkCompression_Create(); CkCompression_putAlgorithm(compress,"deflate"); success = CkCompression_CompressFile(compress,"qa_data/hamlet.xml","qa_data/hamlet_compressed.dat"); if (success != TRUE) { printf("%s\n",CkCompression_lastErrorText(compress)); CkCompression_Dispose(compress); return; } fac = CkFileAccess_Create(); // Examine the uncompressed and compressed sizes: originalPath = "qa_data/hamlet.xml"; // Note: The FileSize method returns a signed 32-bit integer. If the file is potentially larger than 2GB, call FileSizeStr instead to return // the size of the file as a string, then convert to an integer value. printf("uncompressed size: %d\n",CkFileAccess_FileSize(fac,originalPath)); printf("compressed size: %d\n",CkFileAccess_FileSize(fac,"qa_data/hamlet_compressed.dat")); // Decompress in blocks.. facSrc = CkFileAccess_Create(); facDest = CkFileAccess_Create(); CkFileAccess_OpenForRead(facSrc,"qa_data/hamlet_compressed.dat"); // If we compress in 32K chunks, find out how many blocks there will be. blockSize = 32768; numBlocks = CkFileAccess_GetNumBlocks(facSrc,blockSize); // Open an output file for the decompressed data. restoredPath = "qa_output/hamlet_restored.xml"; success = CkFileAccess_OpenForWrite(facDest,restoredPath); if (success != TRUE) { printf("%s\n",CkFileAccess_lastErrorText(facDest)); CkCompression_Dispose(compress); CkFileAccess_Dispose(fac); CkFileAccess_Dispose(facSrc); CkFileAccess_Dispose(facDest); return; } compressedBytes = CkByteData_Create(); i = 0; while (i < numBlocks) { success = CkFileAccess_ReadBlock(facSrc,i,blockSize,compressedBytes); if (i == 0) { decompressedStr = CkCompression_beginDecompressString(compress,compressedBytes); } else { decompressedStr = CkCompression_moreDecompressString(compress,compressedBytes); } CkFileAccess_AppendText(facDest,decompressedStr,"utf-8"); i = i + 1; } // At the very end, flush any remaining content, if any. decompressedStr = CkCompression_endDecompressString(compress); CkFileAccess_AppendText(facDest,decompressedStr,"utf-8"); CkFileAccess_FileClose(facSrc); CkFileAccess_FileClose(facDest); // Examine the size of the restored file. printf("restored size: %d\n",CkFileAccess_FileSize(fac,restoredPath)); // Compare the contents of the original with the restored. bEqualContents = CkFileAccess_FileContentsEqual(fac,restoredPath,originalPath); printf("Contents Equal: %d\n",bEqualContents); CkCompression_Dispose(compress); CkFileAccess_Dispose(fac); CkFileAccess_Dispose(facSrc); CkFileAccess_Dispose(facDest); CkByteData_Dispose(compressedBytes); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.