rapydscript-ns 0.9.2 → 0.9.3

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 (151) 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 +19 -0
  5. package/HACKING.md +103 -103
  6. package/LICENSE +24 -24
  7. package/PYTHON_GAPS.md +420 -0
  8. package/README.md +153 -29
  9. package/TODO.md +16 -118
  10. package/add-toc-to-readme +2 -2
  11. package/bin/export +75 -75
  12. package/bin/rapydscript +70 -70
  13. package/bin/web-repl-export +102 -102
  14. package/build +2 -2
  15. package/language-service/index.js +237 -8
  16. package/memory/project_string_impl.md +43 -0
  17. package/package.json +1 -1
  18. package/publish.py +37 -37
  19. package/release/baselib-plain-pretty.js +248 -38
  20. package/release/baselib-plain-ugly.js +8 -8
  21. package/release/compiler.js +778 -277
  22. package/release/signatures.json +30 -30
  23. package/session.vim +4 -4
  24. package/setup.cfg +2 -2
  25. package/src/ast.pyj +4 -1
  26. package/src/baselib-builtins.pyj +56 -2
  27. package/src/baselib-containers.pyj +2 -0
  28. package/src/baselib-errors.pyj +7 -3
  29. package/src/baselib-internal.pyj +51 -6
  30. package/src/baselib-str.pyj +5 -3
  31. package/src/compiler.pyj +36 -36
  32. package/src/errors.pyj +30 -30
  33. package/src/lib/aes.pyj +646 -646
  34. package/src/lib/asyncio.pyj +534 -0
  35. package/src/lib/base64.pyj +399 -0
  36. package/src/lib/bisect.pyj +73 -0
  37. package/src/lib/collections.pyj +1 -1
  38. package/src/lib/copy.pyj +120 -120
  39. package/src/lib/csv.pyj +494 -0
  40. package/src/lib/elementmaker.pyj +83 -83
  41. package/src/lib/encodings.pyj +126 -126
  42. package/src/lib/gettext.pyj +569 -569
  43. package/src/lib/heapq.pyj +98 -0
  44. package/src/lib/html.pyj +382 -0
  45. package/src/lib/http/__init__.pyj +98 -0
  46. package/src/lib/http/client.pyj +304 -0
  47. package/src/lib/http/cookies.pyj +236 -0
  48. package/src/lib/itertools.pyj +580 -580
  49. package/src/lib/logging.pyj +672 -0
  50. package/src/lib/math.pyj +193 -193
  51. package/src/lib/operator.pyj +11 -11
  52. package/src/lib/pythonize.pyj +20 -20
  53. package/src/lib/random.pyj +118 -118
  54. package/src/lib/react.pyj +74 -74
  55. package/src/lib/string.pyj +357 -0
  56. package/src/lib/textwrap.pyj +329 -0
  57. package/src/lib/traceback.pyj +63 -63
  58. package/src/lib/urllib/__init__.pyj +14 -0
  59. package/src/lib/urllib/error.pyj +66 -0
  60. package/src/lib/urllib/parse.pyj +475 -0
  61. package/src/lib/urllib/request.pyj +86 -0
  62. package/src/lib/uuid.pyj +77 -77
  63. package/src/monaco-language-service/analyzer.js +5 -2
  64. package/src/monaco-language-service/completions.js +26 -0
  65. package/src/monaco-language-service/diagnostics.js +202 -3
  66. package/src/monaco-language-service/dts.js +550 -550
  67. package/src/monaco-language-service/scope.js +1 -0
  68. package/src/output/comments.pyj +45 -45
  69. package/src/output/exceptions.pyj +201 -201
  70. package/src/output/functions.pyj +152 -6
  71. package/src/output/jsx.pyj +164 -164
  72. package/src/output/loops.pyj +17 -2
  73. package/src/output/modules.pyj +1 -1
  74. package/src/output/operators.pyj +15 -0
  75. package/src/output/stream.pyj +0 -1
  76. package/src/output/treeshake.pyj +182 -182
  77. package/src/output/utils.pyj +72 -72
  78. package/src/parse.pyj +80 -17
  79. package/src/string_interpolation.pyj +72 -72
  80. package/src/tokenizer.pyj +1 -1
  81. package/src/unicode_aliases.pyj +576 -576
  82. package/src/utils.pyj +192 -192
  83. package/test/_import_one.pyj +37 -37
  84. package/test/_import_two/__init__.pyj +11 -11
  85. package/test/_import_two/level2/deep.pyj +4 -4
  86. package/test/_import_two/other.pyj +6 -6
  87. package/test/_import_two/sub.pyj +13 -13
  88. package/test/aes_vectors.pyj +421 -421
  89. package/test/annotations.pyj +80 -80
  90. package/test/async_generators.pyj +144 -0
  91. package/test/asyncio.pyj +307 -0
  92. package/test/base64.pyj +202 -0
  93. package/test/bisect.pyj +178 -0
  94. package/test/csv.pyj +405 -0
  95. package/test/decorators.pyj +77 -77
  96. package/test/docstrings.pyj +39 -39
  97. package/test/elementmaker_test.pyj +45 -45
  98. package/test/float_special.pyj +64 -0
  99. package/test/functions.pyj +151 -151
  100. package/test/generators.pyj +41 -41
  101. package/test/generic.pyj +370 -370
  102. package/test/heapq.pyj +174 -0
  103. package/test/html.pyj +212 -0
  104. package/test/http.pyj +259 -0
  105. package/test/imports.pyj +79 -72
  106. package/test/internationalization.pyj +73 -73
  107. package/test/lint.pyj +164 -164
  108. package/test/logging.pyj +356 -0
  109. package/test/long.pyj +130 -0
  110. package/test/loops.pyj +85 -85
  111. package/test/numpy.pyj +734 -734
  112. package/test/parenthesized_with.pyj +141 -0
  113. package/test/python_compat.pyj +3 -5
  114. package/test/python_modulo.pyj +76 -0
  115. package/test/python_modulo_off.pyj +21 -0
  116. package/test/repl.pyj +121 -121
  117. package/test/scoped_flags.pyj +76 -76
  118. package/test/str.pyj +14 -0
  119. package/test/string.pyj +245 -0
  120. package/test/textwrap.pyj +172 -0
  121. package/test/type_display.pyj +48 -0
  122. package/test/type_enforcement.pyj +164 -0
  123. package/test/unit/index.js +14 -6
  124. package/test/unit/language-service-completions.js +119 -0
  125. package/test/unit/language-service-dts.js +543 -543
  126. package/test/unit/language-service-hover.js +455 -455
  127. package/test/unit/language-service-scope.js +32 -0
  128. package/test/unit/language-service.js +127 -3
  129. package/test/unit/run-language-service.js +17 -3
  130. package/test/unit/web-repl.js +2094 -29
  131. package/test/urllib.pyj +193 -0
  132. package/tools/compile.js +1 -1
  133. package/tools/compiler.d.ts +367 -367
  134. package/tools/completer.js +131 -131
  135. package/tools/embedded_compiler.js +7 -7
  136. package/tools/gettext.js +185 -185
  137. package/tools/ini.js +65 -65
  138. package/tools/msgfmt.js +187 -187
  139. package/tools/repl.js +223 -223
  140. package/tools/test.js +118 -118
  141. package/tools/utils.js +128 -128
  142. package/tools/web_repl.js +95 -95
  143. package/try +41 -41
  144. package/web-repl/env.js +196 -196
  145. package/web-repl/index.html +163 -163
  146. package/web-repl/main.js +1 -1
  147. package/web-repl/prism.css +139 -139
  148. package/web-repl/prism.js +113 -113
  149. package/web-repl/rapydscript.js +224 -224
  150. package/web-repl/sha1.js +25 -25
  151. package/test/omit_function_metadata.pyj +0 -20
