From 4752ca24a3e9d3969619ae079f275814b242d943 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fr=C3=A9d=C3=A9ric=20Collonval?= Date: Wed, 4 Dec 2024 17:04:59 +0100 Subject: [PATCH] Add KernelClient.execute_interactive (#2) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Frédéric Collonval --- CHANGELOG.md | 2 + jupyter_kernel_client/client.py | 79 ++++++++++++++++++++++++++++++--- 2 files changed, 74 insertions(+), 7 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 271c61f..06d5afa 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,8 @@ ## 0.1.1 +:warning: Not published + ([Full Changelog](https://github.com/datalayer/jupyter-kernel-client/compare/66064f9f7afe59b2450fc3a15a2e78f4eb606852)) First version diff --git a/jupyter_kernel_client/client.py b/jupyter_kernel_client/client.py index ee3b31d..c6b2075 100644 --- a/jupyter_kernel_client/client.py +++ b/jupyter_kernel_client/client.py @@ -76,7 +76,7 @@ def last_activity(self) -> datetime.datetime | None: else None ) - def execute( + def execute( # noqa: C901 self, code: str, silent: bool = False, @@ -89,11 +89,6 @@ def execute( ) -> dict[str, t.Any]: """Execute code in the kernel interactively - Output will be redisplayed, and stdin prompts will be relayed as well. - - You can pass a custom output_hook callable that will be called - with every IOPub message that is produced instead of the default redisplay. - Args: code: A string of code in the kernel's language. silent: optional (default False) If set, the kernel will execute the code as quietly possible, and @@ -109,7 +104,6 @@ def execute( Flag whether to abort the execution queue, if an exception is encountered. timeout: Timeout to use when waiting for a reply - stdin_hook: Function to be called with stdin_request messages. If not specified, input/getpass will be called. @@ -195,6 +189,77 @@ def output_hook(outputs: list[dict], msg: dict) -> None: "status": reply_content["status"], } + def execute_interactive( + self, + code: str, + silent: bool = False, + store_history: bool = True, + user_expressions: dict[str, t.Any] | None = None, + allow_stdin: bool | None = None, + stop_on_error: bool = True, + timeout: float | None = None, + output_hook: t.Callable | None = None, + stdin_hook: t.Callable | None = None, + ) -> dict[str, t.Any]: + """Execute code in the kernel with low-level API + + Output will be redisplayed, and stdin prompts will be relayed as well. + + You can pass a custom output_hook callable that will be called + with every IOPub message that is produced instead of the default redisplay. + + Parameters + ---------- + code : str + A string of code in the kernel's language. + + silent : bool, optional (default False) + If set, the kernel will execute the code as quietly possible, and + will force store_history to be False. + + store_history : bool, optional (default True) + If set, the kernel will store command history. This is forced + to be False if silent is True. + + user_expressions : dict, optional + A dict mapping names to expressions to be evaluated in the user's + dict. The expression values are returned as strings formatted using + :func:`repr`. + + allow_stdin : bool, optional (default self.allow_stdin) + Flag for whether the kernel can send stdin requests to frontends. + + stop_on_error: bool, optional (default True) + Flag whether to abort the execution queue, if an exception is encountered. + + timeout: float or None (default: None) + Timeout to use when waiting for a reply + + output_hook: callable(msg) + Function to be called with output messages. + If not specified, output will be redisplayed. + + stdin_hook: callable(msg) + Function to be called with stdin_request messages. + If not specified, input/getpass will be called. + + Returns + ------- + reply: dict + The reply message for this request + """ + return self._manager.client.execute_interactive( + code, + silent=silent, + store_history=store_history, + user_expressions=user_expressions, + allow_stdin=allow_stdin, + stop_on_error=stop_on_error, + timeout=timeout, + output_hook=output_hook, + stdin_hook=stdin_hook, + ) + def interrupt(self, timeout: float = REQUEST_TIMEOUT) -> None: """Interrupts the kernel.""" self._manager.interrupt_kernel(timeout=timeout)