You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			72 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
			
		
		
	
	
			72 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
"""Implements a fully blocking kernel client.
 | 
						|
 | 
						|
Useful for test suites and blocking terminal interfaces.
 | 
						|
"""
 | 
						|
# Copyright (c) Jupyter Development Team.
 | 
						|
# Distributed under the terms of the Modified BSD License.
 | 
						|
from __future__ import annotations
 | 
						|
 | 
						|
import typing as t
 | 
						|
 | 
						|
from traitlets import Type
 | 
						|
 | 
						|
from ..channels import HBChannel, ZMQSocketChannel
 | 
						|
from ..client import KernelClient, reqrep
 | 
						|
from ..utils import run_sync
 | 
						|
 | 
						|
 | 
						|
def wrapped(meth: t.Callable, channel: str) -> t.Callable:
 | 
						|
    """Wrap a method on a channel and handle replies."""
 | 
						|
 | 
						|
    def _(self: BlockingKernelClient, *args: t.Any, **kwargs: t.Any) -> t.Any:
 | 
						|
        reply = kwargs.pop("reply", False)
 | 
						|
        timeout = kwargs.pop("timeout", None)
 | 
						|
        msg_id = meth(self, *args, **kwargs)
 | 
						|
        if not reply:
 | 
						|
            return msg_id
 | 
						|
        return self._recv_reply(msg_id, timeout=timeout, channel=channel)
 | 
						|
 | 
						|
    return _
 | 
						|
 | 
						|
 | 
						|
class BlockingKernelClient(KernelClient):
 | 
						|
    """A KernelClient with blocking APIs
 | 
						|
 | 
						|
    ``get_[channel]_msg()`` methods wait for and return messages on channels,
 | 
						|
    raising :exc:`queue.Empty` if no message arrives within ``timeout`` seconds.
 | 
						|
    """
 | 
						|
 | 
						|
    # --------------------------------------------------------------------------
 | 
						|
    # Channel proxy methods
 | 
						|
    # --------------------------------------------------------------------------
 | 
						|
 | 
						|
    get_shell_msg = run_sync(KernelClient._async_get_shell_msg)
 | 
						|
    get_iopub_msg = run_sync(KernelClient._async_get_iopub_msg)
 | 
						|
    get_stdin_msg = run_sync(KernelClient._async_get_stdin_msg)
 | 
						|
    get_control_msg = run_sync(KernelClient._async_get_control_msg)
 | 
						|
 | 
						|
    wait_for_ready = run_sync(KernelClient._async_wait_for_ready)
 | 
						|
 | 
						|
    # The classes to use for the various channels
 | 
						|
    shell_channel_class = Type(ZMQSocketChannel)  # type:ignore[arg-type]
 | 
						|
    iopub_channel_class = Type(ZMQSocketChannel)  # type:ignore[arg-type]
 | 
						|
    stdin_channel_class = Type(ZMQSocketChannel)  # type:ignore[arg-type]
 | 
						|
    hb_channel_class = Type(HBChannel)  # type:ignore[arg-type]
 | 
						|
    control_channel_class = Type(ZMQSocketChannel)  # type:ignore[arg-type]
 | 
						|
 | 
						|
    _recv_reply = run_sync(KernelClient._async_recv_reply)
 | 
						|
 | 
						|
    # replies come on the shell channel
 | 
						|
    execute = reqrep(wrapped, KernelClient.execute)
 | 
						|
    history = reqrep(wrapped, KernelClient.history)
 | 
						|
    complete = reqrep(wrapped, KernelClient.complete)
 | 
						|
    inspect = reqrep(wrapped, KernelClient.inspect)
 | 
						|
    kernel_info = reqrep(wrapped, KernelClient.kernel_info)
 | 
						|
    comm_info = reqrep(wrapped, KernelClient.comm_info)
 | 
						|
 | 
						|
    is_alive = run_sync(KernelClient._async_is_alive)
 | 
						|
    execute_interactive = run_sync(KernelClient._async_execute_interactive)
 | 
						|
 | 
						|
    # replies come on the control channel
 | 
						|
    shutdown = reqrep(wrapped, KernelClient.shutdown, channel="control")
 |