Gzip Unicode C++ Reference Documentation

CkGzipW

Current Version: 11.4.0

This class provides functionality for working with GZIP compression in both file-based and in-memory scenarios. It supports compressing and decompressing:

  • Files (.gz, .tar.gz)
  • Strings (with charset conversion)
  • Binary data (byte[], BinData)
  • Encoded data (Base64, Hex, etc.)

It also allows embedding metadata such as filenames, timestamps, and comments within the GZIP format.

For an extended overview, see Gzip Class Overview.

Object Creation

// Local variable on the stack
CkGzipW obj;

// Dynamically allocate/delete
CkGzipW *pObj = new CkGzipW();
// ...
delete pObj;

Properties

AbortCurrent
bool get_AbortCurrent(void);
void put_AbortCurrent(bool newVal);
Introduced in version 9.5.0.58

Set this property to true to request that the currently running operation be aborted. This is useful for long-running operations such as large file compression or decompression. Methods that complete quickly are generally not affected.

If no method is currently running, the property is automatically reset to false when the next method begins. After an abort occurs, it is also reset to false. Both synchronous and asynchronous operations can be aborted. For synchronous calls, another thread must set this property.

top
Comment
void get_Comment(CkString &str);
const wchar_t *comment(void);
void put_Comment(const wchar_t *str);

An optional comment to embed in the Gzip file when a Compress* method is called.

top
CompressionLevel
int get_CompressionLevel(void);
void put_CompressionLevel(int newVal);
Introduced in version 9.5.0.50

Controls the compression level used when creating Gzip data. The value can range from 0 to 9.

  • 0 = no compression
  • 9 = maximum compression

The default value is 6, which is a typical balance between compression size and speed. Higher levels may take significantly more CPU time while producing only slightly smaller output, depending on the data.

top
DebugLogFilePath
void get_DebugLogFilePath(CkString &str);
const wchar_t *debugLogFilePath(void);
void put_DebugLogFilePath(const wchar_t *str);

If set to a file path, this property logs the LastErrorText of each Chilkat method or property call to the specified file. This logging helps identify the context and history of Chilkat calls leading up to any crash or hang, aiding in debugging.

Enabling the VerboseLogging property provides more detailed information. This property is mainly used for debugging rare instances where a Chilkat method call causes a hang or crash, which should generally not happen.

Possible causes of hangs include:

  • A timeout property set to 0, indicating an infinite timeout.
  • A hang occurring within an event callback in the application code.
  • An internal bug in the Chilkat code causing the hang.

More Information and Examples
top
Filename
void get_Filename(CkString &str);
const wchar_t *filename(void);
void put_Filename(const wchar_t *str);

The filename to embed in the Gzip file when a Compress* method is called. Some Gzip extraction tools use this embedded filename as the default output filename.

top
HeartbeatMs
int get_HeartbeatMs(void);
void put_HeartbeatMs(int newVal);

Specifies the interval, in milliseconds, between AbortCheck event callbacks. These callbacks allow an application to cancel certain long-running operations before they finish.

The default value is 0, which means no AbortCheck callbacks are triggered.

More Information and Examples
top
LastErrorHtml
void get_LastErrorHtml(CkString &str);
const wchar_t *lastErrorHtml(void);

Provides HTML-formatted information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.

top
LastErrorText
void get_LastErrorText(CkString &str);
const wchar_t *lastErrorText(void);

Provides plain text information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.

top
LastErrorXml
void get_LastErrorXml(CkString &str);
const wchar_t *lastErrorXml(void);

Provides XML-formatted information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.

top
LastMethodSuccess
bool get_LastMethodSuccess(void);
void put_LastMethodSuccess(bool newVal);

Indicates the success or failure of the most recent method call: true means success, false means failure. This property remains unchanged by property setters or getters. This method is present to address challenges in checking for null or Nothing returns in certain programming languages. Note: This property does not apply to methods that return integer values or to boolean-returning methods where the boolean does not indicate success or failure.

