????

Your IP : 3.138.178.145


Current Path : /opt/cloudlinux/venv/lib/python3.11/site-packages/_pytest/__pycache__/
Upload File :
Current File : //opt/cloudlinux/venv/lib/python3.11/site-packages/_pytest/__pycache__/pathlib.cpython-311.pyc

�

�܋f�d��x�ddlZddlZddlZddlZddlZddlZddlZddlZddl	Z	ddl
Z
ddlZddlm
Z
ddlmZddlmZddlmZddlmZddlmZddlmZdd	lmZdd
lmZddlmZddlmZdd
lmZddlmZddl	mZddl m!Z!ddl m"Z"ddl m#Z#ddl m$Z$ddl m%Z%ddl m&Z&ddl m'Z'ddl m(Z(ddl m)Z)ddl m*Z*ddl m+Z+ddl,m-Z-ddl.m/Z/ddl0m1Z1dZ2e*de���Z3eeeefZ4d Z5d!�Z6d"e3d#e3fd$�Z7d"e8d%e+e9e(e)e9e9e&e	j:ffd&ed#e;fd'�Z<d"ed#efd(�Z=d"e8d#e8fd)�Z>d"ed#dfd*�Z?d+ed,e8d#e$efd-�Z@d.e#ed,e8d#e$e8fd/�ZAd+ed,e8d#e$e8fd0�ZBd#eCfd1�ZDd+ed2e+e8efd3e+e8efd#dfd4�ZEdld+ed,e8d6eCd#efd7�ZFd8ed#efd9�ZGejHfd:efd;�ZId"ed#dfd<�ZJd"ed=eKd#e;fd>�ZLd"ed=eKd#dfd?�ZMd+ed,e8d@eCd#e$efdA�ZNd+efdB�ZOd+ed,e8d@eCd=eKd#df
dC�ZPd+ed,e8d@eCdDeKd6eCd#efdE�ZQdFe8dGed#efdH�ZRdIe8d"e+e8dJfd#e;fdK�ZSdLe8d#e'e8fdM�ZTdN�ZUGdO�dPe
��ZVGdQ�dReW��ZXeVjYdS�d8e+e8dJfd6e+e8eVfd+ed#efdT�ZZej[�\dU��rdVe8dWe8d#e;fdX�Z]n
dVe8dWe8d#e;fdY�Z]d"ed+ed#e8fdZ�Z^d[e"e8efd\e8d#dfd]�Z_d"ed#e&efd^�Z`d"e+e8dJfd#e%d_fd`�Zad"e+e8dJfdae!d_ge;fd#e$d_fdb�Zbd"e+ee8fd#efdc�Zcddedeed#e&efdf�Zddgedhed#e8fdi�Zedjed2ed#dfdk�ZfdS)m�N)�Enum)�EBADF)�ELOOP)�ENOENT)�ENOTDIR)�partial)�
expanduser)�
expandvars)�isabs)�sep)�Path)�PurePath)�
ModuleType)�Callable)�Dict)�Iterable)�Iterator)�List)�Optional)�Set)�Tuple)�Type)�TypeVar)�Union)�assert_never)�skip)�
PytestWarningi���_AnyPurePath)�bound)�i�c�b�t|dd��tvpt|dd��tvS)N�errno�winerror)�getattr�_IGNORED_ERRORS�_IGNORED_WINERRORS)�	exceptions �`/builddir/build/BUILD/cloudlinux-venv-1.0.6/venv/lib/python3.11/site-packages/_pytest/pathlib.py�
_ignore_errorr);s6���	�7�D�)�)�_�<�	F��9�j�$�/�/�3E�E���path�returnc�,�|�d��S)Nz.lock)�joinpath�r+s r(�
get_lock_pathr0Bs���=�=��!�!�!r*�excinfo�
start_pathc���t|t��r|}n|d}t|t��rdSt|t��s9t	jt
d|�dt|���d|������dS|tj	tj
tjfvrU|tjfvrDt	jt
d�
||t|��|������dSddl�d	td
df�fd�}t!|��}|���r*|jD]"}|t|����||krn�#|t|����||��dS)
zhHandle known read-only errors during rmtree.

    The returned value is used only by our own tests.
    �Fz(rm_rf) error removing �
z: z4(rm_rf) unknown function {} when removing {}:
{}: {}rN�pr,c���tj|��j}tj||�jz�jz��dS�N)�os�stat�st_mode�chmod�S_IRUSR�S_IWUSR)r6�moder:s  �r(�chmod_rwz on_rm_rf_error.<locals>.chmod_rwrs9����w�q�z�z�!��
���D�4�<�'�$�,�6�7�7�7�7�7r*T)�
isinstance�
BaseException�FileNotFoundError�PermissionError�warnings�warnr�typer9�rmdir�remove�unlink�open�formatr:�strr
�is_file�parents)	�funcr+r1r2�excr@r6�parentr:s	        @r(�on_rm_rf_errorrSFs�����'�=�)�)������a�j���#�(�)�)���u��c�?�+�+���
��N�D�N�N�D��I�I�N�N��N�N�O�O�	
�	
�	
��u��B�H�b�i���3�3�3����z�!�!��M��K�R�R��d�D��I�I�s�����
�
�
��u��K�K�K�8�C�8�D�8�8�8�8�8�8�	
�T�
�
�A��y�y�{�{���i�	�	�F��H�S��[�[�!�!�!���#�#���$��H�S��Y�Y�����D��J�J�J��4r*c��tj�d��r=|���}t	tt
|������}|S)a0Get the extended-length version of a path (Windows).

    On Windows, by default, the maximum length of a path (MAX_PATH) is 260
    characters, and operations on paths longer than that fail. But it is possible
    to overcome this by converting the path to "extended-length" form before
    performing the operation:
    https://docs.microsoft.com/en-us/windows/win32/fileio/naming-a-file#maximum-path-length-limitation

    On Windows, this function returns the extended-length absolute version of path.
    On other platforms it returns path unchanged.
    �win32)�sys�platform�
startswith�resolver
�get_extended_length_path_strrMr/s r(�ensure_extended_length_pathr[�sJ���|���w�'�'�=��|�|�~�~���0��T���;�;�<�<���Kr*c��d}d}|�||f��r|S|�d��r
||dd�zS||zS)z1Convert a path to a Windows extended length path.z\\?\z\\?\UNC\z\\�N)rX)r+�long_path_prefix�unc_long_path_prefixs   r(rZrZ�s`�� ��)�����(�*>�?�@�@�������v���/�#�d�1�2�2�h�.�.��d�"�"r*c��t|��}tt|���}tjdkr%tjt|��|���dStjt|��|���dS)zNRemove the path contents recursively, even if some elements
    are read-only.)r2)��)�onexc)�onerrorN)r[rrSrV�version_info�shutil�rmtreerM)r+rds  r(�rm_rfrh�ss��'�t�,�,�D��n��6�6�6�G�
��7�"�"��
�c�$�i�i�w�/�/�/�/�/�/��
�c�$�i�i��1�1�1�1�1�1r*�root�prefixc#�K�|���}|���D]2}|j����|��r|V��3dS)zGFind all elements in root that begin with the prefix, case insensitive.N)�lower�iterdir�namerX)rirj�l_prefix�xs    r(�
find_prefixedrq�s^�����|�|�~�~�H�
�\�\�^�^�����6�<�<�>�>�$�$�X�.�.�	��G�G�G���r*�iterc#�TK�t|��}|D]}|j|d�V��dS)z�Return the parts of the paths following the prefix.

    :param iter: Iterator over path names.
    :param prefix: Expected prefix of the path names.
    N)�lenrn)rrrj�p_lenr6s    r(�extract_suffixesrv�sE����
��K�K�E�
�����f�U�V�V�n������r*c�>�tt||��|��S)z+Combine find_prefixes and extract_suffixes.)rvrq)rirjs  r(�
find_suffixesrx�s���M�$��7�7��@�@�@r*c�D�	t|��S#t$rYdSwxYw)z0Parse number path suffixes, returns -1 on error.���)�int�
ValueError)�	maybe_nums r(�	parse_numr~�s5����9�~�~��������r�r����s��
��target�link_toc���|�|��}	|���n#t$rYnwxYw	|�|��dS#t$rYdSwxYw)aHelper to create the current symlink.

    It's full of race conditions that are reasonably OK to ignore
    for the context of best effort linking to the latest test run.

    The presumption being that in case of much parallelism
    the inaccuracy is going to be acceptable.
    N)r.rJ�OSError�
symlink_to�	Exception)rirr��current_symlinks    r(�_force_symlinkr��s����m�m�F�+�+�O�
���� � � � ���
�
�
���
����
��"�"�7�+�+�+�+�+���
�
�
����
���s�,�
9�9�A�
A"�!A"�r?c
��td��D]�}tttt	||����d���}|dz}|�|�|����}	|�|���t||dz|��|cS#t$rY��wxYwtd�
||������)	zKCreate a directory with an increased number as suffix for the given prefix.�
rz��defaultr4�r?�currentzKcould not create numbered dir with prefix {prefix} in {root} after 10 tries)rjri)�range�max�mapr~rxr.�mkdirr�r�r�rL)rirjr?�i�max_existing�
new_number�new_paths       r(�make_numbered_dirr��s���
�2�Y�Y�
�
���3�y�-��f�*E�*E�F�F�PR�S�S�S��!�A�%�
��=�=�F�!8�J�!8�!8�9�9��	��N�N��N�%�%�%�
�4��)�!3�X�>�>�>��O�O�O��	�	�	�	��D�	�����
0�06��f�4��0P�0P�
�
�	
s�#B�
B�Br6c��t|��}	tjt|��tjtjztjzd��}tj��}t|�����}tj	||��tj
|��|���std���|S#t$r}td|����|�d}~wwxYw)z2Create a lock to prevent premature folder cleanup.i�z/lock path got renamed after successful creationzcannot create lockfile in N)r0r9rKrM�O_WRONLY�O_CREAT�O_EXCL�getpid�encode�write�closerNr��FileExistsError)r6�	lock_path�fd�pid�spid�es      r(�create_cleanup_lockr��s����a� � �I��
�W�S��^�^�R�[�2�:�%=��	�%I�5�
Q�
Q���i�k�k���3�x�x��� � ��
���T����
������� � �"�"�	M��K�L�L�L�����?�?�?��6�1�6�6�7�7�Q�>�����?���s�AC�
C<�$C7�7C<r�c�l�tj��}||fdtdtddfd�}||��S)zFRegister a cleanup function for removing a lock, by default on atexit.r��original_pidr,Nc��tj��}||krdS	|���dS#t$rYdSwxYwr8)r9r�rJr�)r�r��current_pids   r(�cleanup_on_exitz6register_cleanup_lock_removal.<locals>.cleanup_on_exits\���i�k�k���,�&�&��F�	�����������	�	�	��D�D�	���s�3�
A�A)r9r�r
r{)r��registerr�r�s    r(�register_cleanup_lock_removalr�
sS��
�)�+�+�C�*3����4��3��QU������8�O�$�$�$r*c��t|��}d}	t|��}|j}|�dt	j������}|�|��t|��n;#t$r.Y|�(	|�	��dS#t$rYdSwxYwdSwxYw	|�(	|�	��dS#t$rYdSwxYwdS#|�&	|�	��w#t$rYwwxYwwxYw)z^Remove a numbered directory if its lock can be obtained and it does
    not seem to be in use.Nzgarbage-)
