class KCodecs

A collection of commonly used encoding and decoding algorithms. More...

Definition#include <kmdcodec.h>
List of all Methods
Annotated List
Files
Globals
Hierarchy
Index

Public Static Methods


Detailed Description

A wrapper class for the most commonly used encoding and decoding algorithms. Currently there is support for encoding and decoding input using base64, uu and the quoted-printable specifications.

Usage:


 QCString input = "Aladdin:open sesame";
 QCString result = KCodecs::base64Encode(input);
 cout << "Result: " << result.data() << endl;

 Output should be
 Result: QWxhZGRpbjpvcGVuIHNlc2FtZQ==

The above example makes use of the convenience functions (ones that accept/return null-terminated strings) to encode/decode a string. If what you need is to encode or decode binary data, then it is highly recommended that you use the functions that take an input and output QByteArray as arguments. These functions are specifically tailored for encoding and decoding binary data.

QCString  quotedPrintableEncode (const QByteArray & in, bool useCRLF = true)

quotedPrintableEncode

[static]

Encodes the given data using the quoted-printable algorithm.

Parameters:
indata to be encoded.
useCRLFif true the input data is expected to have CRLF line breaks and the output will have CRLF line breaks, too.

Returns: quoted-printable encoded data.

QCString  quotedPrintableEncode (const QCString & str, bool useCRLF = true)

quotedPrintableEncode

[static]

@overload

Same as above except it accepts a null terminated string instead an array.

Parameters:
strdata to be encoded.
useCRLFif true the input data is expected to have CRLF line breaks and the output will have CRLF line breaks, too.

Returns: quoted-printable encoded data.

void  quotedPrintableEncode (const QByteArray & in, QByteArray& out, bool useCRLF)

quotedPrintableEncode

[static]

Encodes the given data using the quoted-printable algorithm.

Use this function if you want the result of the encoding to be placed in another array which cuts down the number of copy operation that have to be performed in the process. This is also the preferred method for encoding binary data.

NOTE: the output array is first reset and then resized appropriately before use, hence, all data stored in the output array will be lost.

Parameters:
indata to be encoded.
outdecoded data.
useCRLFif true the input data is expected to have CRLF line breaks and the output will have CRLF line breaks, too.

Returns: quoted-printable encoded data.

QCString  quotedPrintableDecode (const QByteArray & in)

quotedPrintableDecode

[static]

Decodes a quoted-printable encoded string.

Accepts data with CRLF or standard unix line breaks.

Parameters:
inthe data to be decoded.

Returns: decoded data.

QCString  quotedPrintableDecode (const QCString & str)

quotedPrintableDecode

[static]

@overload

Same as above except it accepts a null terminated string instead an array.

Parameters:
strthe data to be decoded.

Returns: decoded data.

void  quotedPrintableDecode (const QByteArray & in, QByteArray& out)

quotedPrintableDecode

[static]

Decodes a quoted-printable encoded data.

Accepts data with CRLF or standard unix line breaks. Use this function if you want the result of the decoding to be placed in another array which cuts down the number of copy operation that have to be performed in the process. This is also the preferred method for decoding an encoded binary data.

NOTE: the output array is first reset and then resized appropriately before use, hence, all data stored in the output array will be lost.

Parameters:
indata to be encoded.
outdecoded data.

Returns: quoted-printable encoded data.

QCString  uuencode ( const QByteArray& in )

uuencode

[static]

Encodes the given data using the uuencode algorithm.

The output is split into lines starting with the number of encoded octets in the line and ending with a newline. No line is longer than 45 octets (60 characters), excluding the line terminator.

Parameters:
inthe data to be uuencoded

Returns: a uuencoded data.

QCString  uuencode ( const QCString& str )

uuencode

[static]

@overload

Same as the above functions except it accepts a null terminated string instead an array.

Parameters:
strthe string to be uuencoded.

Returns: the encoded string.

