pyodide 0.20.0 → 0.21.0-alpha.1

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,232 @@
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
+ .noblink {
19
+ --animation: terminal-none;
20
+ }
21
+ body {
22
+ background-color: black;
23
+ }
24
+ #jquery-terminal-logo {
25
+ color: white;
26
+ border-color: white;
27
+ position: absolute;
28
+ top: 7px;
29
+ right: 18px;
30
+ z-index: 2;
31
+ }
32
+ #jquery-terminal-logo a {
33
+ color: gray;
34
+ text-decoration: none;
35
+ font-size: 0.7em;
36
+ }
37
+ #loading {
38
+ display: inline-block;
39
+ width: 50px;
40
+ height: 50px;
41
+ position: fixed;
42
+ top: 50%;
43
+ left: 50%;
44
+ border: 3px solid rgba(172, 237, 255, 0.5);
45
+ border-radius: 50%;
46
+ border-top-color: #fff;
47
+ animation: spin 1s ease-in-out infinite;
48
+ -webkit-animation: spin 1s ease-in-out infinite;
49
+ }
50
+
51
+ @keyframes spin {
52
+ to {
53
+ -webkit-transform: rotate(360deg);
54
+ }
55
+ }
56
+ @-webkit-keyframes spin {
57
+ to {
58
+ -webkit-transform: rotate(360deg);
59
+ }
60
+ }
61
+ </style>
62
+ </head>
63
+ <body>
64
+ <div id="jquery-terminal-logo">
65
+ <a href="https://terminal.jcubic.pl/">jQuery Terminal</a>
66
+ </div>
67
+ <div id="loading"></div>
68
+ <script>
69
+ "use strict";
70
+ function sleep(s) {
71
+ return new Promise((resolve) => setTimeout(resolve, s));
72
+ }
73
+
74
+ async function main() {
75
+ let term;
76
+ globalThis.pyodide = await loadPyodide({
77
+ stdin: () => {
78
+ let result = prompt();
79
+ echo(result);
80
+ return result;
81
+ },
82
+ });
83
+ let namespace = pyodide.globals.get("dict")();
84
+ pyodide.runPython(
85
+ `
86
+ import sys
87
+ from pyodide import to_js
88
+ from pyodide.console import PyodideConsole, repr_shorten, BANNER
89
+ import __main__
90
+ BANNER = "Welcome to the Pyodide terminal emulator 🐍\\n" + BANNER
91
+ pyconsole = PyodideConsole(__main__.__dict__)
92
+ import builtins
93
+ async def await_fut(fut):
94
+ res = await fut
95
+ if res is not None:
96
+ builtins._ = res
97
+ return to_js([res], depth=1)
98
+ def clear_console():
99
+ pyconsole.buffer = []
100
+ `,
101
+ { globals: namespace }
102
+ );
103
+ let repr_shorten = namespace.get("repr_shorten");
104
+ let banner = namespace.get("BANNER");
105
+ let await_fut = namespace.get("await_fut");
106
+ let pyconsole = namespace.get("pyconsole");
107
+ let clear_console = namespace.get("clear_console");
108
+ const echo = (msg, ...opts) =>
109
+ term.echo(
110
+ msg.replace("]]", "&rsqb;&rsqb;").replace("[[", "&lsqb;&lsqb;"),
111
+ ...opts
112
+ );
113
+ namespace.destroy();
114
+
115
+ let ps1 = ">>> ",
116
+ ps2 = "... ";
117
+
118
+ async function lock() {
119
+ let resolve;
120
+ let ready = term.ready;
121
+ term.ready = new Promise((res) => (resolve = res));
122
+ await ready;
123
+ return resolve;
124
+ }
125
+
126
+ async function interpreter(command) {
127
+ let unlock = await lock();
128
+ term.pause();
129
+ // multiline should be split (useful when pasting)
130
+ for (const c of command.split("\n")) {
131
+ let fut = pyconsole.push(c);
132
+ term.set_prompt(fut.syntax_check === "incomplete" ? ps2 : ps1);
133
+ switch (fut.syntax_check) {
134
+ case "syntax-error":
135
+ term.error(fut.formatted_error.trimEnd());
136
+ continue;
137
+ case "incomplete":
138
+ continue;
139
+ case "complete":
140
+ break;
141
+ default:
142
+ throw new Error(`Unexpected type ${ty}`);
143
+ }
144
+ // In JavaScript, await automatically also awaits any results of
145
+ // awaits, so if an async function returns a future, it will await
146
+ // the inner future too. This is not what we want so we
147
+ // temporarily put it into a list to protect it.
148
+ let wrapped = await_fut(fut);
149
+ // complete case, get result / error and print it.
150
+ try {
151
+ let [value] = await wrapped;
152
+ if (value !== undefined) {
153
+ echo(
154
+ repr_shorten.callKwargs(value, {
155
+ separator: "\n<long output truncated>\n",
156
+ })
157
+ );
158
+ }
159
+ if (pyodide.isPyProxy(value)) {
160
+ value.destroy();
161
+ }
162
+ } catch (e) {
163
+ if (e.constructor.name === "PythonError") {
164
+ const message = fut.formatted_error || e.message;
165
+ term.error(message.trimEnd());
166
+ } else {
167
+ throw e;
168
+ }
169
+ } finally {
170
+ fut.destroy();
171
+ wrapped.destroy();
172
+ }
173
+ }
174
+ term.resume();
175
+ await sleep(10);
176
+ unlock();
177
+ }
178
+
179
+ term = $("body").terminal(interpreter, {
180
+ greetings: banner,
181
+ prompt: ps1,
182
+ completionEscape: false,
183
+ completion: function (command, callback) {
184
+ callback(pyconsole.complete(command).toJs()[0]);
185
+ },
186
+ keymap: {
187
+ "CTRL+C": async function (event, original) {
188
+ clear_console();
189
+ term.enter();
190
+ echo("KeyboardInterrupt");
191
+ term.set_command("");
192
+ term.set_prompt(ps1);
193
+ },
194
+ TAB: (event, original) => {
195
+ const command = term.before_cursor();
196
+ // Disable completion for whitespaces.
197
+ if (command.trim() === "") {
198
+ term.insert("\t");
199
+ return false;
200
+ }
201
+ return original(event);
202
+ },
203
+ },
204
+ });
205
+ window.term = term;
206
+ pyconsole.stdout_callback = (s) => echo(s, { newline: false });
207
+ pyconsole.stderr_callback = (s) => {
208
+ term.error(s.trimEnd());
209
+ };
210
+ term.ready = Promise.resolve();
211
+ pyodide._api.on_fatal = async (e) => {
212
+ term.error(
213
+ "Pyodide has suffered a fatal error. Please report this to the Pyodide maintainers."
214
+ );
215
+ term.error("The cause of the fatal error was:");
216
+ term.error(e);
217
+ term.error("Look in the browser console for more details.");
218
+ await term.ready;
219
+ term.pause();
220
+ await sleep(15);
221
+ term.pause();
222
+ };
223
+
224
+ const searchParams = new URLSearchParams(window.location.search);
225
+ if (searchParams.has("noblink")) {
226
+ $(".cmd-cursor").addClass("noblink");
227
+ }
228
+ }
229
+ window.console_ready = main();
230
+ </script>
231
+ </body>
232
+ </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.0",
3
+ "version": "0.21.0-alpha.1",
4
4
  "description": "The Pyodide JavaScript package",
