rapydscript-ns 0.9.3 → 0.9.5

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 (111) 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/PYTHON_GAPS.md +52 -142
  8. package/README.md +51 -21
  9. package/TODO.md +1 -26
  10. package/add-toc-to-readme +2 -2
  11. package/bin/export +75 -75
  12. package/bin/rapydscript +0 -0
  13. package/bin/web-repl-export +102 -102
  14. package/build +2 -2
  15. package/language-service/index.js +88 -36
  16. package/package.json +1 -1
  17. package/publish.py +37 -37
  18. package/release/baselib-plain-pretty.js +157 -31
  19. package/release/baselib-plain-ugly.js +5 -5
  20. package/release/compiler.js +724 -426
  21. package/release/signatures.json +29 -29
  22. package/session.vim +4 -4
  23. package/setup.cfg +2 -2
  24. package/src/ast.pyj +7 -0
  25. package/src/baselib-containers.pyj +41 -4
  26. package/src/baselib-errors.pyj +4 -3
  27. package/src/baselib-internal.pyj +47 -18
  28. package/src/baselib-str.pyj +16 -3
  29. package/src/compiler.pyj +36 -36
  30. package/src/errors.pyj +30 -30
  31. package/src/lib/aes.pyj +646 -646
  32. package/src/lib/collections.pyj +227 -3
  33. package/src/lib/copy.pyj +120 -120
  34. package/src/lib/elementmaker.pyj +83 -83
  35. package/src/lib/encodings.pyj +126 -126
  36. package/src/lib/gettext.pyj +569 -569
  37. package/src/lib/itertools.pyj +580 -580
  38. package/src/lib/math.pyj +193 -193
  39. package/src/lib/operator.pyj +11 -11
  40. package/src/lib/pprint.pyj +455 -0
  41. package/src/lib/random.pyj +118 -118
  42. package/src/lib/react.pyj +74 -74
  43. package/src/lib/statistics.pyj +0 -0
  44. package/src/lib/traceback.pyj +63 -63
  45. package/src/lib/uuid.pyj +77 -77
  46. package/src/monaco-language-service/completions.js +21 -14
  47. package/src/monaco-language-service/diagnostics.js +2 -2
  48. package/src/monaco-language-service/dts.js +58 -15
  49. package/src/monaco-language-service/package.json +3 -0
  50. package/src/output/classes.pyj +25 -2
  51. package/src/output/codegen.pyj +4 -1
  52. package/src/output/comments.pyj +45 -45
  53. package/src/output/exceptions.pyj +201 -201
  54. package/src/output/jsx.pyj +164 -164
  55. package/src/output/treeshake.pyj +182 -182
  56. package/src/output/utils.pyj +72 -72
  57. package/src/parse.pyj +42 -7
  58. package/src/string_interpolation.pyj +72 -72
  59. package/src/tokenizer.pyj +18 -2
  60. package/src/unicode_aliases.pyj +576 -576
  61. package/src/utils.pyj +192 -192
  62. package/test/_import_one.pyj +37 -37
  63. package/test/_import_two/__init__.pyj +11 -11
  64. package/test/_import_two/level2/deep.pyj +4 -4
  65. package/test/_import_two/other.pyj +6 -6
  66. package/test/_import_two/sub.pyj +13 -13
  67. package/test/aes_vectors.pyj +421 -421
  68. package/test/annotations.pyj +80 -80
  69. package/test/baselib.pyj +23 -0
  70. package/test/chainmap.pyj +185 -0
  71. package/test/dataclasses.pyj +3 -4
  72. package/test/decorators.pyj +77 -77
  73. package/test/docstrings.pyj +39 -39
  74. package/test/elementmaker_test.pyj +45 -45
  75. package/test/enum.pyj +1 -1
  76. package/test/functions.pyj +151 -151
  77. package/test/generators.pyj +41 -41
  78. package/test/generic.pyj +370 -370
  79. package/test/internationalization.pyj +73 -73
  80. package/test/lint.pyj +164 -164
  81. package/test/loops.pyj +85 -85
  82. package/test/numpy.pyj +734 -734
  83. package/test/pprint.pyj +232 -0
  84. package/test/python_features.pyj +1 -1
  85. package/test/repl.pyj +121 -121
  86. package/test/scoped_flags.pyj +76 -76
  87. package/test/statistics.pyj +224 -0
  88. package/test/str.pyj +4 -4
  89. package/test/unit/index.js +455 -0
  90. package/test/unit/language-service-completions.js +2 -0
  91. package/test/unit/language-service-dts.js +113 -0
  92. package/test/unit/language-service-hover.js +455 -455
  93. package/test/unit/language-service.js +135 -2
  94. package/test/unit/web-repl.js +349 -1
  95. package/tools/compiler.d.ts +367 -367
  96. package/tools/completer.js +131 -131
  97. package/tools/export.js +4 -2
  98. package/tools/gettext.js +185 -185
  99. package/tools/ini.js +65 -65
  100. package/tools/msgfmt.js +187 -187
  101. package/tools/repl.js +223 -223
  102. package/tools/test.js +118 -118
  103. package/tools/utils.js +141 -128
  104. package/tools/web_repl.js +95 -95
  105. package/try +41 -41
  106. package/web-repl/env.js +196 -196
  107. package/web-repl/index.html +163 -163
  108. package/web-repl/prism.css +139 -139
  109. package/web-repl/prism.js +113 -113
  110. package/web-repl/rapydscript.js +228 -226
  111. package/web-repl/sha1.js +25 -25
