# Copyright 2016 The Brotli Authors. All rights reserved. # # Distributed under MIT license. # See file LICENSE for detail or copy at https://opensource.org/licenses/MIT """Functions to compress and decompress data using the Brotli library.""" import _brotli # The library version. version = __version__ = _brotli.__version__ # The compression mode. MODE_GENERIC = _brotli.MODE_GENERIC MODE_TEXT = _brotli.MODE_TEXT MODE_FONT = _brotli.MODE_FONT # The Compressor object. Compressor = _brotli.Compressor # The Decompressor object. Decompressor = _brotli.Decompressor # Compress a byte string. def compress(string, mode=MODE_GENERIC, quality=11, lgwin=22, lgblock=0): """Compress a byte string. Args: string (bytes): The input data. mode (int, optional): The compression mode can be MODE_GENERIC (default), MODE_TEXT (for UTF-8 format text input) or MODE_FONT (for WOFF 2.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. """ compressor = Compressor(mode=mode, quality=quality, lgwin=lgwin, lgblock=lgblock) return compressor.process(string) + compressor.finish() # Decompress a compressed byte string. decompress = _brotli.decompress # Raised if compression or decompression fails. error = _brotli.error