From ce96a51d3826d7779223f68522a96be22cbc9115 Mon Sep 17 00:00:00 2001 From: Roman Yurchak Date: Tue, 22 Dec 2020 08:47:22 +0100 Subject: [PATCH] Create a pyodide-py package (#909) --- Makefile | 4 +- docs/conf.py | 2 +- src/pyodide-py/pyodide/__init__.py | 6 +++ .../pyodide/_base.py} | 44 +------------------ src/pyodide-py/pyodide/console.py | 37 ++++++++++++++++ src/tests/test_pyodide.py | 2 +- 6 files changed, 48 insertions(+), 47 deletions(-) create mode 100644 src/pyodide-py/pyodide/__init__.py rename src/{pyodide.py => pyodide-py/pyodide/_base.py} (74%) create mode 100644 src/pyodide-py/pyodide/console.py diff --git a/Makefile b/Makefile index a5407f7ae..6aa8c6833 100644 --- a/Makefile +++ b/Makefile @@ -186,7 +186,7 @@ root/.built: \ $(PARSO_LIBS) \ src/sitecustomize.py \ src/webbrowser.py \ - src/pyodide.py \ + src/pyodide-py/ \ cpython/remove_modules.txt rm -rf root mkdir -p root/lib @@ -199,7 +199,7 @@ root/.built: \ cp src/webbrowser.py root/lib/python$(PYMINOR) cp src/_testcapi.py root/lib/python$(PYMINOR) cp src/pystone.py root/lib/python$(PYMINOR) - cp src/pyodide.py root/lib/python$(PYMINOR)/site-packages + cp -r src/pyodide-py/pyodide/ $(SITEPACKAGES) ( \ cd root/lib/python$(PYMINOR); \ rm -fr `cat ../../../cpython/remove_modules.txt`; \ diff --git a/docs/conf.py b/docs/conf.py index 4c9318372..197c002fe 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -17,7 +17,7 @@ import sys for base_path in [".", ".."]: sys.path.insert(0, os.path.abspath(base_path)) - sys.path.insert(1, os.path.abspath(os.path.join(base_path, "src"))) + sys.path.insert(1, os.path.abspath(os.path.join(base_path, "src", "pyodide-py"))) sys.path.insert( 2, os.path.abspath(os.path.join(base_path, "packages", "micropip", "micropip")) ) diff --git a/src/pyodide-py/pyodide/__init__.py b/src/pyodide-py/pyodide/__init__.py new file mode 100644 index 000000000..e9e09dd53 --- /dev/null +++ b/src/pyodide-py/pyodide/__init__.py @@ -0,0 +1,6 @@ +from ._base import open_url, eval_code, find_imports, as_nested_list +from .console import get_completions + +__version__ = "0.15.0" + +__all__ = ["open_url", "eval_code", "find_imports", "as_nested_list", "get_completions"] diff --git a/src/pyodide.py b/src/pyodide-py/pyodide/_base.py similarity index 74% rename from src/pyodide.py rename to src/pyodide-py/pyodide/_base.py index 3fd1b0d37..4c3e9a906 100644 --- a/src/pyodide.py +++ b/src/pyodide-py/pyodide/_base.py @@ -5,10 +5,7 @@ A library of helper utilities for connecting Python to the browser environment. import ast from io import StringIO from textwrap import dedent -from typing import Dict, List, Optional, Any - - -__version__ = "0.15.0" +from typing import Dict, List, Any def open_url(url: str) -> StringIO: @@ -128,42 +125,3 @@ def as_nested_list(obj) -> List: return [as_nested_list(x) for x in it] except TypeError: return obj - - -def get_completions( - code: str, cursor: Optional[int] = None, namespaces: Optional[List] = None -) -> List[str]: - """ - Get code autocompletion candidates - - Note that this function requires to have the jedi module loaded. - - Parameters - ---------- - code - the Python code to complete. - cursor - optional position in the code at which to autocomplete - namespaces - a list of namespaces - - Returns - ------- - a list of autocompleted modules - """ - import jedi - import __main__ - - if namespaces is None: - namespaces = [__main__.__dict__] - - if cursor is None: - cursor = len(code) - code = code[:cursor] - interp = jedi.Interpreter(code, namespaces) - completions = interp.completions() - - return [x.name for x in completions] - - -__all__ = ["open_url", "eval_code", "find_imports", "as_nested_list", "get_completions"] diff --git a/src/pyodide-py/pyodide/console.py b/src/pyodide-py/pyodide/console.py new file mode 100644 index 000000000..66c42c00a --- /dev/null +++ b/src/pyodide-py/pyodide/console.py @@ -0,0 +1,37 @@ +from typing import List, Optional + + +def get_completions( + code: str, cursor: Optional[int] = None, namespaces: Optional[List] = None +) -> List[str]: + """ + Get code autocompletion candidates + + Note that this function requires to have the jedi module loaded. + + Parameters + ---------- + code + the Python code to complete. + cursor + optional position in the code at which to autocomplete + namespaces + a list of namespaces + + Returns + ------- + a list of autocompleted modules + """ + import jedi + import __main__ + + if namespaces is None: + namespaces = [__main__.__dict__] + + if cursor is None: + cursor = len(code) + code = code[:cursor] + interp = jedi.Interpreter(code, namespaces) + completions = interp.completions() + + return [x.name for x in completions] diff --git a/src/tests/test_pyodide.py b/src/tests/test_pyodide.py index 9df54128d..c7a89e478 100644 --- a/src/tests/test_pyodide.py +++ b/src/tests/test_pyodide.py @@ -2,7 +2,7 @@ import sys from pathlib import Path from textwrap import dedent -sys.path.append(str(Path(__file__).parents[2] / "src")) +sys.path.append(str(Path(__file__).parents[2] / "src" / "pyodide-py")) from pyodide import find_imports # noqa: E402