package/tools/ini.js CHANGED
@@ -1,65 +1,65 @@
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 fs = require('fs');
10
- var path = require('path');
11
-
12
- function parse_ini_data(data) {
13
- // Based on MIT licensed code from:
14
- // https://github.com/shockie/node-iniparser/blob/master/lib/node-iniparser.js
15
- var ans = {}, match;
16
- var lines = data.split(/\r\n|\r|\n/);
17
- var section = null;
18
- var section_pat = /^\s*\[\s*([^\]]*)\s*\]\s*$/;
19
- var param_pat = /^\s*([\w\.\-\_]+)\s*=\s*(.*?)\s*$/;
20
- var comment_pat = /^\s*;.*$/;
21
-
22
- lines.forEach(function(line) {
23
- if(comment_pat.test(line)) {
24
- return;
25
- } else if(param_pat.test(line)) {
26
- match = line.match(param_pat);
27
- if(section) {
28
- ans[section][match[1]] = match[2];
29
- } else {
30
- ans[match[1]] = match[2];
31
- }
32
- } else if(section_pat.test(line)) {
33
- match = line.match(section_pat);
34
- ans[match[1]] = {};
35
- section = match[1];
36
- } else if(line.length === 0 && section) {
37
- section = null;
38
- }
39
- });
40
- return ans;
41
- }
42
-
43
- function find_cfg_file(toplevel_dir) {
44
- var current_dir = toplevel_dir, previous_dir = toplevel_dir;
45
- do {
46
- try {
47
- return fs.readFileSync(path.join(current_dir, 'setup.cfg'), 'utf-8');
48
- } catch (e) {
49
- if (e.code !== 'ENOENT') throw e;
50
- }
51
- previous_dir = current_dir;
52
- current_dir = path.dirname(current_dir);
53
- } while(current_dir != previous_dir && current_dir);
54
-
55
- return null;
56
- }
57
-
58
- function read_config(toplevel_dir) {
59
- var data = find_cfg_file(toplevel_dir);
60
- if (!data) return {};
61
- return parse_ini_data(data);
62
- }
63
-
64
-
65
- exports.read_config = read_config;
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 fs = require('fs');
10
+ var path = require('path');
11
+
12
+ function parse_ini_data(data) {
13
+ // Based on MIT licensed code from:
14
+ // https://github.com/shockie/node-iniparser/blob/master/lib/node-iniparser.js
15
+ var ans = {}, match;
16
+ var lines = data.split(/\r\n|\r|\n/);
17
+ var section = null;
18
+ var section_pat = /^\s*\[\s*([^\]]*)\s*\]\s*$/;
19
+ var param_pat = /^\s*([\w\.\-\_]+)\s*=\s*(.*?)\s*$/;
20
+ var comment_pat = /^\s*;.*$/;
21
+
22
+ lines.forEach(function(line) {
23
+ if(comment_pat.test(line)) {
24
+ return;
25
+ } else if(param_pat.test(line)) {
26
+ match = line.match(param_pat);
27
+ if(section) {
28
+ ans[section][match[1]] = match[2];
29
+ } else {
30
+ ans[match[1]] = match[2];
31
+ }
32
+ } else if(section_pat.test(line)) {
33
+ match = line.match(section_pat);
34
+ ans[match[1]] = {};
35
+ section = match[1];
36
+ } else if(line.length === 0 && section) {
37
+ section = null;
38
+ }
39
+ });
40
+ return ans;
41
+ }
42
+
43
+ function find_cfg_file(toplevel_dir) {
44
+ var current_dir = toplevel_dir, previous_dir = toplevel_dir;
45
+ do {
46
+ try {
47
+ return fs.readFileSync(path.join(current_dir, 'setup.cfg'), 'utf-8');
48
+ } catch (e) {
49
+ if (e.code !== 'ENOENT') throw e;
50
+ }
51
+ previous_dir = current_dir;
52
+ current_dir = path.dirname(current_dir);
53
+ } while(current_dir != previous_dir && current_dir);
54
+
55
+ return null;
56
+ }
57
+
58
+ function read_config(toplevel_dir) {
59
+ var data = find_cfg_file(toplevel_dir);
60
+ if (!data) return {};
61
+ return parse_ini_data(data);
62
+ }
63
+
64
+
65
+ exports.read_config = read_config;
package/tools/msgfmt.js CHANGED
@@ -1,187 +1,187 @@
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
- function unesc(string) {
10
- return string.replace(/\\"/g, '"').replace(/\\n/g, '\n').replace(/\\r/g, '\r').replace(/\\t/g, '\t').replace(/\\\\/g, '\\');
11
- }
12
-
13
- function parse(data, on_error) {
14
- // Parse a PO file using a state machine (does not work for POT files). Also only extracts data useful
15
- // for JSON output.
16
- var plural_forms = null;
17
- var lines = data.split('\n');
18
- var entries = [];
19
- var current_entry = create_entry();
20
- var lnum = 0;
21
- var nplurals = null;
22
- var language = null;
23
-
24
- function fatal() {
25
- var msg = Array.prototype.slice.call(arguments).join(' ');
26
- if (on_error) { on_error(msg); return; }
27
- console.error(msg);
28
- process.exit(1);
29
- }
30
-
31
- function create_entry() {
32
- return {msgid: null, fuzzy: false, msgstr:[], msgid_plural:null, lnum:null};
33
- }
34
-
35
- function parse_header() {
36
- var raw = current_entry.msgstr[0];
37
- if (raw === undefined) fatal('Header has no msgstr');
38
- raw.split('\n').forEach(function(line) {
39
- if (line.startsWith('Plural-Forms:')) {
40
- plural_forms = line.slice('Plural-Forms:'.length).trim();
41
- var match = /^nplurals\s*=\s*(\d+)\s*;/.exec(plural_forms);
42
- if (!match || match[1] === undefined) fatal('Invalid Plural-Forms header:', plural_forms);
43
- nplurals = parseInt(match[1]);
44
- }
45
- else if (line.startsWith('Language:')) {
46
- language = line.slice('Language:'.length).trim();
47
- }
48
- });
49
- }
50
-
51
- function commit_entry() {
52
- if (current_entry.msgid) {
53
- if (current_entry.msgid_plural !== null) {
54
- if (nplurals === null) fatal('Plural-Forms header missing');
55
- for (var i = 0; i < nplurals; i++) {
56
- if (current_entry.msgstr[i] === undefined) fatal('Missing plural form for entry at line number:', lnum);
57
- }
58
- }
59
- entries.push(current_entry);
60
- } else if (current_entry.msgid === '') parse_header();
61
- current_entry = create_entry();
62
- }
63
-
64
- function read_string(line) {
65
- line = line.trim();
66
- if (!line || line[0] !== '"' || line[line.length - 1] !== '"') {
67
- fatal('Expecting a string at line number:', lnum);
68
- }
69
- return unesc(line.slice(1, -1));
70
- }
71
-
72
- function continuation(line, lines, append, after) {
73
- if (line[0] === '"') append(read_string(line));
74
- else {
75
- state = after;
76
- after(line, lines);
77
- }
78
- }
79
-
80
- function start(line, lines) {
81
- if (line[0] === '#') {
82
- if (line[1] === ',') {
83
- line.slice(2).trimLeft().split(',').forEach(function(flag) {
84
- if (flag.trim().toLowerCase() === 'fuzzy') current_entry.fuzzy = true;
85
- });
86
- }
87
- } else if (line.startsWith('msgid ')) {
88
- current_entry.msgid = read_string(line.slice('msgid '.length));
89
- current_entry.lnum = lnum;
90
- state = function(line, lines) {
91
- continuation(line, lines, function(x) { current_entry.msgid += x; }, after_msgid);
92
- };
93
- } else {
94
- fatal('Expecting msgid at line number:', lnum);
95
- }
96
- }
97
-
98
- function after_msgid(line, lines) {
99
- if (line.startsWith('msgid_plural ')) {
100
- current_entry.msgid_plural = read_string(line.slice('msgid_plural '.length));
101
- state = function(line, lines) {
102
- continuation(line, lines, function(x) { current_entry.msgid_plural += x; }, msgstr);
103
- };
104
- }
105
-
106
- else if (line.startsWith('msgstr ') || line.startsWith('msgstr[')) {
107
- state = msgstr;
108
- msgstr(line, lines);
109
- }
110
-
111
- else fatal('Expecting either msgstr or msgid_plural at line number:', lnum);
112
-
113
- }
114
-
115
- function msgstr(line, lines) {
116
- if (line.startsWith('msgstr ')) {
117
- if (current_entry.msgid_plural !== null) fatal('Expecting msgstr[0] at line number:', lnum);
118
- current_entry.msgstr.push(read_string(line.slice('msgstr '.length)));
119
- state = function(line, lines) {
120
- continuation(line, lines, function(x) { current_entry.msgstr[current_entry.msgstr.length - 1] += x; }, msgstr);
121
- };
122
- }
123
-
124
- else if (line[0] === '#' || line.startsWith('msgid ')) {
125
- if (!current_entry.msgstr.length) fatal('Expecting msgstr at line number:', lnum);
126
- commit_entry();
127
- state = start;
128
- start(line, lines);
129
- }
130
-
131
- else if (line.startsWith('msgstr[')) {
132
- if (current_entry.msgid_plural === null) fatal('Expecting non-plural msgstr at line number:', lnum);
133
- var pnum = /^msgstr\[(\d+)\] /.exec(line);
134
- if (!pnum || pnum[1] === undefined) fatal('Malformed msgstr at line number:', lnum);
135
- var idx = parseInt(pnum[1]);
136
- current_entry.msgstr[idx] = read_string(line.slice(pnum[0].length));
137
- state = function(line, lines) {
138
- continuation(line, lines, function(x) { current_entry.msgstr[idx] += x; }, msgstr);
139
- };
140
- }
141
-
142
- else fatal('Expecting msgstr or msgid at line number:', lnum);
143
- }
144
-
145
- var state = start;
146
-
147
- while (lines.length) {
148
- var line = lines.shift().trim();
149
- lnum += 1;
150
- if (!line) continue;
151
- state(line, lines);
152
- }
153
- commit_entry();
154
- if (language === null) fatal('No language specified in the header of this po file');
155
- return {entries:entries, plural_forms:plural_forms, nplurals:nplurals, language:language};
156
- }
157
-
158
- function read_stdin(cont) {
159
- var chunks = [];
160
- process.stdin.setEncoding('utf8');
161
-
162
- process.stdin.on('readable', function () {
163
- var chunk = process.stdin.read();
164
- if (chunk) chunks.push(chunk);
165
- });
166
-
167
- process.stdin.on('end', function() { cont(chunks.join('')); });
168
- }
169
-
170
- function serialize_catalog(catalog, options) {
171
- if (!options.use_fuzzy) catalog.entries = catalog.entries.filter(function(e) { return !e.fuzzy; });
172
- var entries = {};
173
- catalog.entries.forEach(function (entry) {
174
- entries[entry.msgid] = entry.msgstr;
175
- });
176
- return JSON.stringify({'plural_forms':catalog.plural_forms, 'entries':entries, 'language':catalog.language});
177
- }
178
-
179
- module.exports.cli = function(argv, base_path, src_path, lib_path) {
180
- read_stdin(function process(data) {
181
- var catalog = parse(data);
182
- console.log(serialize_catalog(catalog, argv));
183
- });
184
- };
185
-
186
- module.exports.parse = parse;
187
- module.exports.build = function(data, options) { return serialize_catalog(parse(data), options); };
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
+ function unesc(string) {
10
+ return string.replace(/\\"/g, '"').replace(/\\n/g, '\n').replace(/\\r/g, '\r').replace(/\\t/g, '\t').replace(/\\\\/g, '\\');
11
+ }
12
+
13
+ function parse(data, on_error) {
14
+ // Parse a PO file using a state machine (does not work for POT files). Also only extracts data useful
15
+ // for JSON output.
16
+ var plural_forms = null;
17
+ var lines = data.split('\n');
18
+ var entries = [];
19
+ var current_entry = create_entry();
20
+ var lnum = 0;
21
+ var nplurals = null;
22
+ var language = null;
23
+
24
+ function fatal() {
25
+ var msg = Array.prototype.slice.call(arguments).join(' ');
26
+ if (on_error) { on_error(msg); return; }
27
+ console.error(msg);
28
+ process.exit(1);
29
+ }
30
+
31
+ function create_entry() {
32
+ return {msgid: null, fuzzy: false, msgstr:[], msgid_plural:null, lnum:null};
33
+ }
34
+
35
+ function parse_header() {
36
+ var raw = current_entry.msgstr[0];
37
+ if (raw === undefined) fatal('Header has no msgstr');
38
+ raw.split('\n').forEach(function(line) {
39
+ if (line.startsWith('Plural-Forms:')) {
40
+ plural_forms = line.slice('Plural-Forms:'.length).trim();
41
+ var match = /^nplurals\s*=\s*(\d+)\s*;/.exec(plural_forms);
42
+ if (!match || match[1] === undefined) fatal('Invalid Plural-Forms header:', plural_forms);
43
+ nplurals = parseInt(match[1]);
44
+ }
45
+ else if (line.startsWith('Language:')) {
46
+ language = line.slice('Language:'.length).trim();
47
+ }
48
+ });
49
+ }
50
+
51
+ function commit_entry() {
52
+ if (current_entry.msgid) {
53
+ if (current_entry.msgid_plural !== null) {
54
+ if (nplurals === null) fatal('Plural-Forms header missing');
55
+ for (var i = 0; i < nplurals; i++) {
56
+ if (current_entry.msgstr[i] === undefined) fatal('Missing plural form for entry at line number:', lnum);
57
+ }
58
+ }
59
+ entries.push(current_entry);
60
+ } else if (current_entry.msgid === '') parse_header();
61
+ current_entry = create_entry();
62
+ }
63
+
64
+ function read_string(line) {
65
+ line = line.trim();
66
+ if (!line || line[0] !== '"' || line[line.length - 1] !== '"') {
67
+ fatal('Expecting a string at line number:', lnum);
68
+ }
69
+ return unesc(line.slice(1, -1));
70
+ }
71
+
72
+ function continuation(line, lines, append, after) {
73
+ if (line[0] === '"') append(read_string(line));
74
+ else {
75
+ state = after;
76
+ after(line, lines);
77
+ }
78
+ }
79
+
80
+ function start(line, lines) {
81
+ if (line[0] === '#') {
82
+ if (line[1] === ',') {
83
+ line.slice(2).trimLeft().split(',').forEach(function(flag) {
84
+ if (flag.trim().toLowerCase() === 'fuzzy') current_entry.fuzzy = true;
85
+ });
86
+ }
87
+ } else if (line.startsWith('msgid ')) {
88
+ current_entry.msgid = read_string(line.slice('msgid '.length));
89
+ current_entry.lnum = lnum;
90
+ state = function(line, lines) {
91
+ continuation(line, lines, function(x) { current_entry.msgid += x; }, after_msgid);
92
+ };
93
+ } else {
94
+ fatal('Expecting msgid at line number:', lnum);
95
+ }
96
+ }
97
+
98
+ function after_msgid(line, lines) {
99
+ if (line.startsWith('msgid_plural ')) {
100
+ current_entry.msgid_plural = read_string(line.slice('msgid_plural '.length));
101
+ state = function(line, lines) {
102
+ continuation(line, lines, function(x) { current_entry.msgid_plural += x; }, msgstr);
103
+ };
104
+ }
105
+
106
+ else if (line.startsWith('msgstr ') || line.startsWith('msgstr[')) {
107
+ state = msgstr;
108
+ msgstr(line, lines);
109
+ }
110
+
111
+ else fatal('Expecting either msgstr or msgid_plural at line number:', lnum);
112
+
113
+ }
114
+
115
+ function msgstr(line, lines) {
116
+ if (line.startsWith('msgstr ')) {
117
+ if (current_entry.msgid_plural !== null) fatal('Expecting msgstr[0] at line number:', lnum);
118
+ current_entry.msgstr.push(read_string(line.slice('msgstr '.length)));
119
+ state = function(line, lines) {
120
+ continuation(line, lines, function(x) { current_entry.msgstr[current_entry.msgstr.length - 1] += x; }, msgstr);
121
+ };
122
+ }
123
+
124
+ else if (line[0] === '#' || line.startsWith('msgid ')) {
125
+ if (!current_entry.msgstr.length) fatal('Expecting msgstr at line number:', lnum);
126
+ commit_entry();
127
+ state = start;
128
+ start(line, lines);
129
+ }
130
+
131
+ else if (line.startsWith('msgstr[')) {
132
+ if (current_entry.msgid_plural === null) fatal('Expecting non-plural msgstr at line number:', lnum);
133
+ var pnum = /^msgstr\[(\d+)\] /.exec(line);
134
+ if (!pnum || pnum[1] === undefined) fatal('Malformed msgstr at line number:', lnum);
135
+ var idx = parseInt(pnum[1]);
136
+ current_entry.msgstr[idx] = read_string(line.slice(pnum[0].length));
137
+ state = function(line, lines) {
138
+ continuation(line, lines, function(x) { current_entry.msgstr[idx] += x; }, msgstr);
139
+ };
140
+ }
141
+
142
+ else fatal('Expecting msgstr or msgid at line number:', lnum);
143
+ }
144
+
145
+ var state = start;
146
+
147
+ while (lines.length) {
148
+ var line = lines.shift().trim();
149
+ lnum += 1;
150
+ if (!line) continue;
151
+ state(line, lines);
152
+ }
153
+ commit_entry();
154
+ if (language === null) fatal('No language specified in the header of this po file');
155
+ return {entries:entries, plural_forms:plural_forms, nplurals:nplurals, language:language};
156
+ }
157
+
158
+ function read_stdin(cont) {
159
+ var chunks = [];
160
+ process.stdin.setEncoding('utf8');
161
+
162
+ process.stdin.on('readable', function () {
163
+ var chunk = process.stdin.read();
164
+ if (chunk) chunks.push(chunk);
165
+ });
166
+
167
+ process.stdin.on('end', function() { cont(chunks.join('')); });
168
+ }
169
+
170
+ function serialize_catalog(catalog, options) {
171
+ if (!options.use_fuzzy) catalog.entries = catalog.entries.filter(function(e) { return !e.fuzzy; });
172
+ var entries = {};
173
+ catalog.entries.forEach(function (entry) {
174
+ entries[entry.msgid] = entry.msgstr;
175
+ });
176
+ return JSON.stringify({'plural_forms':catalog.plural_forms, 'entries':entries, 'language':catalog.language});
177
+ }
178
+
179
+ module.exports.cli = function(argv, base_path, src_path, lib_path) {
180
+ read_stdin(function process(data) {
181
+ var catalog = parse(data);
182
+ console.log(serialize_catalog(catalog, argv));
183
+ });
184
+ };
185
+
186
+ module.exports.parse = parse;
187
+ module.exports.build = function(data, options) { return serialize_catalog(parse(data), options); };