r[r�rRr.�uuid�uuid4�renamerhr�rJ)r+r�rR�garbages    r(�maybe_delete_a_numbered_dirr�sy��'�t�,�,�D��I��'��-�-�	�����/�/�";�T�Z�\�\�";�";�<�<�����G����
�g����������
	�� �
�� � �"�"�"�"�"���
�
�
����
����!� �����	�� �
�� � �"�"�"�"�"���
�
�
����
����!� ��9� �
�� � �"�"�"�"���
�
�
���
����!���sr�A#A7�6C�7
B/�C�B�
B)�(B)�.B/�/C�6C�
C�C�D	�#C8�7D	�8
D�D	�D�D	�$consider_lock_dead_if_created_beforec��|���rdSt|��}	|���sdSn#t$rYdSwxYw	|���j}||krGt
jt��5|���	ddd��dS#1swxYwYdS#t$rYdSwxYw)zGCheck if `path` is deletable based on whether the lock file is expired.FTN)
�
is_symlinkr0rNr�r:�st_mtime�
contextlib�suppressrJr�)r+r��lock�	lock_times    r(�ensure_deletabler�7s4���������u�����D���|�|�~�~�	��4�	�������u�u�����
��I�I�K�K�(�	��;�;�;�
�$�W�-�-�
�
����
�
�
��
�
�
�
�
�
�
�
�
�
�
�
����
�
�
�
��u�������u�u����s3�>�
A�A�B8�B+�+B/�2B/�8
C�Cc�H�t||��rt|��dSdS)z8Try to cleanup a folder if we can ensure it's deletable.N)r�r�)r+r�s  r(�try_cleanupr�Ss3����B�C�C�*�#�D�)�)�)�)�)�*�*r*�keepc	#�LK�tttt||����d���}||z
}t	||��}tj|��\}}ttt||����}t||��D]\}}	|	|kr|V��dS)zIList candidates for numbered directories to be removed - follows py.path.rzr�N)	r�r�r~rxrq�	itertools�teerv�zip)
rirjr�r��
max_delete�paths�paths2�numbersr+�numbers
          r(�cleanup_candidatesr�Ys������s�9�m�D�&�&A�&A�B�B�B�O�O�O�L���$�J��$��'�'�E��M�%�(�(�M�E�6��)�-�f�f�=�=�>�>�G��E�7�+�+�����f��Z����J�J�J���r*c���|���D]P}|���r:|������s|����QdSr8)rmr�rY�existsrJ)ri�left_dirs  r(�cleanup_dead_symlinksr�esh���L�L�N�N�"�"����� � �	"��#�#�%�%�,�,�.�.�
"����!�!�!��"�"r*c���|���sdSt|||��D]}t||���|�d��D]}t||���t	|��dS)z-Cleanup for lock driven numbered directories.Nz	garbage-*)r�r�r��globr�)rirjr�r�r+s     r(�cleanup_numbered_dirr�ls����;�;�=�=����"�4���6�6�@�@���D�>�?�?�?�?��	�	�+�&�&�@�@���D�>�?�?�?�?��$�����r*�lock_timeoutc�L�d}td��D]�}	t|||��}|dkrt|��}t|��|���j|z
}	t
jt||||	��|cS#t$r}
|
}Yd}
~
��d}
~
wwxYw|�J�|�)z>Create a numbered dir with a cleanup lock and remove old ones.Nr�r)
r�r�r�r�r:r��atexitr�r�r�)rirjr�r�r?r�r�r6r�r�rQs           r(�make_numbered_dir_with_cleanupr�zs���	
�A�
�2�Y�Y����	�!�$���5�5�A��q�y�y�/��2�2�	�-�i�8�8�8�45�6�6�8�8�3D�|�3S�0��O�$����4�
�
�
��H�H�H���	�	�	��A�A�A�A�A�A�����	����
�=�=�=�
�Gs�5B�
B�B�B�input�rootpathc��t|��}t|��}t|��rt|��S|�|��Sr8)r	r
rr
r.)r�r�s  r(�resolve_from_strr��sJ���u���E��u���E��U�|�|�(��E�{�{��� � ��'�'�'r*�patternzos.PathLike[str]c��t|��}tj�d��}|r2t|vr)t
|vr |�t
t��}t|vr|j}nSt|��}|�	��r0tj�|��sdtj�|��}tj
||��S)a�A port of FNMatcher from py.path.common which works with PurePath() instances.

    The difference between this algorithm and PurePath.match() is that the
    latter matches "**" glob expressions for each part of the path, while
    this algorithm uses the whole path instead.

    For example:
        "tests/foo/bar/doc/test_foo.py" matches pattern "tests/**/doc/test*.py"
        with this algorithm, but not with PurePath.match().

    This algorithm was ported to keep backward-compatibility with existing
    settings which assume paths match according this logic.

    References:
    * https://bugs.python.org/issue29249
    * https://bugs.python.org/issue34731
    �win�*)rrVrWrXr�	posix_sep�replacernrM�is_absoluter9r+r�fnmatch)r�r+�iswin32rns    r(�
fnmatch_exr��s���$�D�>�>�D��l�%�%�e�,�,�G��2�3�g�%�%�)�w�*>�*>��/�/�)�S�1�1��
�'����y����4�y�y�������	,�b�g�m�m�G�&<�&<�	,�+�"�&�+�'�+�+�G��?�4��)�)�)r*�sc���|�t����fd�tt�����D��S)Nc�\��h|](}tj�d|dz���pt��)S)Nr4)r�join)�.0r��partss  �r(�	<setcomp>zparts.<locals>.<setcomp>�s4���G�G�G��C�H�U�7�Q��U�7�^�$�$�+��G�G�Gr*)�splitrr�rt)r�r�s @r(r�r��s:���
�G�G�C�L�L�E�G�G�G�G�U�3�u�:�:�5F�5F�G�G�G�Gr*c��	tjt|��t|��fi|��dS#t$r}t	d|����Yd}~dSd}~wwxYw)zDMake a symlink, or skip the test in case symlinks are not supported.zsymlinks not supported: N)r9�symlinkrMr�r)�src�dst�kwargsr�s    r(�symlink_or_skipr��s{��-�
�
�3�s�8�8�S��X�X�0�0��0�0�0�0�0���-�-�-��
+��
+�
+�,�,�,�,�,�,�,�,�,�����-���s�-1�
A�A�Ac��eZdZdZdZdZdZdS)�
ImportModez6Possible values for `mode` parameter of `import_path`.�prepend�append�	importlibN)�__name__�
__module__�__qualname__�__doc__r�r�r��r*r(r�r��s#������@�@��G�
�F��I�I�Ir*r�c��eZdZdZdS)�ImportPathMismatchErroraRaised on import_path() if there is a mismatch of __file__'s.

    This can happen when `import_path` is called multiple times with different filenames that has
    the same basename but reside in packages
    (for example "/tests1/test_foo.py" and "/tests2/test_foo.py").
    N)r�r�r�r�r�r*r(r�r��s���������r*r�r�c�z�t|��}t|��}|���st|���|tjur�t||��}tjD]/}|�|t|j
��g��}|�n.�0tj�|t|����}|�td|�d|�����tj�
|��}|tj|<|j�|��t#tj|��|St%|��}|�w|j
}	t'|�d���|	��j��}
|
ddkr|
���d�|
��}n|j
}	|j}|tjurHt|	��tjvr,tj�t|	����nn|tjurQt|	��tjdkr-tj�dt|	����nt=|��t	j|��tj|}|j d	kr|StBj"�#d
d��}|dkr�|j$}|�tK|||���|�&d��r
|dd�}|�&tBj'd	z��r%|dtQtBj'd	z���}	tSt|��|��}
n#tT$rd
}
YnwxYw|
stK|||���|S)a�Import and return a module from the given path, which can be a file (a module) or
    a directory (a package).

    The import mechanism used is controlled by the `mode` parameter:

    * `mode == ImportMode.prepend`: the directory containing the module (or package, taking
      `__init__.py` files into account) will be put at the *start* of `sys.path` before
      being imported with `importlib.import_module`.

    * `mode == ImportMode.append`: same as `prepend`, but the directory will be appended
      to the end of `sys.path`, if not already in `sys.path`.

    * `mode == ImportMode.importlib`: uses more fine control mechanisms provided by `importlib`
      to import the module, which avoids having to muck with `sys.path` at all. It effectively
      allows having same-named test modules in different places.

    :param root:
        Used as an anchor when mode == ImportMode.importlib to obtain
        a unique name for the module being imported so it can safely be stored
        into ``sys.modules``.

    :raises ImportPathMismatchError:
        If after importing the given `path` and the module `__file__`
        are different. Only raised in `prepend` and `append` modes.
    NzCan't find module z
 at location �rz�__init__�.r�__init__.py�PY_IGNORE_IMPORTMISMATCH�1)z.pycz.pyoF)+r�r
