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/dist-packages/gi/__pycache__/_ossighelper.cpython-310.pyc
o

b�^��@s�ddlmZddlZddlZddlZddlZddlmZmZddl	m
Z
dd�Zda	ed	d
��Z
e
jZe�ej�ejurCeej�ZndZdd
�Zedd��Zdd�Zgadaedd��ZdS)�)�print_functionN)�closing�contextmanager�)�_gicCslt|d�r|�d�dSzddl}Wntytd��w|��}|�||j�}|�||j||jB�dS)z�Ensures that the socket is not inherited by child processes

    Raises:
        EnvironmentError
        NotImplementedError: With Python <3.4 on Windows
    �set_inheritableFrNz+Not implemented for older Python on Windows)	�hasattrr�fcntl�ImportError�NotImplementedError�fileno�F_GETFD�F_SETFD�
FD_CLOEXEC)�sockr	�fd�flags�r�1/usr/lib/python3/dist-packages/gi/_ossighelper.py�ensure_socket_not_inheritables
��rFc#s��trdVdSddlm�t��\�}t����t|����|fD]}|�d�t|�q"z	t�	|�
��}WntyPdVYWd�Wd�dSwda��fdd�}zRtj
dkri�j���
��}n�j���
��}��|�j�jj�jjB�jjB�jjB|�}z
dVW��|�n��|�wWt�	|�}||�
�kr�t�	|�dant�	|�}||�
�kr�t�	|�dawWd�n1s�wYWd�dSWd�dS1s�wYdS)	a�A decorator for functions which create a glib event loop to keep
    Python signal handlers working while the event loop is idling.

    In case an OS signal is received will wake the default event loop up
    shortly so that any registered Python signal handlers registered through
    signal.signal() can run.

    In case the wrapped function is not called from the main thread it will be
    called as is and it will not wake up the default loop for signals.
    Nr)�GLibFTc
sN|�j@r%zt��d��WSty$}zt|�WYd}~dSd}~wwdS)NrF)�IO_IN�bool�recv�EnvironmentError�print)�source�	condition�e�r�read_socketrr�
signal_notify\s
��z'wakeup_on_signal.<locals>.signal_notify�nt)�_wakeup_fd_is_active�
gi.repositoryr�socket�
socketpairr�setblockingr�signal�
set_wakeup_fdr�
ValueError�os�name�	IOChannel�win32_new_socket�unix_new�io_add_watch�PRIORITY_DEFAULT�IOCondition�IN�HUP�NVAL�ERR�
source_remove)�write_socketr�orig_fdr!�channel�	source_id�write_fdrrr�wakeup_on_signal7s^�

�
����


�
P�r=���cCs t�tj�tjuottj�tkS)z?Returns if on SIGINT the default Python handler would be called)r(�	getsignal�SIGINT�default_int_handler�PyOS_getsig�startup_sigint_ptrrrrr�sigint_handler_is_default�s�rDc
cs��t�sJ�t�tj|�ttj�}z!dVWt�tj�|ur0ttj�|kr2t�tjtj�dSdSdSt�tj�|urLttj�|krMt�tjtj�www)z�Context manager for saving/restoring the SIGINT handler default state.

    Will only restore the default handler again if the handler is not changed
    while the context is active.
    N)rDr(r@rBr?rA)�handler�sig_ptrrrr�&sigint_handler_set_and_restore_default�s �

���rGcCst��jdkS)z@Returns True in case the function is called from the main thread�
MainThread)�	threading�current_threadr,rrrr�is_main_thread�srKc
cs��t�s	dVdSt�s3tr.t�|�zdVWt��}tr!|�dSt��}tr-|�wwdVdSdadd�}t�|�z)t|��dVWd�n1sQwYWtrbt�tj	d�dSt��dStrrt�tj	d�wt��w)a�Installs a SIGINT signal handler in case the default Python one is
    active which calls 'callback' in case the signal occurs.

    Only does something if called from the main thread.

    In case of nested context managers the signal handler will be only
    installed once and the callbacks will be called in the reverse order
    of their registration.

    The old signal handler will be restored in case no signal handler is
    registered while the context is active.
    NFcSstrdSdat���dS)NT)�_sigint_called�_callback_stack�pop)�sig_num�framerrr�sigint_handler�sz0register_sigint_fallback.<locals>.sigint_handler)
rKrDrM�appendrNrLrGr(rAr@)�callback�cbrQrrr�register_sigint_fallback�sB�
��

���
rU)�
__future__rr+r%r(rI�
contextlibrr�rrr#r=�pyos_getsigrBr?r@rArCrDrGrKrMrLrUrrrr�<module>s0
I