add-determinism 0.7.3

RPM buildroot helper to strip nondeterministic bits in files
Documentation
�

��Vc�_cs0�dZddlZddlZddlZddlZddlZ	ddl
mZgd�Z
ddddd	�d
�Zddddd	�d�Zdd�d
�Zd�Zd�Zd�ZGd�d��Zd�ZGd�d��Zeeeeeeeed��h��Zd�Z dd�Z!d�Z"e#dkre!��dSdS)a/Support to pretty-print lists, tuples, & dictionaries recursively.

Very simple, but useful, especially in debugging data structures.

Classes
-------

PrettyPrinter()
    Handle pretty-printing operations onto a stream using a configured
    set of formatting parameters.

Functions
---------

pformat()
    Format a Python object into a pretty-printed representation.

pprint()
    Pretty-print a Python object to a stream [default is sys.stdout].

saferepr()
    Generate a 'standard' repr()-like value, but protect against recursive
    data structures.

�N)�StringIO)�pprint�pformat�
isreadable�isrecursive�saferepr�
PrettyPrinter�pp��PFT��compact�
sort_dicts�underscore_numbersc	s\�t|||||||���}|�|��dS)zAPretty-print a Python object to a stream [default is sys.stdout].)�stream�indent�width�depthrr
rN)rr)	�objectrrrrrr
rZprinter�	         �/usr/lib64/python3.11/pprint.pyrr0sC����f�E���J�-�/�/�/�G��N�N�6������csR�t||||||����|��S)z<Format a Python object into a pretty-printed representation.)rrrrr
r)rr)rrrrrr
r�       rrr9s8����e�5�!(�Z�,>�@�@�@�@G�����Pr)r
cs*�t|g|�Rd|i|��dS)zPretty-print a Python objectr
N)r)rr
ZargsZkwargss    rrr@s+��
�6�:�D�:�:�:�Z�:�6�:�:�:�:�:rcsV�t���|idd��dS)z=Version of repr() which can handle recursive data structures.Nr�r�
_safe_repr�r� rrrD�%���?�?�%�%�f�b�$��:�:�1�=�=rc�V�t���|idd��dS)z4Determine if saferepr(object) is readable by eval().Nrr	rrrrrrHrrcr)z8Determine if object requires a recursive representation.Nr�rrrrrrLrrcs$�eZdZdZdgZd�Zd�ZdS)�	_safe_keyaUHelper function for key functions when sorting unorderable objects.

    The wrapped-object will fallback to a Py2.x style comparison for
    unorderable types (sorting first comparing the type name and then by
    the obj ids).  Does not work recursively, so dict.items() must have
    _safe_key applied to both the key and the value.

    �objcs�||_dS�N)r )�selfr �  r�__init__z_safe_key.__init__\s
