grammar-well 1.3.3 → 2.0.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 (261) hide show
  1. package/README.md +76 -560
  2. package/build/generator/artifacts/basic.d.ts +7 -0
  3. package/build/generator/artifacts/basic.js +24 -0
  4. package/build/generator/artifacts/basic.js.map +1 -0
  5. package/build/generator/artifacts/lexer.d.ts +13 -0
  6. package/build/generator/artifacts/lexer.js +204 -0
  7. package/build/generator/artifacts/lexer.js.map +1 -0
  8. package/build/{compiler/generator → generator}/artifacts/lr.d.ts +14 -14
  9. package/build/{compiler/generator → generator}/artifacts/lr.js +18 -22
  10. package/build/generator/artifacts/lr.js.map +1 -0
  11. package/build/generator/builtin/json.d.ts +183 -0
  12. package/build/generator/builtin/json.js +124 -0
  13. package/build/generator/builtin/json.js.map +1 -0
  14. package/build/generator/builtin/registry.json +1 -0
  15. package/build/generator/builtin/whitespace.d.ts +61 -0
  16. package/build/generator/builtin/whitespace.js +37 -0
  17. package/build/generator/builtin/whitespace.js.map +1 -0
  18. package/build/generator/generator.d.ts +38 -0
  19. package/build/generator/generator.js +368 -0
  20. package/build/generator/generator.js.map +1 -0
  21. package/build/generator/grammars/index.d.ts +2 -0
  22. package/build/generator/grammars/index.js +3 -0
  23. package/build/generator/grammars/index.js.map +1 -0
  24. package/build/generator/grammars/v1.d.ts +1190 -0
  25. package/build/generator/grammars/v1.js +614 -0
  26. package/build/generator/grammars/v1.js.map +1 -0
  27. package/build/generator/grammars/v2.d.ts +1367 -0
  28. package/build/generator/grammars/v2.js +695 -0
  29. package/build/generator/grammars/v2.js.map +1 -0
  30. package/build/generator/import-resolvers/auto.d.ts +2 -0
  31. package/build/generator/import-resolvers/auto.js +11 -0
  32. package/build/generator/import-resolvers/auto.js.map +1 -0
  33. package/build/generator/import-resolvers/browser.d.ts +7 -0
  34. package/build/generator/import-resolvers/browser.js +13 -0
  35. package/build/generator/import-resolvers/browser.js.map +1 -0
  36. package/build/generator/import-resolvers/default.d.ts +2 -0
  37. package/build/generator/import-resolvers/default.js +11 -0
  38. package/build/generator/import-resolvers/default.js.map +1 -0
  39. package/build/generator/import-resolvers/filesystem.d.ts +7 -0
  40. package/build/generator/import-resolvers/filesystem.js +15 -0
  41. package/build/generator/import-resolvers/filesystem.js.map +1 -0
  42. package/build/generator/index.d.ts +3 -0
  43. package/build/generator/index.js +4 -0
  44. package/build/generator/index.js.map +1 -0
  45. package/build/generator/state.d.ts +28 -0
  46. package/build/generator/state.js +73 -0
  47. package/build/generator/state.js.map +1 -0
  48. package/build/generator/stringify/common.d.ts +22 -0
  49. package/build/generator/stringify/common.js +83 -0
  50. package/build/generator/stringify/common.js.map +1 -0
  51. package/build/generator/stringify/exports/javascript.d.ts +3 -0
  52. package/build/generator/stringify/exports/javascript.js +26 -0
  53. package/build/generator/stringify/exports/javascript.js.map +1 -0
  54. package/build/generator/stringify/exports/json.d.ts +2 -0
  55. package/build/generator/stringify/exports/json.js +4 -0
  56. package/build/generator/stringify/exports/json.js.map +1 -0
  57. package/build/generator/stringify/exports/registry.d.ts +20 -0
  58. package/build/generator/stringify/exports/registry.js +17 -0
  59. package/build/generator/stringify/exports/registry.js.map +1 -0
  60. package/build/generator/stringify/exports/typescript.d.ts +2 -0
  61. package/build/generator/stringify/exports/typescript.js +16 -0
  62. package/build/generator/stringify/exports/typescript.js.map +1 -0
  63. package/build/generator/stringify/grammar/v2.d.ts +20 -0
  64. package/build/generator/stringify/grammar/v2.js +211 -0
  65. package/build/generator/stringify/grammar/v2.js.map +1 -0
  66. package/build/generator/stringify/javascript.d.ts +13 -0
  67. package/build/generator/stringify/javascript.js +83 -0
  68. package/build/generator/stringify/javascript.js.map +1 -0
  69. package/build/index.d.ts +7 -6
  70. package/build/index.js +7 -24
  71. package/build/index.js.map +1 -1
  72. package/build/lexers/character-lexer.d.ts +2 -2
  73. package/build/lexers/character-lexer.js +1 -5
  74. package/build/lexers/character-lexer.js.map +1 -1
  75. package/build/lexers/stateful-lexer.d.ts +12 -17
  76. package/build/lexers/stateful-lexer.js +38 -186
  77. package/build/lexers/stateful-lexer.js.map +1 -1
  78. package/build/lexers/token-buffer.d.ts +8 -8
  79. package/build/lexers/token-buffer.js +1 -5
  80. package/build/lexers/token-buffer.js.map +1 -1
  81. package/build/parser/algorithms/cyk.d.ts +6 -6
  82. package/build/parser/algorithms/cyk.js +10 -13
  83. package/build/parser/algorithms/cyk.js.map +1 -1
  84. package/build/parser/algorithms/earley.d.ts +7 -7
  85. package/build/parser/algorithms/earley.js +7 -11
  86. package/build/parser/algorithms/earley.js.map +1 -1
  87. package/build/parser/algorithms/lrk/algorithm.d.ts +3 -3
  88. package/build/parser/algorithms/lrk/algorithm.js +10 -13
  89. package/build/parser/algorithms/lrk/algorithm.js.map +1 -1
  90. package/build/parser/algorithms/lrk/bimap.js +1 -5
  91. package/build/parser/algorithms/lrk/bimap.js.map +1 -1
  92. package/build/parser/algorithms/lrk/canonical-collection.d.ts +7 -7
  93. package/build/parser/algorithms/lrk/canonical-collection.js +11 -15
  94. package/build/parser/algorithms/lrk/canonical-collection.js.map +1 -1
  95. package/build/parser/algorithms/lrk/closure.d.ts +3 -3
  96. package/build/parser/algorithms/lrk/closure.js +3 -7
  97. package/build/parser/algorithms/lrk/closure.js.map +1 -1
  98. package/build/parser/algorithms/lrk/stack.d.ts +6 -6
  99. package/build/parser/algorithms/lrk/stack.js +1 -5
  100. package/build/parser/algorithms/lrk/stack.js.map +1 -1
  101. package/build/parser/algorithms/lrk/state.d.ts +5 -5
  102. package/build/parser/algorithms/lrk/state.js +1 -2
  103. package/build/parser/parse.d.ts +10 -0
  104. package/build/parser/parse.js +34 -0
  105. package/build/parser/parse.js.map +1 -0
  106. package/build/parser/parser.d.ts +6 -17
  107. package/build/parser/parser.js +26 -42
  108. package/build/parser/parser.js.map +1 -1
  109. package/build/tsconfig.tsbuildinfo +1 -0
  110. package/build/typings/ast.d.ts +134 -0
  111. package/build/typings/ast.js +3 -0
  112. package/build/typings/ast.js.map +1 -0
  113. package/build/typings/common.d.ts +4 -0
  114. package/build/typings/common.js +2 -0
  115. package/build/typings/common.js.map +1 -0
  116. package/build/typings/generator.d.ts +58 -0
  117. package/build/typings/generator.js +3 -0
  118. package/build/typings/generator.js.map +1 -0
  119. package/build/typings/index.d.ts +43 -0
  120. package/build/typings/index.js +5 -0
  121. package/build/typings/index.js.map +1 -0
  122. package/build/typings/runtime.d.ts +70 -0
  123. package/build/typings/runtime.js +2 -0
  124. package/build/typings/runtime.js.map +1 -0
  125. package/build/utility/format.d.ts +1 -0
  126. package/build/utility/format.js +12 -0
  127. package/build/utility/format.js.map +1 -0
  128. package/build/utility/formatter.d.ts +1 -0
  129. package/build/utility/formatter.js +12 -0
  130. package/build/utility/formatter.js.map +1 -0
  131. package/build/utility/general.d.ts +1 -1
  132. package/build/utility/general.js +5 -13
  133. package/build/utility/general.js.map +1 -1
  134. package/build/utility/index.d.ts +4 -1
  135. package/build/utility/index.js +4 -17
  136. package/build/utility/index.js.map +1 -1
  137. package/build/utility/lint.d.ts +2 -2
  138. package/build/utility/lint.js +2 -6
  139. package/build/utility/lint.js.map +1 -1
  140. package/build/utility/migrate.d.ts +1 -0
  141. package/build/utility/migrate.js +10 -0
  142. package/build/utility/migrate.js.map +1 -0
  143. package/build/utility/monarch.d.ts +2 -2
  144. package/build/utility/monarch.js +33 -38
  145. package/build/utility/monarch.js.map +1 -1
  146. package/build/utility/parsing.d.ts +6 -0
  147. package/build/utility/parsing.js +26 -0
  148. package/build/utility/parsing.js.map +1 -0
  149. package/build/utility/text-format.d.ts +6 -6
  150. package/build/utility/text-format.js +2 -6
  151. package/build/utility/text-format.js.map +1 -1
  152. package/package.json +17 -24
  153. package/src/generator/artifacts/basic.ts +26 -0
  154. package/src/generator/artifacts/lexer.ts +228 -0
  155. package/src/{compiler/generator → generator}/artifacts/lr.ts +25 -24
  156. package/src/generator/builtin/character.well +7 -0
  157. package/src/generator/builtin/json.well +85 -0
  158. package/src/generator/builtin/number.well +21 -0
  159. package/src/generator/builtin/registry.json +1 -0
  160. package/src/generator/builtin/string.well +54 -0
  161. package/src/generator/builtin/whitespace.well +16 -0
  162. package/src/generator/generator.ts +401 -0
  163. package/src/generator/grammars/index.ts +2 -0
  164. package/src/generator/grammars/v1.ts +620 -0
  165. package/src/generator/grammars/v1.well +422 -0
  166. package/src/generator/grammars/v2.ts +701 -0
  167. package/src/generator/grammars/v2.well +413 -0
  168. package/src/generator/import-resolvers/auto.ts +12 -0
  169. package/src/generator/import-resolvers/browser.ts +13 -0
  170. package/src/generator/import-resolvers/filesystem.ts +18 -0
  171. package/src/generator/index.ts +3 -0
  172. package/src/generator/state.ts +89 -0
  173. package/src/generator/stringify/common.ts +90 -0
  174. package/src/generator/stringify/exports/javascript.ts +29 -0
  175. package/src/generator/stringify/exports/json.ts +5 -0
  176. package/src/generator/stringify/exports/registry.ts +20 -0
  177. package/src/generator/stringify/exports/typescript.ts +17 -0
  178. package/src/generator/stringify/grammar/v2.ts +223 -0
  179. package/src/generator/stringify/javascript.ts +94 -0
  180. package/src/index.ts +7 -6
  181. package/src/lexers/character-lexer.ts +2 -2
  182. package/src/lexers/stateful-lexer.ts +46 -203
  183. package/src/lexers/token-buffer.ts +3 -3
  184. package/src/parser/algorithms/cyk.ts +13 -12
  185. package/src/parser/algorithms/earley.ts +10 -10
  186. package/src/parser/algorithms/lrk/algorithm.ts +8 -7
  187. package/src/parser/algorithms/lrk/canonical-collection.ts +14 -14
  188. package/src/parser/algorithms/lrk/closure.ts +6 -6
  189. package/src/parser/algorithms/lrk/stack.ts +6 -6
  190. package/src/parser/algorithms/lrk/state.ts +5 -5
  191. package/src/parser/parse.ts +45 -0
  192. package/src/typings/ast.ts +148 -0
  193. package/src/typings/common.ts +2 -0
  194. package/src/typings/generator.ts +62 -0
  195. package/src/typings/index.ts +38 -0
  196. package/src/typings/runtime.ts +82 -0
  197. package/src/utility/format.ts +12 -0
  198. package/src/utility/general.ts +1 -2
  199. package/src/utility/index.ts +4 -1
  200. package/src/utility/lint.ts +5 -5
  201. package/src/utility/monarch.ts +34 -34
  202. package/src/utility/parsing.ts +30 -0
  203. package/src/utility/text-format.ts +7 -7
  204. package/.eslintrc.cjs +0 -14
  205. package/bootstrap.ts +0 -45
  206. package/build/compiler/builtin.json +0 -1
  207. package/build/compiler/compiler.d.ts +0 -50
  208. package/build/compiler/compiler.js +0 -249
  209. package/build/compiler/compiler.js.map +0 -1
  210. package/build/compiler/generator/artifacts/lr.js.map +0 -1
  211. package/build/compiler/generator/artifacts/standard.d.ts +0 -7
  212. package/build/compiler/generator/artifacts/standard.js +0 -28
  213. package/build/compiler/generator/artifacts/standard.js.map +0 -1
  214. package/build/compiler/generator/generator.d.ts +0 -24
  215. package/build/compiler/generator/generator.js +0 -217
  216. package/build/compiler/generator/generator.js.map +0 -1
  217. package/build/compiler/gwell.d.ts +0 -1112
  218. package/build/compiler/gwell.js +0 -576
  219. package/build/compiler/gwell.js.map +0 -1
  220. package/build/compiler/import-resolver.d.ts +0 -15
  221. package/build/compiler/import-resolver.js +0 -37
  222. package/build/compiler/import-resolver.js.map +0 -1
  223. package/build/compiler/index.d.ts +0 -2
  224. package/build/compiler/index.js +0 -19
  225. package/build/compiler/index.js.map +0 -1
  226. package/build/compiler/outputs/javascript.d.ts +0 -3
  227. package/build/compiler/outputs/javascript.js +0 -29
  228. package/build/compiler/outputs/javascript.js.map +0 -1
  229. package/build/compiler/outputs/json.d.ts +0 -2
  230. package/build/compiler/outputs/json.js +0 -8
  231. package/build/compiler/outputs/json.js.map +0 -1
  232. package/build/compiler/outputs/typescript.d.ts +0 -2
  233. package/build/compiler/outputs/typescript.js +0 -21
  234. package/build/compiler/outputs/typescript.js.map +0 -1
  235. package/build/parser/algorithms/lr.d.ts +0 -7
  236. package/build/parser/algorithms/lr.js +0 -108
  237. package/build/parser/algorithms/lr.js.map +0 -5
  238. package/build/parser/algorithms/lr0.d.ts +0 -7
  239. package/build/parser/algorithms/lr0.js +0 -156
  240. package/build/parser/algorithms/lr0.js.map +0 -1
  241. package/build/typings.d.ts +0 -226
  242. package/build/typings.js +0 -3
  243. package/build/typings.js.map +0 -1
  244. package/src/compiler/builtin/json.gwell +0 -74
  245. package/src/compiler/builtin/number.gwell +0 -20
  246. package/src/compiler/builtin/string.gwell +0 -48
  247. package/src/compiler/builtin/whitespace.gwell +0 -10
  248. package/src/compiler/builtin.json +0 -1
  249. package/src/compiler/compiler.ts +0 -265
  250. package/src/compiler/generator/artifacts/standard.ts +0 -26
  251. package/src/compiler/generator/generator.ts +0 -237
  252. package/src/compiler/gwell.gwell +0 -294
  253. package/src/compiler/gwell.js +0 -578
  254. package/src/compiler/import-resolver.ts +0 -36
  255. package/src/compiler/index.ts +0 -2
  256. package/src/compiler/outputs/javascript.ts +0 -27
  257. package/src/compiler/outputs/json.ts +0 -5
  258. package/src/compiler/outputs/typescript.ts +0 -18
  259. package/src/parser/parser.ts +0 -77
  260. package/src/typings.ts +0 -248
  261. package/testing.ts +0 -18