5
5
  "keywords": [
6
6
  "python",
@@ -18,38 +18,110 @@
18
18
  "devDependencies": {
19
19
  "@rollup/plugin-commonjs": "^21.0.1",
20
20
  "@rollup/plugin-node-resolve": "^13.1.3",
21
+ "@types/assert": "^1.5.6",
21
22
  "@types/emscripten": "^1.39.5",
22
- "@types/node-fetch": "^3.0.3",
23
+ "@types/expect": "^24.3.0",
24
+ "@types/mocha": "^9.1.0",
25
+ "@types/node": "^17.0.25",
26
+ "@types/node-fetch": "^2.6.1",
27
+ "@types/ws": "^8.5.3",
28
+ "chai": "^4.3.6",
29
+ "chai-as-promised": "^7.1.1",
30
+ "cross-env": "^7.0.3",
31
+ "dts-bundle-generator": "^6.7.0",
23
32
  "error-stack-parser": "^2.0.6",
33
+ "express": "^4.17.3",
24
34
  "mocha": "^9.0.2",
35
+ "npm-run-all": "^4.1.5",
36
+ "nyc": "^15.1.0",
25
37
  "prettier": "^2.2.1",
38
+ "puppeteer": "^13.6.0",
26
39
  "rollup": "^2.48.0",
27
40
  "rollup-plugin-terser": "^7.0.2",
28
41
  "rollup-plugin-ts": "^2.0.5",
29
42
  "terser": "^5.7.0",
30
- "ts-node": "^10.4.0",
43
+ "ts-mocha": "^9.0.2",
31
44
  "tsd": "^0.15.1",
32
- "typescript": "^4.2.4",
33
- "typedoc": "^0.22.11"
45
+ "typedoc": "^0.22.15",
46
+ "typescript": "^4.6.4"
47
+ },
48
+ "main": "pyodide.js",
49
+ "exports": {
50
+ ".": {
51
+ "require": "./pyodide.js",
52
+ "import": "./pyodide.mjs"
53
+ },
54
+ "./pyodide.mjs": "./pyodide.mjs",
55
+ "./pyodide.js": "./pyodide.js",
56
+ "./package.json": "./package.json"
57
+ },
58
+ "files": [
59
+ "pyodide*",
60
+ "packages.json",
61
+ "distutils.tar",
62
+ "console.html"
63
+ ],
64
+ "browser": {
65
+ "child_process": false,
66
+ "crypto": false,
67
+ "fs": false,
68
+ "fs/promises": false,
69
+ "path": false,
70
+ "vm": false,
71
+ "ws": false
34
72
  },
35
- "type": "module",
36
73
  "scripts": {
37
- "test": "mocha --loader node_modules/ts-node/dist/esm.js"
74
+ "test": "npm-run-all test:*",
75
+ "test:unit": "cross-env TEST_NODE=1 ts-mocha -p tsconfig.test.json test/unit/**/*.test.ts",
76
+ "test:node": "cross-env TEST_NODE=1 mocha test/integration/**/*.test.js",
77
+ "test:browser": "mocha test/integration/**/*.test.js",
78
+ "coverage": "cross-env TEST_NODE=1 npm-run-all coverage:*",
79
+ "coverage:build": "nyc npm run test:node"
38
80
  },
39
81
  "mocha": {
82
+ "bail": false,
40
83
  "timeout": 30000,
41
- "file": "./test/conftest.mjs"
84
+ "full-trace": true,
85
+ "inline-diffs": true,
86
+ "check-leaks": false,
87
+ "global": [
88
+ "pyodide",
89
+ "page",
90
+ "chai"
91
+ ],
92
+ "file": [
93
+ "test/conftest.js"
94
+ ]
95
+ },
96
+ "nyc": {
97
+ "reporter": [
98
+ "html",
99
+ "text-summary"
100
+ ],
101
+ "include": [
102
+ "*.ts"
103
+ ],
104
+ "all": true,
105
+ "clean": true,
106
+ "cache": false,
107
+ "instrument": false,
108
+ "checkCoverage": true,
109
+ "statements": 95,
110
+ "functions": 95,
111
+ "branches": 80,
112
+ "lines": 95
42
113
  },
43
114
  "tsd": {
44
115
  "compilerOptions": {
45
116
  "lib": [
46
- "ES2018",
117
+ "ES2017",
47
118
  "DOM"
48
119
  ]
49
120
  }
50
121
  },
51
122
  "dependencies": {
52
123
  "base-64": "^1.0.0",
53
- "node-fetch": "^2.6.1"
124
+ "node-fetch": "^2.6.1",
125
+ "ws": "^8.5.0"
54
126
  }
55
127
  }