top
LastModStr
void get_LastModStr(CkString &str);
const wchar_t *lastModStr(void);
void put_LastModStr(const wchar_t *str);

Specifies the last-modified date/time to embed in the Gzip file when a Compress* method is called.

The value must be provided as an RFC 822 formatted date/time string.

Example:

Tue, 15 Nov 1994 12:45:26 GMT

If this property is not set, the current system date/time is used automatically.

top
UseCurrentDate
bool get_UseCurrentDate(void);
void put_UseCurrentDate(bool newVal);

Controls the last-modified date/time assigned to files created by Uncompress* methods.

When set to true, the extracted file uses the current date/time instead of the date/time stored in the Gzip data.

top
VerboseLogging
bool get_VerboseLogging(void);
void put_VerboseLogging(bool newVal);

If set to true, then the contents of LastErrorText (or LastErrorXml, or LastErrorHtml) may contain more verbose information. The default value is false. Verbose logging should only be used for debugging. The potentially large quantity of logged information may adversely affect peformance.

top
Version
void get_Version(CkString &str);
const wchar_t *version(void);

Version of the component/library, such as "10.1.0"

More Information and Examples
top

Methods

CompressBd
bool CompressBd(CkBinDataW &binDat);
Introduced in version 9.5.0.67

Compresses the contents of a BinData object in place, replacing the original data with Gzip-compressed data.

Returns true for success, false for failure.

More Information and Examples
top
CompressBdAsync (1)
CkTaskW *CompressBdAsync(CkBinDataW &binDat);
Introduced in version 9.5.0.67

Creates an asynchronous task to call the CompressBd method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
CompressFile
bool CompressFile(const wchar_t *srcPath, const wchar_t *destPath);

Compresses a file and writes the result as a Gzip file, typically with a .gz extension.

Returns true for success, false for failure.

More Information and Examples
top
CompressFileAsync (1)
CkTaskW *CompressFileAsync(const wchar_t *srcPath, const wchar_t *destPath);

Creates an asynchronous task to call the CompressFile method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
CompressFile2
bool CompressFile2(const wchar_t *srcPath, const wchar_t *embeddedFilename, const wchar_t *destPath);

Compresses a file and writes the result as a Gzip file, while allowing a different filename to be embedded inside the Gzip data.

The inFilename parameter is the actual file on disk. The srcPath parameter is the filename stored in the Gzip header and may be used by extraction tools as the output filename.

Returns true for success, false for failure.

More Information and Examples
top
CompressFile2Async (1)
CkTaskW *CompressFile2Async(const wchar_t *srcPath, const wchar_t *embeddedFilename, const wchar_t *destPath);

Creates an asynchronous task to call the CompressFile2 method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
CompressFileBd
bool CompressFileBd(const wchar_t *filePath, CkBinDataW &bd);
Introduced in version 11.0.0

Compresses a file and stores the resulting Gzip data in a BinData object.

The compressed output is held in memory. The maximum compressed size is 4 GB.

Returns true for success, false for failure.

top
CompressFileBdAsync (1)
CkTaskW *CompressFileBdAsync(const wchar_t *filePath, CkBinDataW &bd);
Introduced in version 11.0.0

Creates an asynchronous task to call the CompressFileBd method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
CompressSb
bool CompressSb(CkStringBuilderW &sb, const wchar_t *charset, CkBinDataW &bd);
Introduced in version 11.0.0

Compresses the text contained in a StringBuilder and writes the Gzip-compressed result to a BinData object.

Before compression, the string is converted to bytes using the specified character set, such as utf-8, iso-8859-1, or shift_JIS.

Returns true for success, false for failure.

top
CompressSbAsync (1)
CkTaskW *CompressSbAsync(CkStringBuilderW &sb, const wchar_t *charset, CkBinDataW &bd);
Introduced in version 11.0.0

Creates an asynchronous task to call the CompressSb method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
CompressStringENC
bool CompressStringENC(const wchar_t *inStr, const wchar_t *charset, const wchar_t *encoding, CkString &outStr);
const wchar_t *compressStringENC(const wchar_t *inStr, const wchar_t *charset, const wchar_t *encoding);

Compresses a string and returns the Gzip-compressed data as an encoded string.

The input string is first converted to bytes using the specified character set. The compressed binary data is then encoded using the requested encoding, such as base64, hex, url, base32, or quoted-printable.

Returns true for success, false for failure.

top
CompressStringToFile
bool CompressStringToFile(const wchar_t *inStr, const wchar_t *destCharset, const wchar_t *destPath);

Compresses a string and writes the resulting Gzip data to a file.

The string is first converted to bytes using the character set specified by destCharset.

Returns true for success, false for failure.

top
CompressStringToFileAsync (1)
CkTaskW *CompressStringToFileAsync(const wchar_t *inStr, const wchar_t *destCharset, const wchar_t *destPath);

Creates an asynchronous task to call the CompressStringToFile method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
ExamineFile
bool ExamineFile(const wchar_t *filePath);

Checks whether the specified file contains Gzip-formatted data.

Returns true if the file is in Gzip format, or false otherwise.

More Information and Examples
top
IsGzip
bool IsGzip(CkBinDataW &bd);
Introduced in version 11.0.0

Checks whether the data contained in a BinData object is in Gzip format.

Returns true if the data is Gzip-formatted, or false otherwise.

top
LoadTaskCaller
bool LoadTaskCaller(CkTaskW &task);
Introduced in version 9.5.0.80

Loads the caller of the task's async method.

Returns true for success, false for failure.

top
SetDt
bool SetDt(CkDateTimeW &dt);

Sets the last-modified date/time to embed in the Gzip file when a Compress* method is called.

If no date/time is explicitly set, the current system date/time is used.

Returns true for success, false for failure.

More Information and Examples
top
SetExtraData
bool SetExtraData(const wchar_t *encodedData, const wchar_t *encoding);
Introduced in version 11.0.0

Sets optional extra binary data to include in the Gzip header when a Compress* method is called.

The data is passed as an encoded string. Supported encodings include base64, hex, ascii, and many others.

Returns true for success, false for failure.

More Information and Examples
top
UncompressBd
bool UncompressBd(CkBinDataW &binDat);
Introduced in version 9.5.0.67

Decompresses Gzip data contained in a BinData object in place, replacing the compressed data with the uncompressed data.

Returns true for success, false for failure.

top
UncompressBdAsync (1)
CkTaskW *UncompressBdAsync(CkBinDataW &binDat);
Introduced in version 9.5.0.67

Creates an asynchronous task to call the UncompressBd method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
UncompressBdToFile
bool UncompressBdToFile(CkBinDataW &bd, const wchar_t *filePath);
Introduced in version 11.0.0

Decompresses Gzip data stored in a BinData object and writes the result to a file.

Returns true for success, false for failure.

top
UncompressBdToFileAsync (1)
CkTaskW *UncompressBdToFileAsync(CkBinDataW &bd, const wchar_t *filePath);
Introduced in version 11.0.0

Creates an asynchronous task to call the UncompressBdToFile method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
UncompressFile
bool UncompressFile(const wchar_t *srcPath, const wchar_t *destPath);

Decompresses a Gzip file and writes the result to the specified output path.

The output filename is provided by the caller. The filename embedded in the Gzip data is not used.

Returns true for success, false for failure.

More Information and Examples
top
UncompressFileAsync (1)
CkTaskW *UncompressFileAsync(const wchar_t *srcPath, const wchar_t *destPath);

Creates an asynchronous task to call the UncompressFile method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
UncompressFileToString
bool UncompressFileToString(const wchar_t *srcPath, const wchar_t *charset, CkString &outStr);
const wchar_t *uncompressFileToString(const wchar_t *srcPath, const wchar_t *charset);

Decompresses a Gzip file that contains text and returns the uncompressed text as a string.

The charset parameter specifies the character encoding of the uncompressed text, such as utf-8, iso-8859-1, windows-1252, shift_JIS, big5, etc.

