Qt
Internal/Contributor docs for the Qt SDK. Note: These are NOT official API docs; those are found at https://doc.qt.io/
Loading...
Searching...
No Matches
QDecompressHelper Class Reference

#include <qdecompresshelper_p.h>

+ Collaboration diagram for QDecompressHelper:

Public Types

enum  ContentEncoding {
  None , Deflate , GZip , Brotli ,
  Zstandard
}
 

Public Member Functions

 QDecompressHelper ()=default
 
 ~QDecompressHelper ()
 
bool setEncoding (QByteArrayView contentEncoding)
 
bool isCountingBytes () const
 
void setCountingBytesEnabled (bool shouldCount)
 
qint64 uncompressedSize () const
 
bool hasData () const
 
void feed (const QByteArray &data)
 
void feed (QByteArray &&data)
 
void feed (const QByteDataBuffer &buffer)
 
void feed (QByteDataBuffer &&buffer)
 
qsizetype read (char *data, qsizetype maxSize)
 
bool isValid () const
 
void clear ()
 
void setDecompressedSafetyCheckThreshold (qint64 threshold)
 
QString errorString () const
 

Static Public Member Functions

static bool isSupportedEncoding (QByteArrayView encoding)
 
static QByteArrayList acceptedEncoding ()
 

Detailed Description

Definition at line 26 of file qdecompresshelper_p.h.

Member Enumeration Documentation

◆ ContentEncoding

Enumerator
None 
Deflate 
GZip 
Brotli 
Zstandard 

Definition at line 29 of file qdecompresshelper_p.h.

Constructor & Destructor Documentation

◆ QDecompressHelper()

QDecompressHelper::QDecompressHelper ( )
default

◆ ~QDecompressHelper()

QDecompressHelper::~QDecompressHelper ( )

Definition at line 85 of file qdecompresshelper.cpp.

Member Function Documentation

◆ acceptedEncoding()

QByteArrayList QDecompressHelper::acceptedEncoding ( )
static

Definition at line 75 of file qdecompresshelper.cpp.

◆ clear()

void QDecompressHelper::clear ( )

Definition at line 522 of file qdecompresshelper.cpp.

◆ errorString()

QString QDecompressHelper::errorString ( ) const

Returns a string describing the error that occurred or an empty string if no error occurred.

See also
isValid()

Definition at line 517 of file qdecompresshelper.cpp.

◆ feed() [1/4]

void QDecompressHelper::feed ( const QByteArray & data)

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

Definition at line 218 of file qdecompresshelper.cpp.

◆ feed() [2/4]

void QDecompressHelper::feed ( const QByteDataBuffer & buffer)

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

Definition at line 248 of file qdecompresshelper.cpp.

◆ feed() [3/4]

void QDecompressHelper::feed ( QByteArray && data)

Give data to the QDecompressHelper which will be stored until a read is attempted.

If isCountingBytes() is true then it will decompress immediately before discarding the data, but will count the uncompressed byte size.

Definition at line 232 of file qdecompresshelper.cpp.

◆ feed() [4/4]

void QDecompressHelper::feed ( QByteDataBuffer && buffer)

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

Definition at line 264 of file qdecompresshelper.cpp.

◆ hasData()

bool QDecompressHelper::hasData ( ) const

Returns true if there are encoded bytes left or there is some indication that the decoder still has data left internally.

Note
Even if this returns true the next call to read() might read 0 bytes. This most likely means the decompression is done.

Definition at line 479 of file qdecompresshelper.cpp.

◆ isCountingBytes()

bool QDecompressHelper::isCountingBytes ( ) const

Returns true if the QDecompressHelper is measuring the size of the decompressed data.

See also
setCountingBytesEnabled, uncompressedSize

Definition at line 162 of file qdecompresshelper.cpp.

◆ isSupportedEncoding()

bool QDecompressHelper::isSupportedEncoding ( QByteArrayView encoding)
static

Definition at line 70 of file qdecompresshelper.cpp.

◆ isValid()

bool QDecompressHelper::isValid ( ) const

Returns whether or not the object is valid. If it becomes invalid after an operation has been performed then an error has occurred.

See also
errorString()

Definition at line 506 of file qdecompresshelper.cpp.

◆ read()

qsizetype QDecompressHelper::read ( char * data,
qsizetype maxSize )

Definition at line 352 of file qdecompresshelper.cpp.

◆ setCountingBytesEnabled()

void QDecompressHelper::setCountingBytesEnabled ( bool shouldCount)

Enable or disable counting the decompressed size of the data based on shouldCount. Enabling this means the data will be decompressed twice (once for counting and once when data is being read).

Note
Can only be called before contentEncoding is set and data is fed to the object.
See also
isCountingBytes, uncompressedSize

Definition at line 180 of file qdecompresshelper.cpp.

◆ setDecompressedSafetyCheckThreshold()

void QDecompressHelper::setDecompressedSafetyCheckThreshold ( qint64 threshold)

Set the threshold required before the archive bomb detection kicks in. By default this is 10MB. Setting it to -1 is treated as disabling the feature.

Definition at line 429 of file qdecompresshelper.cpp.

◆ setEncoding()

bool QDecompressHelper::setEncoding ( QByteArrayView contentEncoding)

Definition at line 90 of file qdecompresshelper.cpp.

◆ uncompressedSize()

qint64 QDecompressHelper::uncompressedSize ( ) const

Returns the amount of uncompressed bytes left.

Note
Since this is only based on the data received so far the final size could be larger.
It is only valid to call this if isCountingBytes() returns true
See also
isCountingBytes, setCountBytes

Definition at line 202 of file qdecompresshelper.cpp.


The documentation for this class was generated from the following files: