rapydscript-ns 0.8.4 → 0.9.0

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.
Files changed (132) hide show
  1. package/.agignore +1 -1
  2. package/.github/workflows/ci.yml +38 -38
  3. package/=template.pyj +5 -5
  4. package/CHANGELOG.md +18 -0
  5. package/HACKING.md +103 -103
  6. package/LICENSE +24 -24
  7. package/README.md +715 -169
  8. package/TODO.md +9 -2
  9. package/add-toc-to-readme +2 -2
  10. package/bin/export +75 -75
  11. package/bin/rapydscript +70 -70
  12. package/bin/web-repl-export +102 -102
  13. package/build +2 -2
  14. package/language-service/index.js +36 -27
  15. package/package.json +1 -1
  16. package/publish.py +37 -37
  17. package/release/baselib-plain-pretty.js +2358 -168
  18. package/release/baselib-plain-ugly.js +73 -3
  19. package/release/compiler.js +6282 -3092
  20. package/release/signatures.json +31 -30
  21. package/session.vim +4 -4
  22. package/setup.cfg +2 -2
  23. package/src/ast.pyj +1 -0
  24. package/src/baselib-builtins.pyj +340 -2
  25. package/src/baselib-bytes.pyj +664 -0
  26. package/src/baselib-errors.pyj +1 -1
  27. package/src/baselib-internal.pyj +267 -60
  28. package/src/baselib-itertools.pyj +110 -97
  29. package/src/baselib-str.pyj +22 -4
  30. package/src/compiler.pyj +36 -36
  31. package/src/errors.pyj +30 -30
  32. package/src/lib/abc.pyj +317 -0
  33. package/src/lib/aes.pyj +646 -646
  34. package/src/lib/copy.pyj +120 -120
  35. package/src/lib/dataclasses.pyj +532 -0
  36. package/src/lib/elementmaker.pyj +83 -83
  37. package/src/lib/encodings.pyj +126 -126
  38. package/src/lib/enum.pyj +125 -0
  39. package/src/lib/gettext.pyj +569 -569
  40. package/src/lib/itertools.pyj +580 -580
  41. package/src/lib/math.pyj +193 -193
  42. package/src/lib/operator.pyj +11 -11
  43. package/src/lib/pythonize.pyj +20 -20
  44. package/src/lib/random.pyj +118 -118
  45. package/src/lib/re.pyj +504 -470
  46. package/src/lib/react.pyj +74 -74
  47. package/src/lib/traceback.pyj +63 -63
  48. package/src/lib/typing.pyj +577 -0
  49. package/src/lib/uuid.pyj +77 -77
  50. package/src/monaco-language-service/builtins.js +14 -4
  51. package/src/monaco-language-service/diagnostics.js +19 -20
  52. package/src/monaco-language-service/dts.js +550 -550
  53. package/src/output/classes.pyj +62 -26
  54. package/src/output/comments.pyj +45 -45
  55. package/src/output/exceptions.pyj +201 -201
  56. package/src/output/functions.pyj +78 -5
  57. package/src/output/jsx.pyj +164 -164
  58. package/src/output/loops.pyj +5 -2
  59. package/src/output/operators.pyj +100 -34
  60. package/src/output/treeshake.pyj +182 -182
  61. package/src/output/utils.pyj +72 -72
  62. package/src/parse.pyj +80 -16
  63. package/src/string_interpolation.pyj +72 -72
  64. package/src/tokenizer.pyj +9 -4
  65. package/src/unicode_aliases.pyj +576 -576
  66. package/src/utils.pyj +192 -192
  67. package/test/_import_one.pyj +37 -37
  68. package/test/_import_two/__init__.pyj +11 -11
  69. package/test/_import_two/level2/deep.pyj +4 -4
  70. package/test/_import_two/other.pyj +6 -6
  71. package/test/_import_two/sub.pyj +13 -13
  72. package/test/abc.pyj +291 -0
  73. package/test/aes_vectors.pyj +421 -421
  74. package/test/annotations.pyj +80 -80
  75. package/test/arithmetic_nostrict.pyj +88 -0
  76. package/test/arithmetic_types.pyj +169 -0
  77. package/test/baselib.pyj +91 -0
  78. package/test/bytes.pyj +467 -0
  79. package/test/classes.pyj +1 -0
  80. package/test/comparison_ops.pyj +173 -0
  81. package/test/dataclasses.pyj +253 -0
  82. package/test/decorators.pyj +77 -77
  83. package/test/docstrings.pyj +39 -39
  84. package/test/elementmaker_test.pyj +45 -45
  85. package/test/enum.pyj +134 -0
  86. package/test/eval_exec.pyj +56 -0
  87. package/test/format.pyj +148 -0
  88. package/test/functions.pyj +151 -151
  89. package/test/generators.pyj +41 -41
  90. package/test/generic.pyj +370 -370
  91. package/test/imports.pyj +72 -72
  92. package/test/internationalization.pyj +73 -73
  93. package/test/lint.pyj +164 -164
  94. package/test/loops.pyj +85 -85
  95. package/test/numpy.pyj +734 -734
  96. package/test/object.pyj +64 -0
  97. package/test/omit_function_metadata.pyj +20 -20
  98. package/test/python_compat.pyj +17 -15
  99. package/test/python_features.pyj +70 -15
  100. package/test/regexp.pyj +83 -55
  101. package/test/repl.pyj +121 -121
  102. package/test/scoped_flags.pyj +76 -76
  103. package/test/tuples.pyj +96 -0
  104. package/test/typing.pyj +469 -0
  105. package/test/unit/index.js +116 -7
  106. package/test/unit/language-service-dts.js +543 -543
  107. package/test/unit/language-service-hover.js +455 -455
  108. package/test/unit/language-service.js +84 -0
  109. package/test/unit/web-repl.js +804 -1
  110. package/test/vars_locals_globals.pyj +94 -0
  111. package/tools/cli.js +558 -547
  112. package/tools/compile.js +224 -219
  113. package/tools/completer.js +131 -131
  114. package/tools/embedded_compiler.js +262 -251
  115. package/tools/gettext.js +185 -185
  116. package/tools/ini.js +65 -65
  117. package/tools/lint.js +16 -19
  118. package/tools/msgfmt.js +187 -187
  119. package/tools/repl.js +223 -223
  120. package/tools/test.js +118 -118
  121. package/tools/utils.js +128 -128
  122. package/tools/web_repl.js +95 -95
  123. package/try +41 -41
  124. package/web-repl/env.js +196 -196
  125. package/web-repl/index.html +163 -163
  126. package/web-repl/main.js +252 -252
  127. package/web-repl/prism.css +139 -139
  128. package/web-repl/prism.js +113 -113
  129. package/web-repl/rapydscript.js +224 -224
  130. package/web-repl/sha1.js +25 -25
  131. package/PYTHON_DIFFERENCES_REPORT.md +0 -291
  132. package/PYTHON_FEATURE_COVERAGE.md +0 -200