package/tools/test.js CHANGED
@@ -1,118 +1,118 @@
1
- /*
2
- * test.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
- var path = require('path');
9
- var fs = require('fs');
10
- var RapydScript = require('./compiler').create_compiler();
11
- var utils = require('./utils');
12
- var colored = utils.safe_colored;
13
-
14
- module.exports = function(argv, base_path, src_path, lib_path) {
15
- // run all tests and exit
16
- var assert = require("assert");
17
- var os = require('os');
18
- var failures = [];
19
- var vm = require('vm');
20
- var compiler_dir = path.join(base_path, 'dev');
21
- if (!utils.path_exists(path.join(compiler_dir, 'compiler.js'))) compiler_dir = path.join(base_path, 'release');
22
- var test_dir = path.join(base_path, 'test');
23
- var baselib = fs.readFileSync(path.join(lib_path, 'baselib-plain-pretty.js'), 'utf-8');
24
- var files;
25
- var deep_eq = assert.deepEqual;
26
- assert.deepEqual = function(a, b, message) {
27
- // Compare array objects that have extra properties as simple arrays
28
- if (Array.isArray(a) && Array.isArray(b)) {
29
- if (a === b) return;
30
- if (a.length !== b.length) throw new assert.AssertionError({actual:a, expected:b, operator:'deepEqual', stackStartFunction:assert.deepEqual});
31
- for(var i=0; i < a.length; i++) assert.deepEqual(a[i], b[i], message);
32
- } else if (a !== undefined && a !== null && typeof a.__eq__ === 'function') {
33
- if (!a.__eq__(b)) throw new assert.AssertionError({actual:a, expected:b, operator:'deepEqual', stackStartFunction:assert.deepEqual});
34
- } else return deep_eq(a, b, message);
35
- };
36
-
37
- if (argv.files.length) {
38
- files = [];
39
- argv.files.forEach(function(fname) { files.push(fname + '.pyj'); });
40
- } else {
41
- files = fs.readdirSync(test_dir).filter(function(name){
42
- return /^[^_].*\.pyj$/.test(name);
43
- });
44
- }
45
- files.forEach(function(file){
46
- var ast;
47
- var filepath = path.join(test_dir, file);
48
- var failed = false;
49
- try {
50
- ast = RapydScript.parse(fs.readFileSync(filepath, "utf-8"), {
51
- filename: file,
52
- toplevel: ast,
53
- basedir: test_dir,
54
- libdir: path.join(src_path, 'lib'),
55
- });
56
- if (ast.imports && Object.keys(ast.imports).length) {
57
- RapydScript.tree_shake(ast, {
58
- parse: RapydScript.parse,
59
- import_dirs: [],
60
- basedir: test_dir,
61
- libdir: path.join(src_path, 'lib'),
62
- });
63
- }
64
- } catch(e) {
65
- failures.push(file);
66
- failed = true;
67
- console.log(colored(file, 'red') + ': ' + e + "\n\n");
68
- return;
69
- }
70
-
71
- var js_version = 5;
72
- while (js_version < 7) {
73
- // generate output
74
- var output = new RapydScript.OutputStream({
75
- baselib_plain: baselib,
76
- beautify: true,
77
- js_version: js_version,
78
- keep_docstrings: true,
79
- });
80
- ast.print(output);
81
-
82
- // test that output performs correct JS operations
83
- var jsfile = path.join(os.tmpdir(), file + '-es' + js_version + '.js');
84
- var code = output.toString();
85
- try {
86
- vm.runInNewContext(code, {
87
- 'assrt':assert,
88
- '__name__': jsfile,
89
- 'require':require,
90
- 'fs':fs,
91
- 'RapydScript':RapydScript,
92
- 'console':console,
93
- 'compiler_dir': compiler_dir,
94
- 'test_path':test_dir,
95
- 'Buffer': Buffer,
96
- }, {'filename':jsfile});
97
- } catch (e) {
98
- failures.push(file);
99
- failed = true;
100
- fs.writeFileSync(jsfile, code);
101
- console.error('Failed running: ' + colored(jsfile, 'red'));
102
- if (e.stack)
103
- console.error(colored(file, 'red') + ":\n" + e.stack + "\n\n");
104
- else
105
- console.error(colored(file, 'red') + ": " + e + "\n\n");
106
- js_version = 1000;
107
- }
108
- js_version++;
109
- }
110
- if (!failed) console.log(colored(file, 'green') + ": test completed successfully\n");
111
- else { console.log(colored(file, 'red') + ":\ttest failed\n"); }
112
- });
113
- if (failures.length) {
114
- console.log(colored('There were ' + failures.length + ' test failure(s):', 'red'));
115
- console.log.apply(console, failures);
116
- } else console.log(colored('All tests passed!', 'green'));
117
- process.exit((failures.length) ? 1 : 0);
118
- };
1
+ /*
2
+ * test.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
+ var path = require('path');
9
+ var fs = require('fs');
10
+ var RapydScript = require('./compiler').create_compiler();
11
+ var utils = require('./utils');
12
+ var colored = utils.safe_colored;
13
+
14
+ module.exports = function(argv, base_path, src_path, lib_path) {
15
+ // run all tests and exit
16
+ var assert = require("assert");
17
+ var os = require('os');
18
+ var failures = [];
19
+ var vm = require('vm');
20
+ var compiler_dir = path.join(base_path, 'dev');
21
+ if (!utils.path_exists(path.join(compiler_dir, 'compiler.js'))) compiler_dir = path.join(base_path, 'release');
22
+ var test_dir = path.join(base_path, 'test');
23
+ var baselib = fs.readFileSync(path.join(lib_path, 'baselib-plain-pretty.js'), 'utf-8');
24
+ var files;
25
+ var deep_eq = assert.deepEqual;
26
+ assert.deepEqual = function(a, b, message) {
27
+ // Compare array objects that have extra properties as simple arrays
28
+ if (Array.isArray(a) && Array.isArray(b)) {
29
+ if (a === b) return;
30
+ if (a.length !== b.length) throw new assert.AssertionError({actual:a, expected:b, operator:'deepEqual', stackStartFunction:assert.deepEqual});
31
+ for(var i=0; i < a.length; i++) assert.deepEqual(a[i], b[i], message);
32
+ } else if (a !== undefined && a !== null && typeof a.__eq__ === 'function') {
33
+ if (!a.__eq__(b)) throw new assert.AssertionError({actual:a, expected:b, operator:'deepEqual', stackStartFunction:assert.deepEqual});
34
+ } else return deep_eq(a, b, message);
35
+ };
36
+
37
+ if (argv.files.length) {
38
+ files = [];
39
+ argv.files.forEach(function(fname) { files.push(fname + '.pyj'); });
40
+ } else {
41
+ files = fs.readdirSync(test_dir).filter(function(name){
42
+ return /^[^_].*\.pyj$/.test(name);
43
+ });
44
+ }
45
+ files.forEach(function(file){
46
+ var ast;
47
+ var filepath = path.join(test_dir, file);
48
+ var failed = false;
49
+ try {
50
+ ast = RapydScript.parse(fs.readFileSync(filepath, "utf-8"), {
51
+ filename: file,
52
+ toplevel: ast,
53
+ basedir: test_dir,
54
+ libdir: path.join(src_path, 'lib'),
55
+ });
56
+ if (ast.imports && Object.keys(ast.imports).length) {
57
+ RapydScript.tree_shake(ast, {
58
+ parse: RapydScript.parse,
59
+ import_dirs: [],
60
+ basedir: test_dir,
61
+ libdir: path.join(src_path, 'lib'),
62
+ });
63
+ }
64
+ } catch(e) {
65
+ failures.push(file);
66
+ failed = true;
67
+ console.log(colored(file, 'red') + ': ' + e + "\n\n");
68
+ return;
69
+ }
70
+
71
+ var js_version = 5;
72
+ while (js_version < 7) {
73
+ // generate output
74
+ var output = new RapydScript.OutputStream({
75
+ baselib_plain: baselib,
76
+ beautify: true,
77
+ js_version: js_version,
78
+ keep_docstrings: true,
79
+ });
80
+ ast.print(output);
81
+
82
+ // test that output performs correct JS operations
83
+ var jsfile = path.join(os.tmpdir(), file + '-es' + js_version + '.js');
84
+ var code = output.toString();
85
+ try {
86
+ vm.runInNewContext(code, {
87
+ 'assrt':assert,
88
+ '__name__': jsfile,
89
+ 'require':require,
90
+ 'fs':fs,
91
+ 'RapydScript':RapydScript,
92
+ 'console':console,
93
+ 'compiler_dir': compiler_dir,
94
+ 'test_path':test_dir,
95
+ 'Buffer': Buffer,
96
+ }, {'filename':jsfile});
97
+ } catch (e) {
98
+ failures.push(file);
99
+ failed = true;
100
+ fs.writeFileSync(jsfile, code);
101
+ console.error('Failed running: ' + colored(jsfile, 'red'));
102
+ if (e.stack)
103
+ console.error(colored(file, 'red') + ":\n" + e.stack + "\n\n");
104
+ else
105
+ console.error(colored(file, 'red') + ": " + e + "\n\n");
106
+ js_version = 1000;
107
+ }
108
+ js_version++;
109
+ }
110
+ if (!failed) console.log(colored(file, 'green') + ": test completed successfully\n");
111
+ else { console.log(colored(file, 'red') + ":\ttest failed\n"); }
112
+ });
113
+ if (failures.length) {
114
+ console.log(colored('There were ' + failures.length + ' test failure(s):', 'red'));
115
+ console.log.apply(console, failures);
116
+ } else console.log(colored('All tests passed!', 'green'));
117
+ process.exit((failures.length) ? 1 : 0);
118
+ };
package/tools/utils.js CHANGED
@@ -1,128 +1,128 @@
1
- /* vim:fileencoding=utf-8
2
- *
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 comment_contents = /\/\*!?(?:\@preserve)?[ \t]*(?:\r\n|\n)([\s\S]*?)(?:\r\n|\n)[ \t]*\*\//;
10
- var colors = ['red', 'green', 'yellow', 'blue', 'magenta', 'cyan', 'white'];
11
-
12
- function ansi(code) {
13
- code = code || 0;
14
- return String.fromCharCode(27) + '[' + code + 'm';
15
- }
16
-
17
- function path_exists(path) {
18
- var fs = require('fs');
19
- try {
20
- fs.statSync(path);
21
- return true;
22
- } catch(e) {
23
- if (e.code != 'ENOENT') throw e;
24
- }
25
- }
26
-
27
- function colored(string, color, bold) {
28
- var prefix = [];
29
- if (bold) prefix.push(ansi(1));
30
- if (color) prefix.push(ansi(colors.indexOf(color) + 31));
31
- return prefix.join('') + string + ansi(0);
32
- }
33
-
34
- function supports_color(stdout) {
35
- stdout = stdout || process.stdout;
36
- if (stdout && !stdout.isTTY) {
37
- return false;
38
- }
39
-
40
- if (process.platform === 'win32') {
41
- return false;
42
- }
43
-
44
- if ('COLORTERM' in process.env) {
45
- return true;
46
- }
47
-
48
- if (process.env.TERM === 'dumb') {
49
- return false;
50
- }
51
-
52
- if (/^screen|^xterm|^vt100|color|ansi|cygwin|linux/i.test(process.env.TERM)) {
53
- return true;
54
- }
55
-
56
- return false;
57
-
58
- }
59
-
60
- function safe_colored(string) {
61
- return string;
62
- }
63
-
64
- function repeat(str, num) {
65
- return new Array( num + 1 ).join( str );
66
- }
67
-
68
- function generators_available() {
69
- var gen;
70
- try {
71
- eval('gen = function *(){}'); // jshint ignore:line
72
- return typeof gen === 'function' && gen.constructor.name == 'GeneratorFunction';
73
- } catch(e) {
74
- return false;
75
- }
76
- }
77
-
78
- function wrap(lines, width) {
79
- var ans = [];
80
- var prev = '';
81
- lines.forEach(function (line) {
82
- line = prev + line;
83
- prev = '';
84
- if (line.length > width) {
85
- prev = line.substr(width);
86
- if (prev) prev += ' ';
87
- line = line.substr(0, width - 1);
88
- if (line.substr(line.length - 1 !== ' ')) line += '-';
89
- }
90
- ans.push(line);
91
- });
92
- if (prev) ans = ans.concat(wrap([prev]));
93
- return ans;
94
- }
95
-
96
- function merge() {
97
- // Simple merge of properties from all objects
98
- var ans = {};
99
- Array.prototype.slice.call(arguments).forEach(function (arg) {
100
- Object.keys(arg).forEach(function(key) {
101
- ans[key] = arg[key];
102
- });
103
- });
104
- return ans;
105
- }
106
-
107
- function get_import_dirs(paths_string, ignore_env) {
108
- var path = require('path');
109
- var paths = [];
110
- function merge(new_path) {
111
- if (paths.indexOf(new_path) == -1) paths.push(new_path);
112
- }
113
- if (!ignore_env && process && process.env && process.env.RAPYDSCRIPT_IMPORT_PATH) {
114
- process.env.RAPYDSCRIPT_IMPORT_PATH.split(path.delimiter).forEach(merge);
115
- }
116
- if (paths_string) paths_string.split(path.delimiter).forEach(merge);
117
- return paths;
118
- }
119
-
120
- exports.comment_contents = comment_contents;
121
- exports.repeat = repeat;
122
- exports.wrap = wrap;
123
- exports.merge = merge;
124
- exports.colored = colored;
125
- exports.safe_colored = (supports_color()) ? colored : safe_colored;
126
- exports.generators_available = generators_available;
127
- exports.get_import_dirs = get_import_dirs;
128
- exports.path_exists = path_exists;
1
+ /* vim:fileencoding=utf-8
2
+ *
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 comment_contents = /\/\*!?(?:\@preserve)?[ \t]*(?:\r\n|\n)([\s\S]*?)(?:\r\n|\n)[ \t]*\*\//;
10
+ var colors = ['red', 'green', 'yellow', 'blue', 'magenta', 'cyan', 'white'];
11
+
12
+ function ansi(code) {
13
+ code = code || 0;
14
+ return String.fromCharCode(27) + '[' + code + 'm';
15
+ }
16
+
17
+ function path_exists(path) {
18
+ var fs = require('fs');
19
+ try {
20
+ fs.statSync(path);
21
+ return true;
22
+ } catch(e) {
23
+ if (e.code != 'ENOENT') throw e;
24
+ }
25
+ }
26
+
27
+ function colored(string, color, bold) {
28
+ var prefix = [];
29
+ if (bold) prefix.push(ansi(1));
30
+ if (color) prefix.push(ansi(colors.indexOf(color) + 31));
31
+ return prefix.join('') + string + ansi(0);
32
+ }
33
+
34
+ function supports_color(stdout) {
35
+ stdout = stdout || process.stdout;
36
+ if (stdout && !stdout.isTTY) {
37
+ return false;
38
+ }
39
+
40
+ if (process.platform === 'win32') {
41
+ return false;
42
+ }
43
+
44
+ if ('COLORTERM' in process.env) {
45
+ return true;
46
+ }
47
+
48
+ if (process.env.TERM === 'dumb') {
49
+ return false;
50
+ }
51
+
52
+ if (/^screen|^xterm|^vt100|color|ansi|cygwin|linux/i.test(process.env.TERM)) {
53
+ return true;
54
+ }
55
+
56
+ return false;
57
+
58
+ }
59
+
60
+ function safe_colored(string) {
61
+ return string;
62
+ }
63
+
64
+ function repeat(str, num) {
65
+ return new Array( num + 1 ).join( str );
66
+ }
67
+
68
+ function generators_available() {
69
+ var gen;
70
+ try {
71
+ eval('gen = function *(){}'); // jshint ignore:line
72
+ return typeof gen === 'function' && gen.constructor.name == 'GeneratorFunction';
73
+ } catch(e) {
74
+ return false;
75
+ }
76
+ }
77
+
78
+ function wrap(lines, width) {
79
+ var ans = [];
80
+ var prev = '';
81
+ lines.forEach(function (line) {
82
+ line = prev + line;
83
+ prev = '';
84
+ if (line.length > width) {
85
+ prev = line.substr(width);
86
+ if (prev) prev += ' ';
87
+ line = line.substr(0, width - 1);
88
+ if (line.substr(line.length - 1 !== ' ')) line += '-';
89
+ }
90
+ ans.push(line);
91
+ });
92
+ if (prev) ans = ans.concat(wrap([prev]));
93
+ return ans;
94
+ }
95
+
96
+ function merge() {
97
+ // Simple merge of properties from all objects
98
+ var ans = {};
99
+ Array.prototype.slice.call(arguments).forEach(function (arg) {
100
+ Object.keys(arg).forEach(function(key) {
101
+ ans[key] = arg[key];
102
+ });
103
+ });
104
+ return ans;
105
+ }
106
+
107
+ function get_import_dirs(paths_string, ignore_env) {
108
+ var path = require('path');
109
+ var paths = [];
110
+ function merge(new_path) {
111
+ if (paths.indexOf(new_path) == -1) paths.push(new_path);
112
+ }
113
+ if (!ignore_env && process && process.env && process.env.RAPYDSCRIPT_IMPORT_PATH) {
114
+ process.env.RAPYDSCRIPT_IMPORT_PATH.split(path.delimiter).forEach(merge);
115
+ }
116
+ if (paths_string) paths_string.split(path.delimiter).forEach(merge);
117
+ return paths;
118
+ }
119
+
120
+ exports.comment_contents = comment_contents;
121
+ exports.repeat = repeat;
122
+ exports.wrap = wrap;
123
+ exports.merge = merge;
124
+ exports.colored = colored;
125
+ exports.safe_colored = (supports_color()) ? colored : safe_colored;
126
+ exports.generators_available = generators_available;
127
+ exports.get_import_dirs = get_import_dirs;
128
+ exports.path_exists = path_exists;