clarity-pattern-parser 3.0.7 → 3.0.9

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 (62) hide show
  1. package/dist/Cursor.js +105 -0
  2. package/dist/Cursor.js.map +1 -0
  3. package/dist/CursorHistory.js +104 -0
  4. package/dist/CursorHistory.js.map +1 -0
  5. package/dist/Permutor.js +52 -0
  6. package/dist/Permutor.js.map +1 -0
  7. package/dist/TextSuggester.js +223 -0
  8. package/dist/TextSuggester.js.map +1 -0
  9. package/dist/ast/CompositeNode.js +17 -0
  10. package/dist/ast/CompositeNode.js.map +1 -0
  11. package/dist/ast/Node.js +16 -0
  12. package/dist/ast/Node.js.map +1 -0
  13. package/dist/ast/ValueNode.js +14 -0
  14. package/dist/ast/ValueNode.js.map +1 -0
  15. package/dist/ast/Visitor.d.ts +2 -2
  16. package/dist/ast/Visitor.js +209 -0
  17. package/dist/ast/Visitor.js.map +1 -0
  18. package/dist/index.browser.js +38 -32
  19. package/dist/index.browser.js.map +1 -1
  20. package/dist/index.esm.js +38 -32
  21. package/dist/index.esm.js.map +1 -1
  22. package/dist/index.js +38 -32
  23. package/dist/index.js.map +1 -1
  24. package/dist/patterns/ParseError.js +9 -0
  25. package/dist/patterns/ParseError.js.map +1 -0
  26. package/dist/patterns/Pattern.js +127 -0
  27. package/dist/patterns/Pattern.js.map +1 -0
  28. package/dist/patterns/RecursivePattern.js +65 -0
  29. package/dist/patterns/RecursivePattern.js.map +1 -0
  30. package/dist/patterns/composite/AndComposite.js +117 -0
  31. package/dist/patterns/composite/AndComposite.js.map +1 -0
  32. package/dist/patterns/composite/CompositePattern.js +7 -0
  33. package/dist/patterns/composite/CompositePattern.js.map +1 -0
  34. package/dist/patterns/composite/OptionalComposite.js +29 -0
  35. package/dist/patterns/composite/OptionalComposite.js.map +1 -0
  36. package/dist/patterns/composite/OrComposite.js +69 -0
  37. package/dist/patterns/composite/OrComposite.js.map +1 -0
  38. package/dist/patterns/composite/RepeatComposite.js +83 -0
  39. package/dist/patterns/composite/RepeatComposite.js.map +1 -0
  40. package/dist/patterns/value/AndValue.js +118 -0
  41. package/dist/patterns/value/AndValue.js.map +1 -0
  42. package/dist/patterns/value/AnyOfThese.js +59 -0
  43. package/dist/patterns/value/AnyOfThese.js.map +1 -0
  44. package/dist/patterns/value/Literal.js +63 -0
  45. package/dist/patterns/value/Literal.js.map +1 -0
  46. package/dist/patterns/value/NotValue.js +70 -0
  47. package/dist/patterns/value/NotValue.js.map +1 -0
  48. package/dist/patterns/value/OptionalValue.js +32 -0
  49. package/dist/patterns/value/OptionalValue.js.map +1 -0
  50. package/dist/patterns/value/OrValue.js +73 -0
  51. package/dist/patterns/value/OrValue.js.map +1 -0
  52. package/dist/patterns/value/RegexValue.js +69 -0
  53. package/dist/patterns/value/RegexValue.js.map +1 -0
  54. package/dist/patterns/value/RepeatValue.js +84 -0
  55. package/dist/patterns/value/RepeatValue.js.map +1 -0
  56. package/dist/patterns/value/ValuePattern.js +7 -0
  57. package/dist/patterns/value/ValuePattern.js.map +1 -0
  58. package/package.json +1 -1
  59. package/src/TextSuggester.ts +15 -7
  60. package/src/ast/Visitor.ts +40 -40
  61. package/src/tests/TextSuggester.test.ts +15 -0
  62. package/src/tests/javascriptPatterns/json.ts +1 -0