@@ -0,0 +1,24 @@
1
+ import { CommonGenerator } from "../stringify/common.js";
2
+ export class BasicGrammarTable {
3
+ generator;
4
+ constructor(generator) {
5
+ this.generator = generator;
6
+ }
7
+ stringify(depth = 0) {
8
+ if (!this.generator.state.grammar) {
9
+ return null;
10
+ }
11
+ return CommonGenerator.JSON({
12
+ start: JSON.stringify(this.generator.state.grammar.start),
13
+ rules: this.stringifyGrammarRules(depth + 1)
14
+ }, depth);
15
+ }
16
+ stringifyGrammarRules(depth = 0) {
17
+ const map = {};
18
+ for (const rule in this.generator.state.grammar.rules) {
19
+ map[rule] = this.generator.state.grammar.rules[rule].map(v => this.generator.grammarRule(v));
20
+ }
21
+ return CommonGenerator.JSON(map, depth);
22
+ }
23
+ }
24
+ //# sourceMappingURL=basic.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"basic.js","sourceRoot":"","sources":["../../../src/generator/artifacts/basic.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAGzD,MAAM,OAAO,iBAAiB;IAEN;IAApB,YAAoB,SAA8B;QAA9B,cAAS,GAAT,SAAS,CAAqB;IAAI,CAAC;IAEvD,SAAS,CAAC,QAAgB,CAAC;QACvB,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;YAChC,OAAO,IAAI,CAAC;QAChB,CAAC;QACD,OAAO,eAAe,CAAC,IAAI,CAAC;YACxB,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;YACzD,KAAK,EAAE,IAAI,CAAC,qBAAqB,CAAC,KAAK,GAAG,CAAC,CAAC;SAC/C,EAAE,KAAK,CAAC,CAAC;IACd,CAAC;IAEO,qBAAqB,CAAC,QAAgB,CAAC;QAC3C,MAAM,GAAG,GAAG,EAAE,CAAC;QACf,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YACpD,GAAG,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAA;QAChG,CAAC;QACD,OAAO,eAAe,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IAC5C,CAAC;CAEJ"}
@@ -0,0 +1,13 @@
1
+ import { GeneratorLexerConfig } from "../../typings/index.js";
2
+ export declare class LexerArtifact {
3
+ private lexer;
4
+ private resolved;
5
+ private resolving;
6
+ constructor(lexer: GeneratorLexerConfig);
7
+ output(depth?: number): string;
8
+ private lexerConfigStates;
9
+ private lexerConfigStateRules;
10
+ private lexerConfigStateRule;
11
+ private resolveStates;
12
+ private resolveRuleImports;
13
+ }
@@ -0,0 +1,204 @@
1
+ import { CommonGenerator } from "../stringify/common.js";
2
+ export class LexerArtifact {
3
+ lexer;
4
+ resolved = new Set();
5
+ resolving = new Set();
6
+ constructor(lexer) {
7
+ this.lexer = lexer;
8
+ }
9
+ output(depth = 0) {
10
+ if (!this.lexer)
11
+ return null;
12
+ if (typeof this.lexer === 'string')
13
+ return this.lexer;
14
+ return CommonGenerator.JSON({
15
+ start: JSON.stringify(this.lexer.start),
16
+ states: this.lexerConfigStates(this.lexer.states, depth + 1)
17
+ }, depth);
18
+ }
19
+ lexerConfigStates(states, depth) {
20
+ this.resolveStates(this.lexer.start);
21
+ const map = {};
22
+ for (const key in states) {
23
+ const state = states[key];
24
+ map[key] = CommonGenerator.JSON({
25
+ unmatched: state.unmatched ? this.lexerConfigStateRule(state.unmatched) : null,
26
+ rules: this.lexerConfigStateRules(state.rules, depth + 2),
27
+ regex: CompileRegExp(key, state)
28
+ }, depth + 1);
29
+ }
30
+ return CommonGenerator.JSON(map, depth);
31
+ }
32
+ lexerConfigStateRules(rules, depth) {
33
+ const ary = rules.map(rule => {
34
+ if ('import' in rule)
35
+ return CommonGenerator.JSON({ import: JSON.stringify(rule.import) }, -1);
36
+ return this.lexerConfigStateRule(rule);
37
+ });
38
+ return CommonGenerator.JSON(ary, depth);
39
+ }
40
+ lexerConfigStateRule(rule) {
41
+ return CommonGenerator.JSON({
42
+ when: 'when' in rule ? CommonGenerator.SerializeSymbol(rule.when) : null,
43
+ before: JSON.stringify(rule.before),
44
+ skip: JSON.stringify(rule.skip),
45
+ type: JSON.stringify(rule.type),
46
+ tag: JSON.stringify(rule.tag),
47
+ open: JSON.stringify(rule.open),
48
+ close: JSON.stringify(rule.close),
49
+ highlight: JSON.stringify(rule.highlight),
50
+ pop: JSON.stringify(rule.pop),
51
+ set: JSON.stringify(rule.set),
52
+ inset: JSON.stringify(rule.inset),
53
+ goto: JSON.stringify(rule.goto),
54
+ }, -1);
55
+ }
56
+ resolveStates(start) {
57
+ this.resolved = new Set();
58
+ this.resolving = new Set();
59
+ this.resolveRuleImports(start, new Set());
60
+ for (const key in this.lexer.states) {
61
+ if (!this.resolved.has(key)) {
62
+ delete this.lexer.states[key];
63
+ }
64
+ }
65
+ }
66
+ resolveRuleImports(name, chain) {
67
+ if (chain.has(name))
68
+ throw new Error(`Can not resolve circular import of ${name}`);
69
+ if (!this.lexer.states[name])
70
+ throw new Error(`Can not import unknown state ${name}`);
71
+ if (this.resolved.has(name) || this.resolving.has(name))
72
+ return;
73
+ const state = this.lexer.states[name];
74
+ const rules = new UniqueRules();
75
+ chain.add(name);
76
+ this.resolving.add(name);
77
+ for (let i = 0; i < state.rules.length; i++) {
78
+ const rule = state.rules[i];
79
+ if ("import" in rule) {
80
+ for (const ref of rule.import) {
81
+ this.resolveRuleImports(ref, chain);
82
+ rules.push(...this.lexer.states[ref].rules);
83
+ }
84
+ }
85
+ else {
86
+ rules.push(rule);
87
+ if (rule.set && !this.resolving.has(rule.set)) {
88
+ this.resolveRuleImports(rule.set, new Set());
89
+ }
90
+ if (rule.goto && !this.resolving.has(rule.goto)) {
91
+ this.resolveRuleImports(rule.goto, new Set());
92
+ }
93
+ }
94
+ }
95
+ state.rules = rules.rules;
96
+ chain.delete(name);
97
+ this.resolved.add(name);
98
+ }
99
+ }
100
+ class UniqueRules {
101
+ regexps = new Set();
102
+ strings = new Set();
103
+ rules = [];
104
+ push(...rules) {
105
+ for (const rule of rules) {
106
+ if (typeof rule.when === 'object') {
107
+ if (!this.regexps.has(rule.when.regex)) {
108
+ this.regexps.add(rule.when.regex);
109
+ this.rules.push(rule);
110
+ }
111
+ }
112
+ else {
113
+ if (!this.strings.has(rule.when)) {
114
+ this.strings.add(rule.when);
115
+ this.rules.push(rule);
116
+ }
117
+ }
118
+ }
119
+ }
120
+ }
121
+ function CompileRegExp(name, state) {
122
+ const rules = [];
123
+ const subexpressions = [];
124
+ let isUnicode = null;
125
+ let isCI = null;
126
+ for (const options of state.rules) {
127
+ if (RegexLib.IsRegex(options.when)) {
128
+ const { flags } = options.when;
129
+ const u = flags.includes('u');
130
+ const i = flags.includes('i');
131
+ if (isUnicode === null) {
132
+ isUnicode = u;
133
+ }
134
+ else if (isUnicode !== u && !state.unmatched) {
135
+ throw new Error(`Inconsistent Regex Flag /u in state: ${name}`);
136
+ }
137
+ if (isCI === null) {
138
+ isCI = i;
139
+ }
140
+ else if (isCI !== i) {
141
+ throw new Error(`Inconsistent Regex Flag /i in state: ${name}`);
142
+ }
143
+ }
144
+ else {
145
+ if (!isCI) {
146
+ isCI = false;
147
+ }
148
+ else if (isCI) {
149
+ throw new Error(`Inconsistent Regex Flag /i in state: ${name}`);
150
+ }
151
+ }
152
+ rules.push(options);
153
+ const pat = RegexLib.Source(options.when);
154
+ const regexp = new RegExp(pat);
155
+ if (regexp.test("")) {
156
+ throw new Error("RegExp matches empty string: " + regexp);
157
+ }
158
+ if (RegexLib.HasGroups(pat)) {
159
+ throw new Error("RegExp has capture groups: " + regexp + "\nUse (?: … ) instead");
160
+ }
161
+ subexpressions.push(RegexLib.Capture(pat));
162
+ }
163
+ let flags = !state.unmatched ? 'ym' : 'gm';
164
+ if (isUnicode === true)
165
+ flags += "u";
166
+ if (isCI === true)
167
+ flags += "i";
168
+ return `/${new RegExp(RegexLib.Join(subexpressions)).source}/${flags}`;
169
+ }
170
+ class RegexLib {
171
+ static IsRegex(o) {
172
+ return typeof o == 'object' && 'regex' in o;
173
+ }
174
+ static Escape(s) {
175
+ return s.replace(/[-/\\^$*+?.()|[\]{}]/g, '\\$&');
176
+ }
177
+ static HasGroups(s) {
178
+ return (new RegExp('|' + s)).exec('').length > 1;
179
+ }
180
+ static Capture(source) {
181
+ return '(' + source + ')';
182
+ }
183
+ static Join(regexps) {
184
+ if (!regexps.length)
185
+ return '(?!)';
186
+ const source = regexps.map((s) => `(?:${s})`).join('|');
187
+ return `(?:${source})`;
188
+ }
189
+ static Source(search) {
190
+ if (typeof search === 'string') {
191
+ return `(?:${RegexLib.Escape(search)})`;
192
+ }
193
+ try {
194
+ if (RegexLib.IsRegex(search)) {
195
+ return search.regex;
196
+ }
197
+ throw new Error('Not a pattern: ' + search);
198
+ }
199
+ catch (error) {
200
+ throw error;
201
+ }
202
+ }
203
+ }
204
+ //# sourceMappingURL=lexer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lexer.js","sourceRoot":"","sources":["../../../src/generator/artifacts/lexer.ts"],"names":[],"mappings":"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"}
@@ -1,18 +1,18 @@
1
- import { Generator } from "../generator";
2
- import { Dictionary, GeneratorGrammarRule, GeneratorGrammarSymbol } from "../../../typings";
3
- import { Collection, GeneratorSymbolCollection } from "../../../utility/general";
1
+ import { Dictionary, GeneratorGrammarProductionRule, GeneratorGrammarSymbol } from "../../typings/index.js";
2
+ import { Collection, GeneratorSymbolCollection } from "../../utility/general.js";
3
+ import { JavaScriptGenerator } from "../stringify/javascript.js";
4
4
  export declare class LRParseTableBuilder {
5
- generator: Generator;
6
- rules: Collection<GeneratorGrammarRule>;
5
+ generator: JavaScriptGenerator;
6
+ rules: Collection<GeneratorGrammarProductionRule>;
7
7
  table: Dictionary<StateBuilder>;
8
8
  symbols: GeneratorSymbolCollection;
9
- constructor(generator: Generator);
9
+ constructor(generator: JavaScriptGenerator);
10
10
  addState(seed: StateItem[]): StateBuilder;
11
- encodeRule(rule: GeneratorGrammarRule, dot: number): string;
11
+ encodeRule(rule: GeneratorGrammarProductionRule, dot: number): string;
12
12
  encodeStateItems(seed: StateItem[]): string;
13
- serialize(depth?: number): string;
14
- serializeState(state: State, depth?: number): string;
15
- serializeNext(next: Next, depth: number): string;
13
+ stringify(depth?: number): string;
14
+ stringifyState(state: State, depth?: number): string;
15
+ stringifyNext(next: Next, depth: number): string;
16
16
  }
