|
Server : Apache System : Linux server.mata-lashes.com 3.10.0-1160.90.1.el7.x86_64 #1 SMP Thu May 4 15:21:22 UTC 2023 x86_64 User : matalashes ( 1004) PHP Version : 8.1.29 Disable Function : NONE Directory : /proc/17567/root/usr/local/lib/python3.6/site-packages/idna/__pycache__/ |
Upload File : |
3
G�KdY � @ s� d Z ddlZddlmZmZ ee eedf d�dd�Zeeed�d d
�Zeeeef d�dd
�Zeeedf e d�dd�Z
dS )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_�returnc C s� t | �}g }d}xrtt|��D ]b}|d t|�k rL|| ||d d krLq||d |d � }|jt|d |d d �� |}qW t|�S )a Represent 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 ���r )�sorted�range�len�append�
_encode_range�tuple)r �sorted_list�ranges�
last_write�i�
current_range� r �./tmp/pip-build-8nxjc3nm/idna/idna/intranges.py�intranges_from_list s r )�start�endr c C s | d>