Source code for fastcrc.crc32

"""
Compute a CRC-32 checksum of data.
"""
from typing import Optional

from .fastcrc import crc_32_aixm as _crc_32_aixm
from .fastcrc import crc_32_autosar as _crc_32_autosar
from .fastcrc import crc_32_base91_d as _crc_32_base91_d
from .fastcrc import crc_32_bzip2 as _crc_32_bzip2
from .fastcrc import crc_32_cd_rom_edc as _crc_32_cd_rom_edc
from .fastcrc import crc_32_cksum as _crc_32_cksum
from .fastcrc import crc_32_iscsi as _crc_32_iscsi
from .fastcrc import crc_32_iso_hdlc as _crc_32_iso_hdlc
from .fastcrc import crc_32_jamcrc as _crc_32_jamcrc
from .fastcrc import crc_32_mpeg_2 as _crc_32_mpeg_2
from .fastcrc import crc_32_xfer as _crc_32_xfer
from .fastcrc import (
    crc_32_k_reversed_reciprocal_refin as _crc_32_k_reversed_reciprocal_refin,
)

__always_supported = (
    "aixm",
    "autosar",
    "base91_d",
    "bzip2",
    "cd_rom_edc",
    "cksum",
    "iscsi",
    "iso_hdlc",
    "jamcrc",
    "mpeg_2",
    "xfer",
)

algorithms_guaranteed = set(__always_supported)
algorithms_available = set(__always_supported)