17
17
  declare class StateBuilder {
18
18
  private collection;
@@ -23,17 +23,17 @@ declare class StateBuilder {
23
23
  };
24
24
  actions: Map<GeneratorGrammarSymbol, string>;
25
25
  goto: Map<GeneratorGrammarSymbol, string>;
26
- reduce?: GeneratorGrammarRule;
26
+ reduce?: GeneratorGrammarProductionRule;
27
27
  constructor(collection: LRParseTableBuilder, items: StateItem[]);
28
28
  private closure;
29
- serialize(): State;
29
+ export(): State;
30
30
  }
31
31
  interface State {
32
32
  actions: Next[];
33
33
  goto: {
34
34
  [key: string]: string;
35
35
  };
36
- reduce: GeneratorGrammarRule;
36
+ reduce: GeneratorGrammarProductionRule;
37
37
  isFinal: boolean;
38
38
  }
39
39
  type Next = {
@@ -41,7 +41,7 @@ type Next = {
41
41
  next: string;
42
42
  };
43
43
  type StateItem = {
44
- rule: GeneratorGrammarRule;
44
+ rule: GeneratorGrammarProductionRule;
45
45
  dot: number;
46
46
  };
47
47
  interface StateOut {
@@ -1,13 +1,10 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.LRParseTableBuilder = void 0;
4
- const generator_1 = require("../generator");
5
- const general_1 = require("../../../utility/general");
6
- class LRParseTableBuilder {
1
+ import { Collection, GeneratorSymbolCollection } from "../../utility/general.js";
2
+ import { CommonGenerator } from "../stringify/common.js";
3
+ export class LRParseTableBuilder {
7
4
  generator;
8
- rules = new general_1.Collection();
5
+ rules = new Collection();
9
6
  table = Object.create(null);
10
- symbols = new general_1.GeneratorSymbolCollection();
7
+ symbols = new GeneratorSymbolCollection();
11
8
  constructor(generator) {
12
9
  this.generator = generator;
13
10
  const augmented = { name: Symbol(), symbols: [{ rule: generator.state.grammar.start }] };
@@ -31,29 +28,28 @@ class LRParseTableBuilder {
31
28
  encodeStateItems(seed) {
32
29
  return Array.from(new Set(seed)).map(v => this.encodeRule(v.rule, v.dot)).sort().join();
33
30
  }
34
- serialize(depth = 0) {
31
+ stringify(depth = 0) {
35
32
  const map = {};
36
33
  for (const key in this.table) {
37
- map[key] = this.serializeState(this.table[key].serialize(), depth + 1);
34
+ map[key] = this.stringifyState(this.table[key].export(), depth + 1);
38
35
  }
39
- return generator_1.Generator.Pretty(map, depth);
36
+ return CommonGenerator.JSON(map, depth);
40
37
  }
41
- serializeState(state, depth = 0) {
42
- return generator_1.Generator.Pretty({
43
- actions: state.actions.map(v => this.serializeNext(v, depth + 1)),
44
- goto: generator_1.Generator.Pretty(state.goto, depth + 1),
45
- reduce: state.reduce ? this.generator.serializeGrammarRule(state.reduce) : null,
38
+ stringifyState(state, depth = 0) {
39
+ return CommonGenerator.JSON({
40
+ actions: state.actions.map(v => this.stringifyNext(v, depth + 1)),
41
+ goto: CommonGenerator.JSON(state.goto, depth + 1),
42
+ reduce: state.reduce ? this.generator.grammarRule(state.reduce) : null,
46
43
  isFinal: state.isFinal ? 'true' : 'false'
47
44
  }, depth);
48
45
  }
49
- serializeNext(next, depth) {
50
- return generator_1.Generator.Pretty({
51
- symbol: generator_1.Generator.SerializeSymbol(next.symbol),
46
+ stringifyNext(next, depth) {
47
+ return CommonGenerator.JSON({
48
+ symbol: CommonGenerator.SerializeSymbol(next.symbol),
52
49
  next: JSON.stringify(next.next)
53
50
  }, -1);
54
51
  }
55
52
  }
56
- exports.LRParseTableBuilder = LRParseTableBuilder;
57
53
  class StateBuilder {
58
54
  collection;
59
55
  isFinal = false;
@@ -95,7 +91,7 @@ class StateBuilder {
95
91
  return;
96
92
  visited.add(symbol);
97
93
  const stateItem = { rule, dot: dot + 1 };
98
- if (generator_1.Generator.SymbolIsTerminal(symbol)) {
94
+ if (CommonGenerator.SymbolIsTerminal(symbol)) {
99
95
  const id = this.collection.symbols.encode(symbol);
100
96
  this.outputs.action[id] = this.outputs.action[id] || [];
101
97
  this.outputs.action[id].push(stateItem);
@@ -110,7 +106,7 @@ class StateBuilder {
110
106
  }
111
107
  }
112
108
  }
113
- serialize() {
109
+ export() {
114
110
  const actions = [];
115
111
  const goto = {};
116
112
  for (const [symbol, next] of this.actions) {
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lr.js","sourceRoot":"","sources":["../../../src/generator/artifacts/lr.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,183 @@
1
+ declare class grammar {
2
+ artifacts: {
3
+ grammar: {
4
+ rules: {
5
+ _: {
6
+ name: string;
7
+ postprocess: ({ data }: {
8
+ data: any;
9
+ }) => any;
10
+ symbols: string[];
11
+ }[];
12
+ _$RPT01x1: {
13
+ name: string;
14
+ postprocess: ({ data }: {
15
+ data: any;
16
+ }) => any;
17
+ symbols: {
18
+ token: string;
19
+ }[];
20
+ }[];
21
+ __: {
22
+ name: string;
23
+ postprocess: ({ data }: {
24
+ data: any;
25
+ }) => any;
26
+ symbols: string[];
27
+ }[];
28
+ __$RPT1Nx1: ({
29
+ name: string;
30
+ symbols: {
31
+ token: string;
32
+ }[];
33
+ postprocess?: undefined;
34
+ } | {
35
+ name: string;
36
+ postprocess: ({ data }: {
37
+ data: any;
38
+ }) => any;
39
+ symbols: (string | {
40
+ token: string;
41
+ })[];
42
+ })[];
43
+ array: {
44
+ name: string;
45
+ postprocess: ({ data }: {
46
+ data: any;
47
+ }) => any[];
48
+ symbols: (string | {
49
+ literal: string;
50
+ })[];
51
+ }[];
52
+ array$RPT0Nx1: ({
53
+ name: string;
54
+ symbols: any[];
55
+ postprocess?: undefined;
56
+ } | {
57
+ name: string;
58
+ postprocess: ({ data }: {
59
+ data: any;
60
+ }) => any;
61
+ symbols: string[];
62
+ })[];
63
+ array$RPT0Nx1$SUBx1: {
64
+ name: string;
65
+ symbols: (string | {
66
+ literal: string;
67
+ })[];
68
+ }[];
69
+ json: {
70
+ name: string;
71
+ postprocess: ({ data }: {
72
+ data: any;
73
+ }) => any;
74
+ symbols: string[];
75
+ }[];
76
+ json$SUBx1: {
77
+ name: string;
78
+ symbols: string[];
79
+ }[];
80
+ key: {
81
+ name: string;
82
+ postprocess: ({ data }: {
83
+ data: any;
84
+ }) => any;
85
+ symbols: string[];
86
+ }[];
87
+ number: {
88
+ name: string;
89
+ postprocess: ({ data }: {
90
+ data: any;
91
+ }) => number;
92
+ symbols: {
93
+ token: string;
94
+ }[];
95
+ }[];
96
+ object: {
97
+ name: string;
98
+ postprocess: ({ data }: {
99
+ data: any;
100
+ }) => {};
101
+ symbols: (string | {
102
+ literal: string;
103
+ })[];
104
+ }[];
105
+ object$RPT0Nx1: ({
106
+ name: string;
107
+ symbols: any[];
108
+ postprocess?: undefined;
109
+ } | {
110
+ name: string;
111
+ postprocess: ({ data }: {
112
+ data: any;
113
+ }) => any;
114
+ symbols: string[];
115
+ })[];
116
+ object$RPT0Nx1$SUBx1: {
117
+ name: string;
118
+ symbols: (string | {
119
+ literal: string;
120
+ })[];
121
+ }[];
122
+ pair: {
123
+ name: string;
124
+ postprocess: ({ data }: {
125
+ data: any;
126
+ }) => any[];
127
+ symbols: (string | {
128
+ literal: string;
129
+ })[];
130
+ }[];
131
+ string: {
132
+ name: string;
133
+ postprocess: ({ data }: {
134
+ data: any;
135
+ }) => any;
136
+ symbols: {
137
+ token: string;
138
+ }[];
139
+ }[];
140
+ value: ({
141
+ name: string;
142
+ postprocess: ({ data }: {
143
+ data: any;
144
+ }) => any;
145
+ symbols: string[];
146
+ } | {
147
+ name: string;
148
+ postprocess: ({ data }: {
149
+ data: any;
150
+ }) => any;
151
+ symbols: {
152
+ literal: string;
153
+ }[];
154
+ })[];
155
+ };
156
+ start: string;
157
+ };
158
+ lexer: {
159
+ start: string;
160
+ states: {
161
+ json: {
162
+ regex: RegExp;
163
+ rules: ({
164
+ tag: string[];
165
+ when: RegExp;
166
+ } | {
167
+ tag: string[];
168
+ when: string;
169
+ })[];
170
+ };
171
+ whitespace: {
172
+ regex: RegExp;
173
+ rules: {
174
+ tag: string[];
175
+ when: RegExp;
176
+ }[];
177
+ };
178
+ };
179
+ };
180
+ };
181
+ constructor();
182
+ }
183
+ export default grammar;