HEX
Server: LiteSpeed
System: Linux php-prod-1.spaceapp.ru 5.15.0-157-generic #167-Ubuntu SMP Wed Sep 17 21:35:53 UTC 2025 x86_64
User: sport3497 (1034)
PHP: 8.1.33
Disabled: NONE
Upload Files
File: //proc/self/root/usr/lib/python3.10/test/support/__pycache__/import_helper.cpython-310.pyc
o

E�h8�@s�ddlZddlZddlZddlZddlZddlZddlZddlZddlm	Z	ej
ddd��Zdd�Zd	d
�Z
dd�Zddd�dd�Zdd�Zd dd�ZGdd�de�ZGdd�de�Zdd�Zdd�ZdS)!�N�)�unlinkTccsR�|r$t���t�ddt�dVWd�dS1swYdSdVdS)z�Context manager to suppress package and module deprecation
    warnings when importing them.

    If ignore is False, this context manager has no effect.
    �ignorez.+ (module|package)N)�warnings�catch_warnings�filterwarnings�DeprecationWarning)r�r	�1/usr/lib/python3.10/test/support/import_helper.py�_ignore_deprecated_imports
s�
�"�
rcCs$ztj|=WdStyYdSw�N)�sys�modules�KeyError)�namer	r	r
�unloads
�rcCsTt|�tjD] }tj�||d�}t|d�dD]}ttjj||d��qqdS)z�'Forget' a module was ever imported.

    This removes the module from sys.modules and deletes any PEP 3147/488 or
    legacy .pyc files.
    z.py�c)�r�)�optimizationN)	rr
�path�os�joinr�	importlib�util�cache_from_source)�modname�dirname�source�optr	r	r
�forget$s
��r cCsBtj�|�}tj�tj�|��}tj�||d�}t�	||�|S)aMove a PEP 3147/488 pyc file to its legacy pyc location.

    :param source: The file system path to the source file.  The source file
        does not need to exist, however the PEP 3147/488 pyc file must exist.
    :return: The file system path to the legacy pyc file.
    r)
rrrrrr�abspathr�shutil�move)r�pyc_file�up_one�
legacy_pycr	r	r
�make_legacy_pyc4s
r'Fr	)�required_oncCsrt|��+z
t�|�WWd�Sty.}ztj�t|��r#�t�	t
|���d}~ww1s2wYdS)acImport and return the module to be tested, raising SkipTest if
    it is not available.

    If deprecated is True, any module or package deprecation messages
    will be suppressed. If a module is required on a platform but optional for
    others, set required_on to an iterable of platform prefixes which will be
    compared against sys.platform.
    N)rr�
import_module�ImportErrorr
�platform�
startswith�tuple�unittest�SkipTest�str)r�
deprecatedr(�msgr	r	r
r)Bs
	
����r)cCsLi}tdd�|D��}ttj�D]}||vs|�|�r#tj�|�||<q|S)Ncss�|]}|dVqdS)�.Nr	)�.0rr	r	r
�	<genexpr>Vs�z+_save_and_remove_modules.<locals>.<genexpr>)r-�listr
rr,�pop)�names�orig_modules�prefixesrr	r	r
�_save_and_remove_modulesTs�r;c
Cs�t|��ht|�}t|�}|h|�|�}t|�}|D]}dtj|<qz>z|D]}t|�q&WntyIYWt|�tj�|�Wd�dSwt�	|�Wt|�tj�|�Wd�St|�tj�|�w1sowYdS)a9Import and return a module, deliberately bypassing sys.modules.

    This function imports and returns a fresh copy of the named Python module
    by removing the named module from sys.modules before doing the import.
    Note that unlike reload, the original module is not affected by
    this operation.

    *fresh* is an iterable of additional module names that are also removed
    from the sys.modules cache before doing the import. If one of these
    modules can't be imported, None is returned.

    *blocked* is an iterable of module names that are replaced with None
    in the module cache during the import to ensure that attempts to import
    them raise ImportError.

    The named module and any modules named in the *fresh* and *blocked*
    parameters are saved before starting the import and then reinserted into
    sys.modules when the fresh import is complete.

    Module and package deprecation messages are suppressed during this import
    if *deprecated* is True.

    This function will raise ImportError if the named module cannot be
    imported.
    N)
rr6r;r
r�
__import__r*�updaterr))r�fresh�blockedr1r8r9rr	r	r
�import_fresh_module]s2

��
��r@c@�(eZdZdZdd�Zdd�Zdd�ZdS)	�CleanImporta,Context manager to force import to return a new module reference.

    This is useful for testing module-level behaviours, such as
    the emission of a DeprecationWarning on import.

    Use like this:

        with CleanImport("foo"):
            importlib.import_module("foo") # new reference
    cGsJtj��|_|D]}|tjvr"tj|}|j|krtj|j=tj|=qdSr)r
r�copy�original_modules�__name__)�self�module_names�module_name�moduler	r	r
�__init__�s



��zCleanImport.__init__cC�|Srr	�rFr	r	r
�	__enter__��zCleanImport.__enter__cGstj�|j�dSr)r
rr=rD�rF�
ignore_excr	r	r
�__exit__�szCleanImport.__exit__N�rE�
__module__�__qualname__�__doc__rJrMrQr	r	r	r
rB�s

rBc@rA)	�
DirsOnSysPatha�Context manager to temporarily add directories to sys.path.

    This makes a copy of sys.path, appends any directories given
    as positional arguments, then reverts sys.path to the copied
    settings when the context ends.

    Note that *all* sys.path modifications in the body of the
    context manager, including replacement of the object,
    will be reverted at the end of the block.
    cGs(tjdd�|_tj|_tj�|�dSr)r
r�original_value�original_object�extend)rF�pathsr	r	r
rJ�szDirsOnSysPath.__init__cCrKrr	rLr	r	r
rM�rNzDirsOnSysPath.__enter__cGs|jt_|jtjdd�<dSr)rXr
rrWrOr	r	r
rQ�szDirsOnSysPath.__exit__NrRr	r	r	r
rV�s
rVcCstj��fSr)r
rrCr	r	r	r
�
modules_setup�sr[cCs:dd�tj��D�}tj��tj�|�tj�|�dS)NcSs"g|]
\}}|�d�r||f�qS)z
encodings.)r,)r4�k�vr	r	r
�
<listcomp>�s�z#modules_cleanup.<locals>.<listcomp>)r
r�items�clearr=)�
oldmodules�	encodingsr	r	r
�modules_cleanup�s
rc)T)F)r	r	F)�
contextlibr�importlib.utilrr"r
r.r�	os_helperr�contextmanagerrrr r'r)r;r@�objectrBrVr[rcr	r	r	r
�<module>s*
	3