occam-parsers 23.0.114 → 23.0.116

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.
@@ -230,25 +230,10 @@ var TerminalNode = /*#__PURE__*/ function() {
230
230
  }
231
231
  },
232
232
  {
233
- key: "isIncludedIn",
234
- value: function isIncludedIn(node) {
235
- var _this = this;
236
- var includedIn = false;
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
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "occam-parsers",
3
3
  "author": "James Smith",
4
- "version": "23.0.114",
4
+ "version": "23.0.116",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/occam-parsers",
7
7
  "description": "Occam's parsers.",
@@ -16,8 +16,8 @@
16
16
  "devDependencies": {
17
17
  "@swc/core": "^1.5.6",
18
18
  "easy": "^23.0.1",
19
- "easy-layout": "^6.0.233",
20
- "easy-with-style": "^3.0.470",
19
+ "easy-layout": "^6.0.234",
20
+ "easy-with-style": "^3.0.472",
21
21
  "esbuild": "^0.9.6",
22
22
  "express": "^4.17.1",
23
23
  "juxtapose": "^4.0.117",
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;
@@ -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, forwardsSome, backwardsSome } = arrayUtilities,
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
- setParentNode(parentNode) {
53
- this.parentNode = parentNode;
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
- mapChildNode(callback) { return this.childNodes.map(callback); }
224
-
225
- someChildNode(callback) { return this.childNodes.some(callback); }
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 childNodes;
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
- asParseTree(tokens) {
402
- const nonTerminalNode = this, ///
403
- nonTerminalNodeParseTree = NonTerminalNodeParseTree.fromNonTerminalNodeAndTokens(nonTerminalNode, tokens),
404
- parseTree = nonTerminalNodeParseTree; ///
278
+ destroy() {
279
+ this.forEachChildNode((childNode) => {
280
+ childNode.destroy();
281
+ });
405
282
 
406
- return parseTree;
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);
@@ -118,29 +118,12 @@ export default class TerminalNode {
118
118
  return ancestorNodes;
119
119
  }
120
120
 
121
- isIncludedIn(node) {
122
- let includedIn = false;
123
-
124
- if (this === node) {
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 includedIn;
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; ///