
    MhL                    H    d Z ddlmZ ddlZddlmZmZ  G d d          ZdS )zWin32 compatibility utilities.    )annotationsN)AnyCallablec                  .    e Zd ZdZdddZd Zd	 Zd
 ZdS )allow_interruptaD  Utility for fixing CTRL-C events on Windows.

    On Windows, the Python interpreter intercepts CTRL-C events in order to
    translate them into ``KeyboardInterrupt`` exceptions.  It (presumably)
    does this by setting a flag in its "console control handler" and
    checking it later at a convenient location in the interpreter.

    However, when the Python interpreter is blocked waiting for the ZMQ
    poll operation to complete, it must wait for ZMQ's ``select()``
    operation to complete before translating the CTRL-C event into the
    ``KeyboardInterrupt`` exception.

    The only way to fix this seems to be to add our own "console control
    handler" and perform some application-defined operation that will
    unblock the ZMQ polling operation in order to force ZMQ to pass control
    back to the Python interpreter.

    This context manager performs all that Windows-y stuff, providing you
    with a hook that is called when a CTRL-C event is intercepted.  This
    hook allows you to unblock your ZMQ poll operation immediately, which
    will then result in the expected ``KeyboardInterrupt`` exception.

    Without this context manager, your ZMQ-based application will not
    respond normally to CTRL-C events on Windows.  If a CTRL-C event occurs
    while blocked on ZMQ socket polling, the translation to a
    ``KeyboardInterrupt`` exception will be delayed until the I/O completes
    and control returns to the Python interpreter (this may never happen if
    you use an infinite timeout).

    A no-op implementation is provided on non-Win32 systems to avoid the
    application from having to conditionally use it.

    Example usage:

    .. sourcecode:: python

       def stop_my_application():
           # ...

       with allow_interrupt(stop_my_application):
           # main polling loop.

    In a typical ZMQ application, you would use the "self pipe trick" to
    send message to a ``PAIR`` socket in order to interrupt your blocking
    socket polling operation.

    In a Tornado event loop, you can use the ``IOLoop.stop`` method to
    unblock your I/O loop.
    NactionCallable[[], Any] | NonereturnNonec                T    t           j        dk    rdS |                     |           dS )a  Translate ``action`` into a CTRL-C handler.

        ``action`` is a callable that takes no arguments and returns no
        value (returned value is ignored).  It must *NEVER* raise an
        exception.

        If unspecified, a no-op will be used.
        ntN)osname_init_action)selfr   s     O/var/www/html/test/jupyter/venv/lib/python3.11/site-packages/zmq/utils/win32.py__init__zallow_interrupt.__init__@   s.     7d??F&!!!!!    c                    ddl m}m} ddlm}m} |                    d          } |||          }|j        x}| _        ||f|_	        ||_
        d | _        |fd            }	|	| _        d S )Nr   )WINFUNCTYPEwindll)BOOLDWORDkernel32c                     d S N r   r   r   r   z,allow_interrupt._init_action.<locals>.action]   s    tr   c                (    | dk    r
              dS )Nr   r   )eventr   s    r   handlez,allow_interrupt._init_action.<locals>.handleb   s    zz 1r   )ctypesr   r   ctypes.wintypesr   r   LoadLibrarySetConsoleCtrlHandler_SetConsoleCtrlHandlerargtypesrestyper   r    )
r   r   r   r   r   r   r   PHANDLER_ROUTINEr$   r    s
    `        r   r   zallow_interrupt._init_actionM   s    ........////////%%j11 ';tU33*	
 ; +;D)A&(,%>   			 		 		 		 
			 r   c                    t           j        dk    rdS |                     | j        d          }|dk    rt	                      dS )z"Install the custom CTRL-C handler.r   N   r   r   r   r%   r    OSError)r   results     r   	__enter__zallow_interrupt.__enter__p   D    7d??F,,T[!<<Q;; ))O ;r   c                    t           j        dk    rdS |                     | j        d          }|dk    rt	                      dS )z!Remove the custom CTRL-C handler.r   Nr   r+   )r   argsr-   s      r   __exit__zallow_interrupt.__exit__z   r/   r   r   )r   r	   r
   r   )__name__
__module____qualname____doc__r   r   r.   r2   r   r   r   r   r      sf        0 0d" " " " "! ! !F      r   r   )r6   
__future__r   r   typingr   r   r   r   r   r   <module>r9      s|    $ $ # " " " " " 				                u u u u u u u u u ur   