HEX
Server: Apache/2.4.52 (Ubuntu)
System: Linux spn-python 5.15.0-89-generic #99-Ubuntu SMP Mon Oct 30 20:42:41 UTC 2023 x86_64
User: arjun (1000)
PHP: 8.1.2-1ubuntu2.20
Disabled: NONE
Upload Files
File: //lib/python3.12/unittest/__pycache__/util.cpython-312.pyc
�

<��f_���dZddlmZmZddlmZdZdZdZdZ	dZ
dZee	ezezeze
zz
Zedk\sJ�d�Z
d	�Zdd
�Zd�Zd�Zd
�Zd�Zedd�Zd�Zd�Zy)zVarious utility functions.�)�
namedtuple�Counter)�commonprefixT�P��c�n�t|�|z
|z
}|tkDrd|d|||t|�|z
dfz}|S)Nz%s[%d chars]%s)�len�_PLACEHOLDER_LEN)�s�	prefixlen�	suffixlen�skips    �$/usr/lib/python3.12/unittest/util.py�_shortenrsK���q�6�I��	�)�D������*�9�
�t�Q�s�1�v�	�7I�7J�5K�L�L���H�c�����ttt|��}ttt|��}|t
kr|St
|��t	���t
|�z
tztzz
}|tkDrIttztz|�z
zt
ksJ�t�t|��t��fd�|D��St�tt��t��fd�|D��S)Nc3�.�K�|]}�|�dz���y�w�N���.0r�prefixr
s  ��r�	<genexpr>z'_common_shorten_repr.<locals>.<genexpr>'s�����:�T��V�a�	�
�m�+�T�s�c3�T�K�|]}�t|�dtt�z���!y�wr)r�
_MIN_DIFF_LEN�_MIN_END_LENrs  ��rrz'_common_shorten_repr.<locals>.<genexpr>*s-����� ��Q��(�1�Y�Z�=�-��N�N��s�%()�tuple�map�	safe_repr�maxr
�_MAX_LENGTHr�_MIN_BEGIN_LENr�_MIN_COMMON_LENr)�args�maxlen�
common_lenrr
s   @@r�_common_shorten_reprr(s������Y��%�&�D�
��S�$��
 �F�
�����
�$�
�F��F��I���9�$�~�5�8H�H�J�J��O�#�� 0�0�?�B���"�$�&1�2�	2�2��&�.�*�=���:�T�:�:�:�
�f�n�o�
>�F�� �� � � rc��	t|�}|rt	|�t
kr|S|dt
dzS#t$rtj|�}Y�BwxYw)Nz [truncated]...)�repr�	Exception�object�__repr__r
r")�obj�short�results   rr r -sW��&��c����C��K�+�-��
��,�;��"3�3�3��	�&�����%��&�s�/�A�Ac�8�|j�d|j��S)N�.)�
__module__�__qualname__)�clss r�strclassr66s���n�n�c�&6�&6�7�7rc��dx}}g}g}		||}||}||kr-|j|�|dz
}|||k(ry|dz
}|||k(r�nj||kDr-|j|�|dz
}|||k(rG|dz
}|||k(r�n8|dz
}	|||k(r|dz
}|||k(r�|dz
}|||k(r|dz
}|||k(r�	��#|dz
}|||k(r|dz
}|||k(r�wwxYw#t$r.|j||d�|j||d�Y||fSwxYw)arFinds elements in only one or the other of two, sorted input lists.

    Returns a two-element tuple of lists.    The first list contains those
    elements in the "expected" list but not in the "actual" list, and the
    second contains those elements in the "actual" list but not in the
    "expected" list.    Duplicate elements in either input list are ignored.
    r�N)�append�
IndexError�extend)�expected�actual�i�j�missing�
unexpected�e�as        r�sorted_list_differencerD9s���
�I�A���G��J�
�	����A��q�	�A��1�u����q�!��Q����q�k�Q�&���F�A��q�k�Q�&��Q���!�!�!�$��Q����Q�i�1�n���F�A��Q�i�1�n��Q����"�1�+��*��Q���#�1�+��*���F�A� ��)�q�.��Q���!��)�q�.�+��(��F�A� ��)�q�.��Q���!��)�q�.���	��N�N�8�A�B�<�(����f�Q�R�j�)���J���		�sA�:C�1C�8C�?B2�C�0C�2C�C�C�1D
�	D
c��g}|r%|j�}	|j|�|r�%||fS#t$r|j|�Y�#wxYw)z�Same behavior as sorted_list_difference but
    for lists of unorderable items (like dicts).

    As it does a linear search per item (remove) it
    has O(n*n) performance.)�pop�remove�
ValueErrorr9)r<r=r@�items    r�unorderable_list_differencerJbsV���G�
��|�|�~��	!��M�M�$����F�?���	�	!��N�N�4� �	!�s�.�A�
Ac��||kD||kz
S)z.Return -1 if x < y, 0 if x == y and 1 if x > yr)�x�ys  r�
three_way_cmprNss��
��E�a�!�e��r�Mismatchzactual expected valuec�<�t|�t|�}}t|�t|�}}t�}g}t|�D]y\}}	|	|ur�dx}
}t	||�D]}|||	k(s�|
dz
}
|||<�t|�D]\}}
|
|	k(s�|dz
}|||<�|
|k7s�\t|
||	�}|j
|��{t|�D]N\}}	|	|ur�d}t	||�D]}|||	k(s�|dz
}|||<�td||	�}|j
|��P|S)�HReturns list of (cnt_act, cnt_exp, elem) triples where the counts differrr8)�listr
r,�	enumerate�range�	_Mismatchr9)r=r<r�t�m�n�NULLr0r>�elem�cnt_s�cnt_tr?�
other_elem�diffs               r�_count_diff_all_purposer_ysI����<��h��q�A��q�6�3�q�6�q�A��8�D�
�F��Q�<���4��4�<�������q�!��A���t�t�|���
����!���'�q�\�M�A�z��T�!���
����!��*��E�>��U�E�4�0�D��M�M�$�� � �Q�<���4��4�<�����q�!��A���t�t�|���
����!�����E�4�(���
�
�d�� ��Mrc�H�t|�t|�}}g}|j�D];\}}|j|d�}||k7s�t|||�}|j	|��=|j�D](\}}||vs�td||�}|j	|��*|S)rQr)r�items�getrUr9)	r=r<rrVr0rZr[r\r^s	         r�_count_diff_hashablerc�s����6�?�G�H�-�q�A�
�F��w�w�y���e����d�A����E�>��U�E�4�0�D��M�M�$��	!�
�w�w�y���e��q�=��Q��t�,�D��M�M�$��!��MrN)F)�__doc__�collectionsrr�os.pathr�
__unittestr"rr#rr$rrr(r r6rDrJrNrUr_rcrrr�<module>rhs��� �+� �
�
�������������!1�1�O�C� �!�#/�0�1�
������
� �*4�8�&�R�"�
�z�#:�;�	�!�Fr