
    tni                         d Z ddlZej        xZZej        Zej        Zej        Zej        Zej        ZedddfdZ	ej
        Z
ej        ZdS )zCFunctions to compress and decompress data using the Brotli library.    N      c                 |    t          ||||          }|                    |           |                                z   S )a  Compress a byte string.

    Args:
      string (bytes): The input data.
      mode (int, optional): The compression mode; value 0 should be used for
        generic input (MODE_GENERIC); value 1 might be beneficial for UTF-8 text
        input (MODE_TEXT); value 2 tunes encoder for WOFF 2.0 data (MODE_FONT).
        Defaults to 0.
      quality (int, optional): Controls the compression-speed vs compression-
        density tradeoff. The higher the quality, the slower the compression.
        Range is 0 to 11. Defaults to 11.
      lgwin (int, optional): Base 2 logarithm of the sliding window size. Range
        is 10 to 24. Defaults to 22.
      lgblock (int, optional): Base 2 logarithm of the maximum input block size.
        Range is 16 to 24. If set to 0, the value will be set based on the
        quality. Defaults to 0.

    Returns:
      The compressed byte string.

    Raises:
      brotli.error: If arguments are invalid, or compressor fails.
    )modequalitylgwinlgblock)
Compressorprocessfinish)stringr   r   r   r	   
compressors         C/var/www/html/gpu-tools/venv/lib/python3.11/site-packages/brotli.pycompressr      sF    0 we$+- - -Jf%%
(9(9(;(;;;    )__doc___brotli__version__versionMODE_GENERIC	MODE_TEXT	MODE_FONTr
   Decompressorr   
decompresserror r   r   <module>r      s    J I   + ++ #		 
 # '"a < < < <: 
 	r   