package/tools/web_repl.js CHANGED
@@ -1,95 +1,95 @@
1
- /* vim:fileencoding=utf-8
2
- *
3
- * Copyright (C) 2016 Kovid Goyal <kovid at kovidgoyal.net>
4
- *
5
- * Distributed under terms of the BSD license
6
- */
7
- "use strict"; /*jshint node:true */
8
- var vm = require('vm');
9
- var embedded_compiler = require('tools/embedded_compiler.js');
10
-
11
- module.exports = function(compiler, baselib, vf_context) {
12
- var ctx = vm.createContext();
13
- var LINE_CONTINUATION_CHARS = ':\\';
14
- var find_completions = null;
15
- function strip_exports(js) { return js.replace(/^export ((?:async )?function |let )/gm, '$1'); }
16
- var streaming_compiler = embedded_compiler(compiler, baselib, function(js) { return vm.runInContext(strip_exports(js), ctx); }, '__repl__', vf_context);
17
-
18
- return {
19
- 'in_block_mode': false,
20
-
21
- 'replace_print': function replace_print(write_line_func) {
22
- ctx.print = function() {
23
- var parts = [];
24
- for (var i = 0; i < arguments.length; i++)
25
- parts.push(ctx.ρσ_str(arguments[i]));
26
- write_line_func(parts.join(' '));
27
- };
28
- },
29
-
30
- 'is_input_complete': function is_input_complete(source) {
31
- if (!source || !source.trim()) return false;
32
- var lines = source.split('\n');
33
- var last_line = lines[lines.length - 1].trimRight();
34
- if (this.in_block_mode) {
35
- // In a block only exit after two blank lines
36
- if (lines.length < 2) return false;
37
- var second_last_line = lines[lines.length - 2].trimRight();
38
- var block_ended = !!(!last_line && !second_last_line);
39
- if (!block_ended) return false;
40
- this.in_block_mode = false;
41
- return true;
42
- }
43
-
44
- if (last_line && LINE_CONTINUATION_CHARS.indexOf(last_line.substr(last_line.length - 1)) > -1) {
45
- this.in_block_mode = true;
46
- return false;
47
- }
48
- try {
49
- compiler.parse(source, {'filename': '<repl>', 'basedir': '__stdlib__'});
50
- } catch(e) {
51
- if (e.is_eof && e.line === lines.length && e.col > 0) {
52
- return false;
53
- }
54
- this.in_block_mode = false;
55
- return true;
56
- }
57
- this.in_block_mode = false;
58
- return true;
59
- },
60
-
61
- 'compile': function web_repl_compile(code, opts) {
62
- opts = opts || {};
63
- opts.keep_docstrings = true;
64
- opts.filename = '<input>';
65
- return streaming_compiler.compile(code, opts);
66
- },
67
-
68
- 'compile_mapped': function web_repl_compile_mapped(code, opts) {
69
- opts = opts || {};
70
- opts.keep_docstrings = true;
71
- opts.filename = '<input>';
72
- return streaming_compiler.compile_with_sourcemap(code, opts);
73
- },
74
-
75
- 'runjs': function runjs(code) {
76
- var ans = vm.runInContext(strip_exports(code), ctx);
77
- if (ans !== undefined || ans === null) {
78
- ctx.ρσ_repl_val = ans;
79
- var q = vm.runInContext('ρσ_repr(ρσ_repl_val)', ctx);
80
- ans = (q === 'undefined') ? ans.toString() : q;
81
- }
82
- return ans;
83
- },
84
-
85
- 'init_completions': function init_completions(completelib) {
86
- find_completions = completelib(compiler);
87
- },
88
-
89
- 'find_completions': function find_completions_(line) {
90
- return find_completions(line, ctx);
91
- },
92
-
93
- };
94
- };
95
-
1
+ /* vim:fileencoding=utf-8
2
+ *
3
+ * Copyright (C) 2016 Kovid Goyal <kovid at kovidgoyal.net>
4
+ *
5
+ * Distributed under terms of the BSD license
6
+ */
7
+ "use strict"; /*jshint node:true */
8
+ var vm = require('vm');
9
+ var embedded_compiler = require('tools/embedded_compiler.js');
10
+
11
+ module.exports = function(compiler, baselib, vf_context) {
12
+ var ctx = vm.createContext();
13
+ var LINE_CONTINUATION_CHARS = ':\\';
14
+ var find_completions = null;
15
+ function strip_exports(js) { return js.replace(/^export ((?:async )?function |let )/gm, '$1'); }
16
+ var streaming_compiler = embedded_compiler(compiler, baselib, function(js) { return vm.runInContext(strip_exports(js), ctx); }, '__repl__', vf_context);
17
+
18
+ return {
19
+ 'in_block_mode': false,
20
+
21
+ 'replace_print': function replace_print(write_line_func) {
22
+ ctx.print = function() {
23
+ var parts = [];
24
+ for (var i = 0; i < arguments.length; i++)
25
+ parts.push(ctx.ρσ_str(arguments[i]));
26
+ write_line_func(parts.join(' '));
27
+ };
28
+ },
29
+
30
+ 'is_input_complete': function is_input_complete(source) {
31
+ if (!source || !source.trim()) return false;
32
+ var lines = source.split('\n');
33
+ var last_line = lines[lines.length - 1].trimRight();
34
+ if (this.in_block_mode) {
35
+ // In a block only exit after two blank lines
36
+ if (lines.length < 2) return false;
37
+ var second_last_line = lines[lines.length - 2].trimRight();
38
+ var block_ended = !!(!last_line && !second_last_line);
39
+ if (!block_ended) return false;
40
+ this.in_block_mode = false;
41
+ return true;
42
+ }
43
+
44
+ if (last_line && LINE_CONTINUATION_CHARS.indexOf(last_line.substr(last_line.length - 1)) > -1) {
45
+ this.in_block_mode = true;
46
+ return false;
47
+ }
48
+ try {
49
+ compiler.parse(source, {'filename': '<repl>', 'basedir': '__stdlib__'});
50
+ } catch(e) {
51
+ if (e.is_eof && e.line === lines.length && e.col > 0) {
52
+ return false;
53
+ }
54
+ this.in_block_mode = false;
55
+ return true;
56
+ }
57
+ this.in_block_mode = false;
58
+ return true;
59
+ },
60
+
61
+ 'compile': function web_repl_compile(code, opts) {
62
+ opts = opts || {};
63
+ opts.keep_docstrings = true;
64
+ opts.filename = '<input>';
65
+ return streaming_compiler.compile(code, opts);
66
+ },
67
+
68
+ 'compile_mapped': function web_repl_compile_mapped(code, opts) {
69
+ opts = opts || {};
70
+ opts.keep_docstrings = true;
71
+ opts.filename = '<input>';
72
+ return streaming_compiler.compile_with_sourcemap(code, opts);
73
+ },
74
+
75
+ 'runjs': function runjs(code) {
76
+ var ans = vm.runInContext(strip_exports(code), ctx);
77
+ if (ans !== undefined || ans === null) {
78
+ ctx.ρσ_repl_val = ans;
79
+ var q = vm.runInContext('ρσ_repr(ρσ_repl_val)', ctx);
80
+ ans = (q === 'undefined') ? ans.toString() : q;
81
+ }
82
+ return ans;
83
+ },
84
+
85
+ 'init_completions': function init_completions(completelib) {
86
+ find_completions = completelib(compiler);
87
+ },
88
+
89
+ 'find_completions': function find_completions_(line) {
90
+ return find_completions(line, ctx);
91
+ },
92
+
93
+ };
94
+ };
95
+
package/try CHANGED
@@ -1,41 +1,41 @@
1
- #!/usr/bin/env python3
2
-
3
- import subprocess
4
- import sys
5
- import os
6
- import shutil
7
-
8
- args = sys.argv[1:]
9
- source = None
10
-
11
- cmd = ['bin/rapydscript']
12
-
13
- while args:
14
- if args[0] in ('-m', '-x'):
15
- cmd.append(args.pop(0))
16
- elif args[0] == '-f':
17
- args.pop(0)
18
- source = args[0]
19
- cmd.append(source)
20
- else:
21
- break
22
-
23
- raw = ' '.join(args).replace('\\n', '\n')
24
-
25
- if os.path.exists('dev'):
26
- shutil.rmtree('dev')
27
- shutil.copytree('release', 'dev')
28
- subprocess.check_call(cmd[:1] + ['self'])
29
- if source:
30
- p = subprocess.Popen(
31
- ['node', '--stack-trace-limit=1000'] + cmd)
32
- else:
33
- p = subprocess.Popen(
34
- ['node', '--stack-trace-limit=1000'] + cmd, stdin=subprocess.PIPE)
35
- p.stdin.write(raw.encode('utf-8'))
36
- p.stdin.close()
37
- try:
38
- raise SystemExit(p.wait())
39
- except KeyboardInterrupt:
40
- p.kill()
41
- raise SystemExit(1)
1
+ #!/usr/bin/env python3
2
+
3
+ import subprocess
4
+ import sys
5
+ import os
6
+ import shutil
7
+
8
+ args = sys.argv[1:]
9
+ source = None
10
+
11
+ cmd = ['bin/rapydscript']
12
+
13
+ while args:
14
+ if args[0] in ('-m', '-x'):
15
+ cmd.append(args.pop(0))
16
+ elif args[0] == '-f':
17
+ args.pop(0)
18
+ source = args[0]
19
+ cmd.append(source)
20
+ else:
21
+ break
22
+
23
+ raw = ' '.join(args).replace('\\n', '\n')
24
+
25
+ if os.path.exists('dev'):
26
+ shutil.rmtree('dev')
27
+ shutil.copytree('release', 'dev')
28
+ subprocess.check_call(cmd[:1] + ['self'])
29
+ if source:
30
+ p = subprocess.Popen(
31
+ ['node', '--stack-trace-limit=1000'] + cmd)
32
+ else:
33
+ p = subprocess.Popen(
34
+ ['node', '--stack-trace-limit=1000'] + cmd, stdin=subprocess.PIPE)
35
+ p.stdin.write(raw.encode('utf-8'))
36
+ p.stdin.close()
37
+ try:
38
+ raise SystemExit(p.wait())
39
+ except KeyboardInterrupt:
40
+ p.kill()
41
+ raise SystemExit(1)
package/web-repl/env.js CHANGED
@@ -1,196 +1,196 @@
1
- /* vim:fileencoding=utf-8
2
- *
3
- * Copyright (C) 2016 Kovid Goyal <kovid at kovidgoyal.net>
4
- *
5
- * Distributed under terms of the BSD license
6
- */
7
-
8
- var namespace = {}, jsSHA = {};
9
-
10
- var write_cache = {};
11
-
12
- var builtin_modules = {
13
- 'crypto' : {
14
- 'createHash': function create_hash() {
15
- var ans = new jsSHA.jsSHA('SHA-1', 'TEXT');
16
- ans.digest = function hex_digest() { return ans.getHash('HEX'); };
17
- return ans;
18
- },
19
- },
20
-
21
- 'vm': {
22
- 'createContext': function create_context(ctx) {
23
- var iframe = document.createElement('iframe');
24
- iframe.style.display = 'none';
25
- document.body.appendChild(iframe);
26
- var win = iframe.contentWindow;
27
- if(!ctx) ctx = {};
28
- if (!ctx.sha1sum) ctx.sha1sum = sha1sum;
29
- if (!ctx.require) ctx.require = require;
30
- if (!ctx.React) ctx.React = (function() {
31
- var Fragment = Symbol('React.Fragment');
32
-
33
- function createElement(type, props) {
34
- var children = Array.prototype.slice.call(arguments, 2);
35
- return {
36
- type: type,
37
- props: Object.assign({children: children.length === 1 ? children[0] : children}, props)
38
- };
39
- }
40
-
41
- // Minimal hook stubs — enough to run REPL snippets without React DOM.
42
- function useState(initial) {
43
- var state = (typeof initial === 'function') ? initial() : initial;
44
- return [state, function(v) { state = (typeof v === 'function') ? v(state) : v; }];
45
- }
46
-
47
- function useEffect(fn /*, deps */) {
48
- var cleanup = fn();
49
- // cleanup would be called on unmount; ignored in stub
50
- }
51
-
52
- function useLayoutEffect(fn /*, deps */) { fn(); }
53
-
54
- function useMemo(fn /*, deps */) { return fn(); }
55
-
56
- function useCallback(fn /*, deps */) { return fn; }
57
-
58
- function useRef(initial) { return { current: initial }; }
59
-
60
- function useContext(ctx) { return ctx && ctx._currentValue !== undefined ? ctx._currentValue : undefined; }
61
-
62
- function useReducer(reducer, initial, init) {
63
- var state = (init !== undefined) ? init(initial) : initial;
64
- return [state, function(action) { state = reducer(state, action); }];
65
- }
66
-
67
- function useImperativeHandle(ref, create /*, deps */) {
68
- if (ref) ref.current = create();
69
- }
70
-
71
- function useDebugValue() {}
72
-
73
- function useId() { return ':r' + (Math.random() * 1e9 | 0) + ':'; }
74
-
75
- function useTransition() { return [false, function(fn) { fn(); }]; }
76
-
77
- function useDeferredValue(value) { return value; }
78
-
79
- function useSyncExternalStore(subscribe, getSnapshot) { return getSnapshot(); }
80
-
81
- function useInsertionEffect(fn /*, deps */) { fn(); }
82
-
83
- function createContext(defaultValue) {
84
- return { _currentValue: defaultValue, Provider: function(props) { return props.children; }, Consumer: function(props) { return props.children(defaultValue); } };
85
- }
86
-
87
- function createRef() { return { current: null }; }
88
-
89
- function forwardRef(render) {
90
- return function(props) { return render(props, null); };
91
- }
92
-
93
- function memo(Component /*, compare */) { return Component; }
94
-
95
- function lazy(factory) { return factory; }
96
-
97
- function cloneElement(element, props) {
98
- return Object.assign({}, element, { props: Object.assign({}, element.props, props) });
99
- }
100
-
101
- function isValidElement(obj) {
102
- return obj !== null && typeof obj === 'object' && obj.type !== undefined;
103
- }
104
-
105
- function Component() {}
106
- Component.prototype.render = function() { return null; };
107
- Component.prototype.setState = function(update) {
108
- var next = (typeof update === 'function') ? update(this.state) : update;
109
- this.state = Object.assign({}, this.state, next);
110
- };
111
-
112
- function PureComponent() {}
113
- PureComponent.prototype = Object.create(Component.prototype);
114
- PureComponent.prototype.constructor = PureComponent;
115
-
116
- var StrictMode = { type: Symbol('React.StrictMode') };
117
- var Suspense = { type: Symbol('React.Suspense') };
118
- var Profiler = { type: Symbol('React.Profiler') };
119
-
120
- return {
121
- Fragment: Fragment,
122
- createElement: createElement,
123
- useState: useState,
124
- useEffect: useEffect,
125
- useLayoutEffect: useLayoutEffect,
126
- useMemo: useMemo,
127
- useCallback: useCallback,
128
- useRef: useRef,
129
- useContext: useContext,
130
- useReducer: useReducer,
131
- useImperativeHandle: useImperativeHandle,
132
- useDebugValue: useDebugValue,
133
- useId: useId,
134
- useTransition: useTransition,
135
- useDeferredValue: useDeferredValue,
136
- useSyncExternalStore: useSyncExternalStore,
137
- useInsertionEffect: useInsertionEffect,
138
- createContext: createContext,
139
- createRef: createRef,
140
- forwardRef: forwardRef,
141
- memo: memo,
142
- lazy: lazy,
143
- cloneElement: cloneElement,
144
- isValidElement: isValidElement,
145
- Component: Component,
146
- PureComponent: PureComponent,
147
- StrictMode: StrictMode,
148
- Suspense: Suspense,
149
- Profiler: Profiler,
150
- };
151
- })();
152
- Object.keys(ctx).forEach(function(k) { win[k] = ctx[k]; });
153
- return win;
154
- },
155
-
156
- 'runInContext': function run_in_context(code, ctx) {
157
- return ctx.eval(code.replace(/^export ((?:async )?function |let )/gm, '$1'));
158
- },
159
-
160
- 'runInThisContext': eval,
161
- },
162
- 'path': {
163
- 'join': function path_join() { return Array.prototype.slice.call(arguments).join('/'); },
164
- 'dirname': function path_dirname(path) {
165
- return path.split('/').slice(0, -1).join('/');
166
- },
167
- },
168
- 'inspect': function inspect(x) { return x.toString(); },
169
-
170
- 'fs': {
171
- 'readFileSync': function readfile(name) {
172
- if (namespace.virtual_file_system && namespace.virtual_file_system.read_file_sync) {
173
- data = namespace.virtual_file_system.read_file_sync(name);
174
- if (data !== null) return data;
175
- }
176
- var data = namespace.file_data[name];
177
- if (data) return data;
178
- data = write_cache[name];
179
- if (data) return data;
180
- var err = Error();
181
- err.code = 'ENOENT';
182
- throw err;
183
- },
184
-
185
- 'writeFileSync': function writefile(name, data) {
186
- if (namespace.virtual_file_system && namespace.virtual_file_system.write_file_sync) {
187
- namespace.virtual_file_system.write_file_sync(name, data);
188
- } else write_cache[name] = data;
189
- },
190
-
191
- },
192
- };
193
-
194
- function require(name) {
195
- return builtin_modules[name] || {};
196
- }
1
+ /* vim:fileencoding=utf-8
2
+ *
3
+ * Copyright (C) 2016 Kovid Goyal <kovid at kovidgoyal.net>
4
+ *
5
+ * Distributed under terms of the BSD license
6
+ */
7
+
8
+ var namespace = {}, jsSHA = {};
9
+
10
+ var write_cache = {};
11
+
12
+ var builtin_modules = {
13
+ 'crypto' : {
14
+ 'createHash': function create_hash() {
15
+ var ans = new jsSHA.jsSHA('SHA-1', 'TEXT');
16
+ ans.digest = function hex_digest() { return ans.getHash('HEX'); };
17
+ return ans;
18
+ },
19
+ },
20
+
21
+ 'vm': {
22
+ 'createContext': function create_context(ctx) {
23
+ var iframe = document.createElement('iframe');
24
+ iframe.style.display = 'none';
25
+ document.body.appendChild(iframe);
26
+ var win = iframe.contentWindow;
27
+ if(!ctx) ctx = {};
28
+ if (!ctx.sha1sum) ctx.sha1sum = sha1sum;
29
+ if (!ctx.require) ctx.require = require;
30
+ if (!ctx.React) ctx.React = (function() {
31
+ var Fragment = Symbol('React.Fragment');
32
+
33
+ function createElement(type, props) {
34
+ var children = Array.prototype.slice.call(arguments, 2);
35
+ return {
36
+ type: type,
37
+ props: Object.assign({children: children.length === 1 ? children[0] : children}, props)
38
+ };
39
+ }
40
+
41
+ // Minimal hook stubs — enough to run REPL snippets without React DOM.
42
+ function useState(initial) {
43
+ var state = (typeof initial === 'function') ? initial() : initial;
44
+ return [state, function(v) { state = (typeof v === 'function') ? v(state) : v; }];
45
+ }
46
+
47
+ function useEffect(fn /*, deps */) {
48
+ var cleanup = fn();
49
+ // cleanup would be called on unmount; ignored in stub
50
+ }
51
+
52
+ function useLayoutEffect(fn /*, deps */) { fn(); }
53
+
54
+ function useMemo(fn /*, deps */) { return fn(); }
55
+
56
+ function useCallback(fn /*, deps */) { return fn; }
57
+
58
+ function useRef(initial) { return { current: initial }; }
59
+
60
+ function useContext(ctx) { return ctx && ctx._currentValue !== undefined ? ctx._currentValue : undefined; }
61
+
62
+ function useReducer(reducer, initial, init) {
63
+ var state = (init !== undefined) ? init(initial) : initial;
64
+ return [state, function(action) { state = reducer(state, action); }];
65
+ }
66
+
67
+ function useImperativeHandle(ref, create /*, deps */) {
68
+ if (ref) ref.current = create();
69
+ }
70
+
71
+ function useDebugValue() {}
72
+
73
+ function useId() { return ':r' + (Math.random() * 1e9 | 0) + ':'; }
74
+
75
+ function useTransition() { return [false, function(fn) { fn(); }]; }
76
+
77
+ function useDeferredValue(value) { return value; }
78
+
79
+ function useSyncExternalStore(subscribe, getSnapshot) { return getSnapshot(); }
80
+
81
+ function useInsertionEffect(fn /*, deps */) { fn(); }
82
+
83
+ function createContext(defaultValue) {
84
+ return { _currentValue: defaultValue, Provider: function(props) { return props.children; }, Consumer: function(props) { return props.children(defaultValue); } };
85
+ }
86
+
87
+ function createRef() { return { current: null }; }
88
+
89
+ function forwardRef(render) {
90
+ return function(props) { return render(props, null); };
91
+ }
92
+
93
+ function memo(Component /*, compare */) { return Component; }
94
+
95
+ function lazy(factory) { return factory; }
96
+
97
+ function cloneElement(element, props) {
98
+ return Object.assign({}, element, { props: Object.assign({}, element.props, props) });
99
+ }
100
+
101
+ function isValidElement(obj) {
102
+ return obj !== null && typeof obj === 'object' && obj.type !== undefined;
103
+ }
104
+
105
+ function Component() {}
106
+ Component.prototype.render = function() { return null; };
107
+ Component.prototype.setState = function(update) {
108
+ var next = (typeof update === 'function') ? update(this.state) : update;
109
+ this.state = Object.assign({}, this.state, next);
110
+ };
111
+
112
+ function PureComponent() {}
113
+ PureComponent.prototype = Object.create(Component.prototype);
114
+ PureComponent.prototype.constructor = PureComponent;
115
+
116
+ var StrictMode = { type: Symbol('React.StrictMode') };
117
+ var Suspense = { type: Symbol('React.Suspense') };
118
+ var Profiler = { type: Symbol('React.Profiler') };
119
+
120
+ return {
121
+ Fragment: Fragment,
122
+ createElement: createElement,
123
+ useState: useState,
124
+ useEffect: useEffect,
125
+ useLayoutEffect: useLayoutEffect,
126
+ useMemo: useMemo,
127
+ useCallback: useCallback,
128
+ useRef: useRef,
129
+ useContext: useContext,
130
+ useReducer: useReducer,
131
+ useImperativeHandle: useImperativeHandle,
132
+ useDebugValue: useDebugValue,
133
+ useId: useId,
134
+ useTransition: useTransition,
135
+ useDeferredValue: useDeferredValue,
136
+ useSyncExternalStore: useSyncExternalStore,
137
+ useInsertionEffect: useInsertionEffect,
138
+ createContext: createContext,
139
+ createRef: createRef,
140
+ forwardRef: forwardRef,
141
+ memo: memo,
142
+ lazy: lazy,
143
+ cloneElement: cloneElement,
144
+ isValidElement: isValidElement,
145
+ Component: Component,
146
+ PureComponent: PureComponent,
147
+ StrictMode: StrictMode,
148
+ Suspense: Suspense,
149
+ Profiler: Profiler,
150
+ };
151
+ })();
152
+ Object.keys(ctx).forEach(function(k) { win[k] = ctx[k]; });
153
+ return win;
154
+ },
155
+
156
+ 'runInContext': function run_in_context(code, ctx) {
157
+ return ctx.eval(code.replace(/^export ((?:async )?function |let )/gm, '$1'));
158
+ },
159
+
160
+ 'runInThisContext': eval,
161
+ },
162
+ 'path': {
163
+ 'join': function path_join() { return Array.prototype.slice.call(arguments).join('/'); },
164
+ 'dirname': function path_dirname(path) {
165
+ return path.split('/').slice(0, -1).join('/');
166
+ },
167
+ },
168
+ 'inspect': function inspect(x) { return x.toString(); },
169
+
170
+ 'fs': {
171
+ 'readFileSync': function readfile(name) {
172
+ if (namespace.virtual_file_system && namespace.virtual_file_system.read_file_sync) {
173
+ data = namespace.virtual_file_system.read_file_sync(name);
174
+ if (data !== null) return data;
175
+ }
176
+ var data = namespace.file_data[name];
177
+ if (data) return data;
178
+ data = write_cache[name];
179
+ if (data) return data;
180
+ var err = Error();
181
+ err.code = 'ENOENT';
182
+ throw err;
183
+ },
184
+
185
+ 'writeFileSync': function writefile(name, data) {
186
+ if (namespace.virtual_file_system && namespace.virtual_file_system.write_file_sync) {
187
+ namespace.virtual_file_system.write_file_sync(name, data);
188
+ } else write_cache[name] = data;
189
+ },
190
+
191
+ },
192
+ };
193
+
194
+ function require(name) {
195
+ return builtin_modules[name] || {};
196
+ }