From 55c709106c1f0cd927e4436662e7c92803b1c19a Mon Sep 17 00:00:00 2001 From: Matthias Bussonnier Date: Mon, 22 Jan 2024 10:04:32 +0100 Subject: [PATCH] Introduce and IPython extension to make the ``?`` operator work. When ``?`` is used from within and IPython kernel, it will send an extra mimetype that we can listen for on the frontend to show the relevant page. --- papyri-lab/src/widgets.tsx | 2 +- papyri/__init__.py | 23 +++++++++++++++++++++++ 2 files changed, 24 insertions(+), 1 deletion(-) diff --git a/papyri-lab/src/widgets.tsx b/papyri-lab/src/widgets.tsx index cc55528b..1ac40487 100644 --- a/papyri-lab/src/widgets.tsx +++ b/papyri-lab/src/widgets.tsx @@ -33,7 +33,7 @@ const PapyriComponent = (): JSX.Element => { navs.pop(); const pen = navs.pop(); if (pen !== undefined) { - console.log('Settgin search term', pen); + console.log('Setting search term', pen); await setSearchTerm(pen); console.log('... and searchg for ', pen); await search(pen); diff --git a/papyri/__init__.py b/papyri/__init__.py index 462e46c1..60ea31d8 100644 --- a/papyri/__init__.py +++ b/papyri/__init__.py @@ -695,5 +695,28 @@ def open(qualname: str): webbrowser.get().open("file://" + str(path), new=1) +def load_ipython_extension(ipython): + import IPython + + if IPython.version_info < (8, 21): + # bug in IPython < 8, 21 where returning more mimetypes than just text and html override the + # full mimebundle. + print("papyri extension only works with IPython >= 8.21") + return + + def hook(obj, oinfo): + from papyri.utils import full_qual + + # TODO: + # for now just return the fully qualified name of the object, + # so that the frontend can later use a KernelSpy to display the right + # page. + # this is not completely sufficient, we might need to get the module version. + # but we can extend that later. + return {"qualname": full_qual(obj)} + + ipython.inspector.mime_hooks["x-vendor/papyri"] = hook + + if __name__ == "__main__": app()