9n 2 d Z ddlmZ ddddZ dddZdS )z$Bits and bytes related humanization. )annotations)z kBz MBz GBz TBz PBz EBz ZBz YB)z KiBz MiBz GiBz TiBz PiBz EiBz ZiBz YiBKMGTPEZY)decimalbinarygnuF%.1fvaluefloat | strr boolr formatstrreturnc ` |rt d }n|rt d }n
t d }|s|rdnd}t | }t | }|dk r|sd|z S ||k r|sd|z S ||k r|rd |z S t | D ]\ }} ||d
z z }
||
k r n|||z |
z z | z }|S )aP Format a number of bytes like a human readable filesize (e.g. 10 kB).
By default, decimal suffixes (kB, MB) are used.
Non-GNU modes are compatible with jinja2's `filesizeformat` filter.
Examples:
```pycon
>>> naturalsize(3000000)
'3.0 MB'
>>> naturalsize(300, False, True)
'300B'
>>> naturalsize(3000, False, True)
'2.9K'
>>> naturalsize(3000, False, True, "%.3f")
'2.930K'
>>> naturalsize(3000, True)
'2.9 KiB'
>>> naturalsize(10**28)
'10000.0 YB'
>>> naturalsize(-4096, True)
'-4.0 KiB'
```
Args:
value (int, float, str): Integer to convert.
binary (bool): If `True`, uses binary suffixes (KiB, MiB) with base
210 instead of 103.
gnu (bool): If `True`, the binary argument is ignored and GNU-style
(`ls -sh` style) prefixes are used (K, M) with the 2**10 definition.
format (str): Custom formatter.
Returns:
str: Human readable representation of a filesize.
r r r i i z%d Bytez%d Bytesz%dB )suffixesfloatabs enumerate)r r r r suffixbasebytes_ abs_bytesisunitrets q/builddir/build/BUILD/imunify360-venv-2.6.0/opt/imunify360/venv/lib/python3.11/site-packages/humanize/filesize.pynaturalsizer
s T %% %(#)$,6,44D
5\\FFIA~~c~6!!4F""4Cv~&!! 1AtE -.2CJ N)FFr )
r r
r r r r r r
r r
)__doc__
__future__r r r r r r$ sl + * " " " " " " HN E E E E E E Er