occam-parsers 23.0.87 → 23.0.89
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 +79 -71
- package/lib/node/nonTerminal.js +80 -72
- package/package.json +1 -1
- package/src/node/nonTerminal.js +86 -79
package/lib/node/nonTerminal.js
CHANGED
|
@@ -199,30 +199,6 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
199
199
|
return nonTerminalNode;
|
|
200
200
|
}
|
|
201
201
|
},
|
|
202
|
-
{
|
|
203
|
-
key: "isSingular",
|
|
204
|
-
value: function isSingular() {
|
|
205
|
-
var childNodesLength = this.childNodes.length, singular = childNodesLength === 1;
|
|
206
|
-
return singular;
|
|
207
|
-
}
|
|
208
|
-
},
|
|
209
|
-
{
|
|
210
|
-
key: "isLowerPrecedence",
|
|
211
|
-
value: function isLowerPrecedence(ruleName, precedence) {
|
|
212
|
-
var lowerPrecedence;
|
|
213
|
-
if (false) {
|
|
214
|
-
///
|
|
215
|
-
} else if (this.precedence === null) {
|
|
216
|
-
lowerPrecedence = false;
|
|
217
|
-
} else if (this.precedence === Infinity) {
|
|
218
|
-
var firstChildNode = first(this.childNodes);
|
|
219
|
-
lowerPrecedence = firstChildNode.isLowerPrecedence(ruleName, precedence);
|
|
220
|
-
} else {
|
|
221
|
-
lowerPrecedence = this.ruleName === ruleName && this.precedence < precedence;
|
|
222
|
-
}
|
|
223
|
-
return lowerPrecedence;
|
|
224
|
-
}
|
|
225
|
-
},
|
|
226
202
|
{
|
|
227
203
|
key: "getFirstSignificantTokenIndex",
|
|
228
204
|
value: function getFirstSignificantTokenIndex(tokens) {
|
|
@@ -274,6 +250,44 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
274
250
|
return ancestorNodes;
|
|
275
251
|
}
|
|
276
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
|
+
},
|
|
277
291
|
{
|
|
278
292
|
key: "isUnprecedented",
|
|
279
293
|
value: function isUnprecedented() {
|
|
@@ -312,13 +326,6 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
312
326
|
return includedIn;
|
|
313
327
|
}
|
|
314
328
|
},
|
|
315
|
-
{
|
|
316
|
-
key: "isEmpty",
|
|
317
|
-
value: function isEmpty() {
|
|
318
|
-
var childNodesLength = this.childNodes.length, empty = childNodesLength === 0;
|
|
319
|
-
return empty;
|
|
320
|
-
}
|
|
321
|
-
},
|
|
322
329
|
{
|
|
323
330
|
key: "mapChildNode",
|
|
324
331
|
value: function mapChildNode(callback) {
|
|
@@ -349,45 +356,6 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
349
356
|
this.childNodes.forEach(callback);
|
|
350
357
|
}
|
|
351
358
|
},
|
|
352
|
-
{
|
|
353
|
-
key: "match",
|
|
354
|
-
value: function match1(node) {
|
|
355
|
-
var depth = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : Infinity, exactly = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : false;
|
|
356
|
-
var matches = false;
|
|
357
|
-
var nodeNonTerminalNode = node.isNonTerminalNode();
|
|
358
|
-
if (nodeNonTerminalNode) {
|
|
359
|
-
var nonTerminalNode = node, nonTerminalNodeRuleName = nonTerminalNode.getRuleName();
|
|
360
|
-
if (this.ruleName === nonTerminalNodeRuleName) {
|
|
361
|
-
var nonTerminalNodeOpacity = nonTerminalNode.getOpacity();
|
|
362
|
-
if (this.opacity === nonTerminalNodeOpacity) {
|
|
363
|
-
var precedence = this.getPrecedence(), nonTerminalNodePrecedence = nonTerminalNode.getPrecedence();
|
|
364
|
-
if (precedence === nonTerminalNodePrecedence) {
|
|
365
|
-
depth--;
|
|
366
|
-
if (depth === 0) {
|
|
367
|
-
matches = true;
|
|
368
|
-
} else {
|
|
369
|
-
var nonTerminalNodeChildNodes = nonTerminalNode.getChildNodes();
|
|
370
|
-
matches = match(this.childNodes, nonTerminalNodeChildNodes, function(childNode, nonTerminalNodeChildNode) {
|
|
371
|
-
var childNodeMatchesNonTerminalNodeChildNode = childNode.match(nonTerminalNodeChildNode, depth, exactly);
|
|
372
|
-
if (childNodeMatchesNonTerminalNodeChildNode) {
|
|
373
|
-
return true;
|
|
374
|
-
}
|
|
375
|
-
});
|
|
376
|
-
}
|
|
377
|
-
}
|
|
378
|
-
}
|
|
379
|
-
}
|
|
380
|
-
}
|
|
381
|
-
return matches;
|
|
382
|
-
}
|
|
383
|
-
},
|
|
384
|
-
{
|
|
385
|
-
key: "rewrite",
|
|
386
|
-
value: function rewrite() {
|
|
387
|
-
var rewrittenNonTerminalNode = null;
|
|
388
|
-
return rewrittenNonTerminalNode;
|
|
389
|
-
}
|
|
390
|
-
},
|
|
391
359
|
{
|
|
392
360
|
key: "addChildNode",
|
|
393
361
|
value: function addChildNode(addedChildNode, offset) {
|
|
@@ -451,7 +419,8 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
451
419
|
},
|
|
452
420
|
{
|
|
453
421
|
key: "spliceChildNodes",
|
|
454
|
-
value: function spliceChildNodes(start, deleteCount
|
|
422
|
+
value: function spliceChildNodes(start, deleteCount) {
|
|
423
|
+
var addedChildNodes = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : [];
|
|
455
424
|
var _this_childNodes;
|
|
456
425
|
var removedChildNodes = (_this_childNodes = this.childNodes).splice.apply(_this_childNodes, [
|
|
457
426
|
start,
|
|
@@ -486,6 +455,45 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
486
455
|
});
|
|
487
456
|
}
|
|
488
457
|
},
|
|
458
|
+
{
|
|
459
|
+
key: "match",
|
|
460
|
+
value: function match1(node) {
|
|
461
|
+
var depth = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : Infinity, exactly = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : false;
|
|
462
|
+
var matches = false;
|
|
463
|
+
var nodeNonTerminalNode = node.isNonTerminalNode();
|
|
464
|
+
if (nodeNonTerminalNode) {
|
|
465
|
+
var nonTerminalNode = node, nonTerminalNodeRuleName = nonTerminalNode.getRuleName();
|
|
466
|
+
if (this.ruleName === nonTerminalNodeRuleName) {
|
|
467
|
+
var nonTerminalNodeOpacity = nonTerminalNode.getOpacity();
|
|
468
|
+
if (this.opacity === nonTerminalNodeOpacity) {
|
|
469
|
+
var precedence = this.getPrecedence(), nonTerminalNodePrecedence = nonTerminalNode.getPrecedence();
|
|
470
|
+
if (precedence === nonTerminalNodePrecedence) {
|
|
471
|
+
depth--;
|
|
472
|
+
if (depth === 0) {
|
|
473
|
+
matches = true;
|
|
474
|
+
} else {
|
|
475
|
+
var nonTerminalNodeChildNodes = nonTerminalNode.getChildNodes();
|
|
476
|
+
matches = match(this.childNodes, nonTerminalNodeChildNodes, function(childNode, nonTerminalNodeChildNode) {
|
|
477
|
+
var childNodeMatchesNonTerminalNodeChildNode = childNode.match(nonTerminalNodeChildNode, depth, exactly);
|
|
478
|
+
if (childNodeMatchesNonTerminalNodeChildNode) {
|
|
479
|
+
return true;
|
|
480
|
+
}
|
|
481
|
+
});
|
|
482
|
+
}
|
|
483
|
+
}
|
|
484
|
+
}
|
|
485
|
+
}
|
|
486
|
+
}
|
|
487
|
+
return matches;
|
|
488
|
+
}
|
|
489
|
+
},
|
|
490
|
+
{
|
|
491
|
+
key: "rewrite",
|
|
492
|
+
value: function rewrite() {
|
|
493
|
+
var rewrittenNonTerminalNode = null;
|
|
494
|
+
return rewrittenNonTerminalNode;
|
|
495
|
+
}
|
|
496
|
+
},
|
|
489
497
|
{
|
|
490
498
|
key: "asParseTree",
|
|
491
499
|
value: function asParseTree(tokens) {
|
|
@@ -545,4 +553,4 @@ function cloneChildNodes(childNodes) {
|
|
|
545
553
|
return childNodes;
|
|
546
554
|
}
|
|
547
555
|
|
|
548
|
-
//# 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  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.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  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","isSingular","childNodesLength","length","singular","isLowerPrecedence","lowerPrecedence","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","addChildNodes","removeChildNode","removedChildNode","removedChildNodes","removeChildNodes","undefined","removedChildNodesLength","firstReplacedChildNode","firstIndex","indexOf","replaceChildNode","replacedChildNode","replacementChildNodes","replacedChildNodes","replaceChildNodes","replacedChildNodesLength","splice","resetChildNodesParentNode","setChildNodesParentNode","asParseTree","nonTerminalNodeParseTree","NonTerminalNodeParseTree","fromNonTerminalNodeAndTokens","parseTree","clone","remainingArguments","Class","constructor","cloneChildNodes","fromRuleNameChildNodesAndOpacity"],"mappings":"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"}
|
|
556
|
+
//# 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
|
@@ -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
|
|
@@ -345,7 +306,7 @@ export default class NonTerminalNode {
|
|
|
345
306
|
this.spliceChildNodes(start, deleteCount, replacementChildNodes);
|
|
346
307
|
}
|
|
347
308
|
|
|
348
|
-
spliceChildNodes(start, deleteCount, addedChildNodes) {
|
|
309
|
+
spliceChildNodes(start, deleteCount, addedChildNodes = []) {
|
|
349
310
|
const removedChildNodes = this.childNodes.splice(start, deleteCount, ...addedChildNodes);
|
|
350
311
|
|
|
351
312
|
this.resetChildNodesParentNode(removedChildNodes);
|
|
@@ -383,6 +344,52 @@ export default class NonTerminalNode {
|
|
|
383
344
|
});
|
|
384
345
|
}
|
|
385
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
|
+
|
|
386
393
|
asParseTree(tokens) {
|
|
387
394
|
const nonTerminalNode = this, ///
|
|
388
395
|
nonTerminalNodeParseTree = NonTerminalNodeParseTree.fromNonTerminalNodeAndTokens(nonTerminalNode, tokens),
|