pyodide 0.20.1-alpha.1 → 0.20.1-alpha.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/console.html ADDED
@@ -0,0 +1,168 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <meta charset="UTF-8" />
5
+ <script src="https://cdn.jsdelivr.net/npm/jquery"></script>
6
+ <script src="https://cdn.jsdelivr.net/npm/jquery.terminal@2.32.0/js/jquery.terminal.min.js"></script>
7
+ <script src="https://cdn.jsdelivr.net/npm/jquery.terminal@2.23.0/js/unix_formatting.min.js"></script>
8
+ <link
9
+ href="https://cdn.jsdelivr.net/npm/jquery.terminal@2.32.0/css/jquery.terminal.min.css"
10
+ rel="stylesheet"
11
+ />
12
+ <script src="./pyodide.js"></script>
13
+ <style>
14
+ .terminal {
15
+ --size: 1.5;
16
+ --color: rgba(255, 255, 255, 0.8);
17
+ }
18
+ </style>
19
+ </head>
20
+ <body>
21
+ <script>
22
+ "use strict";
23
+ function sleep(s) {
24
+ return new Promise((resolve) => setTimeout(resolve, s));
25
+ }
26
+
27
+ async function main() {
28
+ globalThis.pyodide = await loadPyodide();
29
+ let namespace = pyodide.globals.get("dict")();
30
+ pyodide.runPython(
31
+ `
32
+ import sys
33
+ from pyodide import to_js
34
+ from pyodide.console import PyodideConsole, repr_shorten, BANNER
35
+ import __main__
36
+ BANNER = "Welcome to the Pyodide terminal emulator 🐍\\n" + BANNER
37
+ pyconsole = PyodideConsole(__main__.__dict__)
38
+ import builtins
39
+ async def await_fut(fut):
40
+ res = await fut
41
+ if res is not None:
42
+ builtins._ = res
43
+ return to_js([res], depth=1)
44
+ def clear_console():
45
+ pyconsole.buffer = []
46
+ `,
47
+ { globals: namespace }
48
+ );
49
+ let repr_shorten = namespace.get("repr_shorten");
50
+ let banner = namespace.get("BANNER");
51
+ let await_fut = namespace.get("await_fut");
52
+ let pyconsole = namespace.get("pyconsole");
53
+ let clear_console = namespace.get("clear_console");
54
+ namespace.destroy();
55
+
56
+ let ps1 = ">>> ",
57
+ ps2 = "... ";
58
+
59
+ async function lock() {
60
+ let resolve;
61
+ let ready = term.ready;
62
+ term.ready = new Promise((res) => (resolve = res));
63
+ await ready;
64
+ return resolve;
65
+ }
66
+
67
+ async function interpreter(command) {
68
+ let unlock = await lock();
69
+ term.pause();
70
+ // multiline should be split (useful when pasting)
71
+ for (const c of command.split("\n")) {
72
+ let fut = pyconsole.push(c);
73
+ term.set_prompt(fut.syntax_check === "incomplete" ? ps2 : ps1);
74
+ switch (fut.syntax_check) {
75
+ case "syntax-error":
76
+ term.error(fut.formatted_error.trimEnd());
77
+ continue;
78
+ case "incomplete":
79
+ continue;
80
+ case "complete":
81
+ break;
82
+ default:
83
+ throw new Error(`Unexpected type ${ty}`);
84
+ }
85
+ // In JavaScript, await automatically also awaits any results of
86
+ // awaits, so if an async function returns a future, it will await
87
+ // the inner future too. This is not what we want so we
88
+ // temporarily put it into a list to protect it.
89
+ let wrapped = await_fut(fut);
90
+ // complete case, get result / error and print it.
91
+ try {
92
+ let [value] = await wrapped;
93
+ if (value !== undefined) {
94
+ term.echo(
95
+ repr_shorten.callKwargs(value, {
96
+ separator: "\n[[;orange;]<long output truncated>]\n",
97
+ })
98
+ );
99
+ }
100
+ if (pyodide.isPyProxy(value)) {
101
+ value.destroy();
102
+ }
103
+ } catch (e) {
104
+ if (e.constructor.name === "PythonError") {
105
+ const message = fut.formatted_error || e.message;
106
+ term.error(message.trimEnd());
107
+ } else {
108
+ throw e;
109
+ }
110
+ } finally {
111
+ fut.destroy();
112
+ wrapped.destroy();
113
+ }
114
+ }
115
+ term.resume();
116
+ await sleep(10);
117
+ unlock();
118
+ }
119
+
120
+ let term = $("body").terminal(interpreter, {
121
+ greetings: banner,
122
+ prompt: ps1,
123
+ completionEscape: false,
124
+ completion: function (command, callback) {
125
+ callback(pyconsole.complete(command).toJs()[0]);
126
+ },
127
+ keymap: {
128
+ "CTRL+C": async function (event, original) {
129
+ clear_console();
130
+ term.enter();
131
+ term.echo("KeyboardInterrupt");
132
+ term.set_command("");
133
+ term.set_prompt(ps1);
134
+ },
135
+ TAB: (event, original) => {
136
+ const command = term.before_cursor();
137
+ // Disable completion for whitespaces.
138
+ if (command.trim() === "") {
139
+ term.insert("\t");
140
+ return false;
141
+ }
142
+ return original(event);
143
+ },
144
+ },
145
+ });
146
+ window.term = term;
147
+ pyconsole.stdout_callback = (s) => term.echo(s, { newline: false });
148
+ pyconsole.stderr_callback = (s) => {
149
+ term.error(s.trimEnd());
150
+ };
151
+ term.ready = Promise.resolve();
152
+ pyodide._api.on_fatal = async (e) => {
153
+ term.error(
154
+ "Pyodide has suffered a fatal error. Please report this to the Pyodide maintainers."
155
+ );
156
+ term.error("The cause of the fatal error was:");
157
+ term.error(e);
158
+ term.error("Look in the browser console for more details.");
159
+ await term.ready;
160
+ term.pause();
161
+ await sleep(15);
162
+ term.pause();
163
+ };
164
+ }
165
+ window.console_ready = main();
166
+ </script>
167
+ </body>
168
+ </html>
package/distutils.tar ADDED
Binary file
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "pyodide",
3
- "version": "0.20.1-alpha.1",
3
+ "version": "0.20.1-alpha.2",
4
4
  "description": "The Pyodide JavaScript package",
5
5
  "keywords": [
6
6
  "python",
package/packages.json ADDED
@@ -0,0 +1 @@
1
+ {"info": {"arch": "wasm32", "platform": "Emscripten-1.0"}, "packages": {"cpp-exceptions-test": {"name": "cpp-exceptions-test", "version": "0.1", "file_name": "cpp-exceptions-test-0.1.zip", "install_dir": "site", "shared_library": true, "depends": [], "imports": ["cpp-exceptions-test"]}, "distutils": {"name": "distutils", "version": "1.0", "file_name": "distutils.tar", "install_dir": "lib", "depends": [], "imports": ["distutils"]}, "fpcast-test": {"name": "fpcast-test", "version": "0.1", "file_name": "fpcast_test-0.1.1-cp310-cp310-emscripten_wasm32.whl", "install_dir": "site", "depends": [], "imports": ["fpcast_test"]}, "jinja2": {"name": "Jinja2", "version": "3.1.1", "file_name": "Jinja2-3.1.1-py3-none-any.whl", "install_dir": "site", "depends": ["markupsafe"], "imports": ["jinja2"]}, "markupsafe": {"name": "MarkupSafe", "version": "2.1.1", "file_name": "MarkupSafe-2.1.1-cp310-cp310-emscripten_wasm32.whl", "install_dir": "site", "depends": [], "imports": ["markupsafe"]}, "micropip": {"name": "micropip", "version": "0.1", "file_name": "micropip-0.1-py3-none-any.whl", "install_dir": "site", "depends": ["pyparsing", "packaging", "distutils"], "imports": ["micropip"]}, "openssl": {"name": "openssl", "version": "1.1.1n", "file_name": "openssl-1.1.1n.zip", "install_dir": "site", "shared_library": true, "depends": [], "imports": ["openssl"]}, "packaging": {"name": "packaging", "version": "21.3", "file_name": "packaging-21.3-py3-none-any.whl", "install_dir": "site", "depends": ["pyparsing"], "imports": ["packaging"]}, "pyparsing": {"name": "pyparsing", "version": "3.0.7", "file_name": "pyparsing-3.0.7-py3-none-any.whl", "install_dir": "site", "depends": [], "imports": ["pyparsing"]}, "pytz": {"name": "pytz", "version": "2022.1", "file_name": "pytz-2022.1-py2.py3-none-any.whl", "install_dir": "site", "depends": [], "imports": ["pytz"]}, "regex": {"name": "regex", "version": "2022.3.15", "file_name": "regex-2022.3.15-cp310-cp310-emscripten_wasm32.whl", "install_dir": "site", "depends": [], "imports": ["regex"], "unvendored_tests": true}, "regex-tests": {"name": "regex-tests", "version": "2022.3.15", "depends": ["regex"], "imports": [], "file_name": "regex-tests.tar", "install_dir": "site"}, "sharedlib-test": {"name": "sharedlib-test", "version": "1.0", "file_name": "sharedlib-test-1.0.zip", "install_dir": "site", "shared_library": true, "depends": [], "imports": ["sharedlib-test"]}, "sharedlib-test-py": {"name": "sharedlib-test-py", "version": "1.0", "file_name": "sharedlib_test_py-1.0-cp310-cp310-emscripten_wasm32.whl", "install_dir": "site", "depends": ["sharedlib-test"], "imports": ["sharedlib_test"]}, "ssl": {"name": "ssl", "version": "1.0.0", "file_name": "ssl-1.0.0.zip", "install_dir": "site", "shared_library": true, "depends": ["openssl"], "imports": ["ssl"]}, "test": {"name": "test", "version": "1.0", "file_name": "test.tar", "install_dir": "lib", "depends": [], "imports": ["test"]}}}
Binary file
Binary file