grammar-well 1.1.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 (117) hide show
  1. package/.eslintrc.cjs +14 -0
  2. package/README.md +288 -0
  3. package/bootstrap.ts +35 -0
  4. package/build/compiler/compiler.d.ts +48 -0
  5. package/build/compiler/compiler.js +227 -0
  6. package/build/compiler/compiler.js.map +1 -0
  7. package/build/compiler/generator.d.ts +23 -0
  8. package/build/compiler/generator.js +213 -0
  9. package/build/compiler/generator.js.map +1 -0
  10. package/build/compiler/import-resolver.d.ts +15 -0
  11. package/build/compiler/import-resolver.js +37 -0
  12. package/build/compiler/import-resolver.js.map +1 -0
  13. package/build/compiler/outputs/javascript.d.ts +3 -0
  14. package/build/compiler/outputs/javascript.js +29 -0
  15. package/build/compiler/outputs/javascript.js.map +1 -0
  16. package/build/compiler/outputs/json.d.ts +2 -0
  17. package/build/compiler/outputs/json.js +8 -0
  18. package/build/compiler/outputs/json.js.map +1 -0
  19. package/build/compiler/outputs/typescript.d.ts +2 -0
  20. package/build/compiler/outputs/typescript.js +108 -0
  21. package/build/compiler/outputs/typescript.js.map +1 -0
  22. package/build/grammars/gwell.d.ts +997 -0
  23. package/build/grammars/gwell.js +537 -0
  24. package/build/grammars/gwell.js.map +1 -0
  25. package/build/grammars/json.d.ts +151 -0
  26. package/build/grammars/json.js +112 -0
  27. package/build/grammars/json.js.map +1 -0
  28. package/build/grammars/number.d.ts +239 -0
  29. package/build/grammars/number.js +115 -0
  30. package/build/grammars/number.js.map +1 -0
  31. package/build/grammars/number.json +1 -0
  32. package/build/grammars/string.d.ts +116 -0
  33. package/build/grammars/string.js +50 -0
  34. package/build/grammars/string.js.map +1 -0
  35. package/build/grammars/string.json +1 -0
  36. package/build/grammars/whitespace.d.ts +51 -0
  37. package/build/grammars/whitespace.js +30 -0
  38. package/build/grammars/whitespace.js.map +1 -0
  39. package/build/grammars/whitespace.json +1 -0
  40. package/build/index.d.ts +4 -0
  41. package/build/index.js +21 -0
  42. package/build/index.js.map +1 -0
  43. package/build/lexers/character-lexer.d.ts +27 -0
  44. package/build/lexers/character-lexer.js +71 -0
  45. package/build/lexers/character-lexer.js.map +1 -0
  46. package/build/lexers/stateful-lexer.d.ts +48 -0
  47. package/build/lexers/stateful-lexer.js +309 -0
  48. package/build/lexers/stateful-lexer.js.map +1 -0
  49. package/build/lexers/token-buffer.d.ts +32 -0
  50. package/build/lexers/token-buffer.js +92 -0
  51. package/build/lexers/token-buffer.js.map +1 -0
  52. package/build/parser/algorithms/cyk.d.ts +16 -0
  53. package/build/parser/algorithms/cyk.js +58 -0
  54. package/build/parser/algorithms/cyk.js.map +1 -0
  55. package/build/parser/algorithms/earley.d.ts +48 -0
  56. package/build/parser/algorithms/earley.js +158 -0
  57. package/build/parser/algorithms/earley.js.map +1 -0
  58. package/build/parser/algorithms/lr.d.ts +10 -0
  59. package/build/parser/algorithms/lr.js +34 -0
  60. package/build/parser/algorithms/lr.js.map +1 -0
  61. package/build/parser/parser.d.ts +26 -0
  62. package/build/parser/parser.js +74 -0
  63. package/build/parser/parser.js.map +1 -0
  64. package/build/typings.d.ts +198 -0
  65. package/build/typings.js +3 -0
  66. package/build/typings.js.map +1 -0
  67. package/build/utility/general.d.ts +46 -0
  68. package/build/utility/general.js +112 -0
  69. package/build/utility/general.js.map +1 -0
  70. package/build/utility/lint.d.ts +2 -0
  71. package/build/utility/lint.js +28 -0
  72. package/build/utility/lint.js.map +1 -0
  73. package/build/utility/lr.d.ts +56 -0
  74. package/build/utility/lr.js +131 -0
  75. package/build/utility/lr.js.map +1 -0
  76. package/build/utility/text-format.d.ts +11 -0
  77. package/build/utility/text-format.js +84 -0
  78. package/build/utility/text-format.js.map +1 -0
  79. package/licenses/LICENSE.txt +165 -0
  80. package/licenses/moo.license +29 -0
  81. package/licenses/nearley.license +21 -0
  82. package/package.json +52 -0
  83. package/src/compiler/compiler.ts +239 -0
  84. package/src/compiler/generator.ts +229 -0
  85. package/src/compiler/import-resolver.ts +36 -0
  86. package/src/compiler/outputs/javascript.ts +27 -0
  87. package/src/compiler/outputs/json.ts +5 -0
  88. package/src/compiler/outputs/typescript.ts +105 -0
  89. package/src/grammars/gwell.gwell +278 -0
  90. package/src/grammars/gwell.js +539 -0
  91. package/src/grammars/gwell.json +1 -0
  92. package/src/grammars/json.gwell +75 -0
  93. package/src/grammars/json.js +121 -0
  94. package/src/grammars/json.json +1 -0
  95. package/src/grammars/number.gwell +20 -0
  96. package/src/grammars/number.js +117 -0
  97. package/src/grammars/number.json +1 -0
  98. package/src/grammars/string.gwell +15 -0
  99. package/src/grammars/string.js +52 -0
  100. package/src/grammars/string.json +1 -0
  101. package/src/grammars/whitespace.gwell +6 -0
  102. package/src/grammars/whitespace.js +32 -0
  103. package/src/grammars/whitespace.json +1 -0
  104. package/src/index.ts +4 -0
  105. package/src/lexers/character-lexer.ts +73 -0
  106. package/src/lexers/stateful-lexer.ts +335 -0
  107. package/src/lexers/token-buffer.ts +102 -0
  108. package/src/parser/algorithms/cyk.ts +74 -0
  109. package/src/parser/algorithms/earley.ts +193 -0
  110. package/src/parser/algorithms/lr.ts +37 -0
  111. package/src/parser/parser.ts +77 -0
  112. package/src/typings.ts +221 -0
  113. package/src/utility/general.ts +120 -0
  114. package/src/utility/lint.ts +26 -0
  115. package/src/utility/lr.ts +153 -0
  116. package/src/utility/text-format.ts +84 -0
  117. package/testing.ts +18 -0