r��ImportErrorr��module_name_from_pathrV�	meta_path�	find_specrMrR�util�spec_from_file_location�module_from_spec�modules�loader�exec_module�insert_missing_modules�resolve_package_path�list�with_suffix�relative_tor��popr��stemr�r+r��insertr�
import_modulernr9�environ�get�__file__r��endswithrrt�_is_samerC)r6r?rir+�module_name�
meta_importer�spec�mod�pkg_path�pkg_root�names�ignore�module_file�is_sames              r(�import_pathr%�sp��>�d���D���7�7�D��;�;�=�=� ��$�����z�#�#�#�+�D�$�7�7�� �]�	R�	R�M� �*�*�;��T�[�9I�9I�8J�K�K�D����� ��>�9�9�+�s�4�y�y�Q�Q�D��<��S�;�S�S�T�S�S�T�T�T��n�-�-�d�3�3��#&���K� ������$�$�$��s�{�K�8�8�8��
�#�D�)�)�H����?���T�%�%�b�)�)�5�5�h�?�?�E�F�F����9�
�"�"��I�I�K�K�K��h�h�u�o�o����;���i��
�z� � � ��x�=�=���(�(��H�O�O�C��M�M�*�*�*��	
��#�	#�	#��x�=�=�C�H�Q�K�'�'��H�O�O�A�s�8�}�}�-�-�-���T����
��K�(�(�(�

�+�k�
"�C��y�M�!�!��
�
�Z�^�^�6��
;�
;�F�
��}�}��l����)�+�{�D�I�I�I���� 0�1�1�	+�%�c�r�c�*�K������� 6�7�7�	H�%�&F�#�b�f�}�.D�*E�*E�(F�&F�G�K�	��s�4�y�y�+�6�6�G�G�� �	�	�	��G�G�G�	�����	J�)�+�{�D�I�I�I��Js�8N�N%�$N%r��f1�f2c��t|��t|��kptj�||��Sr8)r
r9r+�samefile�r&r's  r(rrUs0���B�x�x�4��8�8�#�?�r�w�'7�'7��B�'?�'?�?r*c�B�tj�||��Sr8)r9r+r)r*s  r(rrZs���w����B�'�'�'r*c���|�d��}	|�|��}|j}n#t$r|jdd�}YnwxYwd�|��S)z�
    Return a dotted module name based on the given path, anchored on root.

    For example: path="projects/src/tests/test_foo.py" and root="/projects", the
    resulting module name will be "src.tests.test_foo".
    r�r4Nr�)rrr�r|r�)r+ri�
relative_path�
path_partss    r(rr^s������B���D�)��(�(��.�.�
�#�(�
�
��
�$�$�$��Z����^�
�
�
�$�����8�8�J���s�4�A�Ar
rc�6�|�d��}|r�||vrO	tjst�t	j|��n&#t$rt
|d���}|||<YnwxYw|�d��d�|��}|�dSdS)aM
    Used by ``import_path`` to create intermediate modules when using mode=importlib.

    When we want to import a module as "src.tests.test_foo" for example, we need
    to create empty modules "src" and "src.tests" after inserting "src.tests.test_foo",
    otherwise "src.tests.test_foo" is not importable by ``__import__``.
    r�z6Empty module created by pytest's importmode=importlib.)�docrzN)	r�rVr�ModuleNotFoundErrorr�rrrr�)r
r�module_parts�modules    r(r
r
ss����$�$�S�)�)�L�
�-��g�%�%�

.�
�}�.�-�-��'��4�4�4�4��&�
.�
.�
.�#��P�����(.���$�$�$�
.����	��������h�h�|�,�,��#�-�-�-�-�-s�'A� A(�'A(c��d}tj|f|j��D]\}|���rF|�d�����sn|j���sn|}�]|S)z�Return the Python package path by looking for the last
    directory upwards which still contains an __init__.py.

    Returns None if it can not be determined.
    Nr)r��chainrO�is_dirr.rNrn�isidentifier)r+�resultrRs   r(rr�s����F��/�4�'�4�<�8�8�����=�=�?�?�	��?�?�=�1�1�9�9�;�;�
����;�+�+�-�-�
����F���Mr*zos.DirEntry[str]c�@�g}tj|��5}|D]T}	|���n'#t$r}t	|��rYd}~�6�d}~wwxYw|�|���U	ddd��n#1swxYwY|�d����|S)z`Scan a directory recursively, in breadth-first order.

    The returned entries are sorted.
    Nc��|jSr8)rn��entrys r(�<lambda>zscandir.<locals>.<lambda>�s��5�:�r*)�key)r9�scandirrNr�r)r��sort)r+�entriesr�r<�errs     r(r?r?�s��
�G�	��D�	�	�
"�Q��	"�	"�E�
��
�
�������
�
�
� ��%�%���H�H�H�H������
����
�N�N�5�!�!�!�!�	"�
"�
"�
"�
"�
"�
"�
"�
"�
"�
"�
"����
"�
"�
"�
"��L�L�-�-�L�.�.�.��Ns<�A<�2�A<�
A�A�A<�A�A�A<�<B�B�recursec#�K�t|��}|Ed{V��|D]<}|���r&||��rt|j|��Ed{V���=dS)z�Walk a directory recursively, in breadth-first order.

    The `recurse` predicate determines whether a directory is recursed.

    Entries at each directory level are sorted.
    N)r?r6�visitr+)r+rCrAr<s    r(rErE�s������d�m�m�G����������2�2���<�<�>�>�	2�g�g�e�n�n�	2��U�Z��1�1�1�1�1�1�1�1�1��2�2r*c�t�ttj�t	|������S)z�Convert a path to an absolute path using os.path.abspath.

    Prefer this over Path.resolve() (see #6523).
    Prefer this over Path.absolute() (not public, doesn't normalize).
    )r
r9r+�abspathrMr/s r(�absolutepathrH�s&��������D�	�	�*�*�+�+�+r*�path1�path2c��	ttj�t	|��t	|��f����S#t
$rYdSwxYw)z�Return the common part shared with the other path, or None if there is
    no common part.

    If one path is relative and one is absolute, returns None.
    N)r