[docs] def aixm(data: bytes, initial: Optional[int] = None) -> int: """ Compute a CRC-32 checksum of data with the `aixm` algorithm. Algorithm parameters: - ploy: 0x814141ab - init: 0x00000000 - xorout: 0x00000000 - refin: False - refout: False :param bytes data: The data to be computed :param Optional[int] initial: The optional starting value of the checksum :return: The checksum :rtype: int :raises TypeError: if the data is not a bytes-like object """ return _crc_32_aixm(data, initial)
[docs] def autosar(data: bytes, initial: Optional[int] = None) -> int: """ Compute a CRC-32 checksum of data with the `autosar` algorithm. Algorithm parameters: - ploy: 0xf4acfb13 - init: 0xffffffff - xorout: 0xffffffff - refin: True - refout: True :param bytes data: The data to be computed :param Optional[int] initial: The optional starting value of the checksum :return: The checksum :rtype: int :raises TypeError: if the data is not a bytes-like object """ return _crc_32_autosar(data, initial)
[docs] def base91_d(data: bytes, initial: Optional[int] = None) -> int: """ Compute a CRC-32 checksum of data with the `base91 d` algorithm. Algorithm parameters: - ploy: 0xa833982b - init: 0xffffffff - xorout: 0xffffffff - refin: True - refout: True :param bytes data: The data to be computed :param Optional[int] initial: The optional starting value of the checksum :return: The checksum :rtype: int :raises TypeError: if the data is not a bytes-like object """ return _crc_32_base91_d(data, initial)
[docs] def bzip2(data: bytes, initial: Optional[int] = None) -> int: """ Compute a CRC-32 checksum of data with the `bzip2` algorithm. Algorithm parameters: - ploy: 0x04c11db7 - init: 0xffffffff - xorout: 0xffffffff - refin: False - refout: False :param bytes data: The data to be computed :param Optional[int] initial: The optional starting value of the checksum :return: The checksum :rtype: int :raises TypeError: if the data is not a bytes-like object """ return _crc_32_bzip2(data, initial)
[docs] def cd_rom_edc(data: bytes, initial: Optional[int] = None) -> int: """ Compute a CRC-32 checksum of data with the `cd rom edc` algorithm. Algorithm parameters: - ploy: 0x8001801b - init: 0x00000000 - xorout: 0x00000000 - refin: True - refout: True :param bytes data: The data to be computed :param Optional[int] initial: The optional starting value of the checksum :return: The checksum :rtype: int :raises TypeError: if the data is not a bytes-like object """ return _crc_32_cd_rom_edc(data, initial)
[docs] def cksum(data: bytes, initial: Optional[int] = None) -> int: """ Compute a CRC-32 checksum of data with the `cksum` algorithm. Algorithm parameters: - ploy: 0x04c11db7 - init: 0x00000000 - xorout: 0xffffffff - refin: False - refout: False :param bytes data: The data to be computed :param Optional[int] initial: The optional starting value of the checksum :return: The checksum :rtype: int :raises TypeError: if the data is not a bytes-like object """ return _crc_32_cksum(data, initial)
[docs] def iscsi(data: bytes, initial: Optional[int] = None) -> int: """ Compute a CRC-32 checksum of data with the `iscsi` algorithm. Algorithm parameters: - ploy: 0x1edc6f41 - init: 0xffffffff - xorout: 0xffffffff - refin: True - refout: True :param bytes data: The data to be computed :param Optional[int] initial: The optional starting value of the checksum :return: The checksum :rtype: int :raises TypeError: if the data is not a bytes-like object """ return _crc_32_iscsi(data, initial)
[docs] def iso_hdlc(data: bytes, initial: Optional[int] = None) -> int: """ Compute a CRC-32 checksum of data with the `iso hdlc` algorithm. Algorithm parameters: - ploy: 0x04c11db7 - init: 0xffffffff - xorout: 0xffffffff - refin: True - refout: True :param bytes data: The data to be computed :param Optional[int] initial: The optional starting value of the checksum :return: The checksum :rtype: int :raises TypeError: if the data is not a bytes-like object """ return _crc_32_iso_hdlc(data, initial)
[docs] def jamcrc(data: bytes, initial: Optional[int] = None) -> int: """ Compute a CRC-32 checksum of data with the `jamcrc` algorithm. Algorithm parameters: - ploy: 0x04c11db7 - init: 0xffffffff - xorout: 0x00000000 - refin: True - refout: True :param bytes data: The data to be computed :param Optional[int] initial: The optional starting value of the checksum :return: The checksum :rtype: int :raises TypeError: if the data is not a bytes-like object """ return _crc_32_jamcrc(data, initial)
[docs] def mpeg_2(data: bytes, initial: Optional[int] = None) -> int: """ Compute a CRC-32 checksum of data with the `mpeg 2` algorithm. Algorithm parameters: - ploy: 0x04c11db7 - init: 0xffffffff - xorout: 0x00000000 - refin: False - refout: False :param bytes data: The data to be computed :param Optional[int] initial: The optional starting value of the checksum :return: The checksum :rtype: int :raises TypeError: if the data is not a bytes-like object """ return _crc_32_mpeg_2(data, initial)
[docs] def xfer(data: bytes, initial: Optional[int] = None) -> int: """ Compute a CRC-32 checksum of data with the `xfer` algorithm. Algorithm parameters: - ploy: 0x000000af - init: 0x00000000 - xorout: 0x00000000 - refin: False - refout: False :param bytes data: The data to be computed :param Optional[int] initial: The optional starting value of the checksum :return: The checksum :rtype: int :raises TypeError: if the data is not a bytes-like object """ return _crc_32_xfer(data, initial)
[docs] def k_reversed_reciprocal_refin(data: bytes, initial: Optional[int] = None) -> int: """ Compute a CRC-32 checksum of data with the `k reversed reciprocal refin` algorithm. **This method may be removed in the future.** Algorithm parameters: - ploy: 0xba0dc66b - init: 0x00000000 - xorout: 0x00000000 - refin: True - refout: False :param bytes data: The data to be computed :param Optional[int] initial: The optional starting value of the checksum :return: The checksum :rtype: int :raises TypeError: if the data is not a bytes-like object """ return _crc_32_k_reversed_reciprocal_refin(data, initial)