@@ -0,0 +1,309 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ResolveStates = exports.StatefulLexer = void 0;
4
+ class StatefulLexer {
5
+ start;
6
+ states = Object.create(null);
7
+ buffer;
8
+ stack;
9
+ index;
10
+ line;
11
+ column;
12
+ prefetched;
13
+ current;
14
+ unmatched;
15
+ rules;
16
+ regexp;
17
+ tags = new Map();
18
+ constructor({ states, start }) {
19
+ ResolveStates(states, start);
20
+ for (const key in states) {
21
+ this.states[key] = {
22
+ regexp: CompileRegExp(states[key]),
23
+ rules: states[key].rules,
24
+ unmatched: states[key].unmatched ? { type: states[key].unmatched } : null
25
+ };
26
+ }
27
+ this.start = start;
28
+ this.buffer = '';
29
+ this.stack = [];
30
+ this.feed();
31
+ }
32
+ feed(data, state) {
33
+ this.buffer = data || '';
34
+ this.index = 0;
35
+ this.line = state ? state.line : 1;
36
+ this.column = state ? state.column : 1;
37
+ this.prefetched = state?.prefetched;
38
+ this.set(state ? state.state : this.start);
39
+ this.stack = state && state.stack ? state.stack.slice() : [];
40
+ }
41
+ state() {
42
+ return {
43
+ line: this.line,
44
+ column: this.column,
45
+ state: this.current,
46
+ stack: this.stack.slice(),
47
+ prefetched: this.prefetched,
48
+ };
49
+ }
50
+ next() {
51
+ const next = this.matchNext();
52
+ if (!next) {
53
+ return;
54
+ }
55
+ const { rule, text, index } = next;
56
+ if (!rule) {
57
+ throw new Error(`No matching rule for ${text}`);
58
+ }
59
+ const token = this.createToken(rule, text, index);
60
+ this.processRule(rule);
61
+ return token;
62
+ }
63
+ set(current) {
64
+ if (!current || this.current === current)
65
+ return;
66
+ const info = this.states[current];
67
+ this.current = current;
68
+ this.rules = info.rules;
69
+ this.unmatched = info.unmatched;
70
+ this.regexp = info.regexp;
71
+ }
72
+ pop() {
73
+ this.set(this.stack.pop());
74
+ }
75
+ goto(state) {
76
+ this.stack.push(this.current);
77
+ this.set(state);
78
+ }
79
+ matchNext() {
80
+ if (this.index === this.buffer.length) {
81
+ return;
82
+ }
83
+ const { index, buffer } = this;
84
+ let text;
85
+ let rule;
86
+ let match;
87
+ this.regexp.lastIndex = index;
88
+ if (this.prefetched) {
89
+ match = this.prefetched;
90
+ this.prefetched = null;
91
+ }
92
+ else {
93
+ match = this.regexp.exec(buffer);
94
+ }
95
+ if (match == null) {
96
+ rule = this.unmatched;
97
+ text = buffer.slice(index, buffer.length);
98
+ }
99
+ else if (match.index !== index) {
100
+ rule = this.unmatched;
101
+ text = buffer.slice(index, match.index);
102
+ this.prefetched = match;
103
+ }
104
+ else {
105
+ rule = this.getGroup(match);
106
+ text = match[0];
107
+ }
108
+ return { index, rule, text };
109
+ }
110
+ createToken(rule, text, offset) {
111
+ const token = {
112
+ type: rule.type,
113
+ tag: this.getTags(rule.tag),
114
+ value: text,
115
+ text: text,
116
+ offset: offset,
117
+ line: this.line,
118
+ column: this.column,
119
+ state: this.current
120
+ };
121
+ for (let i = 0; i < text.length; i++) {
122
+ this.index++;
123
+ this.column++;
124
+ if (text[i] == '\n') {
125
+ this.line++;
126
+ this.column = 1;
127
+ }
128
+ }
129
+ return token;
130
+ }
131
+ getTags(tags) {
132
+ if (!tags)
133
+ return undefined;
134
+ if (!this.tags.has(tags))
135
+ this.tags.set(tags, new Set(tags));
136
+ return this.tags.get(tags);
137
+ }
138
+ processRule(rule) {
139
+ if (rule.pop) {
140
+ let i = rule.pop === 'all' ? this.stack.length : rule.pop;
141
+ while (i-- > 0) {
142
+ this.pop();
143
+ }
144
+ }
145
+ if (rule.set) {
146
+ this.set(rule.set);
147
+ }
148
+ if (rule.goto) {
149
+ this.goto(rule.goto);
150
+ }
151
+ if (rule.inset) {
152
+ let i = rule.inset;
153
+ while (--i >= 0) {
154
+ this.goto(this.current);
155
+ }
156
+ }
157
+ }
158
+ getGroup(match) {
159
+ for (let i = 0; i < this.rules.length; i++) {
160
+ if (match[i + 1] !== undefined) {
161
+ return this.rules[i];
162
+ }
163
+ }
164
+ throw new Error('Cannot find token type for matched text');
165
+ }
166
+ }
167
+ exports.StatefulLexer = StatefulLexer;
168
+ class RegexLib {
169
+ static IsRegex(o) {
170
+ return o instanceof RegExp;
171
+ }
172
+ static Escape(s) {
173
+ return s.replace(/[-/\\^$*+?.()|[\]{}]/g, '\\$&');
174
+ }
175
+ static HasGroups(s) {
176
+ return (new RegExp('|' + s)).exec('').length > 1;
177
+ }
178
+ static Capture(source) {
179
+ return '(' + source + ')';
180
+ }
181
+ static Join(regexps) {
182
+ if (!regexps.length)
183
+ return '(?!)';
184
+ const source = regexps.map((s) => `(?:${s})`).join('|');
185
+ return `(?:${source})`;
186
+ }
187
+ static Source(search) {
188
+ if (typeof search === 'string') {
189
+ return `(?:${RegexLib.Escape(search)})`;
190
+ }
191
+ if (RegexLib.IsRegex(search)) {
192
+ return search.source;
193
+ }
194
+ throw new Error('Not a pattern: ' + search);
195
+ }
196
+ }
197
+ function CompileRegExp(state) {
198
+ const rules = [];
199
+ const subexpressions = [];
200
+ let isUnicode = null;
201
+ let isCI = null;
202
+ for (const options of state.rules) {
203
+ if (RegexLib.IsRegex(options.when)) {
204
+ const when = options.when;
205
+ if (isUnicode === null) {
206
+ isUnicode = when.unicode;
207
+ }
208
+ else if (isUnicode !== when.unicode && !state.unmatched) {
209
+ throw new Error(`Inconsistent Regex Flag /u in state: ${state.name}`);
210
+ }
211
+ if (isCI === null) {
212
+ isCI = when.ignoreCase;
213
+ }
214
+ else if (isCI !== when.ignoreCase) {
215
+ throw new Error(`Inconsistent Regex Flag /i in state: ${state.name}`);
216
+ }
217
+ }
218
+ else {
219
+ if (isCI == null) {
220
+ isCI = false;
221
+ }
222
+ else if (isCI != false) {
223
+ throw new Error(`Inconsistent Regex Flag /i in state: ${state.name}`);
224
+ }
225
+ }
226
+ rules.push(options);
227
+ const pat = RegexLib.Source(options.when);
228
+ const regexp = new RegExp(pat);
229
+ if (regexp.test("")) {
230
+ throw new Error("RegExp matches empty string: " + regexp);
231
+ }
232
+ if (RegexLib.HasGroups(pat)) {
233
+ throw new Error("RegExp has capture groups: " + regexp + "\nUse (?: … ) instead");
234
+ }
235
+ subexpressions.push(RegexLib.Capture(pat));
236
+ }
237
+ let flags = !state.unmatched ? 'ym' : 'gm';
238
+ if (isUnicode === true)
239
+ flags += "u";
240
+ if (isCI === true)
241
+ flags += "i";
242
+ return new RegExp(RegexLib.Join(subexpressions), flags);
243
+ }
244
+ function ResolveStates(states, start) {
245
+ const resolved = new Set();
246
+ const resolving = new Set();
247
+ const chain = new Set();
248
+ ResolveRuleImports(start, states, resolved, resolving, chain);
249
+ for (const key in states) {
250
+ if (!resolved.has(key)) {
251
+ delete states[key];
252
+ }
253
+ }
254
+ return states;
255
+ }
256
+ exports.ResolveStates = ResolveStates;
257
+ function ResolveRuleImports(name, states, resolved, resolving, chain) {
258
+ if (chain.has(name))
259
+ throw new Error(`Can not resolve circular import of ${name}`);
260
+ if (!states[name])
261
+ throw new Error(`Can not import unknown state ${name}`);
262
+ if (resolved.has(name) || resolving.has(name))
263
+ return;
264
+ const state = states[name];
265
+ const rules = new UniqueRules();
266
+ chain.add(name);
267
+ resolving.add(name);
268
+ for (let i = 0; i < state.rules.length; i++) {
269
+ const rule = state.rules[i];
270
+ if ("import" in rule) {
271
+ for (const ref of rule.import) {
272
+ ResolveRuleImports(ref, states, resolved, resolving, chain);
273
+ rules.push(...states[ref].rules);
274
+ }
275
+ }
276
+ else {
277
+ rules.push(rule);
278
+ if ("set" in rule && !resolving.has(rule.set)) {
279
+ ResolveRuleImports(rule.set, states, resolved, resolving, new Set());
280
+ }
281
+ if ("goto" in rule && !resolving.has(rule.goto)) {
282
+ ResolveRuleImports(rule.goto, states, resolved, resolving, new Set());
283
+ }
284
+ }
285
+ }
286
+ state.rules = rules.rules;
287
+ chain.delete(name);
288
+ resolved.add(name);
289
+ }
290
+ class UniqueRules {
291
+ regexps = new Set();
292
+ strings = new Set();
293
+ rules = [];
294
+ push(...rules) {
295
+ for (const rule of rules) {
296
+ if (RegexLib.IsRegex(rule.when)) {
297
+ if (!this.regexps.has(rule.when.source)) {
298
+ this.rules.push(rule);
299
+ }
300
+ }
301
+ else {
302
+ if (!this.strings.has(rule.when)) {
303
+ this.rules.push(rule);
304
+ }
305
+ }
306
+ }
307
+ }
308
+ }
309
+ //# sourceMappingURL=stateful-lexer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stateful-lexer.js","sourceRoot":"","sources":["../../src/lexers/stateful-lexer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,32 @@
1
+ import { Lexer, TQRestorePoint, LexerToken } from '../typings';
2
+ export declare class TokenBuffer {
3
+ private lexer;
4
+ private history;
5
+ private queued;
6
+ private $historyIndex;
7
+ get offset(): number;
8
+ get line(): number;
9
+ get column(): number;
10
+ get active(): LexerToken;
11
+ get state(): TQRestorePoint;
12
+ constructor(lexer: Lexer);
13
+ reset(buffer: string): void;
14
+ restore(state: TQRestorePoint): void;
15
+ feed(buffer: string, flush?: boolean): void;
16
+ flush(): void;
17
+ previous(): LexerToken;
18
+ next(): LexerToken;
19
+ peek(offset: number): LexerToken;
20
+ private lexerNext;
21
+ [Symbol.iterator](): TokenIterator;
22
+ }
23
+ declare class TokenIterator {
24
+ private buffer;
25
+ constructor(buffer: TokenBuffer);
26
+ next(): {
27
+ value: LexerToken;
28
+ done: boolean;
29
+ };
30
+ [Symbol.iterator](): this;
31
+ }
32
+ export {};
@@ -0,0 +1,92 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TokenBuffer = void 0;
4
+ class TokenBuffer {
5
+ lexer;
6
+ history = [];
7
+ queued = '';
8
+ $historyIndex = -1;
9
+ get offset() { return this.active?.offset || 0; }
10
+ get line() { return this.active?.line || 0; }
11
+ get column() { return this.active?.column || 0; }
12
+ get active() { return this.history[this.$historyIndex]; }
13
+ get state() {
14
+ return { historyIndex: this.$historyIndex, offset: this.offset };
15
+ }
16
+ constructor(lexer) {
17
+ this.lexer = lexer;
18
+ }
19
+ reset(buffer) {
20
+ this.lexer.feed(buffer);
21
+ this.history = [];
22
+ this.$historyIndex = -1;
23
+ }
24
+ restore(state) {
25
+ if (this.history[state.historyIndex].offset != state.offset) {
26
+ return;
27
+ }
28
+ this.$historyIndex = state.historyIndex;
29
+ }
30
+ feed(buffer, flush) {
31
+ this.queued += buffer;
32
+ if (flush) {
33
+ this.flush();
34
+ }
35
+ }
36
+ flush() {
37
+ this.history = this.history.slice(this.$historyIndex);
38
+ this.$historyIndex = 0;
39
+ if (this.lexer.flush) {
40
+ this.lexer.flush();
41
+ }
42
+ }
43
+ previous() {
44
+ if (this.$historyIndex > 0) {
45
+ return this.history[--this.$historyIndex];
46
+ }
47
+ }
48
+ next() {
49
+ if (this.$historyIndex + 1 >= this.history.length) {
50
+ this.lexerNext();
51
+ }
52
+ if (this.$historyIndex + 1 < this.history.length) {
53
+ return this.history[++this.$historyIndex];
54
+ }
55
+ }
56
+ peek(offset) {
57
+ offset += this.$historyIndex;
58
+ while ((offset >= this.history.length) && this.lexerNext()) {
59
+ }
60
+ if (offset >= 0 && offset < this.history.length)
61
+ return this.history[offset];
62
+ }
63
+ lexerNext() {
64
+ let token = this.lexer.next();
65
+ if (typeof token === 'undefined' && this.queued) {
66
+ this.lexer.feed(this.queued, this.$historyIndex >= 0 ? this.lexer.state() : undefined);
67
+ this.queued = '';
68
+ token = this.lexer.next();
69
+ }
70
+ if (token)
71
+ this.history.push(token);
72
+ return token;
73
+ }
74
+ [Symbol.iterator]() {
75
+ return new TokenIterator(this);
76
+ }
77
+ }
78
+ exports.TokenBuffer = TokenBuffer;
79
+ class TokenIterator {
80
+ buffer;
81
+ constructor(buffer) {
82
+ this.buffer = buffer;
83
+ }
84
+ next() {
85
+ const token = this.buffer.next();
86
+ return { value: token, done: !token };
87
+ }
88
+ [Symbol.iterator]() {
89
+ return this;
90
+ }
91
+ }
92
+ //# sourceMappingURL=token-buffer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"token-buffer.js","sourceRoot":"","sources":["../../src/lexers/token-buffer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ import { TokenBuffer } from "../../lexers/token-buffer";
2
+ import { GrammarRule, LanguageDefinition, LexerToken } from "../../typings";
3
+ export declare function CYK(language: LanguageDefinition & {
4
+ tokens: TokenBuffer;
5
+ }, _options?: {}): {
6
+ results: any[];
7
+ };
8
+ export interface NonTerminal {
9
+ rule: GrammarRule;
10
+ left: NonTerminal | Terminal;
11
+ right: NonTerminal | Terminal;
12
+ }
13
+ export interface Terminal {
14
+ rule: GrammarRule;
15
+ token: LexerToken;
16
+ }
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CYK = void 0;
4
+ const general_1 = require("../../utility/general");
5
+ const parser_1 = require("../parser");
6
+ function CYK(language, _options = {}) {
7
+ const { grammar, tokens } = language;
8
+ const terminals = [];
9
+ const nonTerminals = [];
10
+ for (const name in grammar.rules) {
11
+ for (const rule of grammar.rules[name]) {
12
+ const { symbols } = rule;
13
+ if (parser_1.ParserUtility.SymbolIsTerminal(symbols[0])) {
14
+ terminals.push(rule);
15
+ }
16
+ else {
17
+ nonTerminals.push(rule);
18
+ }
19
+ }
20
+ }
21
+ let currentTokenIndex = -1;
22
+ const chart = new general_1.Matrix(0, 0, () => new Map());
23
+ for (const token of tokens) {
24
+ currentTokenIndex++;
25
+ chart.resize(currentTokenIndex + 2, currentTokenIndex + 2);
26
+ for (const rule of terminals) {
27
+ if (parser_1.ParserUtility.TokenMatchesSymbol(token, rule.symbols[0])) {
28
+ chart.get(currentTokenIndex, currentTokenIndex).set(rule.name, { rule, token });
29
+ }
30
+ }
31
+ for (let floor = currentTokenIndex; floor >= 0; floor--) {
32
+ for (let inner = floor; inner <= currentTokenIndex; inner++) {
33
+ const leftCell = chart.get(floor, inner);
34
+ const rightCell = chart.get(inner + 1, currentTokenIndex);
35
+ for (const rule of nonTerminals) {
36
+ const { symbols: [leftSymbol, rightSymbol] } = rule;
37
+ const left = leftCell.get(leftSymbol);
38
+ const right = rightCell.get(rightSymbol);
39
+ if (left && right) {
40
+ chart.get(floor, currentTokenIndex).set(rule.name, { rule, left, right });
41
+ }
42
+ }
43
+ }
44
+ }
45
+ }
46
+ const results = Array.from(chart.get(0, currentTokenIndex).values()).map(v => GetValue(v));
47
+ return { results };
48
+ }
49
+ exports.CYK = CYK;
50
+ function GetValue(ref) {
51
+ if (!ref)
52
+ return;
53
+ if ('token' in ref) {
54
+ return parser_1.ParserUtility.PostProcess(ref.rule, [ref.token]);
55
+ }
56
+ return parser_1.ParserUtility.PostProcess(ref.rule, [GetValue(ref.left), GetValue(ref.right)]);
57
+ }
58
+ //# sourceMappingURL=cyk.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cyk.js","sourceRoot":"","sources":["../../../src/parser/algorithms/cyk.ts"],"names":[],"mappings":";;;AAEA,mDAA+C;AAC/C,sCAA0C;AAE1C,SAAgB,GAAG,CAAC,QAAsD,EAAE,QAAQ,GAAG,EAAE;IACrF,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,QAAQ,CAAC;IAErC,MAAM,SAAS,GAAkB,EAAE,CAAC;IACpC,MAAM,YAAY,GAAkB,EAAE,CAAC;IAEvC,KAAK,MAAM,IAAI,IAAI,OAAO,CAAC,KAAK,EAAE;QAC9B,KAAK,MAAM,IAAI,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE;YACpC,MAAM,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;YACzB,IAAI,sBAAa,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE;gBAC5C,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aACxB;iBAAM;gBACH,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aAC3B;SACJ;KACJ;IAED,IAAI,iBAAiB,GAAG,CAAC,CAAC,CAAC;IAC3B,MAAM,KAAK,GAAG,IAAI,gBAAM,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,IAAI,GAAG,EAA6C,CAAC,CAAC;IAC3F,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;QACxB,iBAAiB,EAAE,CAAC;QACpB,KAAK,CAAC,MAAM,CAAC,iBAAiB,GAAG,CAAC,EAAE,iBAAiB,GAAG,CAAC,CAAC,CAAC;QAC3D,KAAK,MAAM,IAAI,IAAI,SAAS,EAAE;YAC1B,IAAI,sBAAa,CAAC,kBAAkB,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE;gBAC1D,KAAK,CAAC,GAAG,CAAC,iBAAiB,EAAE,iBAAiB,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAA;aAClF;SACJ;QAGD,KAAK,IAAI,KAAK,GAAG,iBAAiB,EAAE,KAAK,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE;YACrD,KAAK,IAAI,KAAK,GAAG,KAAK,EAAE,KAAK,IAAI,iBAAiB,EAAE,KAAK,EAAE,EAAE;gBACzD,MAAM,QAAQ,GAAG,KAAK,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;gBACzC,MAAM,SAAS,GAAG,KAAK,CAAC,GAAG,CAAC,KAAK,GAAG,CAAC,EAAE,iBAAiB,CAAC,CAAC;gBAE1D,KAAK,MAAM,IAAI,IAAI,YAAY,EAAE;oBAC7B,MAAM,EAAE,OAAO,EAAE,CAAC,UAAU,EAAE,WAAW,CAAC,EAAE,GAAG,IAAI,CAAC;oBACpD,MAAM,IAAI,GAA2B,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;oBAC9D,MAAM,KAAK,GAA2B,SAAS,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;oBACjE,IAAI,IAAI,IAAI,KAAK,EAAE;wBACf,KAAK,CAAC,GAAG,CAAC,KAAK,EAAE,iBAAiB,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;qBAC7E;iBACJ;aACJ;SACJ;KACJ;IAED,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,EAAE,iBAAiB,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3F,OAAO,EAAE,OAAO,EAAE,CAAC;AACvB,CAAC;AAhDD,kBAgDC;AAED,SAAS,QAAQ,CAAC,GAA2B;IACzC,IAAI,CAAC,GAAG;QACJ,OAAO;IACX,IAAI,OAAO,IAAI,GAAG,EAAE;QAChB,OAAO,sBAAa,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;KAC3D;IACD,OAAO,sBAAa,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;AACzF,CAAC"}
@@ -0,0 +1,48 @@
1
+ import { Dictionary, GrammarRule, LanguageDefinition } from "../../typings";
2
+ import { TokenBuffer } from "../../lexers/token-buffer";
3
+ export interface EarleyParserOptions {
4
+ keepHistory?: boolean;
5
+ }
6
+ export declare function Earley(language: LanguageDefinition & {
7
+ tokens: TokenBuffer;
8
+ }, options?: EarleyParserOptions): {
9
+ results: any[];
10
+ info: {
11
+ table: Column[];
12
+ };
13
+ };
14
+ declare class Column {
15
+ private rules;
16
+ index: number;
17
+ data: any;
18
+ states: State[];
19
+ wants: Dictionary<State[]>;
20
+ scannable: State[];
21
+ completed: Dictionary<State[]>;
22
+ constructor(rules: Dictionary<GrammarRule[]>, index: number);
23
+ process(): void;
24
+ predict(exp: string): void;
25
+ expects(): GrammarRule[];
26
+ private complete;
27
+ }
28
+ declare class State {
29
+ rule: GrammarRule;
30
+ dot: number;
31
+ reference: number;
32
+ wantedBy: State[];
33
+ isComplete: boolean;
34
+ data: any;
35
+ left: State;
36
+ right: State | StateToken;
37
+ constructor(rule: GrammarRule, dot: number, reference: number, wantedBy: State[]);
38
+ nextState(child: State | StateToken): State;
39
+ finish(): void;
40
+ protected build(): any[];
41
+ }
42
+ interface StateToken {
43
+ data: any;
44
+ token: any;
45
+ isToken: boolean;
46
+ reference: number;
47
+ }
48
+ export {};