Returns true for success, false for failure.

More Information and Examples
top
UncompressFileToStringAsync (1)
CkTaskW *UncompressFileToStringAsync(const wchar_t *srcPath, const wchar_t *charset);

Creates an asynchronous task to call the UncompressFileToString method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
UncompressStringENC
bool UncompressStringENC(const wchar_t *inStr, const wchar_t *charset, const wchar_t *encoding, CkString &outStr);
const wchar_t *uncompressStringENC(const wchar_t *inStr, const wchar_t *charset, const wchar_t *encoding);

Decompresses Gzip data provided as an encoded string and returns the uncompressed result as text.

The input string is first decoded using the specified encoding, such as base64, hex, url, base32, quoted-printable, etc. The decoded Gzip data is then decompressed and converted to text using the specified character set.

Returns true for success, false for failure.

More Information and Examples
top
UnTarGz
bool UnTarGz(const wchar_t *gzPath, const wchar_t *destDir, bool bNoAbsolute);

Extracts a .tar.gz archive to a directory.

The Gzip decompression and TAR extraction are performed in streaming mode. No temporary files are created, and memory usage remains small and constant.

If bNoAbsolute is true, absolute paths in the TAR archive are not allowed. This helps protect against extracting files to unsafe locations, such as system directories.

Returns true for success, false for failure.

top
UnTarGzAsync (1)
CkTaskW *UnTarGzAsync(const wchar_t *gzPath, const wchar_t *destDir, bool bNoAbsolute);

Creates an asynchronous task to call the UnTarGz method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
XfdlToXml
bool XfdlToXml(const wchar_t *xfldData, CkString &outStr);
const wchar_t *xfdlToXml(const wchar_t *xfldData);

Converts base64-encoded, Gzip-compressed XFDL data to XML text.

The input contains base64 data. The method decodes it, decompresses the Gzip data, and returns the resulting XML string.

XFDL (Extensible Forms Description Language) is an XML-based format used to define secure, interactive electronic forms—often including digital signatures and integrity protections—commonly used in government and enterprise applications.

Returns true for success, false for failure.

top

Events

To implement an event callback, your application would define and implement a class that inherits from CkBaseProgressW. Your application can implement methods to override some or all of the default/empty method implementations of the CkBaseProgressW base class.

For example:

  CkGzipW gzip;

  MyGzipProgressW callbackObj;

  gzip.put_EventCallbackObject(&callbackObj);

MyGzipProgressW example:

#include "CkBaseProgressW.h"

class MyGzipProgressW : public CkBaseProgressW {

  public:
    MyGzipProgressW();
    virtual ~MyGzipProgressW();

    void AbortCheck(bool  *abort);

    void PercentDone(int pctDone, bool  *abort);

    void ProgressInfo(const wchar_t *name, const wchar_t *value);

    void TaskCompleted(CkTaskW &task);

};
AbortCheck
void AbortCheck(bool *abort);

Enables a method call to be aborted by triggering the AbortCheck event at intervals defined by the HeartbeatMs property. If HeartbeatMs is set to its default value of 0, no events will occur. For instance, set HeartbeatMs to 200 to trigger 5 AbortCheck events per second.

More Information and Examples
top
PercentDone
void PercentDone(int pctDone, bool *abort);

This provides the percentage completion for any method involving network communications or time-consuming processing, assuming the progress can be measured as a percentage. This event is triggered only when it's possible and logical to express the operation's progress as a percentage. The pctDone argument will range from 1 to 100. For methods that finish quickly, the number of PercentDone callbacks may vary, but the final callback will have pctDone equal to 100. For longer operations, callbacks will not exceed one per percentage point (e.g., 1, 2, 3, ..., 98, 99, 100).

The PercentDone callback also acts as an AbortCheck event. For fast methods where PercentDone fires, an AbortCheck event may not trigger since the PercentDone callback already provides an opportunity to abort. For longer operations, where time between PercentDone callbacks is extended, AbortCheck callbacks enable more responsive operation termination.

