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/compile.js CHANGED
@@ -1,219 +1,224 @@
1
- /*
2
- * compile.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 RapydScript = require("./compiler").create_compiler();
13
- var utils = require('./utils');
14
-
15
- function read_whole_file(filename, cb) {
16
- if (!filename) {
17
- var chunks = [];
18
- process.stdin.setEncoding('utf-8');
19
- process.stdin.on('data', function (chunk) {
20
- chunks.push(chunk);
21
- }).on('end', function () {
22
- cb(null, chunks.join(""));
23
- });
24
- process.openStdin();
25
- } else {
26
- fs.readFile(filename, "utf-8", cb);
27
- }
28
- }
29
-
30
- function makedirs(dir) {
31
- try {
32
- fs.mkdirSync(dir);
33
- } catch(e) {
34
- if (e.code == 'EEXIST') return;
35
- if (e.code == 'ENOENT') { makedirs(path.dirname(dir)); fs.mkdirSync(dir); }
36
- throw e;
37
- }
38
- }
39
-
40
- function process_cache_dir(dir) {
41
- dir = path.resolve(path.normalize(dir));
42
- makedirs(dir);
43
- return dir;
44
- }
45
-
46
- function build_scoped_flags(flags_str) {
47
- var result = Object.create(null);
48
- if (!flags_str) return result;
49
- flags_str.split(',').forEach(function(flag) {
50
- flag = flag.trim();
51
- if (!flag) return;
52
- var val = true;
53
- if (flag.slice(0, 3) === 'no_') { val = false; flag = flag.slice(3); }
54
- result[flag] = val;
55
- });
56
- return result;
57
- }
58
-
59
- module.exports = function(start_time, argv, base_path, src_path, lib_path) {
60
- // configure settings for the output
61
- var cache_dir = argv.cache_dir ? process_cache_dir(argv.cache_dir) : '';
62
- var OUTPUT_OPTIONS = {
63
- beautify: !argv.uglify,
64
- private_scope: !argv.bare && !argv.export_main,
65
- omit_baselib: argv.omit_baselib,
66
- js_version: parseInt(argv.js_version),
67
- keep_docstrings: argv.keep_docstrings,
68
- discard_asserts: argv.discard_asserts,
69
- module_cache_dir: cache_dir,
70
- pythonize_strings: argv.pythonize_strings,
71
- };
72
-
73
- var files = argv.files.slice();
74
- var STATS = {}, TOPLEVEL;
75
- var num_of_files = files.length || 1;
76
-
77
- var global_scoped_flags = build_scoped_flags(argv.python_flags);
78
-
79
- function parse_file(code, file, toplevel) {
80
- return RapydScript.parse(code, {
81
- filename: file,
82
- toplevel: toplevel,
83
- basedir: (file !== '<stdin>') ? path.dirname(file) : undefined,
84
- libdir: path.join(src_path, 'lib'),
85
- import_dirs: utils.get_import_dirs(argv.import_path),
86
- discard_asserts: argv.discard_asserts,
87
- module_cache_dir: cache_dir,
88
- scoped_flags: global_scoped_flags,
89
- });
90
- }
91
-
92
- function write_output(output) {
93
- if (argv.output) {
94
- // Node's filesystem module cannot write directly to /dev/stdout
95
- if (argv.output == '/dev/stdout') console.log(output);
96
- else if (argv.output == '/dev/stderr') console.error(output);
97
- else fs.writeFileSync(argv.output, output, "utf8");
98
- } else if (!argv.execute){
99
- console.log(output);
100
- }
101
- if (argv.execute) {
102
- vm.runInNewContext(output, {'console':console, 'require':require}, {'filename':files[0]});
103
- }
104
- }
105
-
106
- function time_it(name, cont) {
107
- var t1 = new Date().getTime();
108
- var ret = cont();
109
- if (argv.stats) {
110
- var spent = new Date().getTime() - t1;
111
- if (STATS[name]) STATS[name] += spent;
112
- else STATS[name] = spent;
113
- }
114
- return ret;
115
- }
116
-
117
- function compile_single_file(err, code) {
118
- var output;
119
- if (err) {
120
- console.error("ERROR: can't read file: " + files[0]);
121
- process.exit(1);
122
- }
123
- time_it("parse", function(){
124
- var file = files[0] || argv.filename_for_stdin || '<stdin>';
125
- try {
126
- TOPLEVEL = parse_file(code, file, TOPLEVEL);
127
- } catch (e) {
128
- if (!(e instanceof RapydScript.SyntaxError)) throw e;
129
- console.error(e.toString());
130
- process.exit(1);
131
- }
132
- });
133
-
134
- if (TOPLEVEL.imports && Object.keys(TOPLEVEL.imports).length) {
135
- time_it("treeshake", function() {
136
- RapydScript.tree_shake(TOPLEVEL, {
137
- parse: RapydScript.parse,
138
- import_dirs: utils.get_import_dirs(argv.import_path),
139
- basedir: (files[0] !== '<stdin>') ? path.dirname(files[0]) : undefined,
140
- libdir: path.join(src_path, 'lib'),
141
- discard_asserts: argv.discard_asserts,
142
- module_cache_dir: cache_dir,
143
- });
144
- });
145
- }
146
-
147
- try {
148
- output = new RapydScript.OutputStream(OUTPUT_OPTIONS);
149
- } catch(ex) {
150
- if (ex instanceof RapydScript.DefaultsError) {
151
- console.error(ex.message);
152
- process.exit(1);
153
- }
154
- throw ex;
155
- }
156
-
157
- time_it("generate", function(){
158
- TOPLEVEL.print(output);
159
- });
160
-
161
- output = output.get();
162
-
163
- if (argv.export_main) {
164
- output = output.replace(/^(function\smain)/gm, 'export $1')
165
- .replace(/^(async\sfunction\smain)/gm, 'export $1');
166
- }
167
-
168
- write_output(output);
169
-
170
- files = files.slice(1);
171
- if (files.length) {
172
- setImmediate(read_whole_file, files[0], compile_single_file);
173
- return;
174
- }
175
- if (argv.stats) {
176
- console.error(RapydScript.string_template("Timing information (compressed {count} files):", {
177
- count: num_of_files
178
- }));
179
- for (var i in STATS) if (Object.prototype.hasOwnProperty.call(STATS, i)) {
180
- console.error(RapydScript.string_template("- {name}: {time}s", {
181
- name: i,
182
- time: (STATS[i] / 1000).toFixed(3)
183
- }));
184
- }
185
- }
186
- }
187
-
188
-
189
- if (argv.comments) {
190
- if (/^\//.test(argv.comments)) {
191
- OUTPUT_OPTIONS.comments = new Function("return(" + argv.comments + ")")(); // jshint ignore:line
192
- } else if (argv.comments == "all") {
193
- OUTPUT_OPTIONS.comments = true;
194
- } else {
195
- OUTPUT_OPTIONS.comments = function(node, comment) {
196
- var text = comment.value;
197
- var type = comment.type;
198
- if (type == "comment2") {
199
- // multiline comment
200
- return /@preserve|@license|@cc_on/i.test(text);
201
- }
202
- };
203
- }
204
- }
205
-
206
- if (!argv.omit_baselib) {
207
- var which = (OUTPUT_OPTIONS.beautify) ? 'pretty' : 'ugly';
208
- OUTPUT_OPTIONS.baselib_plain = fs.readFileSync(path.join(lib_path, 'baselib-plain-' + which + '.js'), 'utf-8');
209
- }
210
-
211
- if (files.filter(function(el){ return el == "-"; }).length > 1) {
212
- console.error("ERROR: Can read a single file from STDIN (two or more dashes specified)");
213
- process.exit(1);
214
- }
215
-
216
- setImmediate(read_whole_file, files[0], compile_single_file);
217
-
218
- };
219
-
1
+ /*
2
+ * compile.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 RapydScript = require("./compiler").create_compiler();
13
+ var utils = require('./utils');
14
+
15
+ function read_whole_file(filename, cb) {
16
+ if (!filename) {
17
+ var chunks = [];
18
+ process.stdin.setEncoding('utf-8');
19
+ process.stdin.on('data', function (chunk) {
20
+ chunks.push(chunk);
21
+ }).on('end', function () {
22
+ cb(null, chunks.join(""));
23
+ });
24
+ process.openStdin();
25
+ } else {
26
+ fs.readFile(filename, "utf-8", cb);
27
+ }
28
+ }
29
+
30
+ function makedirs(dir) {
31
+ try {
32
+ fs.mkdirSync(dir);
33
+ } catch(e) {
34
+ if (e.code == 'EEXIST') return;
35
+ if (e.code == 'ENOENT') { makedirs(path.dirname(dir)); fs.mkdirSync(dir); }
36
+ throw e;
37
+ }
38
+ }
39
+
40
+ function process_cache_dir(dir) {
41
+ dir = path.resolve(path.normalize(dir));
42
+ makedirs(dir);
43
+ return dir;
44
+ }
45
+
46
+ function build_scoped_flags(flags_str) {
47
+ var result = Object.create(null);
48
+ if (!flags_str) return result;
49
+ flags_str.split(',').forEach(function(flag) {
50
+ flag = flag.trim();
51
+ if (!flag) return;
52
+ var val = true;
53
+ if (flag.slice(0, 3) === 'no_') { val = false; flag = flag.slice(3); }
54
+ result[flag] = val;
55
+ });
56
+ return result;
57
+ }
58
+
59
+ module.exports = function(start_time, argv, base_path, src_path, lib_path) {
60
+ // configure settings for the output
61
+ var cache_dir = argv.cache_dir ? process_cache_dir(argv.cache_dir) : '';
62
+ var OUTPUT_OPTIONS = {
63
+ beautify: !argv.uglify,
64
+ private_scope: !argv.bare && !argv.export_main,
65
+ omit_baselib: argv.omit_baselib,
66
+ js_version: parseInt(argv.js_version),
67
+ keep_docstrings: argv.keep_docstrings,
68
+ discard_asserts: argv.discard_asserts,
69
+ module_cache_dir: cache_dir,
70
+ pythonize_strings: argv.pythonize_strings,
71
+ };
72
+
73
+ var files = argv.files.slice();
74
+ var STATS = {}, TOPLEVEL;
75
+ var num_of_files = files.length || 1;
76
+
77
+ var global_scoped_flags = build_scoped_flags(argv.python_flags);
78
+ if (!argv.legacy_rapydscript) {
79
+ var python_mode_flags = ['dict_literals', 'overload_getitem', 'bound_methods', 'hash_literals', 'overload_operators', 'truthiness', 'jsx'];
80
+ python_mode_flags.forEach(function(f) { if (!(f in global_scoped_flags)) global_scoped_flags[f] = true; });
81
+ if (!argv.pythonize_strings) OUTPUT_OPTIONS.pythonize_strings = true;
82
+ }
83
+
84
+ function parse_file(code, file, toplevel) {
85
+ return RapydScript.parse(code, {
86
+ filename: file,
87
+ toplevel: toplevel,
88
+ basedir: (file !== '<stdin>') ? path.dirname(file) : undefined,
89
+ libdir: path.join(src_path, 'lib'),
90
+ import_dirs: utils.get_import_dirs(argv.import_path),
91
+ discard_asserts: argv.discard_asserts,
92
+ module_cache_dir: cache_dir,
93
+ scoped_flags: global_scoped_flags,
94
+ });
95
+ }
96
+
97
+ function write_output(output) {
98
+ if (argv.output) {
99
+ // Node's filesystem module cannot write directly to /dev/stdout
100
+ if (argv.output == '/dev/stdout') console.log(output);
101
+ else if (argv.output == '/dev/stderr') console.error(output);
102
+ else fs.writeFileSync(argv.output, output, "utf8");
103
+ } else if (!argv.execute){
104
+ console.log(output);
105
+ }
106
+ if (argv.execute) {
107
+ vm.runInNewContext(output, {'console':console, 'require':require}, {'filename':files[0]});
108
+ }
109
+ }
110
+
111
+ function time_it(name, cont) {
112
+ var t1 = new Date().getTime();
113
+ var ret = cont();
114
+ if (argv.stats) {
115
+ var spent = new Date().getTime() - t1;
116
+ if (STATS[name]) STATS[name] += spent;
117
+ else STATS[name] = spent;
118
+ }
119
+ return ret;
120
+ }
121
+
122
+ function compile_single_file(err, code) {
123
+ var output;
124
+ if (err) {
125
+ console.error("ERROR: can't read file: " + files[0]);
126
+ process.exit(1);
127
+ }
128
+ time_it("parse", function(){
129
+ var file = files[0] || argv.filename_for_stdin || '<stdin>';
130
+ try {
131
+ TOPLEVEL = parse_file(code, file, TOPLEVEL);
132
+ } catch (e) {
133
+ if (!(e instanceof RapydScript.SyntaxError)) throw e;
134
+ console.error(e.toString());
135
+ process.exit(1);
136
+ }
137
+ });
138
+
139
+ if (TOPLEVEL.imports && Object.keys(TOPLEVEL.imports).length) {
140
+ time_it("treeshake", function() {
141
+ RapydScript.tree_shake(TOPLEVEL, {
142
+ parse: RapydScript.parse,
143
+ import_dirs: utils.get_import_dirs(argv.import_path),
144
+ basedir: (files[0] !== '<stdin>') ? path.dirname(files[0]) : undefined,
145
+ libdir: path.join(src_path, 'lib'),
146
+ discard_asserts: argv.discard_asserts,
147
+ module_cache_dir: cache_dir,
148
+ });
149
+ });
150
+ }
151
+
152
+ try {
153
+ output = new RapydScript.OutputStream(OUTPUT_OPTIONS);
154
+ } catch(ex) {
155
+ if (ex instanceof RapydScript.DefaultsError) {
156
+ console.error(ex.message);
157
+ process.exit(1);
158
+ }
159
+ throw ex;
160
+ }
161
+
162
+ time_it("generate", function(){
163
+ TOPLEVEL.print(output);
164
+ });
165
+
166
+ output = output.get();
167
+
168
+ if (argv.export_main) {
169
+ output = output.replace(/^(function\smain)/gm, 'export $1')
170
+ .replace(/^(async\sfunction\smain)/gm, 'export $1');
171
+ }
172
+
173
+ write_output(output);
174
+
175
+ files = files.slice(1);
176
+ if (files.length) {
177
+ setImmediate(read_whole_file, files[0], compile_single_file);
178
+ return;
179
+ }
180
+ if (argv.stats) {
181
+ console.error(RapydScript.string_template("Timing information (compressed {count} files):", {
182
+ count: num_of_files
183
+ }));
184
+ for (var i in STATS) if (Object.prototype.hasOwnProperty.call(STATS, i)) {
185
+ console.error(RapydScript.string_template("- {name}: {time}s", {
186
+ name: i,
187
+ time: (STATS[i] / 1000).toFixed(3)
188
+ }));
189
+ }
190
+ }
191
+ }
192
+
193
+
194
+ if (argv.comments) {
195
+ if (/^\//.test(argv.comments)) {
196
+ OUTPUT_OPTIONS.comments = new Function("return(" + argv.comments + ")")(); // jshint ignore:line
197
+ } else if (argv.comments == "all") {
198
+ OUTPUT_OPTIONS.comments = true;
199
+ } else {
200
+ OUTPUT_OPTIONS.comments = function(node, comment) {
201
+ var text = comment.value;
202
+ var type = comment.type;
203
+ if (type == "comment2") {
204
+ // multiline comment
205
+ return /@preserve|@license|@cc_on/i.test(text);
206
+ }
207
+ };
208
+ }
209
+ }
210
+
211
+ if (!argv.omit_baselib) {
212
+ var which = (OUTPUT_OPTIONS.beautify) ? 'pretty' : 'ugly';
213
+ OUTPUT_OPTIONS.baselib_plain = fs.readFileSync(path.join(lib_path, 'baselib-plain-' + which + '.js'), 'utf-8');
214
+ }
215
+
216
+ if (files.filter(function(el){ return el == "-"; }).length > 1) {
217
+ console.error("ERROR: Can read a single file from STDIN (two or more dashes specified)");
218
+ process.exit(1);
219
+ }
220
+
221
+ setImmediate(read_whole_file, files[0], compile_single_file);
222
+
223
+ };
224
+