void  uuencode ( const QByteArray& in, QByteArray& out )

uuencode

[static]

Encodes the given data using the uuencode algorithm.

Use this function if you want the result of the encoding to be placed in another array and cut down the number of copy operation that have to be performed in the process. This is the preffered method for encoding binary data.

NOTE: the output array is first reset and then resized appropriately before use, hence, all data stored in the output array will be lost.

Parameters:
inthe data to be uuencoded.
outthe container for the uudecoded data.

QCString  uudecode ( const QByteArray& in )

uudecode

[static]

Decodes the given data using the uuencode algorithm.

Any 'begin' and 'end' lines like those generated by the utilities in unix and unix-like OS will be automatically ignored.

Parameters:
inthe data uuencoded data to be decoded.

Returns: a decoded string.

QCString  uudecode ( const QCString& str )

uudecode

[static]

@overload

Same as the above functions except it accepts a null terminated string instead an array.

Parameters:
strthe string to be decoded.

Returns: a uudecoded string.

void  uudecode ( const QByteArray& in, QByteArray& out )

uudecode

[static]

Decodes the given data using the uudecode algorithm.

Use this function if you want the result of the decoding to be placed in another array which cuts down the number of copy operation that have to be performed in the process. This is the preferred method for decoding binary data.

Any 'begin' and 'end' lines like those generated by the utilities in unix and unix-like OS will be automatically ignored.

NOTE: the output array is first reset and then resized appropriately before use, hence, all data stored in the output array will be lost.

Parameters:
inthe uuencoded-data to be decoded.
outthe container for the uudecoded data.

QCString  base64Encode ( const QByteArray& in, bool insertLFs = false)

base64Encode

[static]

Encodes the given data using the base64 algorithm.

The boolean argument determines if the encoded data is going to be restricted to 76 characters or less per line as specified by RFC 2045. If insertLFs is true, then there will be 76 characters or less per line.

Parameters:
inthe data to be encoded.
insertLFslimit the number of characters per line.

Returns: a base64 encoded string.

QCString  base64Encode ( const QCString& str, bool insertLFs = false )

base64Encode

[static]

@overload

Same as the above functions except it accepts a null terminated string instead an array.

Parameters:
strthe string to be encoded.
insertLFslimit the number of characters per line.

Returns: the decoded string.

void  base64Encode ( const QByteArray& in, QByteArray& out, bool insertLFs = false )

base64Encode

[static]

Encodes the given data using the base64 algorithm.

Use this function if you want the result of the encoding to be placed in another array which cuts down the number of copy operation that have to be performed in the process. This is also the preferred method for encoding binary data.

The boolean argument determines if the encoded data is going to be restricted to 76 characters or less per line as specified by RFC 2045. If insertLFs is true, then there will be 76 characters or less per line.

NOTE: the output array is first reset and then resized appropriately before use, hence, all data stored in the output array will be lost.

Parameters:
inthe data to be encoded using base64.
outthe container for the encoded data.
insertLFslimit the number of characters per line.

QCString  base64Decode ( const QByteArray& in )

base64Decode

[static]

Decodes the given data that was encoded using the base64 algorithm.

Parameters:
inthe base64-encoded data to be decoded.

Returns: the decoded data.

QCString  base64Decode ( const QCString& str )

base64Decode

[static]

@overload

Same as the above functions except it accepts a null terminated string instead an array.

Parameters:
strthe base64-encoded string.

Returns: the decoded string.

void  base64Decode ( const QByteArray& in, QByteArray& out )

base64Decode

[static]

Decodes the given data that was encoded with the base64 algorithm.

Use this function if you want the result of the decoding to be placed in another array which cuts down the number of copy operation that have to be performed in the process. This is also the preferred method for decoding an encoded binary data.

NOTE: the output array is first reset and then resized appropriately before use, hence, all data stored in the output array will be lost.

Parameters:
inthe encoded data to be decoded.
outthe container for the decoded data.