B `c@sLdZddlZeedddZd eeedddZed krHddlZedS) zNData transformation functions. From bytes to a number, number to bytes, etc. N) raw_bytesreturncCstj|dddS)zConverts a list of bytes or an 8-bit string to an integer. When using unicode strings, encode it to some encoding like UTF8 first. >>> (((128 * 256) + 64) * 256) + 15 8405007 >>> bytes2int(b'\x80@\x0f') 8405007 bigF)signed)int from_bytes)rr4/tmp/pip-target-ywh1gcq3/lib/python/rsa/transform.py bytes2ints r )number fill_sizercCsL|dkrtd|tdt|d}|dkr@||dS||dS)a Convert an unsigned integer to bytes (big-endian):: Does not preserve leading zeros if you don't specify a fill size. :param number: Integer value :param fill_size: If the optional fill size is given the length of the resulting byte string is expected to be the fill size and will be padded with prefix zero bytes to satisfy that length. :returns: Raw bytes (base-256 representation). :raises: ``OverflowError`` when fill_size is given and the number takes up more bytes than fit into the block. This requires the ``overflow`` argument to this function to be set to ``False`` otherwise, no error will be raised. rz&Number must be an unsigned integer: %dr) ValueErrormaxmathceil bit_lengthto_bytes)r r Zbytes_requiredrrr int2bytes%s   r__main__)r) __doc__rbytesrr r__name__doctesttestmodrrrr s