������rcs�	|j|jkS#t$rott|j����t	|j��ftt|j����t	|j��fkcYSwxYwr!)r Z	TypeError�str�type�id)r"Zotherr#r�__lt__z_safe_key.__lt___s���	;��8�e�i�'�'���	;�	;�	;���d�h���(�(�"�T�X�,�,�7���e�i���)�)�2�e�i�=�=�9�:�
;�
;�
;�	;���s��A6B�
BN)�__name__�
__module__�__qualname__�__doc__Z	__slots__r$r(�rrrrPsE����������I����;�;�;�;�;rrcsV�t|d��t|d��fS)z&Helper function for comparing 2-tuplesrr	)r)Ztrr�_safe_tupler.fs!���Q�q�T�?�?�I�a��d�O�O�+�+rcs��eZdZd%dddd�d�Zd�Zd	�Zd
�Zd�Zd�Zd
�Z	iZ
d�Zee
ej
<d�Zee
ejj
<d�Zee
ej
<d�Zee
ej
<d�Zee
ej
<ee
ej
<d�Zee
ej
<d�Zee
ej
<d�Zee
ej
<d�Zee
ej j
<d�Z!e!e
ej"j
<d�Z#d�Z$d�Z%d�Z&d�Z'd�Z(e(e
ej)j
<d�Z*e*e
ej+j
<d�Z,e,e
ej-j
<d �Z.e.e
ej/j
<d!�Z0e0e
ej1j
<d"�Z2e2e
ej3j
<d#�Z4e4e
ej5j
<d$�Z6dS)&rr	r
NFTrcs`�t|��}t|��}|dkrtd���|�|dkrtd���|std���||_||_||_|�||_ntj|_t|��|_	||_
||_dS)a�Handle pretty printing operations onto a stream using a set of
        configured parameters.

        indent
            Number of spaces to indent for each level of nesting.

        width
            Attempted maximum number of columns in the output.

        depth
            The maximum depth to print out nested structures.

        stream
            The desired output stream.  If omitted (or false), the standard
            output stream available at construction will be used.

        compact
            If true, several items will be combined in one line.

        sort_dicts
            If true, dict keys are sorted.

        rzindent must be >= 0Nzdepth must be > 0zwidth must be != 0)�intZ
ValueError�_depth�_indent_per_level�_width�_stream�_sysZstdout�bool�_compact�_sort_dicts�_underscore_numbers)r"rrrrrr
r�        rr$zPrettyPrinter.__init__ks���2�V�����E�
�
���A�:�	4��2�3�3�3��	2��!��	2��0�1�1�1��	3��1�2�2�2����!'�������	'�!�D�L�L��;�D�L��W�
�
��
�%���#5�� � � rcs��|j�;|�||jddid��|j�d��dSdS)Nr�
)r3�_format�write�r"rr#rrzPrettyPrinter.pprint�sP���<�	%��L�L����q�!�R��;�;�;��L���t�$�$�$�$�$�	%�	%rcsz�t��}|�||ddid��|���S�Nr)�	_StringIOr;Zgetvalue)r"rZsios   rrzPrettyPrinter.pformat�s5���k�k�����V�S�!�Q��A�.�.�.��|�|�~�~�rcs>�|�|idd��dS)Nrr��formatr=r#rrzPrettyPrinter.isrecursive�s���{�{�6�2�q�!�,�,�Q�/�/rcsD�|�|idd��\}}}|o|Sr>r@)r"rZs�readable�	recursive�     rrzPrettyPrinter.isreadable�s-��!%���V�R��A�!>�!>���8�Y��)�	�M�)rc
s��t|��}||vr2|�t|����d|_d|_dS|�|||��}|j|z
|z
}	t|��|	kr�|j�	t|��jd��}
|
�d||<|
|||||||dz��||=dStj
|��rpt|t��s[|jjrOt#|jd��r:d|jjjvr'd||<|�||||||dz��||=dS|�|��dS)NTFr	�__wrapped__Z
__create_fn__)r'r<�
_recursion�
_recursive�	_readable�_reprr2�len�	_dispatchZgetr&�__repr__�_dataclassesZis_dataclassZ
isinstanceZ__dataclass_params__�reprZhasattrrEr+�_pprint_dataclass)r"rrr�	allowance�context�level�objid�rep�	max_width�p�           rr;zPrettyPrinter._format�s����6�
�
���G��	��L�L��F�+�+�,�,�,�"�D�O�"�D�N��F��j�j���%�0�0���K�&�(�9�4�	��s�8�8�i��	���"�"�4��<�<�#8�$�?�?�A��
�!"������$����	�7�E�A�I�N�N�N��E�N����+�F�3�3�	
� ���.�.�	
��-�2�	
��&�/�=�9�9�		
�
"�V�_�%@�%M�M�	
�"#�����&�&�v�v�v�y�'�SX�[\�S\�]�]�]��E�N������S�����rcs���jj}|t|��dzz
}�fd�tj���D��}|�|dz��|�||||||��|�d��dS)Nr	csV��g|]%}|j�	|jt�|j��f��&Sr-)rNZname�getattr)Z.0Zfrs  �rz
<listcomp>z3PrettyPrinter._pprint_dataclass.<locals>.<listcomp>�s5���b�b�b�q�[\�[a�b�!�&�'�&�!�&�1�1�2�b�b�br�(�))�	__class__r)rJrMZfieldsr<�_format_namespace_items�	r"rrrrPrQrRZcls_name�itemss	 `       rrOzPrettyPrinter._pprint_dataclass�s�����#�,���#�h�-�-�!�#�#��b�b�b�b�L�<O�PV�<W�<W�b�b�b�����X��^�$�$�$��$�$�U�F�F�I�w�PU�V�V�V����S�����rcsf�|j}|d��|jdkr||jdz
dz��t|��}|ra|jr)t	|���t���}	n|���}	|�|	|||dz||��|d��dS)N�{r	� ��key�})r<r1rJr7�sortedr^r.�_format_dict_items)
r"rrrrPrQrRr<Zlengthr^�
          r�_pprint_dictzPrettyPrinter._pprint_dict�s������
��c�
�
�
��!�A�%�	6��E�4�)�A�-��4�5�5�5��V�����	4���
'��v�|�|�~�~�;�?�?�?����������#�#�E�6�6�9�q�=�$+�U�
4�
4�
4�
��c�
�
�
�
�
rcs��t|��s$|�t|����dS|j}|�|jdz��|�t
|�����||t|j��zdz|dz||��|�d��dS)NrYr	rZ)rJr<rNr[r)r;�listr^)r"rrrrPrQrR�clsr9r�_pprint_ordered_dictz"PrettyPrinter._pprint_ordered_dict�s����6�{�{�	��L�L��f���&�&�&��F�������S�\�C�'�(�(�(����T�&�,�,�.�.�)�)�6��c�#�,�/�/�/�!�3�Y��]��e�	%�	%�	%�	���S�����rcs��|�d��|�||||dz||��|�d��dS)N�[r	z])r<�
_format_items�r"rrrrPrQrRrr�_pprint_listzPrettyPrinter._pprint_list�sU�����S�������6�6�6�9�q�=�"�E�	+�	+�	+����S�����rc	s��|�d��t|��dkrdnd}|�||||t|��z||��|�|��dS)NrYr	z,)rZ)r<rJrl)r"rrrrPrQrR�endcharr9r�
_pprint_tuplezPrettyPrinter._pprint_tuple�su�����S�����f�+�+��*�3�$�$������6�6�6�9�s�7�|�|�3K�"�E�	+�	+�	+����W�����rc	s��t|��s$|�t|����dS|j}|tur|�d��d}n9|�|jdz��d}|t|j��dzz
}t
|t���}|�||||t|��z||��|�|��dS)Nr_rc�({�})r	ra)	rJr<rNr[�setr)rdrrl)	r"rrrrPrQrR�typrorr�_pprint_setzPrettyPrinter._pprint_set�s����6�{�{�	��L�L��f���&�&�&��F�����#�:�	,��L�L������G�G��L�L����,�-�-�-��G��c�#�,�'�'�!�+�+�F���I�.�.�.�����6�6�6�9�s�7�|�|�3K�"�E�	+�	+�	+����W�����rcs|�|j}t|��s|t|����dSg}|�d��}	|dkr
|dz
}|dz
}|j|z
x}
}t|	��D�]L\}}
t|
��}|t|	��dz
kr|
|z}
t|��|
kr|�|���Ytjd|
��}|sJ�|drJ�|�	��|}d}t|��D]�\}}||z}|t|��dz
kr|t|	��dz
kr||z}tt|����|kr'|r"|�t|����|}��|}��|r"|�t|������Nt|��dkr
||��dS|dkr|d��t|��D]'\}}|dkr|dd	|zz��||���(|dkr
|d
��dSdS)NTr	z\S*\s*i�����rYrr:r`rZ)
r<rJrNZ
splitlinesr2�	enumerate�append�reZfindallZpop)r"rrrrPrQrRr<ZchunksZlinesZ
max_width1rU�iZlinerTZpartsZ
max_width2�currentZj�part�	candidates                     r�_pprint_strzPrettyPrinter._pprint_strs�������6�{�{�	��E�$�v�,�,�����F����!�!�$�'�'���A�:�	��a�K�F���N�I�!%��v�!5�5�
�Y� ��'�'�	1�	1�G�A�t��t�*�*�C��C��J�J��N�"�
(��i�'�
��3�x�x�:�%�
1��
�
�c�"�"�"�"��
�9�d�3�3������ ��9�$�$�$��	�	����&�
���(��/�/�	,�	,�G�A�t� '�$��I��C��J�J��N�*�0�q�C��J�J��N�/B�0�"�i�/�
��4�	�?�?�+�+�j�8�,�"�9�"�M�M�$�w�-�-�8�8�8�"&���"+����1��M�M�$�w�-�-�0�0�0���v�;�;�!��	��E�#�J�J�J��F��A�:�	��E�#�J�J�J���'�'�	�	�F�A�s��1�u�
)���d�S��Z�'�(�(�(��E�#�J�J�J�J��A�:�	��E�#�J�J�J�J�J�	�	rcsB�|j}t|��dkr|t|����dS|dk}|r|dz
}|dz
}|d��d}	t||j|z
|��D]"}
||	��||
��|	sdd|zz}	�#|r
|d��dSdS)N�r	rYrvr:r`rZ)r<rJrN�_wrap_bytes_reprr2)r"rrrrPrQrRr<Zparens�delimrTrWr�
_pprint_byteszPrettyPrinter._pprint_bytesDs�������v�;�;�!��	��E�$�v�,�,�����F��!����	��a�K�F���N�I��E�#�J�J�J���#�F�D�K�&�,@�)�L�L�	*�	*�C��E�%�L�L�L��E�#�J�J�J��
*��s�6�z�)����	��E�#�J�J�J�J�J�	�	rc	s��|j}|d��|�t|��||dz|dz||dz��|d��dS)Nz
bytearray(i
r	rZ)r<r��bytes)r"rrrrPrQrRr<r9r�_pprint_bytearrayzPrettyPrinter._pprint_bytearrayYsa�����
��l�������5��=�=�&�&�2�+�$�q�=�'�5�1�9�	>�	>�	>�
��c�
�
�
�
�
rcs��|�d��|�|���||dz|dz||��|�d��dS)Nz
mappingproxy(i
r	rZ)r<r;�copyrmrr�_pprint_mappingproxyz"PrettyPrinter._pprint_mappingproxybs_�����_�%�%�%����V�[�[�]�]�F�F�R�K��Q���e�	%�	%�	%����S�����rcsD�t|��tjurd}n|jj}|t|��dzz
}|j���}|�|dz��|�	||||||��|�d��dS)NZ	namespacer	rYrZ)
r&�_types�SimpleNamespacer[r)rJZ__dict__r^r<r\r]rr�_pprint_simplenamespacez%PrettyPrinter._pprint_simplenamespacejs�����<�<�6�1�1�	1�#�H�H��'�0�H��#�h�-�-�!�#�#����%�%�'�'�����X��^�$�$�$��$�$�U�F�F�I�w�PU�V�V�V����S�����rc	sn�|j}||jz
}dd|zz}t|��dz
}	t|��D]y\}
\}}|
|	k}
|�|||��}||��|d��|�|||t|��zdz|
r|nd||��|
s||���zdS)N�,
r`r	�: r)r<r1rJrwrIr;)r"r^rrrPrQrRr<�delimnl�
last_indexrzrb�ent�lastrTs               rrez PrettyPrinter._format_dict_itemsys�������$�(�(���#��,�&����Z�Z�!�^�
�&�u�-�-�		�		�M�A�z��S��
�?�D��*�*�S�'�5�1�1�C��E�#�J�J�J��E�$�K�K�K��L�L��f�f�s�3�x�x�&7�!�&;�&*�1���� �%�
)�
)�
)��
���g�����		�		rc	sf�|j}dd|zz}t|��dz
}	t|��D]\}
\}}|
|	k}
||��|d��t|��|vr|d��n1|�|||t|��zdz|
r|nd||��|
s||����dS)Nr�r`r	z=�...)r<rJrwr'r;)r"r^rrrPrQrRr<r�r�rzrbr�r�s              rr\z%PrettyPrinter._format_namespace_items�s�������#��,�&����Z�Z�!�^�
�&�u�-�-�
	�
	�M�A�z��S��
�?�D��E�#�J�J�J��E�#�J�J�J��#�w�w�'�!�
-���e��������S�&�&�3�s�8�8�*;�a�*?�*.�5�Y�Y�A�$�e�-�-�-��
���g�����
	�
	rcs��|j}||jz
}|jdkr||jdz
dz��dd|zz}d}	|j|z
dzx}
}t|��}	t	|��}
n#t
$rYdSwxYwd}|s�|
}	t	|��}
n#t
$rd}||z}|
|z}
YnwxYw|jrY|�|||��}t|��dz}|
|kr|}
|	r|}	|
|kr|
|z}
||	��d}	||����||	��|}	|�	||||r|nd||��|��dSdS)	Nr	r`r�rvFTr�, )
r<r1r2ZiterZnextZ
StopIterationr6rIrJr;)r"r^rrrPrQrRr<r�r�rrUZitZnext_entr�r�rTZws                  rrlzPrettyPrinter._format_items�s�������$�(�(���!�A�%�	6��E�4�)�A�-��4�5�5�5��#��,�&���� �K�&�0�1�4�4��	�
�%�[�[��	��B�x�x�H�H���	�	�	��F�F�	�������	)��C�
#���8�8���� �
#�
#�
#����Y�&�	���"����
#�����}�
��j�j��g�u�5�5����H�H�q�L���1�9�(�%�E��(� '���A�:���Q�J�E��E�%�L�L�L� �E��E�#�J�J�J���E�%�L�L�L��E��L�L��f�f�&*�1���� �%�
)�
)�
)�/�	)�	)�	)�	)�	)s$�A,�,
A:�9A:�B�B-�,B-cs��|�||���|j|��\}}}|sd|_|rd|_|S)NFT)rAr�r0rHrG)r"rrQrRrNrBrCrrrIzPrettyPrinter._repr�sT��$(�K�K�������04��U�%D�%D�!��h�	��	#�"�D�N��	#�"�D�O��rcs2�|�||||��S)z�Format object for a specific context, returning a string
        and flags indicating whether the representation is 'readable'
        and whether the object represents a recursive construct.
        )r)r"rrQ�	maxlevelsrRrDrrAzPrettyPrinter.format�s��
���v�w�	�5�A�A�Arcs��t|��s$|�t|����dS|�|j||��}|j}|t|j��dzz
}|�|j�d|�dd|z����|�||||dz||��|�d��dS)Nr	rYr�r`rZ)rJr<rNrIZdefault_factoryr[r)rg)	r"rrrrPrQrRZrdfrirr�_pprint_default_dictz"PrettyPrinter._pprint_default_dict�s����6�{�{�	��L�L��f���&�&�&��F��j�j��/��%�@�@������#�c�l�#�#�a�'�'�����S�\�\�\�3�3�3��f���E�F�F�F����&�&�&�)�a�-��%�P�P�P����S�����rcs��t|��s$|�t|����dS|j}|�|jdz��|jdkr |�|jdz
dz��|���}|�|||t|j��zdz|dz||��|�d��dS)Nrqr	r`rrr)rJr<rNr[r)r1Zmost_commonre)	r"rrrrPrQrRrir^rr�_pprint_counterzPrettyPrinter._pprint_counter�s����6�{�{�	��L�L��f���&�&�&��F�������S�\�D�(�)�)�)��!�A�%�	=��L�L�$�0�1�4��;�<�<�<��"�"�$�$������v� &��S�\�):�):� :�Q� >�	�A�
� '��	0�	0�	0�	���T�����rc	s,�t|j��s$|�t|����dS|j}|�|jdz��|t|j��dzz
}t
|j��D]�\}}	|t|j��dz
kr3|�|	|||dz||��|�d���S|�|	||d||��|�dd|zz����dS)NrYr	rZr�r`)rJZmapsr<rNr[r)rwr;)
r"rrrrPrQrRrirzZmrfr�_pprint_chain_mapzPrettyPrinter._pprint_chain_map�s���6�;���	��L�L��f���&�&�&��F�������S�\�C�'�(�(�(��#�c�l�#�#�a�'�'���f�k�*�*�	3�	3�D�A�q��C���$�$�q�(�(�
3����Q���	�A�
�w��N�N�N����S�!�!�!�!����Q����7�E�B�B�B����U�S�6�\�1�2�2�2�2�
	3�	3rcs2�t|��s$|�t|����dS|j}|�|jdz��|t|j��dzz
}|�d��|j�4|�||||dz||��|�d��dS|�|||d||��|�|j||��}|�dd|z�d|�d	���dS)
NrYr	rkrz])z],
r`zmaxlen=rZ)rJr<rNr[r)ZmaxlenrlrI)	r"rrrrPrQrRriZrmlrr�
_pprint_dequezPrettyPrinter._pprint_deques,���6�{�{�	��L�L��f���&�&�&��F�������S�\�C�'�(�(�(��#�c�l�#�#�a�'�'�����S�����=�	C����v�v�v�y�1�}�&��
/�
/�
/��L�L����������v�v�v�q�&��
/�
/�
/��*�*�V�]�G�U�;�;�C��L�L�L�s�V�|�|�|�S�S�S�A�B�B�B�B�Brc	�J�|�|j|||||dz
��dS�Nr	�r;Zdatarmrr�_pprint_user_dictzPrettyPrinter._pprint_user_dict�*�����V�[�&�&�)�W�e�a�i�P�P�P�P�Prc	r�r�r�rmrr�_pprint_user_listzPrettyPrinter._pprint_user_listr�rc	r�r�r�rmrr�_pprint_user_stringz!PrettyPrinter._pprint_user_string"r�rcs��t|��}|tvrt|��ddfSt|dd��}t	|t
��r.|t
jur |jr|d�ddfSt|��ddfSt	|t���r|tju�r
|sdSt|��}|r
||krdd||vfS||vrt|��ddfSd||<d}d}	g}
|
j}|dz
}|jr)t|���t���}n|���}|D]Y\}
}|�|
|||��\}}}|�||||��\}}}||�d	|����|o|o|}|s|rd}	�Z||=d
d�|
��z||	fSt	|t$��r|t$jus#t	|t&��r�|t&jur�t	|t$��r|sdSd
}nt)|��dkrd}n|sdSd}t|��}|r||kr
|dzd||vfS||vrt|��ddfSd||<d}d}	g}
|
j}|dz
}|D]1}|�||||��\}}}||��|sd}|rd}	�2||=|d�|
��z||	fSt|��}||o|�d��dfS)NTFrLZ_d)z{}TFz{...}r	rar�z{%s}r�)z[]TFz[%s]z(%s,))z()TFz(%s)r�z<)r&�_builtin_scalarsrNrXZ
issubclassr/rLr8�dictr'rFrxr7rdr^r.rAZjoinrh�tuplerJZ
startswith)r"rrQr�rRrtZrrSrBrCZ
componentsrxr^ZkZvZkreprZ	kreadableZkrecurZvreprZ	vreadableZvrecurrAZoZoreprZ	oreadableZorecurrTs                           rrzPrettyPrinter._safe_repr's����6�l�l���"�"�	-���<�<��u�,�,��C��T�*�*���c�3���	1�A���$5�	1��'�
1� �~�~�t�U�2�2��F�|�|�T�5�0�0��c�4� � �	G�Q�$�-�%7�	G��
)�(�(��v�J�J�E��
8�U�i�/�
8���u��'7�7�7����
7�!�&�)�)�5�$�6�6��G�E�N��H��I��J��&�F��Q�J�E���
'��v�|�|�~�~�;�?�?�?����������
%�
%���1�+/�;�;��w�	�5�,2�,2�(��y�&�+/�;�;��w�	�5�,2�,2�(��y�&���5�5�5�%�%�0�1�1�1�#�?�	�?�i���%�V�%� $�I������D�I�I�j�1�1�1�8�Y�F�F��s�D�!�!� 	G�a�4�=�&8� 	G��s�E�"�"� 	G�'(�E�N�':� 	G��#�t�$�$�	
 ��-�,�,�����V����!�
 � ����-�,�,����v�J�J�E��
?�U�i�/�
?���~�u�e�w�.>�>�>����
7�!�&�)�)�5�$�6�6��G�E�N��H��I��J��&�F��Q�J�E��
%�
%��+/�;�;��w�	�5�,2�,2�(��y�&���u�
�
�
� �%�$�H��%� $�I������D�I�I�j�1�1�1�8�Y�F�F��6�l�l���S�4�����!4�!4�4�u�<�<r)r	r
NN)7r)r*r+r$rrrrr;rOrKrgr�rLrj�_collectionsZOrderedDictrnrhrpr�rurs�	frozensetr~r%r�r�r��	bytearrayr�r�ZMappingProxyTyper�r�rer\rlrIrAr�Zdefaultdictr�ZCounterr�ZChainMapr�Zdequer�ZUserDictr�ZUserListr�Z
UserStringrr-rrrrjs6������*6��4�E�*6�*6�*6�*6�*6�X%�%�%�
���
0�0�0�*�*�*����8����I�
�
�
� ,�I�d�m��	�	�	�4H�I�l�&�/�0���� ,�I�d�m�����!.�I�e�n�����"*�I�c�l��$/�I�i� �!�/�/�/�b*�I�c�l�����&!.�I�e�n�����%6�I�i� �!����3G�I�f�%�.�/����2I�I�f�$�-�.����"���&')�')�')�R���B�B�B�	�	�	�4H�I�l�&�/�0����0?�I�l�"�+�,�
3�
3�
3�1B�I�l�#�,�-�C�C�C�$.;�I�l� �)�*�Q�Q�Q�1B�I�l�#�,�-�Q�Q�Q�1B�I�l�#�,�-�Q�Q�Q�3F�I�l�%�.�/�O=�O=�O=�O=�O=rrcsR�dt|��j�dt|���d�S)Nz<Recursion on z	 with id=z>)r&r)r'rrrrFrF{s,����F�|�|�$�$�$�b��j�j�j�j�
2�3rcsl�ddl}|�ddddgddd�fgd	z}t��}|���}|�|iddd
��|���}|�|��|���}td||z
��td||z
��dS)
NrZstring)r	ririi)iii��Tz_safe_repr:zpformat:)�timerZperf_counterrrZprint)rr�rVZt1Zt2Zt3s      r�
_perfcheckr��s����K�K�K�
�E��V�a��V��q�\�\�:�;�f�D�����A�	
�	�	�	�	�B��L�L���T�1�d�+�+�+�	
�	�	�	�	�B��I�I�f����	
�	�	�	�	�B�	�-��b��!�!�!�	�*�b�2�g�����rc#sNK�d}t|��dzdz}tdt|��d��D]W}|||dz�}||z}||kr||z}tt|����|kr|rt|��V�|}�U|}�X|rt|��V�dSdS)Nrrr)rJZrangerN)rrrPr{r�rzr|r}r9rr�r��s������G��v�;�;�!��a��D�
�1�c�&�k�k�1�
%�
%�
 �
 ���a��1��f�~���d�N�	���9�	��Y��E��t�I�����%�'�	 ��
$��7�m�m�#�#�#��G�G��G�G����7�m�m�������rZ__main__)Nr	r
N)r	r
Nr!)$r,Zcollectionsr�ZdataclassesrMryZsysr4Ztypesr�Ziorr?Z__all__rrrrrrrr.rr�r%r�r�ZfloatZcomplexr5r&r�rFr�r�r)r-rr�<module>r�s�����4#�"�"�"�"�"�"�"�	�	�	�	���������$�$�$�$�$�$�"�"�"����T�e������P��d�u�P�P�P�P�P�"'�;�;�;�;�;�>�>�>�>�>�>�>�>�>�;�;�;�;�;�;�;�;�,,�,�,�L=�L=�L=�L=�L=�L=�L=�L=�\�9�c�5�)�U�G�"�D�D��J�J�0�1�1��3�3�3�
�������"�z����J�L�L�L�L�L��r