To abort the operation, set the abort output argument to true. This will cause the method to terminate and return a failure status or corresponding failure value.

More Information and Examples
top
ProgressInfo
void ProgressInfo(const wchar_t *name, const wchar_t *value);

This event callback provides tag name/value pairs that detail what occurs during a method call. To discover existing tag names, create code to handle the event, emit the pairs, and review them. Most tag names are self-explanatory.

More Information and Examples
top
TaskCompleted
void TaskCompleted(CkTaskW &task);

Called from the background thread when an asynchronous task completes.

top

Deprecated

CompressFileToMem Deprecated
bool CompressFileToMem(const wchar_t *inFilename, CkByteData &outData);

Compresses a file and returns the resulting Gzip data as a byte array.

The compressed output is held in memory and has a maximum size limit of 4 GB.

Returns true for success, false for failure.

top
CompressFileToMemAsync Deprecated (1)
CkTaskW *CompressFileToMemAsync(const wchar_t *inFilename);

Creates an asynchronous task to call the CompressFileToMem method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
CompressMemory Deprecated
bool CompressMemory(CkByteData &inData, CkByteData &outData);

Compresses a byte array and returns the result as an in-memory Gzip image.

The uncompressed input data must not exceed 4 GB.

Returns true for success, false for failure.

top
CompressMemoryAsync Deprecated (1)
CkTaskW *CompressMemoryAsync(CkByteData &inData);

Creates an asynchronous task to call the CompressMemory method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
CompressMemToFile Deprecated
bool CompressMemToFile(CkByteData &inData, const wchar_t *destPath);

Compresses a byte array and writes the resulting Gzip data to a file.

Returns true for success, false for failure.

top
CompressMemToFileAsync Deprecated (1)
CkTaskW *CompressMemToFileAsync(CkByteData &inData, const wchar_t *destPath);

Creates an asynchronous task to call the CompressMemToFile method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
CompressString Deprecated
bool CompressString(const wchar_t *inStr, const wchar_t *destCharset, CkByteData &outBytes);

Compresses a string and returns the Gzip-compressed data as a byte array.

The string is first converted to bytes using the character set specified by destCharset. Common values include utf-8, iso-8859-1, and shift_JIS.

Returns true for success, false for failure.

More Information and Examples
top
CompressStringAsync Deprecated (1)
CkTaskW *CompressStringAsync(const wchar_t *inStr, const wchar_t *destCharset);

Creates an asynchronous task to call the CompressString method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
Decode Deprecated
bool Decode(const wchar_t *encodedStr, const wchar_t *encoding, CkByteData &outBytes);
This method is deprecated.

Decodes an encoded string and returns the original data. The encoding mode is determined by encoding. It may be base64, hex, quoted-printable, or url.

Returns true for success, false for failure.

top
DeflateStringENC
bool DeflateStringENC(const wchar_t *inString, const wchar_t *charsetName, const wchar_t *outputEncoding, CkString &outStr);
const wchar_t *deflateStringENC(const wchar_t *inString, const wchar_t *charsetName, const wchar_t *outputEncoding);
This method is deprecated.

Compresses a string using the raw deflate algorithm and returns the compressed data as an encoded string.

The input string is first converted to bytes using the specified character set. The compressed binary data is then encoded using the requested output encoding, such as hex, base64, url, or quoted-printable.

Important: This method produces raw deflate-compressed data, not Gzip-format data. Use the Compress* methods when Gzip format output is required.

Returns true for success, false for failure.

More Information and Examples
top
Encode Deprecated
bool Encode(CkByteData &byteData, const wchar_t *encoding, CkString &outStr);
const wchar_t *encode(CkByteData &byteData, const wchar_t *encoding);
This method is deprecated.

Encodes binary data to a printable string. The encoding mode is determined by encoding. It may be base64, hex, quoted-printable, or url.

Returns true for success, false for failure.

top
ExamineMemory Deprecated
bool ExamineMemory(CkByteData &inGzData);

