Skip to content
This repository has been archived by the owner on Jul 29, 2023. It is now read-only.

Latest commit

 

History

History
62 lines (40 loc) · 2.29 KB

ppmd8.rst

File metadata and controls

62 lines (40 loc) · 2.29 KB

Ppmd8 Objects

Ppmd8Encoder and Ppmd8Decoder classes are intend to use general purpose text compression.

Encoder for PPMd Variant I version 2.

.. py:method:: __init__(max_order: int, mem_size: int, restore_method: int)

    The ``max_order`` parameter is between 2 to 64.
    ``mem_size`` is a memory size in bytes which the encoder use.
    ``restore_method`` should be either ``PPMD8_RESTORE_METHOD_RESTART`` or
    ``PPMD8_RESTORE_METHOD_CUTOFF``.

.. method:: Ppmd8Encoder.encode(data: Union[bytes, bytearray, memoryview])

    compress data, returning a bytes object containing copressed data.
    This data should be concatenated to the output produced by any
    preceding calls to the encode().
    Some input may be kept in internal buffer for later processing.

.. method:: Ppmd8Encoder.flush(endmark: boolean)

    All pending input is processed, and bytes object containing the remaining
    compressed output is returned. After calling flush(), the encode() method
    cannot be called again; the only realistic action is to delete the object.
    flush() method releases some resource the object used.

    When ``endmark`` is true (default), flush write endmark(-1) to end of archive,
    otherwise do not write anything and just flush.

.. py:class:: Ppmd8Decoder

    Decoder for PPMd Variant I version 2.

.. py:method:: __init__(max_order: int, mem_size: int, restore_method)

    The ``max_order`` parameter is between 2 to 64.
    ``mem_size`` is a memory size in bytes which the encoder use.

    These parameters should as same as one when encode the data.

.. method:: Ppmd8Decoder.decode(data: Union[bytes, bytearray, memoryview], length: int)

   decode the given data and returns decoded data.
   When length is -1, maximum output data may be returned.

   If decoder got the end mark, decode() method automatically flush all data and close
   some resource. When reached to end mark, ``Ppmd8Decoder.eof`` member become True.

   When ``Ppmd8Decoder.needs_input`` is True, all input data is exhausted and
   need more input data to generate output. Otherwise, there are some data in internal
   buffer and reusable.

   The decoder may return data which size is smaller than specified length, that is
   because size of input data is not enough to decode.