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.
@@ -142,9 +142,8 @@ var NonTerminalNode = /*#__PURE__*/ function() {
142
142
  {
143
143
  key: "setChildNodes",
144
144
  value: function setChildNodes(childNodes) {
145
- this.resetChildNodesParentNode();
146
- this.childNodes = childNodes;
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
- (_this_childNodes = this.childNodes).splice.apply(_this_childNodes, [
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.childNodes.splice(start, deleteCount);
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
- (_this_childNodes = this.childNodes).splice.apply(_this_childNodes, [
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(replacementChildNodes)));
458
- this.resetChildNodesParentNode(replacedChildNodes);
459
- this.setChildNodesParentNode(replacementChildNodes);
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":"AAAA;;;;;;;eAUqBA;;;yBARU;2BACA;sEAEM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAErC,IAAQC,QAA8CC,yBAAc,CAA5DD,OAAOE,QAAuCD,yBAAc,CAArDC,OAAOC,eAAgCF,yBAAc,CAA9CE,cAAcC,gBAAkBH,yBAAc,CAAhCG,eAC5BC,AAAQC,sBAA8DC,2BAAc,CAApFF,QAA8BG,AAAYC,0BAA4BF,2BAAc,CAAtDC;AAEvB,IAAA,AAAMT,gCAAN;aAAMA,gBACPW,QAAQ,EAAEC,UAAU,EAAEC,UAAU,EAAEC,OAAO,EAAEC,UAAU;gCAD9Cf;QAEjB,IAAI,CAACW,QAAQ,GAAGA;QAChB,IAAI,CAACC,UAAU,GAAGA;QAClB,IAAI,CAACC,UAAU,GAAGA;QAClB,IAAI,CAACC,OAAO,GAAGA;QACf,IAAI,CAACC,UAAU,GAAGA;;kBANDf;;YASnBgB,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACL,QAAQ;YACtB;;;YAEAM,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACL,UAAU;YACxB;;;YAEAM,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACL,UAAU;YACxB;;;YAEAM,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACL,OAAO;YACrB;;;YAEAM,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACL,UAAU;YACxB;;;YAEAM,KAAAA;mBAAAA,SAAAA,YAAYV,QAAQ;gBAClB,IAAI,CAACA,QAAQ,GAAGA;YAClB;;;YAEAW,KAAAA;mBAAAA,SAAAA,cAAcT,UAAU;gBACtB,IAAMU,QAAQ,GACRC,cAAcC,UACdC,kBAAkBb,YAAa,GAAG;gBAExC,IAAI,CAACc,gBAAgB,CAACJ,OAAOC,aAAaE;YAC5C;;;YAEAE,KAAAA;mBAAAA,SAAAA,cAAchB,UAAU;gBACtB,IAAI,CAACA,UAAU,GAAGA;YACpB;;;YAEAiB,KAAAA;mBAAAA,SAAAA,cAAcd,UAAU;gBACtB,IAAI,CAACA,UAAU,GAAGA;YACpB;;;YAEAe,KAAAA;mBAAAA,SAAAA,WAAWhB,OAAO;gBAChB,IAAI,CAACA,OAAO,GAAGA;YACjB;;;YAEAiB,KAAAA;mBAAAA,SAAAA;gBACE,IAAMzB,SAAU,IAAI,CAACQ,OAAO,KAAKP;gBAEjC,OAAOD;YACT;;;YAEA0B,KAAAA;mBAAAA,SAAAA;gBACE,IAAMvB,aAAc,IAAI,CAACK,OAAO,KAAKJ;gBAErC,OAAOD;YACT;;;YAEAwB,KAAAA;mBAAAA,SAAAA;gBACE,IAAMxB,aAAc,IAAI,CAACK,OAAO,KAAK;gBAErC,OAAOL;YACT;;;YAEAyB,KAAAA;mBAAAA,SAAAA;gBACE,IAAMC,eAAe;gBAErB,OAAOA;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA;gBACE,IAAMC,kBAAkB;gBAExB,OAAOA;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA,8BAA8BC,MAAM;gBAClC,IAAIC;gBAEJpC,aAAa,IAAI,CAACS,UAAU,EAAE,SAAC4B;oBAC7B,IAAMC,OAAOD,WAAW,GAAG;oBAE3BD,6BAA6BE,KAAKJ,6BAA6B,CAACC;oBAEhE,IAAIC,+BAA+B,MAAM;wBACvC,OAAO;oBACT;gBACF;gBAEA,OAAOA;YACT;;;YAEAG,KAAAA;mBAAAA,SAAAA,6BAA6BJ,MAAM;gBACjC,IAAIK;gBAEJvC,cAAc,IAAI,CAACQ,UAAU,EAAE,SAAC4B;oBAC9B,IAAMC,OAAOD,WAAW,GAAG;oBAE3BG,4BAA4BF,KAAKC,4BAA4B,CAACJ;oBAE9D,IAAIK,8BAA8B,MAAM;wBACtC,OAAO;oBACT;gBACF;gBAEA,OAAOA;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA;oBAAqBC,oBAAAA,iEAAoB,EAAE;gBACzC,IAAI,CAACjC,UAAU,CAACkC,OAAO,CAAC,SAACN;oBACvBA,UAAUI,oBAAoB,CAACC;gBACjC;gBAEA,OAAOA;YACT;;;YAEAE,KAAAA;mBAAAA,SAAAA;gBACE,IAAMC,gBAAgB,EAAE;gBAExB,IAAIrC,aAAa,IAAI,CAACA,UAAU;gBAEhC,MAAOA,eAAe,KAAM;oBAC1B,IAAMsC,eAAetC,YAAa,GAAG;oBAErCqC,cAAcE,IAAI,CAACD;oBAEnBtC,aAAaA,WAAWK,aAAa;gBACvC;gBAEA,OAAOgC;YACT;;;YAEAG,KAAAA;mBAAAA,SAAAA;gBACE,IAAMC,mBAAmB,IAAI,CAACxC,UAAU,CAACyC,MAAM,EACzCC,eAAeF,kBAAmB,GAAG;gBAE3C,OAAOE;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA;gBACE,IAAMD,eAAe,IAAI,CAACH,eAAe,IACnCK,QAASF,iBAAiB;gBAEhC,OAAOE;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA;gBACE,IAAMH,eAAe,IAAI,CAACH,eAAe,IACnCO,WAAYJ,iBAAiB;gBAEnC,OAAOI;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA,kBAAkBjD,QAAQ,EAAEI,UAAU;gBACpC,IAAI8C;gBAEJ,IAAI,OAAO;gBACT,GAAG;gBACL,OAAO,IAAI,IAAI,CAAC9C,UAAU,KAAK,MAAM;oBACnC8C,kBAAkB;gBACpB,OAAO,IAAI,IAAI,CAAC9C,UAAU,KAAKU,UAAU;oBACvC,IAAMqC,iBAAiB7D,MAAM,IAAI,CAACY,UAAU;oBAE5CgD,kBAAkBC,eAAeF,iBAAiB,CAACjD,UAAUI;gBAC/D,OAAO;oBACL8C,kBAAmB,AAAC,IAAI,CAAClD,QAAQ,KAAKA,YAAc,IAAI,CAACI,UAAU,GAAGA;gBACxE;gBAEA,OAAO8C;YACT;;;YAEAE,KAAAA;mBAAAA,SAAAA;;gBACE,IAAIC,gBAAgB;gBAEpB,IAAI,IAAI,CAACjD,UAAU,KAAK,MAAM;oBAC5BiD,gBAAgB,IAAI,CAACnD,UAAU,CAACoD,IAAI,CAAC,SAACxB;wBACpC,IAAMyB,2BAA2BzB,UAAUmB,iBAAiB,CAAC,MAAKjD,QAAQ,EAAE,MAAKI,UAAU;wBAE3F,IAAImD,0BAA0B;4BAC5B,OAAO;wBACT;oBACF;gBACF;gBAEA,OAAOF;YACT;;;YAEAG,KAAAA;mBAAAA,SAAAA,aAAazB,IAAI;;gBACf,IAAI0B,aAAa;gBAEjB,IAAI,IAAI,KAAK1B,MAAM;oBACjB0B,aAAa;gBACf,OAAO;oBACL,IAAMC,sBAAsB3B,KAAKN,iBAAiB;oBAElD,IAAIiC,qBAAqB;wBACvB,IAAMhC,kBAAkBK,MAClB7B,aAAawB,gBAAgBnB,aAAa;wBAEhDkD,aAAavD,WAAWoD,IAAI,CAAC,SAACxB;4BAC5B,IAAM6B,sBAAsB,MAAKH,YAAY,CAAC1B;4BAE9C,IAAI6B,qBAAqB;gCACvB,OAAO;4BACT;wBACF;oBACF;gBACF;gBAEA,OAAOF;YACT;;;YAEAG,KAAAA;mBAAAA,SAAAA,aAAaC,QAAQ;gBAAI,OAAO,IAAI,CAAC3D,UAAU,CAAC4D,GAAG,CAACD;YAAW;;;YAE/DE,KAAAA;mBAAAA,SAAAA,cAAcF,QAAQ;gBAAI,OAAO,IAAI,CAAC3D,UAAU,CAACoD,IAAI,CAACO;YAAW;;;YAEjEG,KAAAA;mBAAAA,SAAAA,eAAeH,QAAQ;gBAAI,OAAO,IAAI,CAAC3D,UAAU,CAAC+D,KAAK,CAACJ;YAAW;;;YAEnEK,KAAAA;mBAAAA,SAAAA,gBAAgBL,QAAQ,EAAEM,YAAY;gBAAI,OAAO,IAAI,CAACjE,UAAU,CAACkE,MAAM,CAACP,UAAUM;YAAe;;;YAEjGE,KAAAA;mBAAAA,SAAAA,iBAAiBR,QAAQ;gBAAI,IAAI,CAAC3D,UAAU,CAACkC,OAAO,CAACyB;YAAW;;;YAEhES,KAAAA;mBAAAA,SAAAA,aAAaC,cAAc,EAAEC,MAAM;gBACjC,IAAMzD,kBAAkB;oBACpBwD;iBACH;gBAED,IAAI,CAACE,aAAa,CAAC1D,iBAAiByD;YACtC;;;YAEAC,KAAAA;mBAAAA,SAAAA,cAAc1D,eAAe,EAAEyD,MAAM;gBACnC,IAAM5D,QAAQ4D,QACR3D,cAAc;gBAEpB,IAAI,CAACG,gBAAgB,OAArB,IAAI,EAAJ;oBAAsBJ;oBAAOC;iBAAgC,CAA7D,OAA0C,qBAAGE;YAC/C;;;YAEA2D,KAAAA;mBAAAA,SAAAA,gBAAgBC,gBAAgB;gBAC9B,IAAIC;gBAEJA,oBAAoB;oBAClBD;iBACD;gBAEDC,oBAAoB,IAAI,CAACC,gBAAgB,CAACD;gBAE1C,OAAOA;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA,iBAAiBD,iBAAiB;gBAChC,IAAIA,sBAAsBE,WAAW;oBACnCF,oBACE,qBAAG,IAAI,CAAC1E,UAAU;gBAEtB;gBAEA,IAAM6E,0BAA0BH,kBAAkBjC,MAAM;gBAExD,IAAIoC,4BAA4B,GAAG;oBACjC;gBACF;gBAEA,IAAMC,yBAAyB1F,MAAMsF,oBAC/BK,aAAa,IAAI,CAAC/E,UAAU,CAACgF,OAAO,CAACF,yBACrCpE,QAAQqE,YACRpE,cAAckE,yBACdhE,kBAAkB,EAAE;gBAE1B6D,oBAAoB,IAAI,CAAC5D,gBAAgB,CAACJ,OAAOC,aAAaE;gBAE9D,OAAO6D;YACT;;;YAEAO,KAAAA;mBAAAA,SAAAA,iBAAiBC,iBAAiB,EAAEC,qBAAqB;gBACvD,IAAMC,qBAAqB;oBACzBF;iBACD;gBAED,IAAI,CAACG,iBAAiB,CAACD,oBAAoBD;YAC7C;;;YAEAE,KAAAA;mBAAAA,SAAAA,kBAAkBD,kBAAkB,EAAED,qBAAqB;gBACzD,IAAMG,2BAA2BF,mBAAmB3C,MAAM,EACpDqC,yBAAyB1F,MAAMgG,qBAC/BL,aAAa,IAAI,CAAC/E,UAAU,CAACgF,OAAO,CAACF,yBACrCpE,QAAQqE,YACRpE,cAAc2E,0BAA0B,GAAG;gBAEjD,IAAI,CAACxE,gBAAgB,CAACJ,OAAOC,aAAawE;YAC5C;;;YAEArE,KAAAA;mBAAAA,SAAAA,iBAAiBJ,KAAK,EAAEC,WAAW,EAAEE,eAAe;oBACxB;gBAA1B,IAAM6D,oBAAoB,CAAA,mBAAA,IAAI,CAAC1E,UAAU,EAACuF,MAAM,OAAtB,kBAAA;oBAAuB7E;oBAAOC;iBAAgC,CAA9D,OAA2C,qBAAGE;gBAExE,IAAI,CAAC2E,yBAAyB,CAACd;gBAE/B,IAAI,CAACe,uBAAuB,CAAC5E;gBAE7B,OAAO6D;YACT;;;YAEAe,KAAAA;mBAAAA,SAAAA,wBAAwBzF,UAAU;gBAChC,IAAIA,eAAe4E,WAAW;oBAC5B5E,aACE,qBAAG,IAAI,CAACA,UAAU;gBAEtB;gBAEA,IAAMD,aAAa,IAAI;gBAEvBC,WAAWkC,OAAO,CAAC,SAACN;oBAClBA,UAAUb,aAAa,CAAChB;gBAC1B;YACF;;;YAEAyF,KAAAA;mBAAAA,SAAAA,0BAA0BxF,UAAU;gBAClC,IAAIA,eAAe4E,WAAW;oBAC5B5E,aACE,qBAAG,IAAI,CAACA,UAAU;gBAEtB;gBAEA,IAAMD,aAAa;gBAEnBC,WAAWkC,OAAO,CAAC,SAACN;oBAClBA,UAAUb,aAAa,CAAChB;gBAC1B;YACF;;;YAEAT,KAAAA;mBAAAA,SAAAA,OAAMuC,IAAI;oBAAE6D,QAAAA,iEAAQ9E,UAAU+E,UAAAA,iEAAU;gBACtC,IAAIC,UAAU;gBAEd,IAAMpC,sBAAsB3B,KAAKN,iBAAiB;gBAElD,IAAIiC,qBAAqB;oBACvB,IAAMhC,kBAAkBK,MAClBgE,0BAA0BrE,gBAAgBrB,WAAW;oBAE3D,IAAI,IAAI,CAACL,QAAQ,KAAK+F,yBAAyB;wBAC7C,IAAMC,yBAAyBtE,gBAAgBlB,UAAU;wBAEzD,IAAI,IAAI,CAACL,OAAO,KAAK6F,wBAAwB;4BAC3C,IAAM5F,aAAa,IAAI,CAACK,aAAa,IAC/BwF,4BAA4BvE,gBAAgBjB,aAAa;4BAE/D,IAAIL,eAAe6F,2BAA2B;gCAC5CL;gCAEA,IAAIA,UAAU,GAAG;oCACfE,UAAU;gCACZ,OAAO;oCACL,IAAMI,4BAA4BxE,gBAAgBnB,aAAa;oCAE/DuF,UAAUtG,MAAM,IAAI,CAACU,UAAU,EAAEgG,2BAA2B,SAACpE,WAAWqE;wCACtE,IAAMC,2CAA2CtE,UAAUtC,KAAK,CAAC2G,0BAA0BP,OAAOC;wCAElG,IAAIO,0CAA0C;4CAC5C,OAAO;wCACT;oCACF;gCACF;4BACF;wBACF;oBACF;gBACF;gBAEA,OAAON;YACT;;;YAEAO,KAAAA;mBAAAA,SAAAA;gBACE,IAAMC,2BAA2B;gBAEjC,OAAOA;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA,YAAY3E,MAAM;gBAChB,IAAMF,kBAAkB,IAAI,EACtB8E,2BAA2BC,wBAAwB,CAACC,4BAA4B,CAAChF,iBAAiBE,SAClG+E,YAAYH,0BAA2B,GAAG;gBAEhD,OAAOG;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA;gBAAM,IAAA,IAAA,OAAA,UAAA,QAAA,AAAGC,qBAAH,UAAA,OAAA,OAAA,GAAA,OAAA,MAAA;oBAAGA,mBAAH,QAAA,SAAA,CAAA,KAAqB;;gBACzB,IAAMC,QAAQ,IAAI,CAACC,WAAW,EACxB9G,aAAa,MACbD,WAAW,IAAI,CAACA,QAAQ,EACxBE,aAAa8G,gBAAgB,IAAI,CAAC9G,UAAU,GAC5CC,UAAU,IAAI,CAACA,OAAO,EACtBC,aAAa,IAAI,CAACA,UAAU,EAC5BsB,kBAAkB,WAAIoF,OAAJ;oBAAU9G;oBAAUC;oBAAYC;oBAAYC;oBAASC;iBAAkC,CAAvF,OAAiE,qBAAGyG;gBAE5FnF,gBAAgBiE,uBAAuB;gBAEvC,OAAOjE;YACT;;;;YAEOuF,KAAAA;mBAAP,SAAOA,iCAAiCH,KAAK,EAAE9G,QAAQ,EAAEE,UAAU,EAAEC,OAAO;gBAAE,IAAA,IAAA,OAAA,UAAA,QAAA,AAAG0G,qBAAH,UAAA,OAAA,IAAA,OAAA,QAAA,OAAA,GAAA,OAAA,MAAA;oBAAGA,mBAAH,OAAA,KAAA,SAAA,CAAA,KAAqB;;gBACjG,IAAI1G,YAAY2E,WAAW;oBACzB3E,UAAUD,YAAY,GAAG;oBAEzBA,aAAaF,UAAW,GAAG;oBAE3BA,WAAW8G,OAAO,GAAG;oBAErBA,QA5ZezH,iBA4ZW,GAAG;gBAC/B;gBAEA,IAAMY,aAAa,MACbG,aAAa,MACbsB,kBAAkB,WAAIoF,OAAJ;oBAAU9G;oBAAUC;oBAAYC;oBAAYC;oBAASC;iBAAkC,CAAvF,OAAiE,qBAAGyG;gBAE5FnF,gBAAgBiE,uBAAuB;gBAEvC,OAAOjE;YACT;;;WAtamBrC;;AAyarB,SAAS2H,gBAAgB9G,UAAU;IACjCA,aAAaA,WAAW4D,GAAG,CAAC,SAAChC;QAC3BA,YAAYA,UAAU8E,KAAK,IAAK,GAAG;QAEnC,OAAO9E;IACT;IAEA,OAAO5B;AACT"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "occam-parsers",
3
3
  "author": "James Smith",
4
- "version": "23.0.86",
4
+ "version": "23.0.88",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/occam-parsers",
7
7
  "description": "Occam's parsers.",
@@ -42,11 +42,11 @@ export default class NonTerminalNode {
42
42
  }
43
43
 
44
44
  setChildNodes(childNodes) {
45
- this.resetChildNodesParentNode();
45
+ const start = 0,
46
+ deleteCount = Infinity,
47
+ addedChildNodes = childNodes; ///
46
48
 
47
- this.childNodes = childNodes;
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.childNodes.splice(start, deleteCount, ...addedChildNodes);
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.childNodes.splice(start, deleteCount);
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.childNodes.splice(start, deleteCount, ...replacementChildNodes);
306
+ this.spliceChildNodes(start, deleteCount, replacementChildNodes);
307
+ }
349
308
 
350
- this.resetChildNodesParentNode(replacedChildNodes);
309
+ spliceChildNodes(start, deleteCount, addedChildNodes) {
310
+ const removedChildNodes = this.childNodes.splice(start, deleteCount, ...addedChildNodes);
351
311
 
352
- this.setChildNodesParentNode(replacementChildNodes);
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),