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.
@@ -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, addedChildNodes) {
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":"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;oBAAEE,kBAAAA,iEAAkB,EAAE;oBAC7B;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.87",
4
+ "version": "23.0.89",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/occam-parsers",
7
7
  "description": "Occam's parsers.",
@@ -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),