package/dist/Cursor.js ADDED
@@ -0,0 +1,105 @@
1
+ import CursorHistory from "./CursorHistory";
2
+ export default class Cursor {
3
+ constructor(text) {
4
+ this.text = text;
5
+ this.assertValidity();
6
+ this.index = 0;
7
+ this.length = text.length;
8
+ this.history = new CursorHistory();
9
+ this.isInErrorState = false;
10
+ }
11
+ assertValidity() {
12
+ if (this.isNullOrEmpty(this.text)) {
13
+ throw new Error("Illegal Argument: Cursor needs to have a string that has a length greater than 0.");
14
+ }
15
+ }
16
+ startRecording() {
17
+ this.history.startRecording();
18
+ }
19
+ stopRecording() {
20
+ this.history.stopRecording();
21
+ }
22
+ get parseError() {
23
+ return this.history.getFurthestError();
24
+ }
25
+ get lastMatch() {
26
+ return this.history.getFurthestMatch();
27
+ }
28
+ throwError(parseError) {
29
+ this.isInErrorState = true;
30
+ this.history.addError(parseError);
31
+ }
32
+ addMatch(pattern, astNode) {
33
+ this.history.addMatch(pattern, astNode);
34
+ }
35
+ resolveError() {
36
+ this.isInErrorState = false;
37
+ }
38
+ hasUnresolvedError() {
39
+ return this.isInErrorState;
40
+ }
41
+ isNullOrEmpty(value) {
42
+ return value == null || (typeof value === "string" && value.length === 0);
43
+ }
44
+ hasNext() {
45
+ return this.index + 1 < this.text.length;
46
+ }
47
+ hasPrevious() {
48
+ return this.index - 1 >= 0;
49
+ }
50
+ next() {
51
+ if (this.hasNext()) {
52
+ this.index++;
53
+ }
54
+ else {
55
+ throw new Error("Cursor: Out of Bounds Exception.");
56
+ }
57
+ }
58
+ previous() {
59
+ if (this.hasPrevious()) {
60
+ this.index--;
61
+ }
62
+ else {
63
+ throw new Error("Cursor: Out of Bounds Exception.");
64
+ }
65
+ }
66
+ mark() {
67
+ return this.index;
68
+ }
69
+ moveToMark(mark) {
70
+ this.index = mark;
71
+ }
72
+ moveToBeginning() {
73
+ this.index = 0;
74
+ }
75
+ moveToEnd() {
76
+ this.index = this.text.length - 1;
77
+ }
78
+ getChar() {
79
+ return this.text.charAt(this.index);
80
+ }
81
+ getIndex() {
82
+ return this.index;
83
+ }
84
+ setIndex(index) {
85
+ if (typeof index === "number") {
86
+ if (index < 0 || index > this.lastIndex()) {
87
+ throw new Error("Cursor: Out of Bounds Exception.");
88
+ }
89
+ this.index = index;
90
+ }
91
+ }
92
+ isAtBeginning() {
93
+ return this.index === 0;
94
+ }
95
+ isAtEnd() {
96
+ return this.index === this.text.length - 1;
97
+ }
98
+ lastIndex() {
99
+ return this.length - 1;
100
+ }
101
+ didSuccessfullyParse() {
102
+ return !this.hasUnresolvedError() && this.isAtEnd();
103
+ }
104
+ }
105
+ //# sourceMappingURL=Cursor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Cursor.js","sourceRoot":"","sources":["../src/Cursor.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,104 @@
1
+ export default class CursorHistory {
2
+ constructor() {
3
+ this.isRecording = false;
4
+ this.furthestMatch = {
5
+ pattern: null,
6
+ astNode: null,
7
+ };
8
+ this.furthestError = null;
9
+ this.patterns = [];
10
+ this.astNodes = [];
11
+ this.errors = [];
12
+ }
13
+ addMatch(pattern, astNode) {
14
+ if (this.isRecording) {
15
+ this.patterns.push(pattern);
16
+ this.astNodes.push(astNode);
17
+ }
18
+ if (this.furthestMatch.astNode == null ||
19
+ astNode.endIndex >= this.furthestMatch.astNode.endIndex) {
20
+ this.furthestMatch.pattern = pattern;
21
+ this.furthestMatch.astNode = astNode;
22
+ }
23
+ }
24
+ addError(error) {
25
+ if (this.isRecording) {
26
+ this.errors.push(error);
27
+ }
28
+ if (this.furthestError == null || error.index >= this.furthestError.index) {
29
+ this.furthestError = error;
30
+ }
31
+ }
32
+ startRecording() {
33
+ this.isRecording = true;
34
+ }
35
+ stopRecording() {
36
+ this.isRecording = false;
37
+ this.clear();
38
+ }
39
+ clear() {
40
+ this.patterns.length = 0;
41
+ this.astNodes.length = 0;
42
+ this.errors.length = 0;
43
+ }
44
+ getFurthestError() {
45
+ return this.furthestError;
46
+ }
47
+ getFurthestMatch() {
48
+ return this.furthestMatch;
49
+ }
50
+ getLastMatch() {
51
+ if (this.isRecording) {
52
+ return {
53
+ pattern: this.patterns[this.patterns.length - 1] || null,
54
+ astNode: this.astNodes[this.astNodes.length - 1] || null,
55
+ };
56
+ }
57
+ else {
58
+ return this.furthestMatch;
59
+ }
60
+ }
61
+ getLastError() {
62
+ return this.errors[this.errors.length - 1] || null;
63
+ }
64
+ getAllParseStacks() {
65
+ const stacks = this.astNodes.reduce((acc, node) => {
66
+ let container = acc[acc.length - 1];
67
+ if (node.startIndex === 0) {
68
+ container = [];
69
+ acc.push(container);
70
+ }
71
+ container.push(node);
72
+ return acc;
73
+ }, []);
74
+ // There are times when the matching will fail and hit again on the same node.
75
+ // This filters them out.
76
+ // We simply check to see if there is any overlap with the previous one,
77
+ // and if there is we don't add it. This is why we move backwards.
78
+ const cleanedStack = stacks.map((stack) => {
79
+ const cleanedStack = [];
80
+ for (let x = stack.length - 1; x >= 0; x--) {
81
+ const currentNode = stack[x];
82
+ const previousNode = stack[x + 1];
83
+ if (previousNode == null) {
84
+ cleanedStack.unshift(currentNode);
85
+ }
86
+ else {
87
+ const left = Math.max(currentNode.startIndex, previousNode.startIndex);
88
+ const right = Math.min(currentNode.endIndex, previousNode.endIndex);
89
+ const isOverlapping = left <= right;
90
+ if (!isOverlapping) {
91
+ cleanedStack.unshift(currentNode);
92
+ }
93
+ }
94
+ }
95
+ return cleanedStack;
96
+ });
97
+ return cleanedStack;
98
+ }
99
+ getLastParseStack() {
100
+ const stacks = this.getAllParseStacks();
101
+ return stacks[stacks.length - 1] || [];
102
+ }
103
+ }
104
+ //# sourceMappingURL=CursorHistory.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CursorHistory.js","sourceRoot":"","sources":["../src/CursorHistory.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,52 @@
1
+ export default class Permutor {
2
+ constructor() {
3
+ this.array = [];
4
+ this.positionToOptions = {};
5
+ }
6
+ permute(array) {
7
+ this.array = array;
8
+ this.createPositionMap();
9
+ return this.getPermutations();
10
+ }
11
+ getPermutations() {
12
+ return this.array[0].reduce((acc, value, index) => {
13
+ return acc.concat(this.getOptions(0, index));
14
+ }, []);
15
+ }
16
+ getKey(x, y) {
17
+ return `${x}|${y}`;
18
+ }
19
+ createPositionMap() {
20
+ this.positionToOptions = {};
21
+ for (let x = this.array.length - 1; x >= 0; x--) {
22
+ for (let y = 0; y < this.array[x].length; y++) {
23
+ const yValue = this.array[x][y];
24
+ const nextX = x + 1;
25
+ if (this.array[nextX] != null) {
26
+ const options = this.array[nextX];
27
+ const value = options
28
+ .map((option, index) => {
29
+ let permutations = this.getOptions(nextX, index);
30
+ return permutations.map((option) => {
31
+ return `${yValue}${option}`;
32
+ });
33
+ })
34
+ .reduce((acc, value) => {
35
+ return acc.concat(value);
36
+ }, []);
37
+ this.setOptions(x, y, value);
38
+ }
39
+ else {
40
+ this.setOptions(x, y, [yValue]);
41
+ }
42
+ }
43
+ }
44
+ }
45
+ getOptions(x, y) {
46
+ return this.positionToOptions[this.getKey(x, y)];
47
+ }
48
+ setOptions(x, y, value) {
49
+ this.positionToOptions[this.getKey(x, y)] = value;
50
+ }
51
+ }
52
+ //# sourceMappingURL=Permutor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Permutor.js","sourceRoot":"","sources":["../src/Permutor.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,OAAO,OAAO,QAAQ;IAI3B;QACE,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAChB,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;IAC9B,CAAC;IAED,OAAO,CAAC,KAAU;QAChB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,OAAO,IAAI,CAAC,eAAe,EAAE,CAAC;IAChC,CAAC;IAED,eAAe;QACb,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE;YACrD,OAAO,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC;QAC/C,CAAC,EAAE,EAAE,CAAC,CAAC;IACT,CAAC;IAED,MAAM,CAAC,CAAS,EAAE,CAAS;QACzB,OAAO,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;QAE5B,KAAK,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;YAC/C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC7C,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAChC,MAAM,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC;gBAEpB,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE;oBAC7B,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;oBAElC,MAAM,KAAK,GAAG,OAAO;yBAClB,GAAG,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;wBACrB,IAAI,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;wBAEjD,OAAO,YAAY,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;4BACjC,OAAO,GAAG,MAAM,GAAG,MAAM,EAAE,CAAC;wBAC9B,CAAC,CAAC,CAAC;oBACL,CAAC,CAAC;yBACD,MAAM,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;wBACrB,OAAO,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;oBAC3B,CAAC,EAAE,EAAE,CAAC,CAAC;oBAET,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC;iBAC9B;qBAAM;oBACL,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;iBACjC;aACF;SACF;IACH,CAAC;IAED,UAAU,CAAC,CAAS,EAAE,CAAS;QAC7B,OAAO,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACnD,CAAC;IAED,UAAU,CAAC,CAAS,EAAE,CAAS,EAAE,KAAe;QAC9C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;IACpD,CAAC;CACF"}
@@ -0,0 +1,223 @@
1
+ import Cursor from "./Cursor";
2
+ export default class TextSuggester {
3
+ constructor() {
4
+ this.cursor = null;
5
+ this.result = null;
6
+ this.text = "";
7
+ this.match = null;
8
+ this.error = null;
9
+ this.patternMatch = null;
10
+ this.matchedText = "";
11
+ this.rootPattern = null;
12
+ this.tokens = {
13
+ startIndex: 0,
14
+ values: [],
15
+ };
16
+ this.options = [];
17
+ this.parseStack = [];
18
+ }
19
+ suggest(text, pattern) {
20
+ var _a, _b, _c;
21
+ this.reset();
22
+ this.text = text;
23
+ this.rootPattern = pattern;
24
+ // If no text all options are available.
25
+ if (text.length === 0) {
26
+ return {
27
+ pattern: null,
28
+ astNode: null,
29
+ match: null,
30
+ error: null,
31
+ options: {
32
+ startIndex: 0,
33
+ values: pattern.getTokens(),
34
+ },
35
+ isComplete: false,
36
+ parseStack: [],
37
+ };
38
+ }
39
+ this.parse();
40
+ this.saveParseStack();
41
+ this.saveMatchedText();
42
+ this.saveMatch();
43
+ this.saveError();
44
+ this.saveOptions();
45
+ this.saveNextToken();
46
+ return {
47
+ pattern: ((_a = this.patternMatch) === null || _a === void 0 ? void 0 : _a.pattern) || null,
48
+ astNode: ((_b = this.patternMatch) === null || _b === void 0 ? void 0 : _b.astNode) || null,
49
+ match: this.match,
50
+ error: this.error,
51
+ options: this.tokens,
52
+ isComplete: ((_c = this.cursor) === null || _c === void 0 ? void 0 : _c.didSuccessfullyParse()) || false,
53
+ parseStack: this.parseStack,
54
+ };
55
+ }
56
+ reset() {
57
+ this.cursor = null;
58
+ this.result = null;
59
+ this.text = "";
60
+ this.match = null;
61
+ this.error = null;
62
+ this.patternMatch = null;
63
+ this.matchedText = "";
64
+ this.rootPattern = null;
65
+ this.tokens = {
66
+ startIndex: 0,
67
+ values: [],
68
+ };
69
+ this.options = [];
70
+ this.parseStack = [];
71
+ }
72
+ parse() {
73
+ var _a;
74
+ this.rootPattern = this.rootPattern;
75
+ this.cursor = new Cursor(this.text || "");
76
+ this.cursor.startRecording();
77
+ this.result = ((_a = this.rootPattern) === null || _a === void 0 ? void 0 : _a.parse(this.cursor)) || null;
78
+ this.patternMatch = this.cursor.lastMatch;
79
+ }
80
+ saveParseStack() {
81
+ var _a;
82
+ this.parseStack = ((_a = this.cursor) === null || _a === void 0 ? void 0 : _a.history.getLastParseStack()) || [];
83
+ }
84
+ saveMatchedText() {
85
+ var _a, _b;
86
+ if (((_a = this.patternMatch) === null || _a === void 0 ? void 0 : _a.astNode) != null) {
87
+ this.matchedText =
88
+ ((_b = this.text) === null || _b === void 0 ? void 0 : _b.substring(0, this.patternMatch.astNode.endIndex + 1)) || "";
89
+ }
90
+ }
91
+ saveMatch() {
92
+ var _a;
93
+ const node = (_a = this.patternMatch) === null || _a === void 0 ? void 0 : _a.astNode;
94
+ if (node == null) {
95
+ this.match = null;
96
+ return;
97
+ }
98
+ let endIndex = this.matchedText.length - 1;
99
+ this.match = {
100
+ text: this.matchedText,
101
+ startIndex: 0,
102
+ endIndex: endIndex,
103
+ };
104
+ }
105
+ saveError() {
106
+ var _a;
107
+ if (((_a = this.patternMatch) === null || _a === void 0 ? void 0 : _a.astNode) == null) {
108
+ this.error = {
109
+ startIndex: 0,
110
+ endIndex: this.text.length - 1,
111
+ text: this.text,
112
+ };
113
+ return this;
114
+ }
115
+ if (this.patternMatch != null &&
116
+ this.text.length > this.matchedText.length) {
117
+ const difference = this.text.length - this.matchedText.length;
118
+ const startIndex = this.patternMatch.astNode.endIndex + 1;
119
+ const endIndex = startIndex + difference - 1;
120
+ this.error = {
121
+ startIndex: startIndex,
122
+ endIndex: endIndex,
123
+ text: this.text.substring(startIndex, endIndex + 1),
124
+ };
125
+ return;
126
+ }
127
+ else {
128
+ this.error = null;
129
+ return;
130
+ }
131
+ }
132
+ saveNextToken() {
133
+ var _a, _b, _c, _d;
134
+ if (((_a = this.patternMatch) === null || _a === void 0 ? void 0 : _a.pattern) === this.rootPattern &&
135
+ ((_b = this.cursor) === null || _b === void 0 ? void 0 : _b.didSuccessfullyParse())) {
136
+ this.tokens = null;
137
+ return;
138
+ }
139
+ if (((_c = this.patternMatch) === null || _c === void 0 ? void 0 : _c.astNode) == null) {
140
+ let options = (_d = this.rootPattern) === null || _d === void 0 ? void 0 : _d.getTokens();
141
+ const parts = this.text.split(" ").filter((part) => {
142
+ return part.length > 0;
143
+ });
144
+ options = options === null || options === void 0 ? void 0 : options.filter((option) => {
145
+ return parts.some((part) => {
146
+ return option.indexOf(part) > -1;
147
+ });
148
+ });
149
+ if ((options === null || options === void 0 ? void 0 : options.length) === 0) {
150
+ this.tokens = null;
151
+ return;
152
+ }
153
+ this.tokens = {
154
+ startIndex: 0,
155
+ values: options || [],
156
+ };
157
+ return;
158
+ }
159
+ const options = this.options;
160
+ let startIndex = this.matchedText.length;
161
+ if (this.matchedText.length < this.text.length) {
162
+ const leftOver = this.text.substring(this.matchedText.length);
163
+ const partialMatchOptions = options
164
+ .filter((option) => {
165
+ return option.indexOf(leftOver) === 0;
166
+ })
167
+ .map((option) => {
168
+ return option.substring(leftOver.length);
169
+ });
170
+ if (partialMatchOptions.length === 0) {
171
+ this.tokens = null;
172
+ return;
173
+ }
174
+ else {
175
+ if (this.match == null) {
176
+ return;
177
+ }
178
+ this.match = {
179
+ text: this.match.text + leftOver,
180
+ startIndex: this.match.startIndex,
181
+ endIndex: this.match.endIndex + leftOver.length,
182
+ };
183
+ this.error = null;
184
+ this.tokens = {
185
+ startIndex: this.match.endIndex + 1,
186
+ values: partialMatchOptions,
187
+ };
188
+ return;
189
+ }
190
+ }
191
+ this.tokens = {
192
+ startIndex,
193
+ values: options,
194
+ };
195
+ }
196
+ saveOptions() {
197
+ var _a;
198
+ const furthestMatches = (_a = this.cursor) === null || _a === void 0 ? void 0 : _a.history.astNodes.reduce((acc, node, index) => {
199
+ if (node.endIndex === acc.furthestTextIndex) {
200
+ acc.nodeIndexes.push(index);
201
+ }
202
+ else if (node.endIndex > acc.furthestTextIndex) {
203
+ acc.furthestTextIndex = node.endIndex;
204
+ acc.nodeIndexes = [index];
205
+ }
206
+ return acc;
207
+ }, { furthestTextIndex: -1, nodeIndexes: [] });
208
+ const matches = furthestMatches.nodeIndexes.reduce((acc, index) => {
209
+ var _a;
210
+ const pattern = (_a = this.cursor) === null || _a === void 0 ? void 0 : _a.history.patterns[index];
211
+ const tokens = pattern === null || pattern === void 0 ? void 0 : pattern.getNextTokens();
212
+ tokens === null || tokens === void 0 ? void 0 : tokens.forEach((token) => {
213
+ acc[token] = true;
214
+ });
215
+ return acc;
216
+ }, {});
217
+ this.options = Object.keys(matches);
218
+ }
219
+ static suggest(text, pattern) {
220
+ return new TextSuggester().suggest(text, pattern);
221
+ }
222
+ }
223
+ //# sourceMappingURL=TextSuggester.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TextSuggester.js","sourceRoot":"","sources":["../src/TextSuggester.ts"],"names":[],"mappings":"AACA,OAAO,MAAM,MAAM,UAAU,CAAC;AA+B9B,MAAM,CAAC,OAAO,OAAO,aAAa;IAAlC;QACU,WAAM,GAAkB,IAAI,CAAC;QAC7B,WAAM,GAAgB,IAAI,CAAC;QAC3B,SAAI,GAAW,EAAE,CAAC;QAClB,UAAK,GAA2B,IAAI,CAAC;QACrC,UAAK,GAA2B,IAAI,CAAC;QACrC,iBAAY,GAAiB,IAAI,CAAC;QAClC,gBAAW,GAAW,EAAE,CAAC;QACzB,gBAAW,GAAmB,IAAI,CAAC;QACnC,WAAM,GAAiB;YAC7B,UAAU,EAAE,CAAC;YACb,MAAM,EAAE,EAAE;SACX,CAAC;QACM,YAAO,GAAa,EAAE,CAAC;QACvB,eAAU,GAAW,EAAE,CAAC;IAgPlC,CAAC;IA9OC,OAAO,CAAC,IAAY,EAAE,OAAgB;;QACpC,IAAI,CAAC,KAAK,EAAE,CAAC;QAEb,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC;QAE3B,wCAAwC;QACxC,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;YACrB,OAAO;gBACL,OAAO,EAAE,IAAI;gBACb,OAAO,EAAE,IAAI;gBACb,KAAK,EAAE,IAAI;gBACX,KAAK,EAAE,IAAI;gBACX,OAAO,EAAE;oBACP,UAAU,EAAE,CAAC;oBACb,MAAM,EAAE,OAAO,CAAC,SAAS,EAAE;iBAC5B;gBACD,UAAU,EAAE,KAAK;gBACjB,UAAU,EAAE,EAAE;aACK,CAAC;SACvB;QAED,IAAI,CAAC,KAAK,EAAE,CAAC;QACb,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,aAAa,EAAE,CAAC;QAErB,OAAO;YACL,OAAO,EAAE,CAAA,MAAA,IAAI,CAAC,YAAY,0CAAE,OAAO,KAAI,IAAI;YAC3C,OAAO,EAAE,CAAA,MAAA,IAAI,CAAC,YAAY,0CAAE,OAAO,KAAI,IAAI;YAC3C,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,OAAO,EAAE,IAAI,CAAC,MAAM;YACpB,UAAU,EAAE,CAAA,MAAA,IAAI,CAAC,MAAM,0CAAE,oBAAoB,EAAE,KAAI,KAAK;YACxD,UAAU,EAAE,IAAI,CAAC,UAAU;SACR,CAAC;IACxB,CAAC;IAEO,KAAK;QACX,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QACf,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,MAAM,GAAG;YACZ,UAAU,EAAE,CAAC;YACb,MAAM,EAAE,EAAE;SACX,CAAC;QACF,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;QAClB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;IAEO,KAAK;;QACX,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QACpC,IAAI,CAAC,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QAC1C,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;QAC7B,IAAI,CAAC,MAAM,GAAG,CAAA,MAAA,IAAI,CAAC,WAAW,0CAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,KAAI,IAAI,CAAC;QAC3D,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;IAC5C,CAAC;IAEO,cAAc;;QACpB,IAAI,CAAC,UAAU,GAAG,CAAA,MAAA,IAAI,CAAC,MAAM,0CAAE,OAAO,CAAC,iBAAiB,EAAE,KAAI,EAAE,CAAC;IACnE,CAAC;IAEO,eAAe;;QACrB,IAAI,CAAA,MAAA,IAAI,CAAC,YAAY,0CAAE,OAAO,KAAI,IAAI,EAAE;YACtC,IAAI,CAAC,WAAW;gBACd,CAAA,MAAA,IAAI,CAAC,IAAI,0CAAE,SAAS,CAAC,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC,KAAI,EAAE,CAAC;SACzE;IACH,CAAC;IAEO,SAAS;;QACf,MAAM,IAAI,GAAG,MAAA,IAAI,CAAC,YAAY,0CAAE,OAAO,CAAC;QAExC,IAAI,IAAI,IAAI,IAAI,EAAE;YAChB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;YAClB,OAAO;SACR;QAED,IAAI,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC;QAE3C,IAAI,CAAC,KAAK,GAAG;YACX,IAAI,EAAE,IAAI,CAAC,WAAW;YACtB,UAAU,EAAE,CAAC;YACb,QAAQ,EAAE,QAAQ;SACnB,CAAC;IACJ,CAAC;IAEO,SAAS;;QACf,IAAI,CAAA,MAAA,IAAI,CAAC,YAAY,0CAAE,OAAO,KAAI,IAAI,EAAE;YACtC,IAAI,CAAC,KAAK,GAAG;gBACX,UAAU,EAAE,CAAC;gBACb,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC;gBAC9B,IAAI,EAAE,IAAI,CAAC,IAAI;aAChB,CAAC;YACF,OAAO,IAAI,CAAC;SACb;QAED,IACE,IAAI,CAAC,YAAY,IAAI,IAAI;YACzB,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,EAC1C;YACA,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;YAC9D,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;YAC1D,MAAM,QAAQ,GAAG,UAAU,GAAG,UAAU,GAAG,CAAC,CAAC;YAE7C,IAAI,CAAC,KAAK,GAAG;gBACX,UAAU,EAAE,UAAU;gBACtB,QAAQ,EAAE,QAAQ;gBAClB,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,QAAQ,GAAG,CAAC,CAAC;aACpD,CAAC;YAEF,OAAO;SACR;aAAM;YACL,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;YAClB,OAAO;SACR;IACH,CAAC;IAEO,aAAa;;QACnB,IACE,CAAA,MAAA,IAAI,CAAC,YAAY,0CAAE,OAAO,MAAK,IAAI,CAAC,WAAW;aAC/C,MAAA,IAAI,CAAC,MAAM,0CAAE,oBAAoB,EAAE,CAAA,EACnC;YACA,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;YACnB,OAAO;SACR;QAED,IAAI,CAAA,MAAA,IAAI,CAAC,YAAY,0CAAE,OAAO,KAAI,IAAI,EAAE;YACtC,IAAI,OAAO,GAAG,MAAA,IAAI,CAAC,WAAW,0CAAE,SAAS,EAAE,CAAC;YAC5C,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,IAAS,EAAE,EAAE;gBACtD,OAAO,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;YACzB,CAAC,CAAC,CAAC;YAEH,OAAO,GAAG,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,CAAC,CAAC,MAAW,EAAE,EAAE;gBACxC,OAAO,KAAK,CAAC,IAAI,CAAC,CAAC,IAAS,EAAE,EAAE;oBAC9B,OAAO,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;gBACnC,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YAEH,IAAI,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,MAAK,CAAC,EAAE;gBACzB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;gBACnB,OAAO;aACR;YAED,IAAI,CAAC,MAAM,GAAG;gBACZ,UAAU,EAAE,CAAC;gBACb,MAAM,EAAE,OAAO,IAAI,EAAE;aACtB,CAAC;YAEF,OAAO;SACR;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC7B,IAAI,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;QAEzC,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAC9C,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;YAC9D,MAAM,mBAAmB,GAAG,OAAO;iBAChC,MAAM,CAAC,CAAC,MAAW,EAAE,EAAE;gBACtB,OAAO,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACxC,CAAC,CAAC;iBACD,GAAG,CAAC,CAAC,MAAW,EAAE,EAAE;gBACnB,OAAO,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;YAC3C,CAAC,CAAC,CAAC;YAEL,IAAI,mBAAmB,CAAC,MAAM,KAAK,CAAC,EAAE;gBACpC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;gBACnB,OAAO;aACR;iBAAM;gBACL,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,EAAE;oBACtB,OAAO;iBACR;gBAED,IAAI,CAAC,KAAK,GAAG;oBACX,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,QAAQ;oBAChC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU;oBACjC,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,QAAQ,CAAC,MAAM;iBAChD,CAAC;gBAEF,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;gBAElB,IAAI,CAAC,MAAM,GAAG;oBACZ,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,CAAC;oBACnC,MAAM,EAAE,mBAAmB;iBAC5B,CAAC;gBAEF,OAAO;aACR;SACF;QAED,IAAI,CAAC,MAAM,GAAG;YACZ,UAAU;YACV,MAAM,EAAE,OAAO;SAChB,CAAC;IACJ,CAAC;IAEO,WAAW;;QACjB,MAAM,eAAe,GAAG,MAAA,IAAI,CAAC,MAAM,0CAAE,OAAO,CAAC,QAAQ,CAAC,MAAM,CAC1D,CAAC,GAAQ,EAAE,IAAS,EAAE,KAAU,EAAE,EAAE;YAClC,IAAI,IAAI,CAAC,QAAQ,KAAK,GAAG,CAAC,iBAAiB,EAAE;gBAC3C,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aAC7B;iBAAM,IAAI,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC,iBAAiB,EAAE;gBAChD,GAAG,CAAC,iBAAiB,GAAG,IAAI,CAAC,QAAQ,CAAC;gBACtC,GAAG,CAAC,WAAW,GAAG,CAAC,KAAK,CAAC,CAAC;aAC3B;YAED,OAAO,GAAG,CAAC;QACb,CAAC,EACD,EAAE,iBAAiB,EAAE,CAAC,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,CAC3C,CAAC;QAEF,MAAM,OAAO,GAAG,eAAe,CAAC,WAAW,CAAC,MAAM,CAChD,CAAC,GAAQ,EAAE,KAAU,EAAE,EAAE;;YACvB,MAAM,OAAO,GAAG,MAAA,IAAI,CAAC,MAAM,0CAAE,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACrD,MAAM,MAAM,GAAG,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,aAAa,EAAE,CAAC;YAExC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,OAAO,CAAC,CAAC,KAAU,EAAE,EAAE;gBAC7B,GAAG,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC;YACpB,CAAC,CAAC,CAAC;YAEH,OAAO,GAAG,CAAC;QACb,CAAC,EACD,EAAE,CACH,CAAC;QAEF,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACtC,CAAC;IAED,MAAM,CAAC,OAAO,CAAC,IAAY,EAAE,OAAgB;QAC3C,OAAO,IAAI,aAAa,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IACpD,CAAC;CACF"}
@@ -0,0 +1,17 @@
1
+ import Node from "./Node";
2
+ export default class CompositeNode extends Node {
3
+ constructor(type, name, startIndex = 0, endIndex = 0) {
4
+ super(type, name, startIndex, endIndex, true);
5
+ }
6
+ clone() {
7
+ const node = new CompositeNode(this.type, this.name, this.startIndex, this.endIndex);
8
+ node.children = this.children.map((child) => {
9
+ return child.clone();
10
+ });
11
+ return node;
12
+ }
13
+ toString() {
14
+ return this.children.map((child) => child.toString()).join("");
15
+ }
16
+ }
17
+ //# sourceMappingURL=CompositeNode.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CompositeNode.js","sourceRoot":"","sources":["../../src/ast/CompositeNode.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,QAAQ,CAAC;AAE1B,MAAM,CAAC,OAAO,OAAO,aAAc,SAAQ,IAAI;IAC7C,YAAY,IAAY,EAAE,IAAY,EAAE,UAAU,GAAG,CAAC,EAAE,QAAQ,GAAG,CAAC;QAClE,KAAK,CAAC,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;IAChD,CAAC;IAED,KAAK;QACH,MAAM,IAAI,GAAG,IAAI,aAAa,CAC5B,IAAI,CAAC,IAAI,EACT,IAAI,CAAC,IAAI,EACT,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,QAAQ,CACd,CAAC;QAEF,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YAC1C,OAAO,KAAK,CAAC,KAAK,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC;IACd,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACjE,CAAC;CACF"}
@@ -0,0 +1,16 @@
1
+ export default class Node {
2
+ constructor(type, name, startIndex, endIndex, isComposite = false) {
3
+ this.children = [];
4
+ this.value = "";
5
+ this.type = type;
6
+ this.name = name;
7
+ this.startIndex = startIndex;
8
+ this.endIndex = endIndex;
9
+ this.isComposite = isComposite;
10
+ if (typeof this.startIndex !== "number" ||
11
+ typeof this.endIndex !== "number") {
12
+ throw new Error("Invalid Arguments: startIndex and endIndex need to be number.");
13
+ }
14
+ }
15
+ }
16
+ //# sourceMappingURL=Node.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Node.js","sourceRoot":"","sources":["../../src/ast/Node.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,OAAO,OAAgB,IAAI;IAShC,YACE,IAAY,EACZ,IAAY,EACZ,UAAkB,EAClB,QAAgB,EAChB,WAAW,GAAG,KAAK;QARd,aAAQ,GAAW,EAAE,CAAC;QACtB,UAAK,GAAW,EAAE,CAAC;QASxB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAE/B,IACE,OAAO,IAAI,CAAC,UAAU,KAAK,QAAQ;YACnC,OAAO,IAAI,CAAC,QAAQ,KAAK,QAAQ,EACjC;YACA,MAAM,IAAI,KAAK,CACb,+DAA+D,CAChE,CAAC;SACH;IACH,CAAC;CAKF"}
@@ -0,0 +1,14 @@
1
+ import Node from "./Node";
2
+ export default class ValueNode extends Node {
3
+ constructor(type, name, value, startIndex = 0, endIndex = 0) {
4
+ super(type, name, startIndex, endIndex);
5
+ this.value = value;
6
+ }
7
+ clone() {
8
+ return new ValueNode(this.type, this.name, this.value, this.startIndex, this.endIndex);
9
+ }
10
+ toString() {
11
+ return this.value;
12
+ }
13
+ }
14
+ //# sourceMappingURL=ValueNode.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ValueNode.js","sourceRoot":"","sources":["../../src/ast/ValueNode.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,QAAQ,CAAC;AAE1B,MAAM,CAAC,OAAO,OAAO,SAAU,SAAQ,IAAI;IACzC,YACE,IAAY,EACZ,IAAY,EACZ,KAAa,EACb,UAAU,GAAG,CAAC,EACd,QAAQ,GAAG,CAAC;QAEZ,KAAK,CAAC,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;QACxC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED,KAAK;QACH,OAAO,IAAI,SAAS,CAClB,IAAI,CAAC,IAAI,EACT,IAAI,CAAC,IAAI,EACT,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,QAAQ,CACd,CAAC;IACJ,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;CACF"}
@@ -12,8 +12,6 @@ export default class Visitor {
12
12
  append(callback: (node: Node) => Node): this;
13
13
  transform(callback: (node: Node) => Node): this;
14
14
  private recursiveTransform;
15
- walkUp(node: Node, callback: (node: Node, ancestors: Node[]) => void, ancestors?: Node[]): this;
16
- walkDown(node: Node, callback: (node: Node, ancestors: Node[]) => void, ancestors?: Node[]): this;
17
15
  selectAll(): Visitor;
18
16
  selectNode(node: Node): Visitor;
19
17
  deselectNode(node: Node): Visitor;
@@ -28,4 +26,6 @@ export default class Visitor {
28
26
  clear(): this;
29
27
  setRoot(root: Node | null): this;
30
28
  static select(root: Node, callback?: (node: Node) => boolean): Visitor;
29
+ static walkUp(node: Node, callback: (node: Node, ancestors: Node[]) => void, ancestors?: Node[]): typeof Visitor;
30
+ static walkDown(node: Node, callback: (node: Node, ancestors: Node[]) => void, ancestors?: Node[]): typeof Visitor;
31
31
  }