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.
- package/.eslintrc.cjs +14 -0
- package/README.md +288 -0
- package/bootstrap.ts +35 -0
- package/build/compiler/compiler.d.ts +48 -0
- package/build/compiler/compiler.js +227 -0
- package/build/compiler/compiler.js.map +1 -0
- package/build/compiler/generator.d.ts +23 -0
- package/build/compiler/generator.js +213 -0
- package/build/compiler/generator.js.map +1 -0
- package/build/compiler/import-resolver.d.ts +15 -0
- package/build/compiler/import-resolver.js +37 -0
- package/build/compiler/import-resolver.js.map +1 -0
- package/build/compiler/outputs/javascript.d.ts +3 -0
- package/build/compiler/outputs/javascript.js +29 -0
- package/build/compiler/outputs/javascript.js.map +1 -0
- package/build/compiler/outputs/json.d.ts +2 -0
- package/build/compiler/outputs/json.js +8 -0
- package/build/compiler/outputs/json.js.map +1 -0
- package/build/compiler/outputs/typescript.d.ts +2 -0
- package/build/compiler/outputs/typescript.js +108 -0
- package/build/compiler/outputs/typescript.js.map +1 -0
- package/build/grammars/gwell.d.ts +997 -0
- package/build/grammars/gwell.js +537 -0
- package/build/grammars/gwell.js.map +1 -0
- package/build/grammars/json.d.ts +151 -0
- package/build/grammars/json.js +112 -0
- package/build/grammars/json.js.map +1 -0
- package/build/grammars/number.d.ts +239 -0
- package/build/grammars/number.js +115 -0
- package/build/grammars/number.js.map +1 -0
- package/build/grammars/number.json +1 -0
- package/build/grammars/string.d.ts +116 -0
- package/build/grammars/string.js +50 -0
- package/build/grammars/string.js.map +1 -0
- package/build/grammars/string.json +1 -0
- package/build/grammars/whitespace.d.ts +51 -0
- package/build/grammars/whitespace.js +30 -0
- package/build/grammars/whitespace.js.map +1 -0
- package/build/grammars/whitespace.json +1 -0
- package/build/index.d.ts +4 -0
- package/build/index.js +21 -0
- package/build/index.js.map +1 -0
- package/build/lexers/character-lexer.d.ts +27 -0
- package/build/lexers/character-lexer.js +71 -0
- package/build/lexers/character-lexer.js.map +1 -0
- package/build/lexers/stateful-lexer.d.ts +48 -0
- package/build/lexers/stateful-lexer.js +309 -0
- package/build/lexers/stateful-lexer.js.map +1 -0
- package/build/lexers/token-buffer.d.ts +32 -0
- package/build/lexers/token-buffer.js +92 -0
- package/build/lexers/token-buffer.js.map +1 -0
- package/build/parser/algorithms/cyk.d.ts +16 -0
- package/build/parser/algorithms/cyk.js +58 -0
- package/build/parser/algorithms/cyk.js.map +1 -0
- package/build/parser/algorithms/earley.d.ts +48 -0
- package/build/parser/algorithms/earley.js +158 -0
- package/build/parser/algorithms/earley.js.map +1 -0
- package/build/parser/algorithms/lr.d.ts +10 -0
- package/build/parser/algorithms/lr.js +34 -0
- package/build/parser/algorithms/lr.js.map +1 -0
- package/build/parser/parser.d.ts +26 -0
- package/build/parser/parser.js +74 -0
- package/build/parser/parser.js.map +1 -0
- package/build/typings.d.ts +198 -0
- package/build/typings.js +3 -0
- package/build/typings.js.map +1 -0
- package/build/utility/general.d.ts +46 -0
- package/build/utility/general.js +112 -0
- package/build/utility/general.js.map +1 -0
- package/build/utility/lint.d.ts +2 -0
- package/build/utility/lint.js +28 -0
- package/build/utility/lint.js.map +1 -0
- package/build/utility/lr.d.ts +56 -0
- package/build/utility/lr.js +131 -0
- package/build/utility/lr.js.map +1 -0
- package/build/utility/text-format.d.ts +11 -0
- package/build/utility/text-format.js +84 -0
- package/build/utility/text-format.js.map +1 -0
- package/licenses/LICENSE.txt +165 -0
- package/licenses/moo.license +29 -0
- package/licenses/nearley.license +21 -0
- package/package.json +52 -0
- package/src/compiler/compiler.ts +239 -0
- package/src/compiler/generator.ts +229 -0
- package/src/compiler/import-resolver.ts +36 -0
- package/src/compiler/outputs/javascript.ts +27 -0
- package/src/compiler/outputs/json.ts +5 -0
- package/src/compiler/outputs/typescript.ts +105 -0
- package/src/grammars/gwell.gwell +278 -0
- package/src/grammars/gwell.js +539 -0
- package/src/grammars/gwell.json +1 -0
- package/src/grammars/json.gwell +75 -0
- package/src/grammars/json.js +121 -0
- package/src/grammars/json.json +1 -0
- package/src/grammars/number.gwell +20 -0
- package/src/grammars/number.js +117 -0
- package/src/grammars/number.json +1 -0
- package/src/grammars/string.gwell +15 -0
- package/src/grammars/string.js +52 -0
- package/src/grammars/string.json +1 -0
- package/src/grammars/whitespace.gwell +6 -0
- package/src/grammars/whitespace.js +32 -0
- package/src/grammars/whitespace.json +1 -0
- package/src/index.ts +4 -0
- package/src/lexers/character-lexer.ts +73 -0
- package/src/lexers/stateful-lexer.ts +335 -0
- package/src/lexers/token-buffer.ts +102 -0
- package/src/parser/algorithms/cyk.ts +74 -0
- package/src/parser/algorithms/earley.ts +193 -0
- package/src/parser/algorithms/lr.ts +37 -0
- package/src/parser/parser.ts +77 -0
- package/src/typings.ts +221 -0
- package/src/utility/general.ts +120 -0
- package/src/utility/lint.ts +26 -0
- package/src/utility/lr.ts +153 -0
- package/src/utility/text-format.ts +84 -0
- 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":";;;AAEA,MAAa,WAAW;IAeA;IAdZ,OAAO,GAAiB,EAAE,CAAC;IAC3B,MAAM,GAAW,EAAE,CAAC;IAEpB,aAAa,GAAG,CAAC,CAAC,CAAC;IAE3B,IAAI,MAAM,KAAK,OAAO,IAAI,CAAC,MAAM,EAAE,MAAM,IAAI,CAAC,CAAA,CAAC,CAAC;IAChD,IAAI,IAAI,KAAK,OAAO,IAAI,CAAC,MAAM,EAAE,IAAI,IAAI,CAAC,CAAA,CAAC,CAAC;IAC5C,IAAI,MAAM,KAAK,OAAO,IAAI,CAAC,MAAM,EAAE,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC;IACjD,IAAI,MAAM,KAAK,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;IAEzD,IAAI,KAAK;QACL,OAAO,EAAE,YAAY,EAAE,IAAI,CAAC,aAAa,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC;IACrE,CAAC;IAED,YAAoB,KAAY;QAAZ,UAAK,GAAL,KAAK,CAAO;IAAI,CAAC;IAErC,KAAK,CAAC,MAAc;QAChB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACxB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;QAClB,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC;IAC5B,CAAC;IAED,OAAO,CAAC,KAAqB;QACzB,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,IAAI,KAAK,CAAC,MAAM,EAAE;YACzD,OAAO;SACV;QACD,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,YAAY,CAAC;IAC5C,CAAC;IAED,IAAI,CAAC,MAAc,EAAE,KAAe;QAChC,IAAI,CAAC,MAAM,IAAI,MAAM,CAAC;QACtB,IAAI,KAAK,EAAE;YACP,IAAI,CAAC,KAAK,EAAE,CAAC;SAChB;IACL,CAAC;IAED,KAAK;QACD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACtD,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QACvB,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE;YAClB,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAA;SACrB;IACL,CAAC;IAED,QAAQ;QACJ,IAAI,IAAI,CAAC,aAAa,GAAG,CAAC,EAAE;YACxB,OAAO,IAAI,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;SAC7C;IACL,CAAC;IAED,IAAI;QACA,IAAI,IAAI,CAAC,aAAa,GAAG,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;YAC/C,IAAI,CAAC,SAAS,EAAE,CAAC;SACpB;QACD,IAAI,IAAI,CAAC,aAAa,GAAG,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;YAC9C,OAAO,IAAI,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;SAC7C;IACL,CAAC;IAED,IAAI,CAAC,MAAc;QACf,MAAM,IAAI,IAAI,CAAC,aAAa,CAAC;QAC7B,OAAO,CAAC,MAAM,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE,EAAE;SAE3D;QACD,IAAI,MAAM,IAAI,CAAC,IAAI,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM;YAC3C,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IAEO,SAAS;QACb,IAAI,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;QAE9B,IAAI,OAAO,KAAK,KAAK,WAAW,IAAI,IAAI,CAAC,MAAM,EAAE;YAC7C,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,aAAa,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;YACvF,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;YACjB,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;SAC7B;QACD,IAAI,KAAK;YACL,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7B,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,CAAC,MAAM,CAAC,QAAQ,CAAC;QACb,OAAO,IAAI,aAAa,CAAC,IAAI,CAAC,CAAA;IAClC,CAAC;CAEJ;AAtFD,kCAsFC;AAED,MAAM,aAAa;IACK;IAApB,YAAoB,MAAmB;QAAnB,WAAM,GAAN,MAAM,CAAa;IAAI,CAAC;IAE5C,IAAI;QACA,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAA;QAChC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,KAAK,EAAE,CAAA;IACzC,CAAC;IAED,CAAC,MAAM,CAAC,QAAQ,CAAC;QACb,OAAO,IAAI,CAAA;IACf,CAAC;CACJ"}
|
|
@@ -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":"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"}
|
|
@@ -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 {};
|