pyodide 0.20.0-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 +168 -0
- package/distutils.tar +0 -0
- package/package.json +31 -9
- package/packages.json +1 -0
- package/pyodide-0.20.1-alpha.2.tgz +0 -0
- package/pyodide.asm.data +0 -0
- package/pyodide.asm.js +17 -0
- package/pyodide.asm.wasm +0 -0
- package/pyodide.d.ts +560 -0
- package/pyodide.js +16 -0
- package/pyodide.js.map +1 -0
- package/pyodide.mjs +16 -0
- package/pyodide.mjs.map +1 -0
- package/pyodide_py.tar +0 -0
- package/README.md +0 -40
- package/api.ts +0 -459
- package/compat.ts +0 -146
- package/error_handling.gen.ts +0 -294
- package/index.d.ts +0 -1
- package/index.test-d.ts +0 -162
- package/load-package.ts +0 -402
- package/module.ts +0 -117
- package/pyodide.ts +0 -309
- package/pyodide.umd.ts +0 -3
- package/pyproxy.gen.ts +0 -1418
- package/rollup.config.js +0 -43
- package/test/conftest.js +0 -7
- package/test/filesystem.test.js +0 -12
- package/test/module.test.js +0 -10
- package/test/pyodide.test.mjs +0 -26
- package/tsconfig.json +0 -15
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.
|
|
3
|
+
"version": "0.20.1-alpha.2",
|
|
4
4
|
"description": "The Pyodide JavaScript package",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"python",
|
|
@@ -18,8 +18,14 @@
|
|
|
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/
|
|
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
|
+
"dts-bundle-generator": "^6.7.0",
|
|
23
29
|
"error-stack-parser": "^2.0.6",
|
|
24
30
|
"mocha": "^9.0.2",
|
|
25
31
|
"prettier": "^2.2.1",
|
|
@@ -27,18 +33,33 @@
|
|
|
27
33
|
"rollup-plugin-terser": "^7.0.2",
|
|
28
34
|
"rollup-plugin-ts": "^2.0.5",
|
|
29
35
|
"terser": "^5.7.0",
|
|
30
|
-
"ts-
|
|
36
|
+
"ts-mocha": "^9.0.2",
|
|
31
37
|
"tsd": "^0.15.1",
|
|
32
|
-
"
|
|
33
|
-
"
|
|
38
|
+
"typedoc": "^0.22.11",
|
|
39
|
+
"typescript": "^4.2.4"
|
|
34
40
|
},
|
|
35
|
-
"
|
|
41
|
+
"main": "pyodide.js",
|
|
42
|
+
"exports": {
|
|
43
|
+
".": {
|
|
44
|
+
"require": "./pyodide.js",
|
|
45
|
+
"import": "./pyodide.mjs"
|
|
46
|
+
},
|
|
47
|
+
"./pyodide.mjs": "./pyodide.mjs",
|
|
48
|
+
"./pyodide.js": "./pyodide.js",
|
|
49
|
+
"./package.json": "./package.json"
|
|
50
|
+
},
|
|
51
|
+
"files": [
|
|
52
|
+
"pyodide*",
|
|
53
|
+
"packages.json",
|
|
54
|
+
"distutils.tar",
|
|
55
|
+
"console.html"
|
|
56
|
+
],
|
|
36
57
|
"scripts": {
|
|
37
|
-
"test": "mocha
|
|
58
|
+
"test": "ts-mocha -p tsconfig.test.json test/**/*.test.ts"
|
|
38
59
|
},
|
|
39
60
|
"mocha": {
|
|
40
61
|
"timeout": 30000,
|
|
41
|
-
"file": "
|
|
62
|
+
"file": "test/conftest.ts"
|
|
42
63
|
},
|
|
43
64
|
"tsd": {
|
|
44
65
|
"compilerOptions": {
|
|
@@ -50,6 +71,7 @@
|
|
|
50
71
|
},
|
|
51
72
|
"dependencies": {
|
|
52
73
|
"base-64": "^1.0.0",
|
|
53
|
-
"node-fetch": "^2.6.1"
|
|
74
|
+
"node-fetch": "^2.6.1",
|
|
75
|
+
"ws": "^8.5.0"
|
|
54
76
|
}
|
|
55
77
|
}
|
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
|
package/pyodide.asm.data
ADDED
|
Binary file
|