%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /usr/lib/python3/dist-packages/idna/__pycache__/
Upload File :
Create Path :
Current File : //usr/lib/python3/dist-packages/idna/__pycache__/intranges.cpython-312.pyc

�

��=fY���dZddlZddlmZmZdeedeedffd�Zded	edefd
�Zdedeeeffd�Zd
edeedfde	fd�Z
y)a	
Given a list of integers, made up of (hopefully) a small number of long runs
of consecutive integers, compute a representation of the form
((start1, end1), (start2, end2) ...). Then answer the question "was x present
in the original list?" in time O(log(# runs)).
�N)�List�Tuple�list_�return.c��t|�}g}d}tt|��D]V}|dzt|�kr||||dzdz
k(r�&||dz|dz}|jt	|d|ddz��|}�Xt|�S)aRepresent a list of integers as a sequence of ranges:
    ((start_0, end_0), (start_1, end_1), ...), such that the original
    integers are exactly those x such that start_i <= x < end_i for some i.

    Ranges are encoded as single integers (start << 32 | end), not as tuples.
    ����r)�sorted�range�len�append�
_encode_range�tuple)r�sorted_list�ranges�
last_write�i�
current_ranges      �0/usr/lib/python3/dist-packages/idna/intranges.py�intranges_from_listrs�����-�K�
�F��J�
�3�{�#�
$����Q�3��[�!�!��1�~��Q�q�S�!1�!�!3�3��#�J�q�L��1��5�
��
�
�m�M�!�$4�m�B�6G�!�6K�L�M��
�
���=���start�endc��|dz|zS)N� �)rrs  rrr s���R�K�3��r�rc��|dz	|dzfS)Nrl��r)rs r�
_decode_ranger#s��
��G�q�M�*�+�+r�int_rc���t|d�}tj||�}|dkDr!t||dz
�\}}||cxkr|kry|t	|�krt||�\}}||k(ryy)z=Determine if `int_` falls into one of the ranges in `ranges`.rr	TF)r�bisect�bisect_leftrr)r r�tuple_�pos�left�right�_s       r�intranges_containr)'s���
�4��
#�F�
�
�
�V�V�
,�C��Q�w�#�F�3�q�5�M�2���e��4��%��� ��S��[����s��,���a��4�<��r)�__doc__r"�typingrr�intrrr�boolr)rrr�<module>r.s�������t�C�y��U�3��8�_��*���3��3��,�S�,�U�3��8�_�,��C���s�C�x���T�r

Zerion Mini Shell 1.0