Checks whether the provided byte array contains Gzip-formatted data.

Returns true if the data is in Gzip format, or false otherwise.

top
GetDt
CkDateTimeW *GetDt(void);
This method is deprecated.

Applications should instead access the LastModStr property.

Gets the last-modification date/time to be embedded within the .gz.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
InflateStringENC
bool InflateStringENC(const wchar_t *inString, const wchar_t *convertFromCharset, const wchar_t *inputEncoding, CkString &outStr);
const wchar_t *inflateStringENC(const wchar_t *inString, const wchar_t *convertFromCharset, const wchar_t *inputEncoding);
This method is deprecated.

Decompresses data previously compressed with DeflateStringENC.

The input string is first decoded using the specified input encoding, such as hex, base64, url, or quoted-printable. The resulting compressed bytes are then inflated, and the final bytes are converted to a string using the specified character set.

Returns true for success, false for failure.

top
ReadFile Deprecated
bool ReadFile(const wchar_t *path, CkByteData &outBytes);
This method is deprecated.

Reads a binary file into memory and returns the byte array. Note: This method does not parse a Gzip, it is only a convenience method for reading a binary file into memory.

Returns true for success, false for failure.

top
UncompressFileToMem Deprecated
bool UncompressFileToMem(const wchar_t *srcPath, CkByteData &outData);

Decompresses a Gzip file and returns the uncompressed data as a byte array.

The uncompressed output is held in memory and must not exceed 4 GB.

Returns true for success, false for failure.

top
UncompressFileToMemAsync Deprecated (1)
CkTaskW *UncompressFileToMemAsync(const wchar_t *srcPath);

Creates an asynchronous task to call the UncompressFileToMem method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
UncompressMemory Deprecated
bool UncompressMemory(CkByteData &inData, CkByteData &outData);

Decompresses an in-memory Gzip image and returns the uncompressed data as a byte array.

The uncompressed output is held in memory and must not exceed 4 GB.

Returns true for success, false for failure.

top
UncompressMemoryAsync Deprecated (1)
CkTaskW *UncompressMemoryAsync(CkByteData &inData);

Creates an asynchronous task to call the UncompressMemory method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
UncompressMemToFile Deprecated
bool UncompressMemToFile(CkByteData &inData, const wchar_t *destPath);

Decompresses an in-memory Gzip image and writes the uncompressed data to a file.

Returns true for success, false for failure.

top
UncompressMemToFileAsync Deprecated (1)
CkTaskW *UncompressMemToFileAsync(CkByteData &inData, const wchar_t *destPath);

Creates an asynchronous task to call the UncompressMemToFile method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
UncompressString Deprecated
bool UncompressString(CkByteData &inData, const wchar_t *inCharset, CkString &outStr);
const wchar_t *uncompressString(CkByteData &inData, const wchar_t *inCharset);

Decompresses Gzip-compressed data and returns the result as a string.

After decompression, the result is raw binary data (a sequence of bytes). These bytes are then interpreted as text using the specified character set (such as utf-8, iso-8859-1, etc.) to produce the final string.

Internally, Chilkat converts the byte sequence to a string by interpreting the bytes according to the specified character set. For example, if utf-8 is specified, the bytes are treated as the UTF-8 byte representation of text and decoded into the internal string format used by the programming language.

It is important that the character set matches the one originally used when the data was compressed. If the wrong character set is used, the byte-to-text conversion may produce incorrect or unreadable characters.

Returns true for success, false for failure.

More Information and Examples
top
UncompressStringAsync Deprecated (1)
CkTaskW *UncompressStringAsync(CkByteData &inData, const wchar_t *inCharset);

Creates an asynchronous task to call the UncompressString method with the arguments provided.

Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.

Note: The application is responsible for deleting (via the C++ delete operator) the object returned by this method.

Returns NULL on failure

top
WriteFile Deprecated
bool WriteFile(const wchar_t *path, CkByteData &binaryData);
This method is deprecated.

A convenience method for writing a binary byte array to a file.

Returns true for success, false for failure.

top