occam-parsers 23.0.115 → 23.0.117
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/example.js +514 -428
- package/lib/index.js +5 -1
- package/lib/mixins/node.js +195 -0
- package/lib/node/nonTerminal.js +24 -176
- package/lib/node/terminal.js +12 -27
- package/package.json +1 -1
- package/src/index.js +2 -0
- package/src/mixins/node.js +205 -0
- package/src/node/nonTerminal.js +21 -141
- package/src/node/terminal.js +10 -30
package/lib/node/terminal.js
CHANGED
|
@@ -230,25 +230,10 @@ var TerminalNode = /*#__PURE__*/ function() {
|
|
|
230
230
|
}
|
|
231
231
|
},
|
|
232
232
|
{
|
|
233
|
-
key: "
|
|
234
|
-
value: function
|
|
235
|
-
var
|
|
236
|
-
|
|
237
|
-
if (this === node) {
|
|
238
|
-
includedIn = true;
|
|
239
|
-
} else {
|
|
240
|
-
var nodeNonTerminalNode = node.isNonTerminalNode();
|
|
241
|
-
if (nodeNonTerminalNode) {
|
|
242
|
-
var nonTerminalNode = node, childNodes = nonTerminalNode.getChildNodes();
|
|
243
|
-
includedIn = childNodes.some(function(childNode) {
|
|
244
|
-
var includedInChildNode = _this.isIncludedIn(childNode);
|
|
245
|
-
if (includedInChildNode) {
|
|
246
|
-
return true;
|
|
247
|
-
}
|
|
248
|
-
});
|
|
249
|
-
}
|
|
250
|
-
}
|
|
251
|
-
return includedIn;
|
|
233
|
+
key: "asParseTree",
|
|
234
|
+
value: function asParseTree(tokens) {
|
|
235
|
+
var terminalNode = this, terminalNodeParseTree = _terminalNode.default.fromTerminalNodeAndTokens(terminalNode, tokens), parseTree = terminalNodeParseTree; ///
|
|
236
|
+
return parseTree;
|
|
252
237
|
}
|
|
253
238
|
},
|
|
254
239
|
{
|
|
@@ -264,13 +249,6 @@ var TerminalNode = /*#__PURE__*/ function() {
|
|
|
264
249
|
return matches;
|
|
265
250
|
}
|
|
266
251
|
},
|
|
267
|
-
{
|
|
268
|
-
key: "asParseTree",
|
|
269
|
-
value: function asParseTree(tokens) {
|
|
270
|
-
var terminalNode = this, terminalNodeParseTree = _terminalNode.default.fromTerminalNodeAndTokens(terminalNode, tokens), parseTree = terminalNodeParseTree; ///
|
|
271
|
-
return parseTree;
|
|
272
|
-
}
|
|
273
|
-
},
|
|
274
252
|
{
|
|
275
253
|
key: "clone",
|
|
276
254
|
value: function clone() {
|
|
@@ -283,6 +261,13 @@ var TerminalNode = /*#__PURE__*/ function() {
|
|
|
283
261
|
].concat(_to_consumable_array(remainingArguments)));
|
|
284
262
|
return terminalNode;
|
|
285
263
|
}
|
|
264
|
+
},
|
|
265
|
+
{
|
|
266
|
+
key: "destroy",
|
|
267
|
+
value: function destroy() {
|
|
268
|
+
this.parentNode = null;
|
|
269
|
+
this.significantToken = null;
|
|
270
|
+
}
|
|
286
271
|
}
|
|
287
272
|
], [
|
|
288
273
|
{
|
|
@@ -322,4 +307,4 @@ var TerminalNode = /*#__PURE__*/ function() {
|
|
|
322
307
|
return TerminalNode;
|
|
323
308
|
}();
|
|
324
309
|
|
|
325
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/node/terminal.js"],"sourcesContent":["\"use strict\";\n\nimport TerminalNodeParseTree from \"../parseTree/terminalNode\";\n\nexport default class TerminalNode {\n  constructor(parentNode, significantToken) {\n    this.parentNode = parentNode;\n    this.significantToken = significantToken;\n  }\n\n  getParentNode() {\n    return this.parentNode;\n  }\n\n  getSignificantToken() {\n    return this.significantToken;\n  }\n\n  setParentNode(parentNode) {\n    this.parentNode = parentNode;\n  }\n\n  setSignificantToken(significantToken) {\n    this.significantToken = significantToken;\n  }\n\n  isStartOfContentNode() {\n    const startOfContentNode = false;\n\n    return startOfContentNode;\n  }\n\n  isNoWhitespaceNode() {\n    const noWhitespaceNode = false;\n\n    return noWhitespaceNode;\n  }\n\n  isEpsilonNode() {\n    const epsilonNode = false;\n\n    return epsilonNode;\n  }\n\n  isTerminalNode() {\n    const terminalNode = true;\n    \n    return terminalNode;\n  }\n\n  isNonTerminalNode() {\n    const nonTerminalNode = false;\n\n    return nonTerminalNode;\n  }\n\n  getType() { return this.significantToken.getType(); }\n\n  getContent() { return this.significantToken.getContent(); }\n\n  getPrecedence()  {\n    const precedence = null;\n\n    return precedence;\n  }\n\n  isLowerPrecedence(parentRuleName, parentPrecedence) {\n    const lowerPrecedence = false;\n\n    return lowerPrecedence;\n  }\n\n  getFirstSignificantTokenIndex(tokens) {\n    const significantTokenIndex = this.getSignificantTokenIndex(tokens),\n          firstSignificantTokenIndex = significantTokenIndex; ///\n\n    return firstSignificantTokenIndex;\n  }\n\n  getLastSignificantTokenIndex(tokens) {\n    const significantTokenIndex = this.getSignificantTokenIndex(tokens),\n          lastSignificantTokenIndex = significantTokenIndex; ///\n\n    return lastSignificantTokenIndex;\n  }\n\n  getSignificantTokenIndex(tokens) {\n    let significantTokenIndex = null;\n\n    if (this.significantToken !== null) {\n      significantTokenIndex = tokens.indexOf(this.significantToken);\n    }\n\n    return significantTokenIndex;\n  }\n\n  getSignificantTokens(significantTokens = []) {\n    if (this.significantToken !== null) {\n      significantTokens.push(this.significantToken);\n    }\n\n    return significantTokens;\n  }\n\n  getAncestorNodes() {\n    const ancestorNodes = [];\n\n    let parentNode = this.parentNode;\n\n    while (parentNode !== null) {\n      const ancestorNode = parentNode;  ///\n\n      ancestorNodes.push(ancestorNode);\n\n      parentNode = parentNode.getParentNode();\n    }\n\n    return ancestorNodes;\n  }\n\n  isIncludedIn(node) {\n    let includedIn = false;\n\n    if (this === node) {\n      includedIn = true;\n    } else {\n      const nodeNonTerminalNode = node.isNonTerminalNode();\n\n      if (nodeNonTerminalNode) {\n        const nonTerminalNode = node, ///\n              childNodes = nonTerminalNode.getChildNodes();\n\n        includedIn = childNodes.some((childNode) => {\n          const includedInChildNode = this.isIncludedIn(childNode);\n\n          if (includedInChildNode) {\n            return true;\n          }\n        });\n      }\n    }\n\n    return includedIn;\n  }\n\n  match(node, depth = Infinity, exactly = false) {\n    let matches = false;\n\n    const nodeTerminalNode = node.isTerminalNode();\n\n    if (nodeTerminalNode) {\n      const terminalNode = node,  ///\n            significantToken = terminalNode.getSignificantToken();\n\n      matches = exactly ?\n                  (this.significantToken === significantToken) :\n                     this.significantToken.match(significantToken);\n    }\n\n    return matches;\n  }\n\n  asParseTree(tokens) {\n    const terminalNode = this,  ///\n          terminalNodeParseTree = TerminalNodeParseTree.fromTerminalNodeAndTokens(terminalNode, tokens),\n          parseTree = terminalNodeParseTree;  ///\n\n    return parseTree;\n  }\n\n  clone(...remainingArguments) {\n    const Class = this.constructor,\n          parentNode = null,\n          significantToken = this.significantToken,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n\n    return terminalNode;\n  }\n\n  static fromNothing(Class, ...remainingArguments) {\n    if (Class === undefined) {\n      Class = TerminalNode; ///\n    }\n\n    const parentNode = null,\n          significantToken = null,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n\n    return terminalNode;\n  }\n\n  static fromSignificantToken(Class, significantToken, ...remainingArguments) {\n    if (significantToken === undefined) {\n      significantToken = Class; ///\n\n      Class = TerminalNode; ///\n    }\n\n    const parentNode = null,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n    \n    return terminalNode;\n  }\n}\n"],"names":["TerminalNode","parentNode","significantToken","getParentNode","getSignificantToken","setParentNode","setSignificantToken","isStartOfContentNode","startOfContentNode","isNoWhitespaceNode","noWhitespaceNode","isEpsilonNode","epsilonNode","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","getType","getContent","getPrecedence","precedence","isLowerPrecedence","parentRuleName","parentPrecedence","lowerPrecedence","getFirstSignificantTokenIndex","tokens","significantTokenIndex","getSignificantTokenIndex","firstSignificantTokenIndex","getLastSignificantTokenIndex","lastSignificantTokenIndex","indexOf","getSignificantTokens","significantTokens","push","getAncestorNodes","ancestorNodes","ancestorNode","isIncludedIn","node","includedIn","nodeNonTerminalNode","childNodes","getChildNodes","some","childNode","includedInChildNode","match","depth","Infinity","exactly","matches","nodeTerminalNode","asParseTree","terminalNodeParseTree","TerminalNodeParseTree","fromTerminalNodeAndTokens","parseTree","clone","remainingArguments","Class","constructor","fromNothing","undefined","fromSignificantToken"],"mappings":"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"}
|
|
310
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/node/terminal.js"],"sourcesContent":["\"use strict\";\n\nimport TerminalNodeParseTree from \"../parseTree/terminalNode\";\n\nexport default class TerminalNode {\n  constructor(parentNode, significantToken) {\n    this.parentNode = parentNode;\n    this.significantToken = significantToken;\n  }\n\n  getParentNode() {\n    return this.parentNode;\n  }\n\n  getSignificantToken() {\n    return this.significantToken;\n  }\n\n  setParentNode(parentNode) {\n    this.parentNode = parentNode;\n  }\n\n  setSignificantToken(significantToken) {\n    this.significantToken = significantToken;\n  }\n\n  isStartOfContentNode() {\n    const startOfContentNode = false;\n\n    return startOfContentNode;\n  }\n\n  isNoWhitespaceNode() {\n    const noWhitespaceNode = false;\n\n    return noWhitespaceNode;\n  }\n\n  isEpsilonNode() {\n    const epsilonNode = false;\n\n    return epsilonNode;\n  }\n\n  isTerminalNode() {\n    const terminalNode = true;\n    \n    return terminalNode;\n  }\n\n  isNonTerminalNode() {\n    const nonTerminalNode = false;\n\n    return nonTerminalNode;\n  }\n\n  getType() { return this.significantToken.getType(); }\n\n  getContent() { return this.significantToken.getContent(); }\n\n  getPrecedence()  {\n    const precedence = null;\n\n    return precedence;\n  }\n\n  isLowerPrecedence(parentRuleName, parentPrecedence) {\n    const lowerPrecedence = false;\n\n    return lowerPrecedence;\n  }\n\n  getFirstSignificantTokenIndex(tokens) {\n    const significantTokenIndex = this.getSignificantTokenIndex(tokens),\n          firstSignificantTokenIndex = significantTokenIndex; ///\n\n    return firstSignificantTokenIndex;\n  }\n\n  getLastSignificantTokenIndex(tokens) {\n    const significantTokenIndex = this.getSignificantTokenIndex(tokens),\n          lastSignificantTokenIndex = significantTokenIndex; ///\n\n    return lastSignificantTokenIndex;\n  }\n\n  getSignificantTokenIndex(tokens) {\n    let significantTokenIndex = null;\n\n    if (this.significantToken !== null) {\n      significantTokenIndex = tokens.indexOf(this.significantToken);\n    }\n\n    return significantTokenIndex;\n  }\n\n  getSignificantTokens(significantTokens = []) {\n    if (this.significantToken !== null) {\n      significantTokens.push(this.significantToken);\n    }\n\n    return significantTokens;\n  }\n\n  getAncestorNodes() {\n    const ancestorNodes = [];\n\n    let parentNode = this.parentNode;\n\n    while (parentNode !== null) {\n      const ancestorNode = parentNode;  ///\n\n      ancestorNodes.push(ancestorNode);\n\n      parentNode = parentNode.getParentNode();\n    }\n\n    return ancestorNodes;\n  }\n\n  asParseTree(tokens) {\n    const terminalNode = this,  ///\n          terminalNodeParseTree = TerminalNodeParseTree.fromTerminalNodeAndTokens(terminalNode, tokens),\n          parseTree = terminalNodeParseTree;  ///\n\n    return parseTree;\n  }\n\n  match(node, depth = Infinity, exactly = false) {\n    let matches = false;\n\n    const nodeTerminalNode = node.isTerminalNode();\n\n    if (nodeTerminalNode) {\n      const terminalNode = node,  ///\n            significantToken = terminalNode.getSignificantToken();\n\n      matches = exactly ?\n                  (this.significantToken === significantToken) :\n                     this.significantToken.match(significantToken);\n    }\n\n    return matches;\n  }\n\n  clone(...remainingArguments) {\n    const Class = this.constructor,\n          parentNode = null,\n          significantToken = this.significantToken,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n\n    return terminalNode;\n  }\n\n  destroy() {\n    this.parentNode = null;\n    this.significantToken = null;\n  }\n\n  static fromNothing(Class, ...remainingArguments) {\n    if (Class === undefined) {\n      Class = TerminalNode; ///\n    }\n\n    const parentNode = null,\n          significantToken = null,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n\n    return terminalNode;\n  }\n\n  static fromSignificantToken(Class, significantToken, ...remainingArguments) {\n    if (significantToken === undefined) {\n      significantToken = Class; ///\n\n      Class = TerminalNode; ///\n    }\n\n    const parentNode = null,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n    \n    return terminalNode;\n  }\n}\n"],"names":["TerminalNode","parentNode","significantToken","getParentNode","getSignificantToken","setParentNode","setSignificantToken","isStartOfContentNode","startOfContentNode","isNoWhitespaceNode","noWhitespaceNode","isEpsilonNode","epsilonNode","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","getType","getContent","getPrecedence","precedence","isLowerPrecedence","parentRuleName","parentPrecedence","lowerPrecedence","getFirstSignificantTokenIndex","tokens","significantTokenIndex","getSignificantTokenIndex","firstSignificantTokenIndex","getLastSignificantTokenIndex","lastSignificantTokenIndex","indexOf","getSignificantTokens","significantTokens","push","getAncestorNodes","ancestorNodes","ancestorNode","asParseTree","terminalNodeParseTree","TerminalNodeParseTree","fromTerminalNodeAndTokens","parseTree","match","node","depth","Infinity","exactly","matches","nodeTerminalNode","clone","remainingArguments","Class","constructor","destroy","fromNothing","undefined","fromSignificantToken"],"mappings":"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"}
|
package/package.json
CHANGED
package/src/index.js
CHANGED
|
@@ -4,6 +4,8 @@ export { default as BNFParser } from "./bnf/parser";
|
|
|
4
4
|
export { default as BasicParser } from "./basic/parser";
|
|
5
5
|
export { default as CommonParser } from "./common/parser";
|
|
6
6
|
|
|
7
|
+
export { default as nodeMixins } from "./mixins/node";
|
|
8
|
+
|
|
7
9
|
export { default as rulesUtilities } from "./utilities/rules";
|
|
8
10
|
export { default as parserUtilities } from "./utilities/parser";
|
|
9
11
|
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import { arrayUtilities } from "necessary";
|
|
4
|
+
|
|
5
|
+
const { first, forwardsSome, backwardsSome } = arrayUtilities;
|
|
6
|
+
|
|
7
|
+
function getMultiplicity() {
|
|
8
|
+
const childNodesLength = this.childNodes.length,
|
|
9
|
+
multiplicity = childNodesLength; ///
|
|
10
|
+
|
|
11
|
+
return multiplicity;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
function mapChildNode(callback) { return this.childNodes.map(callback); }
|
|
15
|
+
|
|
16
|
+
function someChildNode(callback) { return this.childNodes.some(callback); }
|
|
17
|
+
|
|
18
|
+
function findChildNode(callback) { return this.childNodes.find(callback); }
|
|
19
|
+
|
|
20
|
+
function everyChildNode(callback) { return this.childNodes.every(callback); }
|
|
21
|
+
|
|
22
|
+
function filterChildNode(callback) { return this.childNodes.filter(callback); }
|
|
23
|
+
|
|
24
|
+
function reduceChildNode(callback, initialValue) { return this.childNodes.reduce(callback, initialValue); }
|
|
25
|
+
|
|
26
|
+
function forEachChildNode(callback) { this.childNodes.forEach(callback); }
|
|
27
|
+
|
|
28
|
+
function forwardsSomeChildNode(callback) { return forwardsSome(this.childNodes, callback); }
|
|
29
|
+
|
|
30
|
+
function backwardsSomeChildNode(callback) { return backwardsSome(this.childNodes, callback); }
|
|
31
|
+
|
|
32
|
+
function indexOfChildNode(childNode) { return this.childNodes.indexOf(childNode); }
|
|
33
|
+
|
|
34
|
+
function setChildNodesParentNode(childNodes) {
|
|
35
|
+
if (childNodes === undefined) {
|
|
36
|
+
childNodes = [
|
|
37
|
+
...this.childNodes
|
|
38
|
+
];
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
const parentNode = this;
|
|
42
|
+
|
|
43
|
+
childNodes.forEach((childNode) => {
|
|
44
|
+
childNode.setParentNode(parentNode);
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
function resetChildNodesParentNode(childNodes) {
|
|
49
|
+
if (childNodes === undefined) {
|
|
50
|
+
childNodes = [
|
|
51
|
+
...this.childNodes
|
|
52
|
+
];
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
const parentNode = null;
|
|
56
|
+
|
|
57
|
+
childNodes.forEach((childNode) => {
|
|
58
|
+
childNode.setParentNode(parentNode);
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
function addChildNode(addedChildNode, startIndex) {
|
|
63
|
+
const addedChildNodes = [
|
|
64
|
+
addedChildNode
|
|
65
|
+
];
|
|
66
|
+
|
|
67
|
+
this.addChildNodes(addedChildNodes, startIndex);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
function addChildNodes(addedChildNodes, startIndex) {
|
|
71
|
+
const deleteCount = 0;
|
|
72
|
+
|
|
73
|
+
this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
function removeChildNode(removedChildNode) {
|
|
77
|
+
let removedChildNodes;
|
|
78
|
+
|
|
79
|
+
removedChildNodes = [
|
|
80
|
+
removedChildNode
|
|
81
|
+
];
|
|
82
|
+
|
|
83
|
+
removedChildNodes = this.removeChildNodes(removedChildNodes);
|
|
84
|
+
|
|
85
|
+
return removedChildNodes;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
function removeChildNodes(removedChildNodes) {
|
|
89
|
+
if (removedChildNodes === undefined) {
|
|
90
|
+
removedChildNodes = [
|
|
91
|
+
...this.childNodes
|
|
92
|
+
];
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
const removedChildNodesLength = removedChildNodes.length;
|
|
96
|
+
|
|
97
|
+
if (removedChildNodesLength === 0) {
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
const firstReplacedChildNode = first(removedChildNodes),
|
|
102
|
+
firstIndex = this.childNodes.indexOf(firstReplacedChildNode),
|
|
103
|
+
startIndex = firstIndex, ///
|
|
104
|
+
deleteCount = removedChildNodesLength, ///
|
|
105
|
+
addedChildNodes = [];
|
|
106
|
+
|
|
107
|
+
removedChildNodes = this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);
|
|
108
|
+
|
|
109
|
+
return removedChildNodes;
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
function replaceChildNode(replacedChildNode, replacementChildNodes) {
|
|
113
|
+
const replacedChildNodes = [
|
|
114
|
+
replacedChildNode
|
|
115
|
+
];
|
|
116
|
+
|
|
117
|
+
this.replaceChildNodes(replacedChildNodes, replacementChildNodes);
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
function replaceChildNodes(replacedChildNodes, replacementChildNodes) {
|
|
121
|
+
const replacedChildNodesLength = replacedChildNodes.length,
|
|
122
|
+
firstReplacedChildNode = first(replacedChildNodes),
|
|
123
|
+
firstIndex = this.childNodes.indexOf(firstReplacedChildNode),
|
|
124
|
+
startIndex = firstIndex, ///
|
|
125
|
+
deleteCount = replacedChildNodesLength; ///
|
|
126
|
+
|
|
127
|
+
this.spliceChildNodes(startIndex, deleteCount, replacementChildNodes);
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
function appendChildNode(appendedChildNode) {
|
|
131
|
+
const appendedChildNodes = [
|
|
132
|
+
appendedChildNode
|
|
133
|
+
];
|
|
134
|
+
|
|
135
|
+
this.appendChildNodes(appendedChildNodes);
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
function appendChildNodes(appendedChildNodes) {
|
|
139
|
+
const addedChildNodes = appendedChildNodes, ///
|
|
140
|
+
multiplicity = this.getMultiplicity(),
|
|
141
|
+
startIndex = multiplicity; ///
|
|
142
|
+
|
|
143
|
+
this.addChildNodes(addedChildNodes, startIndex);
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
function prependChildNode(prependedChildNode) {
|
|
147
|
+
const prependedChildNodes = [
|
|
148
|
+
prependedChildNode
|
|
149
|
+
];
|
|
150
|
+
|
|
151
|
+
this.prependChildNodes(prependedChildNodes);
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
function prependChildNodes(prependedChildNodes) {
|
|
155
|
+
const addedChildNodes = prependedChildNodes, ///
|
|
156
|
+
startIndex = 0;
|
|
157
|
+
|
|
158
|
+
this.addChildNodes(addedChildNodes, startIndex);
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
function spliceChildNodes(startIndex, deleteCount, addedChildNodes = []) {
|
|
162
|
+
const removedChildNodes = this.childNodes.splice(startIndex, deleteCount, ...addedChildNodes);
|
|
163
|
+
|
|
164
|
+
this.resetChildNodesParentNode(removedChildNodes);
|
|
165
|
+
|
|
166
|
+
this.setChildNodesParentNode(addedChildNodes);
|
|
167
|
+
|
|
168
|
+
return removedChildNodes;
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
function sliceChildNodes(startIndex, endIndex = Infinity) {
|
|
172
|
+
const childNodes = this.childNodes.slice(startIndex, endIndex);
|
|
173
|
+
|
|
174
|
+
return childNodes;
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
const nodeMixins = {
|
|
178
|
+
getMultiplicity,
|
|
179
|
+
mapChildNode,
|
|
180
|
+
someChildNode,
|
|
181
|
+
findChildNode,
|
|
182
|
+
everyChildNode,
|
|
183
|
+
filterChildNode,
|
|
184
|
+
reduceChildNode,
|
|
185
|
+
forEachChildNode,
|
|
186
|
+
forwardsSomeChildNode,
|
|
187
|
+
backwardsSomeChildNode,
|
|
188
|
+
indexOfChildNode,
|
|
189
|
+
setChildNodesParentNode,
|
|
190
|
+
resetChildNodesParentNode,
|
|
191
|
+
addChildNode,
|
|
192
|
+
addChildNodes,
|
|
193
|
+
removeChildNode,
|
|
194
|
+
removeChildNodes,
|
|
195
|
+
replaceChildNode,
|
|
196
|
+
replaceChildNodes,
|
|
197
|
+
appendChildNode,
|
|
198
|
+
appendChildNodes,
|
|
199
|
+
prependChildNode,
|
|
200
|
+
prependChildNodes,
|
|
201
|
+
spliceChildNodes,
|
|
202
|
+
sliceChildNodes
|
|
203
|
+
};
|
|
204
|
+
|
|
205
|
+
export default nodeMixins;
|
package/src/node/nonTerminal.js
CHANGED
|
@@ -3,9 +3,10 @@
|
|
|
3
3
|
import { arrayUtilities } from "necessary";
|
|
4
4
|
import { specialSymbols } from "occam-lexers";
|
|
5
5
|
|
|
6
|
+
import nodeMixins from "../mixins/node";
|
|
6
7
|
import NonTerminalNodeParseTree from "../parseTree/nonTerminalNode";
|
|
7
8
|
|
|
8
|
-
const { first, match
|
|
9
|
+
const { first, match } = arrayUtilities,
|
|
9
10
|
{ opaque: opaqueSpecialSymbol , semiOpaque: semiOpaqueSpecialSymbol } = specialSymbols;
|
|
10
11
|
|
|
11
12
|
export default class NonTerminalNode {
|
|
@@ -41,6 +42,10 @@ export default class NonTerminalNode {
|
|
|
41
42
|
this.ruleName = ruleName;
|
|
42
43
|
}
|
|
43
44
|
|
|
45
|
+
setParentNode(parentNode) {
|
|
46
|
+
this.parentNode = parentNode;
|
|
47
|
+
}
|
|
48
|
+
|
|
44
49
|
setChildNodes(childNodes) {
|
|
45
50
|
const startIndex = 0,
|
|
46
51
|
deleteCount = Infinity,
|
|
@@ -49,18 +54,14 @@ export default class NonTerminalNode {
|
|
|
49
54
|
this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);
|
|
50
55
|
}
|
|
51
56
|
|
|
52
|
-
|
|
53
|
-
this.
|
|
57
|
+
setOpacity(opacity) {
|
|
58
|
+
this.opacity = opacity;
|
|
54
59
|
}
|
|
55
60
|
|
|
56
61
|
setPrecedence(precedence) {
|
|
57
62
|
this.precedence = precedence;
|
|
58
63
|
}
|
|
59
64
|
|
|
60
|
-
setOpacity(opacity) {
|
|
61
|
-
this.opacity = opacity;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
65
|
isOpaque() {
|
|
65
66
|
const opaque = (this.opacity === opaqueSpecialSymbol);
|
|
66
67
|
|
|
@@ -220,136 +221,12 @@ export default class NonTerminalNode {
|
|
|
220
221
|
return unprecedented;
|
|
221
222
|
}
|
|
222
223
|
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
findChildNode(callback) { return this.childNodes.find(callback); }
|
|
228
|
-
|
|
229
|
-
everyChildNode(callback) { return this.childNodes.every(callback); }
|
|
230
|
-
|
|
231
|
-
filterChildNode(callback) { return this.childNodes.filter(callback); }
|
|
232
|
-
|
|
233
|
-
reduceChildNode(callback, initialValue) { return this.childNodes.reduce(callback, initialValue); }
|
|
234
|
-
|
|
235
|
-
forEachChildNode(callback) { this.childNodes.forEach(callback); }
|
|
236
|
-
|
|
237
|
-
forwardsSomeChildNode(callback) { return forwardsSome(this.childNodes, callback); }
|
|
238
|
-
|
|
239
|
-
backwardsSomeChildNode(callback) { return backwardsSome(this.childNodes, callback); }
|
|
240
|
-
|
|
241
|
-
indexOfChildNode(childNode) { return this.childNodes.indexOf(childNode); }
|
|
242
|
-
|
|
243
|
-
setChildNodesParentNode(childNodes) {
|
|
244
|
-
if (childNodes === undefined) {
|
|
245
|
-
childNodes = [
|
|
246
|
-
...this.childNodes
|
|
247
|
-
];
|
|
248
|
-
}
|
|
249
|
-
|
|
250
|
-
const parentNode = this;
|
|
251
|
-
|
|
252
|
-
childNodes.forEach((childNode) => {
|
|
253
|
-
childNode.setParentNode(parentNode);
|
|
254
|
-
});
|
|
255
|
-
}
|
|
256
|
-
|
|
257
|
-
resetChildNodesParentNode(childNodes) {
|
|
258
|
-
if (childNodes === undefined) {
|
|
259
|
-
childNodes = [
|
|
260
|
-
...this.childNodes
|
|
261
|
-
];
|
|
262
|
-
}
|
|
263
|
-
|
|
264
|
-
const parentNode = null;
|
|
265
|
-
|
|
266
|
-
childNodes.forEach((childNode) => {
|
|
267
|
-
childNode.setParentNode(parentNode);
|
|
268
|
-
});
|
|
269
|
-
}
|
|
270
|
-
|
|
271
|
-
addChildNode(addedChildNode, startIndex) {
|
|
272
|
-
const addedChildNodes = [
|
|
273
|
-
addedChildNode
|
|
274
|
-
];
|
|
275
|
-
|
|
276
|
-
this.addChildNodes(addedChildNodes, startIndex);
|
|
277
|
-
}
|
|
278
|
-
|
|
279
|
-
addChildNodes(addedChildNodes, startIndex) {
|
|
280
|
-
const deleteCount = 0;
|
|
281
|
-
|
|
282
|
-
this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);
|
|
283
|
-
}
|
|
284
|
-
|
|
285
|
-
removeChildNode(removedChildNode) {
|
|
286
|
-
let removedChildNodes;
|
|
287
|
-
|
|
288
|
-
removedChildNodes = [
|
|
289
|
-
removedChildNode
|
|
290
|
-
];
|
|
291
|
-
|
|
292
|
-
removedChildNodes = this.removeChildNodes(removedChildNodes);
|
|
293
|
-
|
|
294
|
-
return removedChildNodes;
|
|
295
|
-
}
|
|
296
|
-
|
|
297
|
-
removeChildNodes(removedChildNodes) {
|
|
298
|
-
if (removedChildNodes === undefined) {
|
|
299
|
-
removedChildNodes = [
|
|
300
|
-
...this.childNodes
|
|
301
|
-
];
|
|
302
|
-
}
|
|
303
|
-
|
|
304
|
-
const removedChildNodesLength = removedChildNodes.length;
|
|
305
|
-
|
|
306
|
-
if (removedChildNodesLength === 0) {
|
|
307
|
-
return;
|
|
308
|
-
}
|
|
309
|
-
|
|
310
|
-
const firstReplacedChildNode = first(removedChildNodes),
|
|
311
|
-
firstIndex = this.childNodes.indexOf(firstReplacedChildNode),
|
|
312
|
-
startIndex = firstIndex, ///
|
|
313
|
-
deleteCount = removedChildNodesLength, ///
|
|
314
|
-
addedChildNodes = [];
|
|
315
|
-
|
|
316
|
-
removedChildNodes = this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);
|
|
317
|
-
|
|
318
|
-
return removedChildNodes;
|
|
319
|
-
}
|
|
320
|
-
|
|
321
|
-
replaceChildNode(replacedChildNode, replacementChildNodes) {
|
|
322
|
-
const replacedChildNodes = [
|
|
323
|
-
replacedChildNode
|
|
324
|
-
];
|
|
325
|
-
|
|
326
|
-
this.replaceChildNodes(replacedChildNodes, replacementChildNodes);
|
|
327
|
-
}
|
|
328
|
-
|
|
329
|
-
replaceChildNodes(replacedChildNodes, replacementChildNodes) {
|
|
330
|
-
const replacedChildNodesLength = replacedChildNodes.length,
|
|
331
|
-
firstReplacedChildNode = first(replacedChildNodes),
|
|
332
|
-
firstIndex = this.childNodes.indexOf(firstReplacedChildNode),
|
|
333
|
-
startIndex = firstIndex, ///
|
|
334
|
-
deleteCount = replacedChildNodesLength; ///
|
|
335
|
-
|
|
336
|
-
this.spliceChildNodes(startIndex, deleteCount, replacementChildNodes);
|
|
337
|
-
}
|
|
338
|
-
|
|
339
|
-
spliceChildNodes(startIndex, deleteCount, addedChildNodes = []) {
|
|
340
|
-
const removedChildNodes = this.childNodes.splice(startIndex, deleteCount, ...addedChildNodes);
|
|
341
|
-
|
|
342
|
-
this.resetChildNodesParentNode(removedChildNodes);
|
|
343
|
-
|
|
344
|
-
this.setChildNodesParentNode(addedChildNodes);
|
|
345
|
-
|
|
346
|
-
return removedChildNodes;
|
|
347
|
-
}
|
|
348
|
-
|
|
349
|
-
sliceChildNodes(startIndex, endIndex = Infinity) {
|
|
350
|
-
const childNodes = this.childNodes.slice(startIndex, endIndex);
|
|
224
|
+
asParseTree(tokens) {
|
|
225
|
+
const nonTerminalNode = this, ///
|
|
226
|
+
nonTerminalNodeParseTree = NonTerminalNodeParseTree.fromNonTerminalNodeAndTokens(nonTerminalNode, tokens),
|
|
227
|
+
parseTree = nonTerminalNodeParseTree; ///
|
|
351
228
|
|
|
352
|
-
return
|
|
229
|
+
return parseTree;
|
|
353
230
|
}
|
|
354
231
|
|
|
355
232
|
match(node, depth = Infinity, exactly = false) {
|
|
@@ -398,12 +275,13 @@ export default class NonTerminalNode {
|
|
|
398
275
|
return rewrittenNonTerminalNode;
|
|
399
276
|
}
|
|
400
277
|
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
278
|
+
destroy() {
|
|
279
|
+
this.forEachChildNode((childNode) => {
|
|
280
|
+
childNode.destroy();
|
|
281
|
+
});
|
|
405
282
|
|
|
406
|
-
|
|
283
|
+
this.parentNode = null;
|
|
284
|
+
this.childNodes = null;
|
|
407
285
|
}
|
|
408
286
|
|
|
409
287
|
clone(...remainingArguments) {
|
|
@@ -450,3 +328,5 @@ function cloneChildNodes(childNodes) {
|
|
|
450
328
|
|
|
451
329
|
return childNodes;
|
|
452
330
|
}
|
|
331
|
+
|
|
332
|
+
Object.assign(NonTerminalNode.prototype, nodeMixins);
|
package/src/node/terminal.js
CHANGED
|
@@ -118,29 +118,12 @@ export default class TerminalNode {
|
|
|
118
118
|
return ancestorNodes;
|
|
119
119
|
}
|
|
120
120
|
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
includedIn = true;
|
|
126
|
-
} else {
|
|
127
|
-
const nodeNonTerminalNode = node.isNonTerminalNode();
|
|
128
|
-
|
|
129
|
-
if (nodeNonTerminalNode) {
|
|
130
|
-
const nonTerminalNode = node, ///
|
|
131
|
-
childNodes = nonTerminalNode.getChildNodes();
|
|
132
|
-
|
|
133
|
-
includedIn = childNodes.some((childNode) => {
|
|
134
|
-
const includedInChildNode = this.isIncludedIn(childNode);
|
|
135
|
-
|
|
136
|
-
if (includedInChildNode) {
|
|
137
|
-
return true;
|
|
138
|
-
}
|
|
139
|
-
});
|
|
140
|
-
}
|
|
141
|
-
}
|
|
121
|
+
asParseTree(tokens) {
|
|
122
|
+
const terminalNode = this, ///
|
|
123
|
+
terminalNodeParseTree = TerminalNodeParseTree.fromTerminalNodeAndTokens(terminalNode, tokens),
|
|
124
|
+
parseTree = terminalNodeParseTree; ///
|
|
142
125
|
|
|
143
|
-
return
|
|
126
|
+
return parseTree;
|
|
144
127
|
}
|
|
145
128
|
|
|
146
129
|
match(node, depth = Infinity, exactly = false) {
|
|
@@ -160,14 +143,6 @@ export default class TerminalNode {
|
|
|
160
143
|
return matches;
|
|
161
144
|
}
|
|
162
145
|
|
|
163
|
-
asParseTree(tokens) {
|
|
164
|
-
const terminalNode = this, ///
|
|
165
|
-
terminalNodeParseTree = TerminalNodeParseTree.fromTerminalNodeAndTokens(terminalNode, tokens),
|
|
166
|
-
parseTree = terminalNodeParseTree; ///
|
|
167
|
-
|
|
168
|
-
return parseTree;
|
|
169
|
-
}
|
|
170
|
-
|
|
171
146
|
clone(...remainingArguments) {
|
|
172
147
|
const Class = this.constructor,
|
|
173
148
|
parentNode = null,
|
|
@@ -177,6 +152,11 @@ export default class TerminalNode {
|
|
|
177
152
|
return terminalNode;
|
|
178
153
|
}
|
|
179
154
|
|
|
155
|
+
destroy() {
|
|
156
|
+
this.parentNode = null;
|
|
157
|
+
this.significantToken = null;
|
|
158
|
+
}
|
|
159
|
+
|
|
180
160
|
static fromNothing(Class, ...remainingArguments) {
|
|
181
161
|
if (Class === undefined) {
|
|
182
162
|
Class = TerminalNode; ///
|