package/packages.json ADDED
@@ -0,0 +1 @@
1
+ {"info": {"arch": "wasm32", "platform": "emscripten_3_1_13", "version": "0.21.0a1"}, "packages": {"atomicwrites": {"name": "atomicwrites", "version": "1.4.0", "file_name": "atomicwrites-1.4.0-py2.py3-none-any.whl", "install_dir": "site", "sha256": "237146adf2f517b84d907b8b579caaec792d5243bb4c117b57560629c2dc79a0", "depends": [], "imports": ["atomicwrites"]}, "attrs": {"name": "attrs", "version": "21.4.0", "file_name": "attrs-21.4.0-py2.py3-none-any.whl", "install_dir": "site", "sha256": "4393237a312ba2ec6fa490b93566cde759f5a4de1e25118c56ae998c38fe4e8b", "depends": ["six"], "imports": ["attr"]}, "cpp-exceptions-test": {"name": "cpp-exceptions-test", "version": "0.1", "file_name": "cpp-exceptions-test-0.1.zip", "install_dir": "dynlib", "sha256": "088fcd75ce1692f3c249ce8de905817ea3ea29206ec6cea5d277256e8c092e50", "shared_library": true, "depends": [], "imports": ["cpp-exceptions-test"]}, "distutils": {"name": "distutils", "version": "1.0", "file_name": "distutils.tar", "install_dir": "lib", "sha256": "3b1e2f843b2ccc6051de76cfefcded12f823ab001434d2433123b3db622b5bcb", "depends": [], "imports": ["distutils"]}, "fpcast-test": {"name": "fpcast-test", "version": "0.1", "file_name": "fpcast_test-0.1.1-cp310-cp310-emscripten_3_1_13_wasm32.whl", "install_dir": "site", "sha256": "fc577390d579c21de678ab740c0ae27f32402734885b7c6785bc502fa9d6d107", "depends": [], "imports": ["fpcast_test"]}, "iniconfig": {"name": "iniconfig", "version": "1.1.1", "file_name": "iniconfig-1.1.1-py2.py3-none-any.whl", "install_dir": "site", "sha256": "5de5455987d5a66ace8fe11db6815b57befeea9b6819e88ae88807701298aa20", "depends": [], "imports": ["iniconfig"]}, "jinja2": {"name": "Jinja2", "version": "3.1.1", "file_name": "Jinja2-3.1.1-py3-none-any.whl", "install_dir": "site", "sha256": "3f5068218f8ca47de3de1f1c9be066c2a540eb9bed1d17f0353a9b6aee1b0630", "depends": ["markupsafe"], "imports": ["jinja2"]}, "markupsafe": {"name": "MarkupSafe", "version": "2.1.1", "file_name": "MarkupSafe-2.1.1-cp310-cp310-emscripten_3_1_13_wasm32.whl", "install_dir": "site", "sha256": "8e5b3281ca206a92405108a724f4992dcdfec0d5a718765d63a512f10562130e", "depends": [], "imports": ["markupsafe"]}, "micropip": {"name": "micropip", "version": "0.1", "file_name": "micropip-0.1-py3-none-any.whl", "install_dir": "site", "sha256": "8e947375560230746273c740e4d26a904a048221536b72933b26d1f546f2bb3c", "depends": ["pyparsing", "packaging", "distutils"], "imports": ["micropip"]}, "more-itertools": {"name": "more-itertools", "version": "8.12.0", "file_name": "more_itertools-8.12.0-py3-none-any.whl", "install_dir": "site", "sha256": "f8e09598a125c346dd5e69ead05459280e5b347fe1e4dbaa92aa6e45350476d8", "depends": [], "imports": ["more_itertools"]}, "openssl": {"name": "openssl", "version": "1.1.1n", "file_name": "openssl-1.1.1n.zip", "install_dir": "dynlib", "sha256": "29480dd5e9d9d1a69627abd29ede0ab730c435988edf395118fd8c1f977c7f9b", "shared_library": true, "depends": [], "imports": ["openssl"]}, "packaging": {"name": "packaging", "version": "21.3", "file_name": "packaging-21.3-py3-none-any.whl", "install_dir": "site", "sha256": "bb80805523dc2a1f24d44dec76474f1f9a5b72c535ba3afccd72fe52ee47e502", "depends": ["pyparsing"], "imports": ["packaging"]}, "pluggy": {"name": "pluggy", "version": "1.0.0", "file_name": "pluggy-1.0.0-py2.py3-none-any.whl", "install_dir": "site", "sha256": "80c41b914a0f60f136b62c374d5980ffe37d1af492047699b1e1bb613f52a2d8", "depends": [], "imports": ["pluggy"]}, "py": {"name": "py", "version": "1.11.0", "file_name": "py-1.11.0-py2.py3-none-any.whl", "install_dir": "site", "sha256": "59cb61e1123f6eabbf7974474e46f501ed4cd843e6759272409a286e36af23ae", "depends": [], "imports": ["py", "py.code"]}, "pyparsing": {"name": "pyparsing", "version": "3.0.7", "file_name": "pyparsing-3.0.7-py3-none-any.whl", "install_dir": "site", "sha256": "9cb547629bc7703312a8c8e46531cce1cc0a19c7e24fd3869b98431e90dac9fb", "depends": [], "imports": ["pyparsing"]}, "pytest": {"name": "pytest", "version": "7.1.1", "file_name": "pytest-7.1.1-py3-none-any.whl", "install_dir": "site", "sha256": "aa556bd16302f318888e7ba6a8166cd84c6cb31764d8dd9741473c4410aa52ed", "depends": ["atomicwrites", "attrs", "more-itertools", "pluggy", "py", "setuptools", "six", "iniconfig"], "imports": ["pytest"]}, "pytz": {"name": "pytz", "version": "2022.1", "file_name": "pytz-2022.1-py2.py3-none-any.whl", "install_dir": "site", "sha256": "d06a432bc742ccce9051043fa62771787c4b5c620d4611633e31ea52515de3e4", "depends": [], "imports": ["pytz"]}, "regex": {"name": "regex", "version": "2022.3.15", "file_name": "regex-2022.3.15-cp310-cp310-emscripten_3_1_13_wasm32.whl", "install_dir": "site", "sha256": "6d3fdd2ced1ae9cf59e6a771ffe9aebb2bce9136eb4cd59fdf65eb5715d1dfdd", "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", "sha256": "afaa6f0455b93f9d4ff54056a69bd932a4082ce5a376e044123419f59062b1fd"}, "setuptools": {"name": "setuptools", "version": "62.0.0", "file_name": "setuptools-62.0.0-py3-none-any.whl", "install_dir": "site", "sha256": "ff5d5c7806624a298caaa62a6bc7246f88a72135a33bf3807d10083dec7f1a4c", "depends": ["distutils", "pyparsing"], "imports": ["setuptools", "pkg_resources"]}, "sharedlib-test": {"name": "sharedlib-test", "version": "1.0", "file_name": "sharedlib-test-1.0.zip", "install_dir": "dynlib", "sha256": "3acb04720253832756563b81359bb3d17f6f4dc3ff25a1b961f3ff5523b9e984", "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_3_1_13_wasm32.whl", "install_dir": "site", "sha256": "c200cda407a33858b01d044b676ee269bdff32a6204777e9610765623a3e0664", "depends": ["sharedlib-test"], "imports": ["sharedlib_test"]}, "six": {"name": "six", "version": "1.16.0", "file_name": "six-1.16.0-py2.py3-none-any.whl", "install_dir": "site", "sha256": "634cb16760fff9ebd1009030ccab240545906787d3c95453a00b50fc4847462c", "depends": [], "imports": ["six"]}, "ssl": {"name": "ssl", "version": "1.0.0", "file_name": "ssl-1.0.0.zip", "install_dir": "lib", "sha256": "93f9d8469b0e60863924b4dd5253766d5c623da6f77a10ff18db9695dd4b7b49", "shared_library": true, "depends": ["openssl"], "imports": ["ssl"]}, "tblib": {"name": "tblib", "version": "1.7.0", "file_name": "tblib-1.7.0-py2.py3-none-any.whl", "install_dir": "site", "sha256": "2532542bdb8b27077934a3f26b48c201afa2fc38f35fc6339a85babb4d382806", "depends": [], "imports": ["tblib"]}, "test": {"name": "test", "version": "1.0", "file_name": "test.tar", "install_dir": "lib", "sha256": "dd6b8b2cdc6904db79063469e36a053db85f077621bd5a5ed265cadfedbba1a2", "depends": [], "imports": ["test"]}}}
Binary file