occam-parsers 23.0.86 → 23.0.88
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 +94 -84
- package/lib/node/nonTerminal.js +95 -85
- package/package.json +1 -1
- package/src/node/nonTerminal.js +102 -92
package/lib/node/nonTerminal.js
CHANGED
|
@@ -142,9 +142,8 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
142
142
|
{
|
|
143
143
|
key: "setChildNodes",
|
|
144
144
|
value: function setChildNodes(childNodes) {
|
|
145
|
-
|
|
146
|
-
this.
|
|
147
|
-
this.setChildNodesParentNode();
|
|
145
|
+
var start = 0, deleteCount = Infinity, addedChildNodes = childNodes; ///
|
|
146
|
+
this.spliceChildNodes(start, deleteCount, addedChildNodes);
|
|
148
147
|
}
|
|
149
148
|
},
|
|
150
149
|
{
|
|
@@ -200,30 +199,6 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
200
199
|
return nonTerminalNode;
|
|
201
200
|
}
|
|
202
201
|
},
|
|
203
|
-
{
|
|
204
|
-
key: "isSingular",
|
|
205
|
-
value: function isSingular() {
|
|
206
|
-
var childNodesLength = this.childNodes.length, singular = childNodesLength === 1;
|
|
207
|
-
return singular;
|
|
208
|
-
}
|
|
209
|
-
},
|
|
210
|
-
{
|
|
211
|
-
key: "isLowerPrecedence",
|
|
212
|
-
value: function isLowerPrecedence(ruleName, precedence) {
|
|
213
|
-
var lowerPrecedence;
|
|
214
|
-
if (false) {
|
|
215
|
-
///
|
|
216
|
-
} else if (this.precedence === null) {
|
|
217
|
-
lowerPrecedence = false;
|
|
218
|
-
} else if (this.precedence === Infinity) {
|
|
219
|
-
var firstChildNode = first(this.childNodes);
|
|
220
|
-
lowerPrecedence = firstChildNode.isLowerPrecedence(ruleName, precedence);
|
|
221
|
-
} else {
|
|
222
|
-
lowerPrecedence = this.ruleName === ruleName && this.precedence < precedence;
|
|
223
|
-
}
|
|
224
|
-
return lowerPrecedence;
|
|
225
|
-
}
|
|
226
|
-
},
|
|
227
202
|
{
|
|
228
203
|
key: "getFirstSignificantTokenIndex",
|
|
229
204
|
value: function getFirstSignificantTokenIndex(tokens) {
|
|
@@ -275,6 +250,44 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
275
250
|
return ancestorNodes;
|
|
276
251
|
}
|
|
277
252
|
},
|
|
253
|
+
{
|
|
254
|
+
key: "getMultiplicity",
|
|
255
|
+
value: function getMultiplicity() {
|
|
256
|
+
var childNodesLength = this.childNodes.length, multiplicity = childNodesLength; ///
|
|
257
|
+
return multiplicity;
|
|
258
|
+
}
|
|
259
|
+
},
|
|
260
|
+
{
|
|
261
|
+
key: "isEmpty",
|
|
262
|
+
value: function isEmpty() {
|
|
263
|
+
var multiplicity = this.getMultiplicity(), empty = multiplicity === 0;
|
|
264
|
+
return empty;
|
|
265
|
+
}
|
|
266
|
+
},
|
|
267
|
+
{
|
|
268
|
+
key: "isSingular",
|
|
269
|
+
value: function isSingular() {
|
|
270
|
+
var multiplicity = this.getMultiplicity(), singular = multiplicity === 1;
|
|
271
|
+
return singular;
|
|
272
|
+
}
|
|
273
|
+
},
|
|
274
|
+
{
|
|
275
|
+
key: "isLowerPrecedence",
|
|
276
|
+
value: function isLowerPrecedence(ruleName, precedence) {
|
|
277
|
+
var lowerPrecedence;
|
|
278
|
+
if (false) {
|
|
279
|
+
///
|
|
280
|
+
} else if (this.precedence === null) {
|
|
281
|
+
lowerPrecedence = false;
|
|
282
|
+
} else if (this.precedence === Infinity) {
|
|
283
|
+
var firstChildNode = first(this.childNodes);
|
|
284
|
+
lowerPrecedence = firstChildNode.isLowerPrecedence(ruleName, precedence);
|
|
285
|
+
} else {
|
|
286
|
+
lowerPrecedence = this.ruleName === ruleName && this.precedence < precedence;
|
|
287
|
+
}
|
|
288
|
+
return lowerPrecedence;
|
|
289
|
+
}
|
|
290
|
+
},
|
|
278
291
|
{
|
|
279
292
|
key: "isUnprecedented",
|
|
280
293
|
value: function isUnprecedented() {
|
|
@@ -313,13 +326,6 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
313
326
|
return includedIn;
|
|
314
327
|
}
|
|
315
328
|
},
|
|
316
|
-
{
|
|
317
|
-
key: "isEmpty",
|
|
318
|
-
value: function isEmpty() {
|
|
319
|
-
var childNodesLength = this.childNodes.length, empty = childNodesLength === 0;
|
|
320
|
-
return empty;
|
|
321
|
-
}
|
|
322
|
-
},
|
|
323
329
|
{
|
|
324
330
|
key: "mapChildNode",
|
|
325
331
|
value: function mapChildNode(callback) {
|
|
@@ -350,45 +356,6 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
350
356
|
this.childNodes.forEach(callback);
|
|
351
357
|
}
|
|
352
358
|
},
|
|
353
|
-
{
|
|
354
|
-
key: "match",
|
|
355
|
-
value: function match1(node) {
|
|
356
|
-
var depth = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : Infinity, exactly = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : false;
|
|
357
|
-
var matches = false;
|
|
358
|
-
var nodeNonTerminalNode = node.isNonTerminalNode();
|
|
359
|
-
if (nodeNonTerminalNode) {
|
|
360
|
-
var nonTerminalNode = node, nonTerminalNodeRuleName = nonTerminalNode.getRuleName();
|
|
361
|
-
if (this.ruleName === nonTerminalNodeRuleName) {
|
|
362
|
-
var nonTerminalNodeOpacity = nonTerminalNode.getOpacity();
|
|
363
|
-
if (this.opacity === nonTerminalNodeOpacity) {
|
|
364
|
-
var precedence = this.getPrecedence(), nonTerminalNodePrecedence = nonTerminalNode.getPrecedence();
|
|
365
|
-
if (precedence === nonTerminalNodePrecedence) {
|
|
366
|
-
depth--;
|
|
367
|
-
if (depth === 0) {
|
|
368
|
-
matches = true;
|
|
369
|
-
} else {
|
|
370
|
-
var nonTerminalNodeChildNodes = nonTerminalNode.getChildNodes();
|
|
371
|
-
matches = match(this.childNodes, nonTerminalNodeChildNodes, function(childNode, nonTerminalNodeChildNode) {
|
|
372
|
-
var childNodeMatchesNonTerminalNodeChildNode = childNode.match(nonTerminalNodeChildNode, depth, exactly);
|
|
373
|
-
if (childNodeMatchesNonTerminalNodeChildNode) {
|
|
374
|
-
return true;
|
|
375
|
-
}
|
|
376
|
-
});
|
|
377
|
-
}
|
|
378
|
-
}
|
|
379
|
-
}
|
|
380
|
-
}
|
|
381
|
-
}
|
|
382
|
-
return matches;
|
|
383
|
-
}
|
|
384
|
-
},
|
|
385
|
-
{
|
|
386
|
-
key: "rewrite",
|
|
387
|
-
value: function rewrite() {
|
|
388
|
-
var rewrittenNonTerminalNode = null;
|
|
389
|
-
return rewrittenNonTerminalNode;
|
|
390
|
-
}
|
|
391
|
-
},
|
|
392
359
|
{
|
|
393
360
|
key: "addChildNode",
|
|
394
361
|
value: function addChildNode(addedChildNode, offset) {
|
|
@@ -401,13 +368,11 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
401
368
|
{
|
|
402
369
|
key: "addChildNodes",
|
|
403
370
|
value: function addChildNodes(addedChildNodes, offset) {
|
|
404
|
-
var _this_childNodes;
|
|
405
371
|
var start = offset, deleteCount = 0;
|
|
406
|
-
|
|
372
|
+
this.spliceChildNodes.apply(this, [
|
|
407
373
|
start,
|
|
408
374
|
deleteCount
|
|
409
375
|
].concat(_to_consumable_array(addedChildNodes)));
|
|
410
|
-
this.setChildNodesParentNode(addedChildNodes);
|
|
411
376
|
}
|
|
412
377
|
},
|
|
413
378
|
{
|
|
@@ -431,9 +396,8 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
431
396
|
if (removedChildNodesLength === 0) {
|
|
432
397
|
return;
|
|
433
398
|
}
|
|
434
|
-
var firstReplacedChildNode = first(removedChildNodes), firstIndex = this.childNodes.indexOf(firstReplacedChildNode), start = firstIndex, deleteCount = removedChildNodesLength;
|
|
435
|
-
this.
|
|
436
|
-
this.resetChildNodesParentNode(removedChildNodes);
|
|
399
|
+
var firstReplacedChildNode = first(removedChildNodes), firstIndex = this.childNodes.indexOf(firstReplacedChildNode), start = firstIndex, deleteCount = removedChildNodesLength, addedChildNodes = [];
|
|
400
|
+
removedChildNodes = this.spliceChildNodes(start, deleteCount, addedChildNodes);
|
|
437
401
|
return removedChildNodes;
|
|
438
402
|
}
|
|
439
403
|
},
|
|
@@ -449,14 +413,21 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
449
413
|
{
|
|
450
414
|
key: "replaceChildNodes",
|
|
451
415
|
value: function replaceChildNodes(replacedChildNodes, replacementChildNodes) {
|
|
452
|
-
var _this_childNodes;
|
|
453
416
|
var replacedChildNodesLength = replacedChildNodes.length, firstReplacedChildNode = first(replacedChildNodes), firstIndex = this.childNodes.indexOf(firstReplacedChildNode), start = firstIndex, deleteCount = replacedChildNodesLength; ///
|
|
454
|
-
|
|
417
|
+
this.spliceChildNodes(start, deleteCount, replacementChildNodes);
|
|
418
|
+
}
|
|
419
|
+
},
|
|
420
|
+
{
|
|
421
|
+
key: "spliceChildNodes",
|
|
422
|
+
value: function spliceChildNodes(start, deleteCount, addedChildNodes) {
|
|
423
|
+
var _this_childNodes;
|
|
424
|
+
var removedChildNodes = (_this_childNodes = this.childNodes).splice.apply(_this_childNodes, [
|
|
455
425
|
start,
|
|
456
426
|
deleteCount
|
|
457
|
-
].concat(_to_consumable_array(
|
|
458
|
-
this.resetChildNodesParentNode(
|
|
459
|
-
this.setChildNodesParentNode(
|
|
427
|
+
].concat(_to_consumable_array(addedChildNodes)));
|
|
428
|
+
this.resetChildNodesParentNode(removedChildNodes);
|
|
429
|
+
this.setChildNodesParentNode(addedChildNodes);
|
|
430
|
+
return removedChildNodes;
|
|
460
431
|
}
|
|
461
432
|
},
|
|
462
433
|
{
|
|
@@ -483,6 +454,45 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
483
454
|
});
|
|
484
455
|
}
|
|
485
456
|
},
|
|
457
|
+
{
|
|
458
|
+
key: "match",
|
|
459
|
+
value: function match1(node) {
|
|
460
|
+
var depth = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : Infinity, exactly = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : false;
|
|
461
|
+
var matches = false;
|
|
462
|
+
var nodeNonTerminalNode = node.isNonTerminalNode();
|
|
463
|
+
if (nodeNonTerminalNode) {
|
|
464
|
+
var nonTerminalNode = node, nonTerminalNodeRuleName = nonTerminalNode.getRuleName();
|
|
465
|
+
if (this.ruleName === nonTerminalNodeRuleName) {
|
|
466
|
+
var nonTerminalNodeOpacity = nonTerminalNode.getOpacity();
|
|
467
|
+
if (this.opacity === nonTerminalNodeOpacity) {
|
|
468
|
+
var precedence = this.getPrecedence(), nonTerminalNodePrecedence = nonTerminalNode.getPrecedence();
|
|
469
|
+
if (precedence === nonTerminalNodePrecedence) {
|
|
470
|
+
depth--;
|
|
471
|
+
if (depth === 0) {
|
|
472
|
+
matches = true;
|
|
473
|
+
} else {
|
|
474
|
+
var nonTerminalNodeChildNodes = nonTerminalNode.getChildNodes();
|
|
475
|
+
matches = match(this.childNodes, nonTerminalNodeChildNodes, function(childNode, nonTerminalNodeChildNode) {
|
|
476
|
+
var childNodeMatchesNonTerminalNodeChildNode = childNode.match(nonTerminalNodeChildNode, depth, exactly);
|
|
477
|
+
if (childNodeMatchesNonTerminalNodeChildNode) {
|
|
478
|
+
return true;
|
|
479
|
+
}
|
|
480
|
+
});
|
|
481
|
+
}
|
|
482
|
+
}
|
|
483
|
+
}
|
|
484
|
+
}
|
|
485
|
+
}
|
|
486
|
+
return matches;
|
|
487
|
+
}
|
|
488
|
+
},
|
|
489
|
+
{
|
|
490
|
+
key: "rewrite",
|
|
491
|
+
value: function rewrite() {
|
|
492
|
+
var rewrittenNonTerminalNode = null;
|
|
493
|
+
return rewrittenNonTerminalNode;
|
|
494
|
+
}
|
|
495
|
+
},
|
|
486
496
|
{
|
|
487
497
|
key: "asParseTree",
|
|
488
498
|
value: function asParseTree(tokens) {
|
|
@@ -542,4 +552,4 @@ function cloneChildNodes(childNodes) {
|
|
|
542
552
|
return childNodes;
|
|
543
553
|
}
|
|
544
554
|
|
|
545
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/node/nonTerminal.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\nimport { specialSymbols } from \"occam-lexers\";\n\nimport NonTerminalNodeParseTree from \"../parseTree/nonTerminalNode\";\n\nconst { first, match, forwardsSome, backwardsSome } = arrayUtilities,\n      { opaque: opaqueSpecialSymbol , semiOpaque: semiOpaqueSpecialSymbol } = specialSymbols;\n\nexport default class NonTerminalNode {\n  constructor(ruleName, parentNode, childNodes, opacity, precedence) {\n    this.ruleName = ruleName;\n    this.parentNode = parentNode;\n    this.childNodes = childNodes;\n    this.opacity = opacity;\n    this.precedence = precedence;\n  }\n\n  getRuleName() {\n    return this.ruleName;\n  }\n\n  getParentNode() {\n    return this.parentNode;\n  }\n\n  getChildNodes() {\n    return this.childNodes;\n  }\n\n  getOpacity() {\n    return this.opacity;\n  }\n\n  getPrecedence() {\n    return this.precedence;\n  }\n\n  setRuleName(ruleName) {\n    this.ruleName = ruleName;\n  }\n\n  setChildNodes(childNodes) {\n    this.resetChildNodesParentNode();\n\n    this.childNodes = childNodes;\n\n    this.setChildNodesParentNode();\n  }\n\n  setParentNode(parentNode) {\n    this.parentNode = parentNode;\n  }\n\n  setPrecedence(precedence) {\n    this.precedence = precedence;\n  }\n\n  setOpacity(opacity) {\n    this.opacity = opacity;\n  }\n\n  isOpaque() {\n    const opaque = (this.opacity === opaqueSpecialSymbol);\n\n    return opaque;\n  }\n\n  isSemiOpaque() {\n    const semiOpaque = (this.opacity === semiOpaqueSpecialSymbol);\n\n    return semiOpaque;\n  }\n\n  isTransparent() {\n    const semiOpaque = (this.opacity === null);\n\n    return semiOpaque;\n  }\n\n  isTerminalNode() {\n    const terminalNode = false;\n\n    return terminalNode;\n  }\n\n  isNonTerminalNode() {\n    const nonTerminalNode = true;\n\n    return nonTerminalNode;\n  }\n\n  isSingular() {\n    const childNodesLength = this.childNodes.length,\n          singular = (childNodesLength === 1);\n\n    return singular;\n  }\n\n  isLowerPrecedence(ruleName, precedence) {\n    let lowerPrecedence;\n\n    if (false) {\n      ///\n    } else if (this.precedence === null) {\n      lowerPrecedence = false;\n    } else if (this.precedence === Infinity) {\n      const firstChildNode = first(this.childNodes);\n\n      lowerPrecedence = firstChildNode.isLowerPrecedence(ruleName, precedence);\n    } else {\n      lowerPrecedence = ((this.ruleName === ruleName) && (this.precedence < precedence));\n    }\n\n    return lowerPrecedence;\n  }\n\n  getFirstSignificantTokenIndex(tokens) {\n    let firstSignificantTokenIndex;\n\n    forwardsSome(this.childNodes, (childNode) => {\n      const node = childNode; ///\n\n      firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens);\n\n      if (firstSignificantTokenIndex !== null) {\n        return true;\n      }\n    });\n\n    return firstSignificantTokenIndex;\n  }\n\n  getLastSignificantTokenIndex(tokens) {\n    let lastSignificantTokenIndex;\n\n    backwardsSome(this.childNodes, (childNode) => {\n      const node = childNode; ///\n\n      lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens);\n\n      if (lastSignificantTokenIndex !== null) {\n        return true;\n      }\n    });\n\n    return lastSignificantTokenIndex;\n  }\n\n  getSignificantTokens(significantTokens = []) {\n    this.childNodes.forEach((childNode) => {\n      childNode.getSignificantTokens(significantTokens);\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  isUnprecedented() {\n    let unprecedented = false;\n\n    if (this.precedence !== null) {\n      unprecedented = this.childNodes.some((childNode) => {  ///\n        const childNodeLowerPrecedence = childNode.isLowerPrecedence(this.ruleName, this.precedence);\n\n        if (childNodeLowerPrecedence) {\n          return true;\n        }\n      });\n    }\n\n    return unprecedented;\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  isEmpty() {\n    const childNodesLength = this.childNodes.length,\n          empty = (childNodesLength === 0);\n\n    return empty;\n  }\n\n  mapChildNode(callback) { return this.childNodes.map(callback); }\n\n  someChildNode(callback) { return this.childNodes.some(callback); }\n\n  everyChildNode(callback) { return this.childNodes.every(callback); }\n\n  reduceChildNode(callback, initialValue) { return this.childNodes.reduce(callback, initialValue); }\n\n  forEachChildNode(callback) { this.childNodes.forEach(callback); }\n\n  match(node, depth = Infinity, exactly = false) {\n    let matches = false;\n\n    const nodeNonTerminalNode = node.isNonTerminalNode();\n\n    if (nodeNonTerminalNode) {\n      const nonTerminalNode = node, ///\n            nonTerminalNodeRuleName = nonTerminalNode.getRuleName();\n\n      if (this.ruleName === nonTerminalNodeRuleName) {\n        const nonTerminalNodeOpacity = nonTerminalNode.getOpacity();\n\n        if (this.opacity === nonTerminalNodeOpacity) {\n          const precedence = this.getPrecedence(),\n                nonTerminalNodePrecedence = nonTerminalNode.getPrecedence();\n\n          if (precedence === nonTerminalNodePrecedence) {\n            depth--;\n\n            if (depth === 0) {\n              matches = true;\n            } else {\n              const nonTerminalNodeChildNodes = nonTerminalNode.getChildNodes();\n\n              matches = match(this.childNodes, nonTerminalNodeChildNodes, (childNode, nonTerminalNodeChildNode) => {\n                const childNodeMatchesNonTerminalNodeChildNode = childNode.match(nonTerminalNodeChildNode, depth, exactly);\n\n                if (childNodeMatchesNonTerminalNodeChildNode) {\n                  return true;\n                }\n              });\n            }\n          }\n        }\n      }\n    }\n\n    return matches;\n  }\n\n  rewrite() {\n    const rewrittenNonTerminalNode = null;\n\n    return rewrittenNonTerminalNode;\n  }\n\n  addChildNode(addedChildNode, offset) {\n    const addedChildNodes = [\n        addedChildNode\n    ];\n\n    this.addChildNodes(addedChildNodes, offset);\n  }\n\n  addChildNodes(addedChildNodes, offset) {\n    const start = offset, ///\n          deleteCount = 0;\n\n    this.childNodes.splice(start, deleteCount, ...addedChildNodes);\n\n    this.setChildNodesParentNode(addedChildNodes);\n  }\n\n  removeChildNode(removedChildNode) {\n    let removedChildNodes;\n\n    removedChildNodes = [\n      removedChildNode\n    ];\n\n    removedChildNodes = this.removeChildNodes(removedChildNodes);\n\n    return removedChildNodes;\n  }\n\n  removeChildNodes(removedChildNodes) {\n    if (removedChildNodes === undefined) {\n      removedChildNodes = [\n        ...this.childNodes\n      ];\n    }\n\n    const removedChildNodesLength = removedChildNodes.length;\n\n    if (removedChildNodesLength === 0) {\n      return;\n    }\n\n    const firstReplacedChildNode = first(removedChildNodes),\n          firstIndex = this.childNodes.indexOf(firstReplacedChildNode),\n          start = firstIndex, ///\n          deleteCount = removedChildNodesLength; ///\n\n    this.childNodes.splice(start, deleteCount);\n\n    this.resetChildNodesParentNode(removedChildNodes);\n\n    return removedChildNodes;\n  }\n\n  replaceChildNode(replacedChildNode, replacementChildNodes) {\n    const replacedChildNodes = [\n      replacedChildNode\n    ];\n\n    this.replaceChildNodes(replacedChildNodes, replacementChildNodes);\n  }\n\n  replaceChildNodes(replacedChildNodes, replacementChildNodes) {\n    const replacedChildNodesLength = replacedChildNodes.length,\n          firstReplacedChildNode = first(replacedChildNodes),\n          firstIndex = this.childNodes.indexOf(firstReplacedChildNode),\n          start = firstIndex, ///\n          deleteCount = replacedChildNodesLength; ///\n\n    this.childNodes.splice(start, deleteCount, ...replacementChildNodes);\n\n    this.resetChildNodesParentNode(replacedChildNodes);\n\n    this.setChildNodesParentNode(replacementChildNodes);\n  }\n\n  setChildNodesParentNode(childNodes) {\n    if (childNodes === undefined) {\n      childNodes = [\n        ...this.childNodes\n      ];\n    }\n\n    const parentNode = this;\n\n    childNodes.forEach((childNode) => {\n      childNode.setParentNode(parentNode);\n    });\n  }\n\n  resetChildNodesParentNode(childNodes) {\n    if (childNodes === undefined) {\n      childNodes = [\n        ...this.childNodes\n      ];\n    }\n\n    const parentNode = null;\n\n    childNodes.forEach((childNode) => {\n      childNode.setParentNode(parentNode);\n    });\n  }\n\n  asParseTree(tokens) {\n    const nonTerminalNode = this,  ///\n          nonTerminalNodeParseTree = NonTerminalNodeParseTree.fromNonTerminalNodeAndTokens(nonTerminalNode, tokens),\n          parseTree = nonTerminalNodeParseTree;  ///\n\n    return parseTree;\n  }\n\n  clone(...remainingArguments) {\n    const Class = this.constructor,\n          parentNode = null,\n          ruleName = this.ruleName,\n          childNodes = cloneChildNodes(this.childNodes),\n          opacity = this.opacity,\n          precedence = this.precedence,\n          nonTerminalNode = new Class(ruleName, parentNode, childNodes, opacity, precedence, ...remainingArguments);\n\n    nonTerminalNode.setChildNodesParentNode();\n\n    return nonTerminalNode;\n  }\n\n  static fromRuleNameChildNodesAndOpacity(Class, ruleName, childNodes, opacity, ...remainingArguments) {\n    if (opacity === undefined) {\n      opacity = childNodes; ///\n\n      childNodes = ruleName;  ///\n\n      ruleName = Class; ///\n\n      Class = NonTerminalNode;  ///\n    }\n\n    const parentNode = null,\n          precedence = null,\n          nonTerminalNode = new Class(ruleName, parentNode, childNodes, opacity, precedence, ...remainingArguments);\n\n    nonTerminalNode.setChildNodesParentNode();\n\n    return nonTerminalNode;\n  }\n}\n\nfunction cloneChildNodes(childNodes) {\n  childNodes = childNodes.map((childNode) => {  ///\n    childNode = childNode.clone();  ///\n\n    return childNode;\n  });\n\n  return childNodes;\n}\n"],"names":["NonTerminalNode","first","arrayUtilities","match","forwardsSome","backwardsSome","opaque","opaqueSpecialSymbol","specialSymbols","semiOpaque","semiOpaqueSpecialSymbol","ruleName","parentNode","childNodes","opacity","precedence","getRuleName","getParentNode","getChildNodes","getOpacity","getPrecedence","setRuleName","setChildNodes","resetChildNodesParentNode","setChildNodesParentNode","setParentNode","setPrecedence","setOpacity","isOpaque","isSemiOpaque","isTransparent","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","isSingular","childNodesLength","length","singular","isLowerPrecedence","lowerPrecedence","Infinity","firstChildNode","getFirstSignificantTokenIndex","tokens","firstSignificantTokenIndex","childNode","node","getLastSignificantTokenIndex","lastSignificantTokenIndex","getSignificantTokens","significantTokens","forEach","getAncestorNodes","ancestorNodes","ancestorNode","push","isUnprecedented","unprecedented","some","childNodeLowerPrecedence","isIncludedIn","includedIn","nodeNonTerminalNode","includedInChildNode","isEmpty","empty","mapChildNode","callback","map","someChildNode","everyChildNode","every","reduceChildNode","initialValue","reduce","forEachChildNode","depth","exactly","matches","nonTerminalNodeRuleName","nonTerminalNodeOpacity","nonTerminalNodePrecedence","nonTerminalNodeChildNodes","nonTerminalNodeChildNode","childNodeMatchesNonTerminalNodeChildNode","rewrite","rewrittenNonTerminalNode","addChildNode","addedChildNode","offset","addedChildNodes","addChildNodes","start","deleteCount","splice","removeChildNode","removedChildNode","removedChildNodes","removeChildNodes","undefined","removedChildNodesLength","firstReplacedChildNode","firstIndex","indexOf","replaceChildNode","replacedChildNode","replacementChildNodes","replacedChildNodes","replaceChildNodes","replacedChildNodesLength","asParseTree","nonTerminalNodeParseTree","NonTerminalNodeParseTree","fromNonTerminalNodeAndTokens","parseTree","clone","remainingArguments","Class","constructor","cloneChildNodes","fromRuleNameChildNodesAndOpacity"],"mappings":"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"}
|
|
555
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/node/nonTerminal.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\nimport { specialSymbols } from \"occam-lexers\";\n\nimport NonTerminalNodeParseTree from \"../parseTree/nonTerminalNode\";\n\nconst { first, match, forwardsSome, backwardsSome } = arrayUtilities,\n      { opaque: opaqueSpecialSymbol , semiOpaque: semiOpaqueSpecialSymbol } = specialSymbols;\n\nexport default class NonTerminalNode {\n  constructor(ruleName, parentNode, childNodes, opacity, precedence) {\n    this.ruleName = ruleName;\n    this.parentNode = parentNode;\n    this.childNodes = childNodes;\n    this.opacity = opacity;\n    this.precedence = precedence;\n  }\n\n  getRuleName() {\n    return this.ruleName;\n  }\n\n  getParentNode() {\n    return this.parentNode;\n  }\n\n  getChildNodes() {\n    return this.childNodes;\n  }\n\n  getOpacity() {\n    return this.opacity;\n  }\n\n  getPrecedence() {\n    return this.precedence;\n  }\n\n  setRuleName(ruleName) {\n    this.ruleName = ruleName;\n  }\n\n  setChildNodes(childNodes) {\n    const start = 0,\n          deleteCount = Infinity,\n          addedChildNodes = childNodes;  ///\n\n    this.spliceChildNodes(start, deleteCount, addedChildNodes);\n  }\n\n  setParentNode(parentNode) {\n    this.parentNode = parentNode;\n  }\n\n  setPrecedence(precedence) {\n    this.precedence = precedence;\n  }\n\n  setOpacity(opacity) {\n    this.opacity = opacity;\n  }\n\n  isOpaque() {\n    const opaque = (this.opacity === opaqueSpecialSymbol);\n\n    return opaque;\n  }\n\n  isSemiOpaque() {\n    const semiOpaque = (this.opacity === semiOpaqueSpecialSymbol);\n\n    return semiOpaque;\n  }\n\n  isTransparent() {\n    const semiOpaque = (this.opacity === null);\n\n    return semiOpaque;\n  }\n\n  isTerminalNode() {\n    const terminalNode = false;\n\n    return terminalNode;\n  }\n\n  isNonTerminalNode() {\n    const nonTerminalNode = true;\n\n    return nonTerminalNode;\n  }\n\n  getFirstSignificantTokenIndex(tokens) {\n    let firstSignificantTokenIndex;\n\n    forwardsSome(this.childNodes, (childNode) => {\n      const node = childNode; ///\n\n      firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens);\n\n      if (firstSignificantTokenIndex !== null) {\n        return true;\n      }\n    });\n\n    return firstSignificantTokenIndex;\n  }\n\n  getLastSignificantTokenIndex(tokens) {\n    let lastSignificantTokenIndex;\n\n    backwardsSome(this.childNodes, (childNode) => {\n      const node = childNode; ///\n\n      lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens);\n\n      if (lastSignificantTokenIndex !== null) {\n        return true;\n      }\n    });\n\n    return lastSignificantTokenIndex;\n  }\n\n  getSignificantTokens(significantTokens = []) {\n    this.childNodes.forEach((childNode) => {\n      childNode.getSignificantTokens(significantTokens);\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  getMultiplicity() {\n    const childNodesLength = this.childNodes.length,\n          multiplicity = childNodesLength;  ///\n\n    return multiplicity;\n  }\n\n  isEmpty() {\n    const multiplicity = this.getMultiplicity(),\n          empty = (multiplicity === 0);\n\n    return empty;\n  }\n\n  isSingular() {\n    const multiplicity = this.getMultiplicity(),\n          singular = (multiplicity === 1);\n\n    return singular;\n  }\n\n  isLowerPrecedence(ruleName, precedence) {\n    let lowerPrecedence;\n\n    if (false) {\n      ///\n    } else if (this.precedence === null) {\n      lowerPrecedence = false;\n    } else if (this.precedence === Infinity) {\n      const firstChildNode = first(this.childNodes);\n\n      lowerPrecedence = firstChildNode.isLowerPrecedence(ruleName, precedence);\n    } else {\n      lowerPrecedence = ((this.ruleName === ruleName) && (this.precedence < precedence));\n    }\n\n    return lowerPrecedence;\n  }\n\n  isUnprecedented() {\n    let unprecedented = false;\n\n    if (this.precedence !== null) {\n      unprecedented = this.childNodes.some((childNode) => {  ///\n        const childNodeLowerPrecedence = childNode.isLowerPrecedence(this.ruleName, this.precedence);\n\n        if (childNodeLowerPrecedence) {\n          return true;\n        }\n      });\n    }\n\n    return unprecedented;\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  mapChildNode(callback) { return this.childNodes.map(callback); }\n\n  someChildNode(callback) { return this.childNodes.some(callback); }\n\n  everyChildNode(callback) { return this.childNodes.every(callback); }\n\n  reduceChildNode(callback, initialValue) { return this.childNodes.reduce(callback, initialValue); }\n\n  forEachChildNode(callback) { this.childNodes.forEach(callback); }\n\n  addChildNode(addedChildNode, offset) {\n    const addedChildNodes = [\n        addedChildNode\n    ];\n\n    this.addChildNodes(addedChildNodes, offset);\n  }\n\n  addChildNodes(addedChildNodes, offset) {\n    const start = offset, ///\n          deleteCount = 0;\n\n    this.spliceChildNodes(start, deleteCount, ...addedChildNodes);\n  }\n\n  removeChildNode(removedChildNode) {\n    let removedChildNodes;\n\n    removedChildNodes = [\n      removedChildNode\n    ];\n\n    removedChildNodes = this.removeChildNodes(removedChildNodes);\n\n    return removedChildNodes;\n  }\n\n  removeChildNodes(removedChildNodes) {\n    if (removedChildNodes === undefined) {\n      removedChildNodes = [\n        ...this.childNodes\n      ];\n    }\n\n    const removedChildNodesLength = removedChildNodes.length;\n\n    if (removedChildNodesLength === 0) {\n      return;\n    }\n\n    const firstReplacedChildNode = first(removedChildNodes),\n          firstIndex = this.childNodes.indexOf(firstReplacedChildNode),\n          start = firstIndex, ///\n          deleteCount = removedChildNodesLength, ///\n          addedChildNodes = [];\n\n    removedChildNodes = this.spliceChildNodes(start, deleteCount, addedChildNodes);\n\n    return removedChildNodes;\n  }\n\n  replaceChildNode(replacedChildNode, replacementChildNodes) {\n    const replacedChildNodes = [\n      replacedChildNode\n    ];\n\n    this.replaceChildNodes(replacedChildNodes, replacementChildNodes);\n  }\n\n  replaceChildNodes(replacedChildNodes, replacementChildNodes) {\n    const replacedChildNodesLength = replacedChildNodes.length,\n          firstReplacedChildNode = first(replacedChildNodes),\n          firstIndex = this.childNodes.indexOf(firstReplacedChildNode),\n          start = firstIndex, ///\n          deleteCount = replacedChildNodesLength; ///\n\n    this.spliceChildNodes(start, deleteCount, replacementChildNodes);\n  }\n\n  spliceChildNodes(start, deleteCount, addedChildNodes) {\n    const removedChildNodes = this.childNodes.splice(start, deleteCount, ...addedChildNodes);\n\n    this.resetChildNodesParentNode(removedChildNodes);\n\n    this.setChildNodesParentNode(addedChildNodes);\n\n    return removedChildNodes;\n  }\n\n  setChildNodesParentNode(childNodes) {\n    if (childNodes === undefined) {\n      childNodes = [\n        ...this.childNodes\n      ];\n    }\n\n    const parentNode = this;\n\n    childNodes.forEach((childNode) => {\n      childNode.setParentNode(parentNode);\n    });\n  }\n\n  resetChildNodesParentNode(childNodes) {\n    if (childNodes === undefined) {\n      childNodes = [\n        ...this.childNodes\n      ];\n    }\n\n    const parentNode = null;\n\n    childNodes.forEach((childNode) => {\n      childNode.setParentNode(parentNode);\n    });\n  }\n\n  match(node, depth = Infinity, exactly = false) {\n    let matches = false;\n\n    const nodeNonTerminalNode = node.isNonTerminalNode();\n\n    if (nodeNonTerminalNode) {\n      const nonTerminalNode = node, ///\n            nonTerminalNodeRuleName = nonTerminalNode.getRuleName();\n\n      if (this.ruleName === nonTerminalNodeRuleName) {\n        const nonTerminalNodeOpacity = nonTerminalNode.getOpacity();\n\n        if (this.opacity === nonTerminalNodeOpacity) {\n          const precedence = this.getPrecedence(),\n                nonTerminalNodePrecedence = nonTerminalNode.getPrecedence();\n\n          if (precedence === nonTerminalNodePrecedence) {\n            depth--;\n\n            if (depth === 0) {\n              matches = true;\n            } else {\n              const nonTerminalNodeChildNodes = nonTerminalNode.getChildNodes();\n\n              matches = match(this.childNodes, nonTerminalNodeChildNodes, (childNode, nonTerminalNodeChildNode) => {\n                const childNodeMatchesNonTerminalNodeChildNode = childNode.match(nonTerminalNodeChildNode, depth, exactly);\n\n                if (childNodeMatchesNonTerminalNodeChildNode) {\n                  return true;\n                }\n              });\n            }\n          }\n        }\n      }\n    }\n\n    return matches;\n  }\n\n  rewrite() {\n    const rewrittenNonTerminalNode = null;\n\n    return rewrittenNonTerminalNode;\n  }\n\n  asParseTree(tokens) {\n    const nonTerminalNode = this,  ///\n          nonTerminalNodeParseTree = NonTerminalNodeParseTree.fromNonTerminalNodeAndTokens(nonTerminalNode, tokens),\n          parseTree = nonTerminalNodeParseTree;  ///\n\n    return parseTree;\n  }\n\n  clone(...remainingArguments) {\n    const Class = this.constructor,\n          parentNode = null,\n          ruleName = this.ruleName,\n          childNodes = cloneChildNodes(this.childNodes),\n          opacity = this.opacity,\n          precedence = this.precedence,\n          nonTerminalNode = new Class(ruleName, parentNode, childNodes, opacity, precedence, ...remainingArguments);\n\n    nonTerminalNode.setChildNodesParentNode();\n\n    return nonTerminalNode;\n  }\n\n  static fromRuleNameChildNodesAndOpacity(Class, ruleName, childNodes, opacity, ...remainingArguments) {\n    if (opacity === undefined) {\n      opacity = childNodes; ///\n\n      childNodes = ruleName;  ///\n\n      ruleName = Class; ///\n\n      Class = NonTerminalNode;  ///\n    }\n\n    const parentNode = null,\n          precedence = null,\n          nonTerminalNode = new Class(ruleName, parentNode, childNodes, opacity, precedence, ...remainingArguments);\n\n    nonTerminalNode.setChildNodesParentNode();\n\n    return nonTerminalNode;\n  }\n}\n\nfunction cloneChildNodes(childNodes) {\n  childNodes = childNodes.map((childNode) => {  ///\n    childNode = childNode.clone();  ///\n\n    return childNode;\n  });\n\n  return childNodes;\n}\n"],"names":["NonTerminalNode","first","arrayUtilities","match","forwardsSome","backwardsSome","opaque","opaqueSpecialSymbol","specialSymbols","semiOpaque","semiOpaqueSpecialSymbol","ruleName","parentNode","childNodes","opacity","precedence","getRuleName","getParentNode","getChildNodes","getOpacity","getPrecedence","setRuleName","setChildNodes","start","deleteCount","Infinity","addedChildNodes","spliceChildNodes","setParentNode","setPrecedence","setOpacity","isOpaque","isSemiOpaque","isTransparent","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","getFirstSignificantTokenIndex","tokens","firstSignificantTokenIndex","childNode","node","getLastSignificantTokenIndex","lastSignificantTokenIndex","getSignificantTokens","significantTokens","forEach","getAncestorNodes","ancestorNodes","ancestorNode","push","getMultiplicity","childNodesLength","length","multiplicity","isEmpty","empty","isSingular","singular","isLowerPrecedence","lowerPrecedence","firstChildNode","isUnprecedented","unprecedented","some","childNodeLowerPrecedence","isIncludedIn","includedIn","nodeNonTerminalNode","includedInChildNode","mapChildNode","callback","map","someChildNode","everyChildNode","every","reduceChildNode","initialValue","reduce","forEachChildNode","addChildNode","addedChildNode","offset","addChildNodes","removeChildNode","removedChildNode","removedChildNodes","removeChildNodes","undefined","removedChildNodesLength","firstReplacedChildNode","firstIndex","indexOf","replaceChildNode","replacedChildNode","replacementChildNodes","replacedChildNodes","replaceChildNodes","replacedChildNodesLength","splice","resetChildNodesParentNode","setChildNodesParentNode","depth","exactly","matches","nonTerminalNodeRuleName","nonTerminalNodeOpacity","nonTerminalNodePrecedence","nonTerminalNodeChildNodes","nonTerminalNodeChildNode","childNodeMatchesNonTerminalNodeChildNode","rewrite","rewrittenNonTerminalNode","asParseTree","nonTerminalNodeParseTree","NonTerminalNodeParseTree","fromNonTerminalNodeAndTokens","parseTree","clone","remainingArguments","Class","constructor","cloneChildNodes","fromRuleNameChildNodesAndOpacity"],"mappings":"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"}
|
package/package.json
CHANGED
package/src/node/nonTerminal.js
CHANGED
|
@@ -42,11 +42,11 @@ export default class NonTerminalNode {
|
|
|
42
42
|
}
|
|
43
43
|
|
|
44
44
|
setChildNodes(childNodes) {
|
|
45
|
-
|
|
45
|
+
const start = 0,
|
|
46
|
+
deleteCount = Infinity,
|
|
47
|
+
addedChildNodes = childNodes; ///
|
|
46
48
|
|
|
47
|
-
this.
|
|
48
|
-
|
|
49
|
-
this.setChildNodesParentNode();
|
|
49
|
+
this.spliceChildNodes(start, deleteCount, addedChildNodes);
|
|
50
50
|
}
|
|
51
51
|
|
|
52
52
|
setParentNode(parentNode) {
|
|
@@ -91,31 +91,6 @@ export default class NonTerminalNode {
|
|
|
91
91
|
return nonTerminalNode;
|
|
92
92
|
}
|
|
93
93
|
|
|
94
|
-
isSingular() {
|
|
95
|
-
const childNodesLength = this.childNodes.length,
|
|
96
|
-
singular = (childNodesLength === 1);
|
|
97
|
-
|
|
98
|
-
return singular;
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
isLowerPrecedence(ruleName, precedence) {
|
|
102
|
-
let lowerPrecedence;
|
|
103
|
-
|
|
104
|
-
if (false) {
|
|
105
|
-
///
|
|
106
|
-
} else if (this.precedence === null) {
|
|
107
|
-
lowerPrecedence = false;
|
|
108
|
-
} else if (this.precedence === Infinity) {
|
|
109
|
-
const firstChildNode = first(this.childNodes);
|
|
110
|
-
|
|
111
|
-
lowerPrecedence = firstChildNode.isLowerPrecedence(ruleName, precedence);
|
|
112
|
-
} else {
|
|
113
|
-
lowerPrecedence = ((this.ruleName === ruleName) && (this.precedence < precedence));
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
return lowerPrecedence;
|
|
117
|
-
}
|
|
118
|
-
|
|
119
94
|
getFirstSignificantTokenIndex(tokens) {
|
|
120
95
|
let firstSignificantTokenIndex;
|
|
121
96
|
|
|
@@ -172,6 +147,45 @@ export default class NonTerminalNode {
|
|
|
172
147
|
return ancestorNodes;
|
|
173
148
|
}
|
|
174
149
|
|
|
150
|
+
getMultiplicity() {
|
|
151
|
+
const childNodesLength = this.childNodes.length,
|
|
152
|
+
multiplicity = childNodesLength; ///
|
|
153
|
+
|
|
154
|
+
return multiplicity;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
isEmpty() {
|
|
158
|
+
const multiplicity = this.getMultiplicity(),
|
|
159
|
+
empty = (multiplicity === 0);
|
|
160
|
+
|
|
161
|
+
return empty;
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
isSingular() {
|
|
165
|
+
const multiplicity = this.getMultiplicity(),
|
|
166
|
+
singular = (multiplicity === 1);
|
|
167
|
+
|
|
168
|
+
return singular;
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
isLowerPrecedence(ruleName, precedence) {
|
|
172
|
+
let lowerPrecedence;
|
|
173
|
+
|
|
174
|
+
if (false) {
|
|
175
|
+
///
|
|
176
|
+
} else if (this.precedence === null) {
|
|
177
|
+
lowerPrecedence = false;
|
|
178
|
+
} else if (this.precedence === Infinity) {
|
|
179
|
+
const firstChildNode = first(this.childNodes);
|
|
180
|
+
|
|
181
|
+
lowerPrecedence = firstChildNode.isLowerPrecedence(ruleName, precedence);
|
|
182
|
+
} else {
|
|
183
|
+
lowerPrecedence = ((this.ruleName === ruleName) && (this.precedence < precedence));
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
return lowerPrecedence;
|
|
187
|
+
}
|
|
188
|
+
|
|
175
189
|
isUnprecedented() {
|
|
176
190
|
let unprecedented = false;
|
|
177
191
|
|
|
@@ -213,13 +227,6 @@ export default class NonTerminalNode {
|
|
|
213
227
|
return includedIn;
|
|
214
228
|
}
|
|
215
229
|
|
|
216
|
-
isEmpty() {
|
|
217
|
-
const childNodesLength = this.childNodes.length,
|
|
218
|
-
empty = (childNodesLength === 0);
|
|
219
|
-
|
|
220
|
-
return empty;
|
|
221
|
-
}
|
|
222
|
-
|
|
223
230
|
mapChildNode(callback) { return this.childNodes.map(callback); }
|
|
224
231
|
|
|
225
232
|
someChildNode(callback) { return this.childNodes.some(callback); }
|
|
@@ -230,52 +237,6 @@ export default class NonTerminalNode {
|
|
|
230
237
|
|
|
231
238
|
forEachChildNode(callback) { this.childNodes.forEach(callback); }
|
|
232
239
|
|
|
233
|
-
match(node, depth = Infinity, exactly = false) {
|
|
234
|
-
let matches = false;
|
|
235
|
-
|
|
236
|
-
const nodeNonTerminalNode = node.isNonTerminalNode();
|
|
237
|
-
|
|
238
|
-
if (nodeNonTerminalNode) {
|
|
239
|
-
const nonTerminalNode = node, ///
|
|
240
|
-
nonTerminalNodeRuleName = nonTerminalNode.getRuleName();
|
|
241
|
-
|
|
242
|
-
if (this.ruleName === nonTerminalNodeRuleName) {
|
|
243
|
-
const nonTerminalNodeOpacity = nonTerminalNode.getOpacity();
|
|
244
|
-
|
|
245
|
-
if (this.opacity === nonTerminalNodeOpacity) {
|
|
246
|
-
const precedence = this.getPrecedence(),
|
|
247
|
-
nonTerminalNodePrecedence = nonTerminalNode.getPrecedence();
|
|
248
|
-
|
|
249
|
-
if (precedence === nonTerminalNodePrecedence) {
|
|
250
|
-
depth--;
|
|
251
|
-
|
|
252
|
-
if (depth === 0) {
|
|
253
|
-
matches = true;
|
|
254
|
-
} else {
|
|
255
|
-
const nonTerminalNodeChildNodes = nonTerminalNode.getChildNodes();
|
|
256
|
-
|
|
257
|
-
matches = match(this.childNodes, nonTerminalNodeChildNodes, (childNode, nonTerminalNodeChildNode) => {
|
|
258
|
-
const childNodeMatchesNonTerminalNodeChildNode = childNode.match(nonTerminalNodeChildNode, depth, exactly);
|
|
259
|
-
|
|
260
|
-
if (childNodeMatchesNonTerminalNodeChildNode) {
|
|
261
|
-
return true;
|
|
262
|
-
}
|
|
263
|
-
});
|
|
264
|
-
}
|
|
265
|
-
}
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
}
|
|
269
|
-
|
|
270
|
-
return matches;
|
|
271
|
-
}
|
|
272
|
-
|
|
273
|
-
rewrite() {
|
|
274
|
-
const rewrittenNonTerminalNode = null;
|
|
275
|
-
|
|
276
|
-
return rewrittenNonTerminalNode;
|
|
277
|
-
}
|
|
278
|
-
|
|
279
240
|
addChildNode(addedChildNode, offset) {
|
|
280
241
|
const addedChildNodes = [
|
|
281
242
|
addedChildNode
|
|
@@ -288,9 +249,7 @@ export default class NonTerminalNode {
|
|
|
288
249
|
const start = offset, ///
|
|
289
250
|
deleteCount = 0;
|
|
290
251
|
|
|
291
|
-
this.
|
|
292
|
-
|
|
293
|
-
this.setChildNodesParentNode(addedChildNodes);
|
|
252
|
+
this.spliceChildNodes(start, deleteCount, ...addedChildNodes);
|
|
294
253
|
}
|
|
295
254
|
|
|
296
255
|
removeChildNode(removedChildNode) {
|
|
@@ -321,11 +280,10 @@ export default class NonTerminalNode {
|
|
|
321
280
|
const firstReplacedChildNode = first(removedChildNodes),
|
|
322
281
|
firstIndex = this.childNodes.indexOf(firstReplacedChildNode),
|
|
323
282
|
start = firstIndex, ///
|
|
324
|
-
deleteCount = removedChildNodesLength
|
|
283
|
+
deleteCount = removedChildNodesLength, ///
|
|
284
|
+
addedChildNodes = [];
|
|
325
285
|
|
|
326
|
-
this.
|
|
327
|
-
|
|
328
|
-
this.resetChildNodesParentNode(removedChildNodes);
|
|
286
|
+
removedChildNodes = this.spliceChildNodes(start, deleteCount, addedChildNodes);
|
|
329
287
|
|
|
330
288
|
return removedChildNodes;
|
|
331
289
|
}
|
|
@@ -345,11 +303,17 @@ export default class NonTerminalNode {
|
|
|
345
303
|
start = firstIndex, ///
|
|
346
304
|
deleteCount = replacedChildNodesLength; ///
|
|
347
305
|
|
|
348
|
-
this.
|
|
306
|
+
this.spliceChildNodes(start, deleteCount, replacementChildNodes);
|
|
307
|
+
}
|
|
349
308
|
|
|
350
|
-
|
|
309
|
+
spliceChildNodes(start, deleteCount, addedChildNodes) {
|
|
310
|
+
const removedChildNodes = this.childNodes.splice(start, deleteCount, ...addedChildNodes);
|
|
351
311
|
|
|
352
|
-
this.
|
|
312
|
+
this.resetChildNodesParentNode(removedChildNodes);
|
|
313
|
+
|
|
314
|
+
this.setChildNodesParentNode(addedChildNodes);
|
|
315
|
+
|
|
316
|
+
return removedChildNodes;
|
|
353
317
|
}
|
|
354
318
|
|
|
355
319
|
setChildNodesParentNode(childNodes) {
|
|
@@ -380,6 +344,52 @@ export default class NonTerminalNode {
|
|
|
380
344
|
});
|
|
381
345
|
}
|
|
382
346
|
|
|
347
|
+
match(node, depth = Infinity, exactly = false) {
|
|
348
|
+
let matches = false;
|
|
349
|
+
|
|
350
|
+
const nodeNonTerminalNode = node.isNonTerminalNode();
|
|
351
|
+
|
|
352
|
+
if (nodeNonTerminalNode) {
|
|
353
|
+
const nonTerminalNode = node, ///
|
|
354
|
+
nonTerminalNodeRuleName = nonTerminalNode.getRuleName();
|
|
355
|
+
|
|
356
|
+
if (this.ruleName === nonTerminalNodeRuleName) {
|
|
357
|
+
const nonTerminalNodeOpacity = nonTerminalNode.getOpacity();
|
|
358
|
+
|
|
359
|
+
if (this.opacity === nonTerminalNodeOpacity) {
|
|
360
|
+
const precedence = this.getPrecedence(),
|
|
361
|
+
nonTerminalNodePrecedence = nonTerminalNode.getPrecedence();
|
|
362
|
+
|
|
363
|
+
if (precedence === nonTerminalNodePrecedence) {
|
|
364
|
+
depth--;
|
|
365
|
+
|
|
366
|
+
if (depth === 0) {
|
|
367
|
+
matches = true;
|
|
368
|
+
} else {
|
|
369
|
+
const nonTerminalNodeChildNodes = nonTerminalNode.getChildNodes();
|
|
370
|
+
|
|
371
|
+
matches = match(this.childNodes, nonTerminalNodeChildNodes, (childNode, nonTerminalNodeChildNode) => {
|
|
372
|
+
const childNodeMatchesNonTerminalNodeChildNode = childNode.match(nonTerminalNodeChildNode, depth, exactly);
|
|
373
|
+
|
|
374
|
+
if (childNodeMatchesNonTerminalNodeChildNode) {
|
|
375
|
+
return true;
|
|
376
|
+
}
|
|
377
|
+
});
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
}
|
|
381
|
+
}
|
|
382
|
+
}
|
|
383
|
+
|
|
384
|
+
return matches;
|
|
385
|
+
}
|
|
386
|
+
|
|
387
|
+
rewrite() {
|
|
388
|
+
const rewrittenNonTerminalNode = null;
|
|
389
|
+
|
|
390
|
+
return rewrittenNonTerminalNode;
|
|
391
|
+
}
|
|
392
|
+
|
|
383
393
|
asParseTree(tokens) {
|
|
384
394
|
const nonTerminalNode = this, ///
|
|
385
395
|
nonTerminalNodeParseTree = NonTerminalNodeParseTree.fromNonTerminalNodeAndTokens(nonTerminalNode, tokens),
|