rapydscript-ns 0.9.0 → 0.9.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.
Files changed (100) 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 +10 -0
  5. package/HACKING.md +103 -103
  6. package/LICENSE +24 -24
  7. package/README.md +7 -6
  8. package/TODO.md +116 -1
  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 +9 -9
  15. package/language-service/language-service.d.ts +1 -1
  16. package/package.json +6 -2
  17. package/publish.py +37 -37
  18. package/release/compiler.js +246 -231
  19. package/release/signatures.json +23 -23
  20. package/session.vim +4 -4
  21. package/setup.cfg +2 -2
  22. package/src/compiler.pyj +36 -36
  23. package/src/errors.pyj +30 -30
  24. package/src/lib/aes.pyj +646 -646
  25. package/src/lib/contextlib.pyj +379 -0
  26. package/src/lib/copy.pyj +120 -120
  27. package/src/lib/datetime.pyj +712 -0
  28. package/src/lib/elementmaker.pyj +83 -83
  29. package/src/lib/encodings.pyj +126 -126
  30. package/src/lib/gettext.pyj +569 -569
  31. package/src/lib/io.pyj +500 -0
  32. package/src/lib/itertools.pyj +580 -580
  33. package/src/lib/json.pyj +227 -0
  34. package/src/lib/math.pyj +193 -193
  35. package/src/lib/operator.pyj +11 -11
  36. package/src/lib/pythonize.pyj +20 -20
  37. package/src/lib/random.pyj +118 -118
  38. package/src/lib/react.pyj +74 -74
  39. package/src/lib/traceback.pyj +63 -63
  40. package/src/lib/uuid.pyj +77 -77
  41. package/src/monaco-language-service/diagnostics.js +4 -4
  42. package/src/monaco-language-service/dts.js +550 -550
  43. package/src/monaco-language-service/index.js +2 -2
  44. package/src/output/comments.pyj +45 -45
  45. package/src/output/exceptions.pyj +201 -201
  46. package/src/output/jsx.pyj +164 -164
  47. package/src/output/loops.pyj +9 -0
  48. package/src/output/treeshake.pyj +182 -182
  49. package/src/output/utils.pyj +72 -72
  50. package/src/string_interpolation.pyj +72 -72
  51. package/src/tokenizer.pyj +1 -1
  52. package/src/unicode_aliases.pyj +576 -576
  53. package/src/utils.pyj +192 -192
  54. package/test/_import_one.pyj +37 -37
  55. package/test/_import_two/__init__.pyj +11 -11
  56. package/test/_import_two/level2/deep.pyj +4 -4
  57. package/test/_import_two/other.pyj +6 -6
  58. package/test/_import_two/sub.pyj +13 -13
  59. package/test/aes_vectors.pyj +421 -421
  60. package/test/annotations.pyj +80 -80
  61. package/test/contextlib.pyj +362 -0
  62. package/test/datetime.pyj +500 -0
  63. package/test/debugger_stmt.pyj +41 -0
  64. package/test/decorators.pyj +77 -77
  65. package/test/docstrings.pyj +39 -39
  66. package/test/elementmaker_test.pyj +45 -45
  67. package/test/functions.pyj +151 -151
  68. package/test/generators.pyj +41 -41
  69. package/test/generic.pyj +370 -370
  70. package/test/imports.pyj +72 -72
  71. package/test/internationalization.pyj +73 -73
  72. package/test/io.pyj +316 -0
  73. package/test/json.pyj +196 -0
  74. package/test/lint.pyj +164 -164
  75. package/test/loops.pyj +85 -85
  76. package/test/numpy.pyj +734 -734
  77. package/test/omit_function_metadata.pyj +20 -20
  78. package/test/repl.pyj +121 -121
  79. package/test/scoped_flags.pyj +76 -76
  80. package/test/unit/index.js +66 -0
  81. package/test/unit/language-service-dts.js +543 -543
  82. package/test/unit/language-service-hover.js +455 -455
  83. package/test/unit/language-service.js +1 -1
  84. package/test/unit/web-repl.js +533 -0
  85. package/tools/compiler.d.ts +367 -0
  86. package/tools/completer.js +131 -131
  87. package/tools/gettext.js +185 -185
  88. package/tools/ini.js +65 -65
  89. package/tools/msgfmt.js +187 -187
  90. package/tools/repl.js +223 -223
  91. package/tools/test.js +118 -118
  92. package/tools/utils.js +128 -128
  93. package/tools/web_repl.js +95 -95
  94. package/try +41 -41
  95. package/web-repl/env.js +196 -196
  96. package/web-repl/index.html +163 -163
  97. package/web-repl/prism.css +139 -139
  98. package/web-repl/prism.js +113 -113
  99. package/web-repl/rapydscript.js +224 -224
  100. package/web-repl/sha1.js +25 -25
package/tools/repl.js CHANGED
@@ -1,223 +1,223 @@
1
- /*
2
- * repl.js
3
- * Copyright (C) 2015 Kovid Goyal <kovid at kovidgoyal.net>
4
- *
5
- * Distributed under terms of the BSD license.
6
- */
7
- "use strict"; /*jshint node:true */
8
-
9
- var fs = require('fs');
10
- var path = require('path');
11
- var vm = require('vm');
12
- var util = require('util');
13
- var utils = require('./utils');
14
- var completelib = require('./completer');
15
- var colored = utils.safe_colored;
16
- var RapydScript = (typeof create_rapydscript_compiler === 'function') ? create_rapydscript_compiler() : require('./compiler').create_compiler();
17
- var has_prop = Object.prototype.hasOwnProperty.call.bind(Object.prototype.hasOwnProperty);
18
-
19
- function strip_exports(js) { return js.replace(/^export ((?:async )?function |let )/gm, '$1'); }
20
-
21
- function create_ctx(baselib, show_js, console) {
22
- var ctx = vm.createContext({'console':console, 'show_js': !!show_js, 'RapydScript':RapydScript, 'require':require});
23
- vm.runInContext(baselib, ctx, {'filename':'baselib-plain-pretty.js'});
24
- vm.runInContext('var __name__ = "__repl__";', ctx);
25
- return ctx;
26
- }
27
-
28
-
29
- var homedir = process.env[(process.platform == 'win32') ? 'USERPROFILE' : 'HOME'];
30
- var cachedir = expanduser(process.env.XDG_CACHE_HOME || '~/.cache');
31
-
32
- function expanduser(x) {
33
- if (!x) return x;
34
- if (x === '~') return homedir;
35
- if (x.slice(0, 2) != '~/') return x;
36
- return path.join(homedir, x.slice(2));
37
- }
38
-
39
- function repl_defaults(options) {
40
- options = options || {};
41
- if (!options.input) options.input = process.stdin;
42
- if (!options.output) options.output = process.stdout;
43
- if (options.show_js === undefined) options.show_js = true;
44
- if (!options.ps1) options.ps1 = '>>> ';
45
- if (!options.ps2) options.ps2 = '... ';
46
- if (!options.console) options.console = console;
47
- if (!options.readline) options.readline = require('readline');
48
- if (options.terminal === undefined) options.terminal = options.output.isTTY;
49
- if (options.histfile === undefined) options.histfile = path.join(cachedir, 'rapydscript-repl.history');
50
-
51
- options.colored = (options.terminal) ? colored : (function (string) { return string; });
52
- options.historySize = options.history_size || 1000;
53
- return options;
54
- }
55
-
56
- function read_history(options) {
57
- if (options.histfile) {
58
- try {
59
- return fs.readFileSync(options.histfile, 'utf-8').split('\n');
60
- } catch (e) { return []; }
61
- }
62
- }
63
-
64
- function write_history(options, history) {
65
- if (options.histfile) {
66
- history = history.join('\n');
67
- try {
68
- return fs.writeFileSync(options.histfile, history, 'utf-8');
69
- } catch (e) {}
70
- }
71
- }
72
-
73
-
74
- module.exports = function(options) {
75
- options = repl_defaults(options);
76
- options.completer = completer;
77
- var rl = options.readline.createInterface(options);
78
- var ps1 = options.colored(options.ps1, 'green');
79
- var ps2 = options.colored(options.ps2, 'yellow');
80
- var ctx = create_ctx(print_ast(RapydScript.parse('(def ():\n yield 1\n)'), true), options.show_js, options.console);
81
- var buffer = [];
82
- var more = false;
83
- var LINE_CONTINUATION_CHARS = ':\\';
84
- var toplevel;
85
- var import_dirs = utils.get_import_dirs();
86
- var find_completions = completelib(RapydScript, options);
87
-
88
- options.console.log(options.colored('Welcome to the RapydScript REPL! Press Ctrl+C then Ctrl+D to quit.', 'green', true));
89
- if (options.show_js)
90
- options.console.log(options.colored('Use show_js=False to stop the REPL from showing the compiled JavaScript.', 'green', true));
91
- else
92
- options.console.log(options.colored('Use show_js=True to have the REPL show the compiled JavaScript before executing it.', 'green', true));
93
- options.console.log();
94
-
95
- function print_ast(ast, keep_baselib) {
96
- var output_options = {omit_baselib:!keep_baselib, write_name:false, private_scope:false, beautify:true, keep_docstrings:true, repl_mode:true};
97
- if (keep_baselib) output_options.baselib_plain = fs.readFileSync(path.join(options.lib_path, 'baselib-plain-pretty.js'), 'utf-8');
98
- var output = new RapydScript.OutputStream(output_options);
99
- ast.print(output);
100
- return output.get();
101
- }
102
-
103
-
104
- function resetbuffer() { buffer = []; }
105
-
106
- function completer(line) {
107
- return find_completions(line, ctx);
108
- }
109
-
110
- function prompt() {
111
- var lw = '';
112
- if (more && buffer.length) {
113
- var prev_line = buffer[buffer.length - 1];
114
- if (prev_line.trimRight().substr(prev_line.length - 1) == ':') lw = ' ';
115
- prev_line = prev_line.match(/^\s+/);
116
- if (prev_line) lw += prev_line;
117
- }
118
- rl.setPrompt((more) ? ps2 : ps1);
119
- if (rl.sync_prompt) rl.prompt(lw);
120
- else {
121
- rl.prompt();
122
- if (lw) rl.write(lw);
123
- }
124
- }
125
-
126
- function runjs(js) {
127
- var result;
128
- if (vm.runInContext('show_js', ctx)) {
129
- options.console.log(options.colored('---------- Compiled JavaScript ---------', 'green', true));
130
- options.console.log(js);
131
- options.console.log(options.colored('---------- Running JavaScript ---------', 'green', true));
132
- }
133
- try {
134
- // Despite what the docs say node does not actually output any errors by itself
135
- // so, in case this bug is fixed later, we turn it off explicitly.
136
- result = vm.runInContext(strip_exports(js), ctx, {'filename':'<repl>', 'displayErrors':false});
137
- } catch(e) {
138
- if (e.stack) options.console.error(e.stack);
139
- else options.console.error(e.toString());
140
- }
141
-
142
- if (result !== undefined) {
143
- options.console.log(util.inspect(result, {'colors':options.terminal}));
144
- }
145
- }
146
-
147
- function compile_source(source) {
148
- var classes = (toplevel) ? toplevel.classes : undefined;
149
- var scoped_flags = (toplevel) ? toplevel.scoped_flags: undefined;
150
- try {
151
- toplevel = RapydScript.parse(source, {
152
- 'filename':'<repl>',
153
- 'basedir': process.cwd(),
154
- 'libdir': options.imp_path,
155
- 'import_dirs': import_dirs,
156
- 'classes': classes,
157
- 'scoped_flags': scoped_flags,
158
- });
159
- } catch(e) {
160
- if (e.is_eof && e.line == buffer.length && e.col > 0) return true;
161
- if (e.message && e.line !== undefined) options.console.log(e.line + ':' + e.col + ':' + e.message);
162
- else options.console.log(e.stack || e.toString());
163
- return false;
164
- }
165
- var output = print_ast(toplevel);
166
- if (classes) {
167
- var exports = {};
168
- toplevel.exports.forEach(function (name) { exports[name] = true; });
169
- Object.getOwnPropertyNames(classes).forEach(function (name) {
170
- if (!has_prop(exports, name) && !has_prop(toplevel.classes, name))
171
- toplevel.classes[name] = classes[name];
172
- });
173
- }
174
- scoped_flags = toplevel.scoped_flags;
175
- runjs(output);
176
- return false;
177
- }
178
-
179
- function push(line) {
180
- buffer.push(line);
181
- var ll = line.trimRight();
182
- if (ll && LINE_CONTINUATION_CHARS.indexOf(ll.substr(ll.length - 1)) > -1)
183
- return true;
184
- var source = buffer.join('\n');
185
- if (!source.trim()) { resetbuffer(); return false; }
186
- var incomplete = compile_source(source);
187
- if (!incomplete) resetbuffer();
188
- return incomplete;
189
- }
190
-
191
- rl.on('line', function(line) {
192
- if (more) {
193
- // We are in a block
194
- var line_is_empty = !line.trimLeft();
195
- if (line_is_empty && buffer.length && !buffer[buffer.length - 1].trimLeft()) {
196
- // We have two empty lines, evaluate the block
197
- more = push(line.trimLeft());
198
- } else buffer.push(line);
199
- } else more = push(line); // Not in a block, evaluate line
200
- prompt();
201
- })
202
-
203
- .on('close', function() {
204
- options.console.log('Bye!');
205
- if (rl.history) write_history(options, rl.history);
206
- process.exit(0);
207
- })
208
-
209
- .on('SIGINT', function() {
210
- rl.clearLine();
211
- options.console.log('Keyboard Interrupt');
212
- resetbuffer();
213
- more = false;
214
- prompt();
215
- })
216
-
217
- .on('SIGCONT', function() {
218
- prompt();
219
- });
220
-
221
- rl.history = read_history(options);
222
- prompt();
223
- };
1
+ /*
2
+ * repl.js
3
+ * Copyright (C) 2015 Kovid Goyal <kovid at kovidgoyal.net>
4
+ *
5
+ * Distributed under terms of the BSD license.
6
+ */
7
+ "use strict"; /*jshint node:true */
8
+
9
+ var fs = require('fs');
10
+ var path = require('path');
11
+ var vm = require('vm');
12
+ var util = require('util');
13
+ var utils = require('./utils');
14
+ var completelib = require('./completer');
15
+ var colored = utils.safe_colored;
16
+ var RapydScript = (typeof create_rapydscript_compiler === 'function') ? create_rapydscript_compiler() : require('./compiler').create_compiler();
17
+ var has_prop = Object.prototype.hasOwnProperty.call.bind(Object.prototype.hasOwnProperty);
18
+
19
+ function strip_exports(js) { return js.replace(/^export ((?:async )?function |let )/gm, '$1'); }
20
+
21
+ function create_ctx(baselib, show_js, console) {
22
+ var ctx = vm.createContext({'console':console, 'show_js': !!show_js, 'RapydScript':RapydScript, 'require':require});
23
+ vm.runInContext(baselib, ctx, {'filename':'baselib-plain-pretty.js'});
24
+ vm.runInContext('var __name__ = "__repl__";', ctx);
25
+ return ctx;
26
+ }
27
+
28
+
29
+ var homedir = process.env[(process.platform == 'win32') ? 'USERPROFILE' : 'HOME'];
30
+ var cachedir = expanduser(process.env.XDG_CACHE_HOME || '~/.cache');
31
+
32
+ function expanduser(x) {
33
+ if (!x) return x;
34
+ if (x === '~') return homedir;
35
+ if (x.slice(0, 2) != '~/') return x;
36
+ return path.join(homedir, x.slice(2));
37
+ }
38
+
39
+ function repl_defaults(options) {
40
+ options = options || {};
41
+ if (!options.input) options.input = process.stdin;
42
+ if (!options.output) options.output = process.stdout;
43
+ if (options.show_js === undefined) options.show_js = true;
44
+ if (!options.ps1) options.ps1 = '>>> ';
45
+ if (!options.ps2) options.ps2 = '... ';
46
+ if (!options.console) options.console = console;
47
+ if (!options.readline) options.readline = require('readline');
48
+ if (options.terminal === undefined) options.terminal = options.output.isTTY;
49
+ if (options.histfile === undefined) options.histfile = path.join(cachedir, 'rapydscript-repl.history');
50
+
51
+ options.colored = (options.terminal) ? colored : (function (string) { return string; });
52
+ options.historySize = options.history_size || 1000;
53
+ return options;
54
+ }
55
+
56
+ function read_history(options) {
57
+ if (options.histfile) {
58
+ try {
59
+ return fs.readFileSync(options.histfile, 'utf-8').split('\n');
60
+ } catch (e) { return []; }
61
+ }
62
+ }
63
+
64
+ function write_history(options, history) {
65
+ if (options.histfile) {
66
+ history = history.join('\n');
67
+ try {
68
+ return fs.writeFileSync(options.histfile, history, 'utf-8');
69
+ } catch (e) {}
70
+ }
71
+ }
72
+
73
+
74
+ module.exports = function(options) {
75
+ options = repl_defaults(options);
76
+ options.completer = completer;
77
+ var rl = options.readline.createInterface(options);
78
+ var ps1 = options.colored(options.ps1, 'green');
79
+ var ps2 = options.colored(options.ps2, 'yellow');
80
+ var ctx = create_ctx(print_ast(RapydScript.parse('(def ():\n yield 1\n)'), true), options.show_js, options.console);
81
+ var buffer = [];
82
+ var more = false;
83
+ var LINE_CONTINUATION_CHARS = ':\\';
84
+ var toplevel;
85
+ var import_dirs = utils.get_import_dirs();
86
+ var find_completions = completelib(RapydScript, options);
87
+
88
+ options.console.log(options.colored('Welcome to the RapydScript REPL! Press Ctrl+C then Ctrl+D to quit.', 'green', true));
89
+ if (options.show_js)
90
+ options.console.log(options.colored('Use show_js=False to stop the REPL from showing the compiled JavaScript.', 'green', true));
91
+ else
92
+ options.console.log(options.colored('Use show_js=True to have the REPL show the compiled JavaScript before executing it.', 'green', true));
93
+ options.console.log();
94
+
95
+ function print_ast(ast, keep_baselib) {
96
+ var output_options = {omit_baselib:!keep_baselib, write_name:false, private_scope:false, beautify:true, keep_docstrings:true, repl_mode:true};
97
+ if (keep_baselib) output_options.baselib_plain = fs.readFileSync(path.join(options.lib_path, 'baselib-plain-pretty.js'), 'utf-8');
98
+ var output = new RapydScript.OutputStream(output_options);
99
+ ast.print(output);
100
+ return output.get();
101
+ }
102
+
103
+
104
+ function resetbuffer() { buffer = []; }
105
+
106
+ function completer(line) {
107
+ return find_completions(line, ctx);
108
+ }
109
+
110
+ function prompt() {
111
+ var lw = '';
112
+ if (more && buffer.length) {
113
+ var prev_line = buffer[buffer.length - 1];
114
+ if (prev_line.trimRight().substr(prev_line.length - 1) == ':') lw = ' ';
115
+ prev_line = prev_line.match(/^\s+/);
116
+ if (prev_line) lw += prev_line;
117
+ }
118
+ rl.setPrompt((more) ? ps2 : ps1);
119
+ if (rl.sync_prompt) rl.prompt(lw);
120
+ else {
121
+ rl.prompt();
122
+ if (lw) rl.write(lw);
123
+ }
124
+ }
125
+
126
+ function runjs(js) {
127
+ var result;
128
+ if (vm.runInContext('show_js', ctx)) {
129
+ options.console.log(options.colored('---------- Compiled JavaScript ---------', 'green', true));
130
+ options.console.log(js);
131
+ options.console.log(options.colored('---------- Running JavaScript ---------', 'green', true));
132
+ }
133
+ try {
134
+ // Despite what the docs say node does not actually output any errors by itself
135
+ // so, in case this bug is fixed later, we turn it off explicitly.
136
+ result = vm.runInContext(strip_exports(js), ctx, {'filename':'<repl>', 'displayErrors':false});
137
+ } catch(e) {
138
+ if (e.stack) options.console.error(e.stack);
139
+ else options.console.error(e.toString());
140
+ }
141
+
142
+ if (result !== undefined) {
143
+ options.console.log(util.inspect(result, {'colors':options.terminal}));
144
+ }
145
+ }
146
+
147
+ function compile_source(source) {
148
+ var classes = (toplevel) ? toplevel.classes : undefined;
149
+ var scoped_flags = (toplevel) ? toplevel.scoped_flags: undefined;
150
+ try {
151
+ toplevel = RapydScript.parse(source, {
152
+ 'filename':'<repl>',
153
+ 'basedir': process.cwd(),
154
+ 'libdir': options.imp_path,
155
+ 'import_dirs': import_dirs,
156
+ 'classes': classes,
157
+ 'scoped_flags': scoped_flags,
158
+ });
159
+ } catch(e) {
160
+ if (e.is_eof && e.line == buffer.length && e.col > 0) return true;
161
+ if (e.message && e.line !== undefined) options.console.log(e.line + ':' + e.col + ':' + e.message);
162
+ else options.console.log(e.stack || e.toString());
163
+ return false;
164
+ }
165
+ var output = print_ast(toplevel);
166
+ if (classes) {
167
+ var exports = {};
168
+ toplevel.exports.forEach(function (name) { exports[name] = true; });
169
+ Object.getOwnPropertyNames(classes).forEach(function (name) {
170
+ if (!has_prop(exports, name) && !has_prop(toplevel.classes, name))
171
+ toplevel.classes[name] = classes[name];
172
+ });
173
+ }
174
+ scoped_flags = toplevel.scoped_flags;
175
+ runjs(output);
176
+ return false;
177
+ }
178
+
179
+ function push(line) {
180
+ buffer.push(line);
181
+ var ll = line.trimRight();
182
+ if (ll && LINE_CONTINUATION_CHARS.indexOf(ll.substr(ll.length - 1)) > -1)
183
+ return true;
184
+ var source = buffer.join('\n');
185
+ if (!source.trim()) { resetbuffer(); return false; }
186
+ var incomplete = compile_source(source);
187
+ if (!incomplete) resetbuffer();
188
+ return incomplete;
189
+ }
190
+
191
+ rl.on('line', function(line) {
192
+ if (more) {
193
+ // We are in a block
194
+ var line_is_empty = !line.trimLeft();
195
+ if (line_is_empty && buffer.length && !buffer[buffer.length - 1].trimLeft()) {
196
+ // We have two empty lines, evaluate the block
197
+ more = push(line.trimLeft());
198
+ } else buffer.push(line);
199
+ } else more = push(line); // Not in a block, evaluate line
200
+ prompt();
201
+ })
202
+
203
+ .on('close', function() {
204
+ options.console.log('Bye!');
205
+ if (rl.history) write_history(options, rl.history);
206
+ process.exit(0);
207
+ })
208
+
209
+ .on('SIGINT', function() {
210
+ rl.clearLine();
211
+ options.console.log('Keyboard Interrupt');
212
+ resetbuffer();
213
+ more = false;
214
+ prompt();
215
+ })
216
+
217
+ .on('SIGCONT', function() {
218
+ prompt();
219
+ });
220
+
221
+ rl.history = read_history(options);
222
+ prompt();
223
+ };