r9r+�
commonpathrMr|)rIrJs  r(rLrL�sX����B�G�&�&��E�
�
�C��J�J�'?�@�@�A�A�A�������t�t����s�AA
�

A�A�	directory�destc��t|t��sJ�t|t��sJ�||krtjSt	||��}|st|��S|�|��}|�|��}tjjgtj	gt|j��z�|j�R�S)z�Return a string which is a relative path from directory to dest such
    that directory/bestrelpath == dest.

    The paths must be either both absolute or both relative.

    If no such path can be determined, returns dest.
    )rAr
r9�curdirrLrMrr+r��pardirrtr�)rMrN�base�reldirectory�reldests     r(�bestrelpathrU�s����i��&�&�&�&�&��d�D�!�!�!�!�!��y����y���i��&�&�D����4�y�y���(�(��.�.�L����t�$�$�G�
�7�<��
�9�+��L�.�/�/�
/��
��	���r*�sourcec��|���sJ�t|d����D]�}t|��}|�|��}||z}|j�d���|���r(|�tj	|������|�
��rtj||����|���r|�d�����dS)z.Recursively copy a source directory to target.c�,�|���Sr8)r�r;s r(r=zcopytree.<locals>.<lambda>�s���9I�9I�9K�9K�5K�r*)rCT)�exist_okN)
r6rEr
rrRr�r�r�r9�readlinkrNrf�copyfile)rVrr<rp�relpath�newxs      r(�copytreer^�s����=�=�?�?���?��v�'K�'K�L�L�L�
&�
&����K�K���-�-��'�'����������4��(�(�(��<�<�>�>�	&��O�O�B�K��N�N�+�+�+�+�
�Y�Y�[�[�	&��O�A�t�$�$�$�$�
�X�X�Z�Z�	&��J�J��J�%�%�%��
&�
&r*)r�)gr�r�r��importlib.utilr�r�r9rfrV�typesr�rE�enumrr"rrrr�	functoolsr�os.pathr	r
rr�pathlibr
r�	posixpathr�r�typingrrrrrrrrrrr�_pytest.compatr�_pytest.outcomesr�_pytest.warning_typesr�LOCK_TIMEOUTrr%r&r)r0rMrB�
TracebackType�boolrSr[rZrhrqrvrxr{r~r�r�r�r�r�r��floatr�r�r�r�r�r�r�r�r�r�r�rr�r�r%rWrXrrr
rr?rErHrLrUr^r�r*r(�<module>rns�	��
�
�
�
�����������������	�	�	�	�
�
�
�
�
�
�
�
�������������������������������������������������������������������������������������&�&�&�&�&�&�������������������������������������������������������������������������'�'�'�'�'�'�!�!�!�!�!�!�/�/�/�/�/�/����w�~�X�6�6�6���7�E�5�1�������"��"��"�"�"�"�<�

�<���
�d�=�!�=�(�5�;N�2O�O�P�	R��<��<�
�<�<�<�<�~�d��t�����$	#�s�	#�s�	#�	#�	#�	#�2��2��2�2�2�2����c��h�t�n������8�H�-��s��x��}�����A��A�c�A�h�s�m�A�A�A�A�
�C�����
�
�
��c�8�m�,�
�7<�S�$�Y�7G�
�	�
�
�
�
�,
�
�D�
�#�
�S�
�T�
�
�
�
�*�4��D�����"=C�O�%�%�T�%�%�%�%�"�d��t�����8�4��u��QU�����8*�d�*�%�*�D�*�*�*�*�	�T�	�3�	�c�	�h�t�n�	�	�	�	�"��"�"�"�"� �
� �� �#&� �NS� �	� � � � ��
�������	�
��
�
����B(�C�(�4�(�D�(�(�(�(�!*��!*�5��.@�)@�#A�!*�d�!*�!*�!*�!*�HH�S�H�S��X�H�H�H�H�
-�-�-���������������k����$.�#5�h�h�h��S�$�
$�%�h���Z��
 �h��	h�
�h�h�h�h�Z�<���5�!�!�(�@�S�@�c�@�d�@�@�@�@�@�
(�S�(�c�(�d�(�(�(�(� �� �D� �S� � � � �*-�D��j��$9�-��-�PT�-�-�-�-�:�t���������"�%��/�/�0��T�:L�5M�����*
2�
��'�'�
(�
2�3;�=O�<P�RV�<V�3W�
2�
� �!�
2�
2�
2�
2� ,�u�T�3�Y�'�,�D�,�,�,�,�	�d�	�4�	�H�T�N�	�	�	�	��4��t�������>
&�T�
&�4�
&�D�
&�
&�
&�
&�
&�
&r*