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.
- package/dist/Cursor.js +105 -0
- package/dist/Cursor.js.map +1 -0
- package/dist/CursorHistory.js +104 -0
- package/dist/CursorHistory.js.map +1 -0
- package/dist/Permutor.js +52 -0
- package/dist/Permutor.js.map +1 -0
- package/dist/TextSuggester.js +223 -0
- package/dist/TextSuggester.js.map +1 -0
- package/dist/ast/CompositeNode.js +17 -0
- package/dist/ast/CompositeNode.js.map +1 -0
- package/dist/ast/Node.js +16 -0
- package/dist/ast/Node.js.map +1 -0
- package/dist/ast/ValueNode.js +14 -0
- package/dist/ast/ValueNode.js.map +1 -0
- package/dist/ast/Visitor.d.ts +2 -2
- package/dist/ast/Visitor.js +209 -0
- package/dist/ast/Visitor.js.map +1 -0
- package/dist/index.browser.js +38 -32
- package/dist/index.browser.js.map +1 -1
- package/dist/index.esm.js +38 -32
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +38 -32
- package/dist/index.js.map +1 -1
- package/dist/patterns/ParseError.js +9 -0
- package/dist/patterns/ParseError.js.map +1 -0
- package/dist/patterns/Pattern.js +127 -0
- package/dist/patterns/Pattern.js.map +1 -0
- package/dist/patterns/RecursivePattern.js +65 -0
- package/dist/patterns/RecursivePattern.js.map +1 -0
- package/dist/patterns/composite/AndComposite.js +117 -0
- package/dist/patterns/composite/AndComposite.js.map +1 -0
- package/dist/patterns/composite/CompositePattern.js +7 -0
- package/dist/patterns/composite/CompositePattern.js.map +1 -0
- package/dist/patterns/composite/OptionalComposite.js +29 -0
- package/dist/patterns/composite/OptionalComposite.js.map +1 -0
- package/dist/patterns/composite/OrComposite.js +69 -0
- package/dist/patterns/composite/OrComposite.js.map +1 -0
- package/dist/patterns/composite/RepeatComposite.js +83 -0
- package/dist/patterns/composite/RepeatComposite.js.map +1 -0
- package/dist/patterns/value/AndValue.js +118 -0
- package/dist/patterns/value/AndValue.js.map +1 -0
- package/dist/patterns/value/AnyOfThese.js +59 -0
- package/dist/patterns/value/AnyOfThese.js.map +1 -0
- package/dist/patterns/value/Literal.js +63 -0
- package/dist/patterns/value/Literal.js.map +1 -0
- package/dist/patterns/value/NotValue.js +70 -0
- package/dist/patterns/value/NotValue.js.map +1 -0
- package/dist/patterns/value/OptionalValue.js +32 -0
- package/dist/patterns/value/OptionalValue.js.map +1 -0
- package/dist/patterns/value/OrValue.js +73 -0
- package/dist/patterns/value/OrValue.js.map +1 -0
- package/dist/patterns/value/RegexValue.js +69 -0
- package/dist/patterns/value/RegexValue.js.map +1 -0
- package/dist/patterns/value/RepeatValue.js +84 -0
- package/dist/patterns/value/RepeatValue.js.map +1 -0
- package/dist/patterns/value/ValuePattern.js +7 -0
- package/dist/patterns/value/ValuePattern.js.map +1 -0
- package/package.json +1 -1
- package/src/TextSuggester.ts +15 -7
- package/src/ast/Visitor.ts +40 -40
- package/src/tests/TextSuggester.test.ts +15 -0
- 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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"}
|
package/dist/Permutor.js
ADDED
|
@@ -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":"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"}
|
|
@@ -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"}
|
package/dist/ast/Node.js
ADDED
|
@@ -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"}
|
package/dist/ast/Visitor.d.ts
CHANGED
|
@@ -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
|
}
|