occam-parsers 23.0.89 → 23.0.91

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,8 +142,8 @@ var NonTerminalNode = /*#__PURE__*/ function() {
142
142
  {
143
143
  key: "setChildNodes",
144
144
  value: function setChildNodes(childNodes) {
145
- var start = 0, deleteCount = Infinity, addedChildNodes = childNodes; ///
146
- this.spliceChildNodes(start, deleteCount, addedChildNodes);
145
+ var startIndex = 0, deleteCount = Infinity, addedChildNodes = childNodes; ///
146
+ this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);
147
147
  }
148
148
  },
149
149
  {
@@ -203,7 +203,7 @@ var NonTerminalNode = /*#__PURE__*/ function() {
203
203
  key: "getFirstSignificantTokenIndex",
204
204
  value: function getFirstSignificantTokenIndex(tokens) {
205
205
  var firstSignificantTokenIndex;
206
- forwardsSome(this.childNodes, function(childNode) {
206
+ this.forwardsSomeChildNode(function(childNode) {
207
207
  var node = childNode; ///
208
208
  firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens);
209
209
  if (firstSignificantTokenIndex !== null) {
@@ -217,7 +217,7 @@ var NonTerminalNode = /*#__PURE__*/ function() {
217
217
  key: "getLastSignificantTokenIndex",
218
218
  value: function getLastSignificantTokenIndex(tokens) {
219
219
  var lastSignificantTokenIndex;
220
- backwardsSome(this.childNodes, function(childNode) {
220
+ this.backwardsSomeChildNode(function(childNode) {
221
221
  var node = childNode; ///
222
222
  lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens);
223
223
  if (lastSignificantTokenIndex !== null) {
@@ -356,6 +356,42 @@ var NonTerminalNode = /*#__PURE__*/ function() {
356
356
  this.childNodes.forEach(callback);
357
357
  }
358
358
  },
359
+ {
360
+ key: "forwardsSomeChildNode",
361
+ value: function forwardsSomeChildNode(callback) {
362
+ return forwardsSome(this.childNodes, callback);
363
+ }
364
+ },
365
+ {
366
+ key: "backwardsSomeChildNode",
367
+ value: function backwardsSomeChildNode(callback) {
368
+ return backwardsSome(this.childNodes, callback);
369
+ }
370
+ },
371
+ {
372
+ key: "setChildNodesParentNode",
373
+ value: function setChildNodesParentNode(childNodes) {
374
+ if (childNodes === undefined) {
375
+ childNodes = _to_consumable_array(this.childNodes);
376
+ }
377
+ var parentNode = this;
378
+ childNodes.forEach(function(childNode) {
379
+ childNode.setParentNode(parentNode);
380
+ });
381
+ }
382
+ },
383
+ {
384
+ key: "resetChildNodesParentNode",
385
+ value: function resetChildNodesParentNode(childNodes) {
386
+ if (childNodes === undefined) {
387
+ childNodes = _to_consumable_array(this.childNodes);
388
+ }
389
+ var parentNode = null;
390
+ childNodes.forEach(function(childNode) {
391
+ childNode.setParentNode(parentNode);
392
+ });
393
+ }
394
+ },
359
395
  {
360
396
  key: "addChildNode",
361
397
  value: function addChildNode(addedChildNode, offset) {
@@ -368,9 +404,9 @@ var NonTerminalNode = /*#__PURE__*/ function() {
368
404
  {
369
405
  key: "addChildNodes",
370
406
  value: function addChildNodes(addedChildNodes, offset) {
371
- var start = offset, deleteCount = 0;
407
+ var startIndex = offset, deleteCount = 0;
372
408
  this.spliceChildNodes.apply(this, [
373
- start,
409
+ startIndex,
374
410
  deleteCount
375
411
  ].concat(_to_consumable_array(addedChildNodes)));
376
412
  }
@@ -396,8 +432,8 @@ var NonTerminalNode = /*#__PURE__*/ function() {
396
432
  if (removedChildNodesLength === 0) {
397
433
  return;
398
434
  }
399
- var firstReplacedChildNode = first(removedChildNodes), firstIndex = this.childNodes.indexOf(firstReplacedChildNode), start = firstIndex, deleteCount = removedChildNodesLength, addedChildNodes = [];
400
- removedChildNodes = this.spliceChildNodes(start, deleteCount, addedChildNodes);
435
+ var firstReplacedChildNode = first(removedChildNodes), firstIndex = this.childNodes.indexOf(firstReplacedChildNode), startIndex = firstIndex, deleteCount = removedChildNodesLength, addedChildNodes = [];
436
+ removedChildNodes = this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);
401
437
  return removedChildNodes;
402
438
  }
403
439
  },
@@ -413,17 +449,17 @@ var NonTerminalNode = /*#__PURE__*/ function() {
413
449
  {
414
450
  key: "replaceChildNodes",
415
451
  value: function replaceChildNodes(replacedChildNodes, replacementChildNodes) {
416
- var replacedChildNodesLength = replacedChildNodes.length, firstReplacedChildNode = first(replacedChildNodes), firstIndex = this.childNodes.indexOf(firstReplacedChildNode), start = firstIndex, deleteCount = replacedChildNodesLength; ///
417
- this.spliceChildNodes(start, deleteCount, replacementChildNodes);
452
+ var replacedChildNodesLength = replacedChildNodes.length, firstReplacedChildNode = first(replacedChildNodes), firstIndex = this.childNodes.indexOf(firstReplacedChildNode), startIndex = firstIndex, deleteCount = replacedChildNodesLength; ///
453
+ this.spliceChildNodes(startIndex, deleteCount, replacementChildNodes);
418
454
  }
419
455
  },
420
456
  {
421
457
  key: "spliceChildNodes",
422
- value: function spliceChildNodes(start, deleteCount) {
458
+ value: function spliceChildNodes(startIndex, deleteCount) {
423
459
  var addedChildNodes = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : [];
424
460
  var _this_childNodes;
425
461
  var removedChildNodes = (_this_childNodes = this.childNodes).splice.apply(_this_childNodes, [
426
- start,
462
+ startIndex,
427
463
  deleteCount
428
464
  ].concat(_to_consumable_array(addedChildNodes)));
429
465
  this.resetChildNodesParentNode(removedChildNodes);
@@ -432,27 +468,10 @@ var NonTerminalNode = /*#__PURE__*/ function() {
432
468
  }
433
469
  },
434
470
  {
435
- key: "setChildNodesParentNode",
436
- value: function setChildNodesParentNode(childNodes) {
437
- if (childNodes === undefined) {
438
- childNodes = _to_consumable_array(this.childNodes);
439
- }
440
- var parentNode = this;
441
- childNodes.forEach(function(childNode) {
442
- childNode.setParentNode(parentNode);
443
- });
444
- }
445
- },
446
- {
447
- key: "resetChildNodesParentNode",
448
- value: function resetChildNodesParentNode(childNodes) {
449
- if (childNodes === undefined) {
450
- childNodes = _to_consumable_array(this.childNodes);
451
- }
452
- var parentNode = null;
453
- childNodes.forEach(function(childNode) {
454
- childNode.setParentNode(parentNode);
455
- });
471
+ key: "sliceChildNodes",
472
+ value: function sliceChildNodes(startIndex, endIndex) {
473
+ var childNodes = this.childNodes.slice(startIndex, endIndex);
474
+ return childNodes;
456
475
  }
457
476
  },
458
477
  {
@@ -553,4 +572,4 @@ function cloneChildNodes(childNodes) {
553
572
  return childNodes;
554
573
  }
555
574
 
556
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/node/nonTerminal.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\nimport { specialSymbols } from \"occam-lexers\";\n\nimport NonTerminalNodeParseTree from \"../parseTree/nonTerminalNode\";\n\nconst { first, match, forwardsSome, backwardsSome } = arrayUtilities,\n      { opaque: opaqueSpecialSymbol , semiOpaque: semiOpaqueSpecialSymbol } = specialSymbols;\n\nexport default class NonTerminalNode {\n  constructor(ruleName, parentNode, childNodes, opacity, precedence) {\n    this.ruleName = ruleName;\n    this.parentNode = parentNode;\n    this.childNodes = childNodes;\n    this.opacity = opacity;\n    this.precedence = precedence;\n  }\n\n  getRuleName() {\n    return this.ruleName;\n  }\n\n  getParentNode() {\n    return this.parentNode;\n  }\n\n  getChildNodes() {\n    return this.childNodes;\n  }\n\n  getOpacity() {\n    return this.opacity;\n  }\n\n  getPrecedence() {\n    return this.precedence;\n  }\n\n  setRuleName(ruleName) {\n    this.ruleName = ruleName;\n  }\n\n  setChildNodes(childNodes) {\n    const start = 0,\n          deleteCount = Infinity,\n          addedChildNodes = childNodes;  ///\n\n    this.spliceChildNodes(start, deleteCount, addedChildNodes);\n  }\n\n  setParentNode(parentNode) {\n    this.parentNode = parentNode;\n  }\n\n  setPrecedence(precedence) {\n    this.precedence = precedence;\n  }\n\n  setOpacity(opacity) {\n    this.opacity = opacity;\n  }\n\n  isOpaque() {\n    const opaque = (this.opacity === opaqueSpecialSymbol);\n\n    return opaque;\n  }\n\n  isSemiOpaque() {\n    const semiOpaque = (this.opacity === semiOpaqueSpecialSymbol);\n\n    return semiOpaque;\n  }\n\n  isTransparent() {\n    const semiOpaque = (this.opacity === null);\n\n    return semiOpaque;\n  }\n\n  isTerminalNode() {\n    const terminalNode = false;\n\n    return terminalNode;\n  }\n\n  isNonTerminalNode() {\n    const nonTerminalNode = true;\n\n    return nonTerminalNode;\n  }\n\n  getFirstSignificantTokenIndex(tokens) {\n    let firstSignificantTokenIndex;\n\n    forwardsSome(this.childNodes, (childNode) => {\n      const node = childNode; ///\n\n      firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens);\n\n      if (firstSignificantTokenIndex !== null) {\n        return true;\n      }\n    });\n\n    return firstSignificantTokenIndex;\n  }\n\n  getLastSignificantTokenIndex(tokens) {\n    let lastSignificantTokenIndex;\n\n    backwardsSome(this.childNodes, (childNode) => {\n      const node = childNode; ///\n\n      lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens);\n\n      if (lastSignificantTokenIndex !== null) {\n        return true;\n      }\n    });\n\n    return lastSignificantTokenIndex;\n  }\n\n  getSignificantTokens(significantTokens = []) {\n    this.childNodes.forEach((childNode) => {\n      childNode.getSignificantTokens(significantTokens);\n    });\n\n    return significantTokens;\n  }\n\n  getAncestorNodes() {\n    const ancestorNodes = [];\n\n    let parentNode = this.parentNode;\n\n    while (parentNode !== null) {\n      const ancestorNode = parentNode;  ///\n\n      ancestorNodes.push(ancestorNode);\n\n      parentNode = parentNode.getParentNode();\n    }\n\n    return ancestorNodes;\n  }\n\n  getMultiplicity() {\n    const childNodesLength = this.childNodes.length,\n          multiplicity = childNodesLength;  ///\n\n    return multiplicity;\n  }\n\n  isEmpty() {\n    const multiplicity = this.getMultiplicity(),\n          empty = (multiplicity === 0);\n\n    return empty;\n  }\n\n  isSingular() {\n    const multiplicity = this.getMultiplicity(),\n          singular = (multiplicity === 1);\n\n    return singular;\n  }\n\n  isLowerPrecedence(ruleName, precedence) {\n    let lowerPrecedence;\n\n    if (false) {\n      ///\n    } else if (this.precedence === null) {\n      lowerPrecedence = false;\n    } else if (this.precedence === Infinity) {\n      const firstChildNode = first(this.childNodes);\n\n      lowerPrecedence = firstChildNode.isLowerPrecedence(ruleName, precedence);\n    } else {\n      lowerPrecedence = ((this.ruleName === ruleName) && (this.precedence < precedence));\n    }\n\n    return lowerPrecedence;\n  }\n\n  isUnprecedented() {\n    let unprecedented = false;\n\n    if (this.precedence !== null) {\n      unprecedented = this.childNodes.some((childNode) => {  ///\n        const childNodeLowerPrecedence = childNode.isLowerPrecedence(this.ruleName, this.precedence);\n\n        if (childNodeLowerPrecedence) {\n          return true;\n        }\n      });\n    }\n\n    return unprecedented;\n  }\n\n  isIncludedIn(node) {\n    let includedIn = false;\n\n    if (this === node) {\n      includedIn = true;\n    } else {\n      const nodeNonTerminalNode = node.isNonTerminalNode();\n\n      if (nodeNonTerminalNode) {\n        const nonTerminalNode = node, ///\n              childNodes = nonTerminalNode.getChildNodes();\n\n        includedIn = childNodes.some((childNode) => {\n          const includedInChildNode = this.isIncludedIn(childNode);\n\n          if (includedInChildNode) {\n            return true;\n          }\n        });\n      }\n    }\n\n    return includedIn;\n  }\n\n  mapChildNode(callback) { return this.childNodes.map(callback); }\n\n  someChildNode(callback) { return this.childNodes.some(callback); }\n\n  everyChildNode(callback) { return this.childNodes.every(callback); }\n\n  reduceChildNode(callback, initialValue) { return this.childNodes.reduce(callback, initialValue); }\n\n  forEachChildNode(callback) { this.childNodes.forEach(callback); }\n\n  addChildNode(addedChildNode, offset) {\n    const addedChildNodes = [\n        addedChildNode\n    ];\n\n    this.addChildNodes(addedChildNodes, offset);\n  }\n\n  addChildNodes(addedChildNodes, offset) {\n    const start = offset, ///\n          deleteCount = 0;\n\n    this.spliceChildNodes(start, deleteCount, ...addedChildNodes);\n  }\n\n  removeChildNode(removedChildNode) {\n    let removedChildNodes;\n\n    removedChildNodes = [\n      removedChildNode\n    ];\n\n    removedChildNodes = this.removeChildNodes(removedChildNodes);\n\n    return removedChildNodes;\n  }\n\n  removeChildNodes(removedChildNodes) {\n    if (removedChildNodes === undefined) {\n      removedChildNodes = [\n        ...this.childNodes\n      ];\n    }\n\n    const removedChildNodesLength = removedChildNodes.length;\n\n    if (removedChildNodesLength === 0) {\n      return;\n    }\n\n    const firstReplacedChildNode = first(removedChildNodes),\n          firstIndex = this.childNodes.indexOf(firstReplacedChildNode),\n          start = firstIndex, ///\n          deleteCount = removedChildNodesLength, ///\n          addedChildNodes = [];\n\n    removedChildNodes = this.spliceChildNodes(start, deleteCount, addedChildNodes);\n\n    return removedChildNodes;\n  }\n\n  replaceChildNode(replacedChildNode, replacementChildNodes) {\n    const replacedChildNodes = [\n      replacedChildNode\n    ];\n\n    this.replaceChildNodes(replacedChildNodes, replacementChildNodes);\n  }\n\n  replaceChildNodes(replacedChildNodes, replacementChildNodes) {\n    const replacedChildNodesLength = replacedChildNodes.length,\n          firstReplacedChildNode = first(replacedChildNodes),\n          firstIndex = this.childNodes.indexOf(firstReplacedChildNode),\n          start = firstIndex, ///\n          deleteCount = replacedChildNodesLength; ///\n\n    this.spliceChildNodes(start, deleteCount, replacementChildNodes);\n  }\n\n  spliceChildNodes(start, deleteCount, addedChildNodes = []) {\n    const removedChildNodes = this.childNodes.splice(start, deleteCount, ...addedChildNodes);\n\n    this.resetChildNodesParentNode(removedChildNodes);\n\n    this.setChildNodesParentNode(addedChildNodes);\n\n    return removedChildNodes;\n  }\n\n  setChildNodesParentNode(childNodes) {\n    if (childNodes === undefined) {\n      childNodes = [\n        ...this.childNodes\n      ];\n    }\n\n    const parentNode = this;\n\n    childNodes.forEach((childNode) => {\n      childNode.setParentNode(parentNode);\n    });\n  }\n\n  resetChildNodesParentNode(childNodes) {\n    if (childNodes === undefined) {\n      childNodes = [\n        ...this.childNodes\n      ];\n    }\n\n    const parentNode = null;\n\n    childNodes.forEach((childNode) => {\n      childNode.setParentNode(parentNode);\n    });\n  }\n\n  match(node, depth = Infinity, exactly = false) {\n    let matches = false;\n\n    const nodeNonTerminalNode = node.isNonTerminalNode();\n\n    if (nodeNonTerminalNode) {\n      const nonTerminalNode = node, ///\n            nonTerminalNodeRuleName = nonTerminalNode.getRuleName();\n\n      if (this.ruleName === nonTerminalNodeRuleName) {\n        const nonTerminalNodeOpacity = nonTerminalNode.getOpacity();\n\n        if (this.opacity === nonTerminalNodeOpacity) {\n          const precedence = this.getPrecedence(),\n                nonTerminalNodePrecedence = nonTerminalNode.getPrecedence();\n\n          if (precedence === nonTerminalNodePrecedence) {\n            depth--;\n\n            if (depth === 0) {\n              matches = true;\n            } else {\n              const nonTerminalNodeChildNodes = nonTerminalNode.getChildNodes();\n\n              matches = match(this.childNodes, nonTerminalNodeChildNodes, (childNode, nonTerminalNodeChildNode) => {\n                const childNodeMatchesNonTerminalNodeChildNode = childNode.match(nonTerminalNodeChildNode, depth, exactly);\n\n                if (childNodeMatchesNonTerminalNodeChildNode) {\n                  return true;\n                }\n              });\n            }\n          }\n        }\n      }\n    }\n\n    return matches;\n  }\n\n  rewrite() {\n    const rewrittenNonTerminalNode = null;\n\n    return rewrittenNonTerminalNode;\n  }\n\n  asParseTree(tokens) {\n    const nonTerminalNode = this,  ///\n          nonTerminalNodeParseTree = NonTerminalNodeParseTree.fromNonTerminalNodeAndTokens(nonTerminalNode, tokens),\n          parseTree = nonTerminalNodeParseTree;  ///\n\n    return parseTree;\n  }\n\n  clone(...remainingArguments) {\n    const Class = this.constructor,\n          parentNode = null,\n          ruleName = this.ruleName,\n          childNodes = cloneChildNodes(this.childNodes),\n          opacity = this.opacity,\n          precedence = this.precedence,\n          nonTerminalNode = new Class(ruleName, parentNode, childNodes, opacity, precedence, ...remainingArguments);\n\n    nonTerminalNode.setChildNodesParentNode();\n\n    return nonTerminalNode;\n  }\n\n  static fromRuleNameChildNodesAndOpacity(Class, ruleName, childNodes, opacity, ...remainingArguments) {\n    if (opacity === undefined) {\n      opacity = childNodes; ///\n\n      childNodes = ruleName;  ///\n\n      ruleName = Class; ///\n\n      Class = NonTerminalNode;  ///\n    }\n\n    const parentNode = null,\n          precedence = null,\n          nonTerminalNode = new Class(ruleName, parentNode, childNodes, opacity, precedence, ...remainingArguments);\n\n    nonTerminalNode.setChildNodesParentNode();\n\n    return nonTerminalNode;\n  }\n}\n\nfunction cloneChildNodes(childNodes) {\n  childNodes = childNodes.map((childNode) => {  ///\n    childNode = childNode.clone();  ///\n\n    return childNode;\n  });\n\n  return childNodes;\n}\n"],"names":["NonTerminalNode","first","arrayUtilities","match","forwardsSome","backwardsSome","opaque","opaqueSpecialSymbol","specialSymbols","semiOpaque","semiOpaqueSpecialSymbol","ruleName","parentNode","childNodes","opacity","precedence","getRuleName","getParentNode","getChildNodes","getOpacity","getPrecedence","setRuleName","setChildNodes","start","deleteCount","Infinity","addedChildNodes","spliceChildNodes","setParentNode","setPrecedence","setOpacity","isOpaque","isSemiOpaque","isTransparent","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","getFirstSignificantTokenIndex","tokens","firstSignificantTokenIndex","childNode","node","getLastSignificantTokenIndex","lastSignificantTokenIndex","getSignificantTokens","significantTokens","forEach","getAncestorNodes","ancestorNodes","ancestorNode","push","getMultiplicity","childNodesLength","length","multiplicity","isEmpty","empty","isSingular","singular","isLowerPrecedence","lowerPrecedence","firstChildNode","isUnprecedented","unprecedented","some","childNodeLowerPrecedence","isIncludedIn","includedIn","nodeNonTerminalNode","includedInChildNode","mapChildNode","callback","map","someChildNode","everyChildNode","every","reduceChildNode","initialValue","reduce","forEachChildNode","addChildNode","addedChildNode","offset","addChildNodes","removeChildNode","removedChildNode","removedChildNodes","removeChildNodes","undefined","removedChildNodesLength","firstReplacedChildNode","firstIndex","indexOf","replaceChildNode","replacedChildNode","replacementChildNodes","replacedChildNodes","replaceChildNodes","replacedChildNodesLength","splice","resetChildNodesParentNode","setChildNodesParentNode","depth","exactly","matches","nonTerminalNodeRuleName","nonTerminalNodeOpacity","nonTerminalNodePrecedence","nonTerminalNodeChildNodes","nonTerminalNodeChildNode","childNodeMatchesNonTerminalNodeChildNode","rewrite","rewrittenNonTerminalNode","asParseTree","nonTerminalNodeParseTree","NonTerminalNodeParseTree","fromNonTerminalNodeAndTokens","parseTree","clone","remainingArguments","Class","constructor","cloneChildNodes","fromRuleNameChildNodesAndOpacity"],"mappings":"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"}
575
+ //# 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 startIndex = 0,\n          deleteCount = Infinity,\n          addedChildNodes = childNodes;  ///\n\n    this.spliceChildNodes(startIndex, 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    this.forwardsSomeChildNode((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    this.backwardsSomeChildNode((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  forwardsSomeChildNode(callback) { return forwardsSome(this.childNodes, callback); }\n\n  backwardsSomeChildNode(callback) { return backwardsSome(this.childNodes, callback); }\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  addChildNode(addedChildNode, offset) {\n    const addedChildNodes = [\n        addedChildNode\n    ];\n\n    this.addChildNodes(addedChildNodes, offset);\n  }\n\n  addChildNodes(addedChildNodes, offset) {\n    const startIndex = offset, ///\n          deleteCount = 0;\n\n    this.spliceChildNodes(startIndex, 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          startIndex = firstIndex, ///\n          deleteCount = removedChildNodesLength, ///\n          addedChildNodes = [];\n\n    removedChildNodes = this.spliceChildNodes(startIndex, 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          startIndex = firstIndex, ///\n          deleteCount = replacedChildNodesLength; ///\n\n    this.spliceChildNodes(startIndex, deleteCount, replacementChildNodes);\n  }\n\n  spliceChildNodes(startIndex, deleteCount, addedChildNodes = []) {\n    const removedChildNodes = this.childNodes.splice(startIndex, deleteCount, ...addedChildNodes);\n\n    this.resetChildNodesParentNode(removedChildNodes);\n\n    this.setChildNodesParentNode(addedChildNodes);\n\n    return removedChildNodes;\n  }\n\n  sliceChildNodes(startIndex, endIndex) {\n    const childNodes = this.childNodes.slice(startIndex, endIndex);\n\n    return childNodes;\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","startIndex","deleteCount","Infinity","addedChildNodes","spliceChildNodes","setParentNode","setPrecedence","setOpacity","isOpaque","isSemiOpaque","isTransparent","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","getFirstSignificantTokenIndex","tokens","firstSignificantTokenIndex","forwardsSomeChildNode","childNode","node","getLastSignificantTokenIndex","lastSignificantTokenIndex","backwardsSomeChildNode","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","setChildNodesParentNode","undefined","resetChildNodesParentNode","addChildNode","addedChildNode","offset","addChildNodes","removeChildNode","removedChildNode","removedChildNodes","removeChildNodes","removedChildNodesLength","firstReplacedChildNode","firstIndex","indexOf","replaceChildNode","replacedChildNode","replacementChildNodes","replacedChildNodes","replaceChildNodes","replacedChildNodesLength","splice","sliceChildNodes","endIndex","slice","depth","exactly","matches","nonTerminalNodeRuleName","nonTerminalNodeOpacity","nonTerminalNodePrecedence","nonTerminalNodeChildNodes","nonTerminalNodeChildNode","childNodeMatchesNonTerminalNodeChildNode","rewrite","rewrittenNonTerminalNode","asParseTree","nonTerminalNodeParseTree","NonTerminalNodeParseTree","fromNonTerminalNodeAndTokens","parseTree","clone","remainingArguments","Class","constructor","cloneChildNodes","fromRuleNameChildNodesAndOpacity"],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "occam-parsers",
3
3
  "author": "James Smith",
4
- "version": "23.0.89",
4
+ "version": "23.0.91",
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
- const start = 0,
45
+ const startIndex = 0,
46
46
  deleteCount = Infinity,
47
47
  addedChildNodes = childNodes; ///
48
48
 
49
- this.spliceChildNodes(start, deleteCount, addedChildNodes);
49
+ this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);
50
50
  }
51
51
 
52
52
  setParentNode(parentNode) {
@@ -94,7 +94,7 @@ export default class NonTerminalNode {
94
94
  getFirstSignificantTokenIndex(tokens) {
95
95
  let firstSignificantTokenIndex;
96
96
 
97
- forwardsSome(this.childNodes, (childNode) => {
97
+ this.forwardsSomeChildNode((childNode) => {
98
98
  const node = childNode; ///
99
99
 
100
100
  firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens);
@@ -110,7 +110,7 @@ export default class NonTerminalNode {
110
110
  getLastSignificantTokenIndex(tokens) {
111
111
  let lastSignificantTokenIndex;
112
112
 
113
- backwardsSome(this.childNodes, (childNode) => {
113
+ this.backwardsSomeChildNode((childNode) => {
114
114
  const node = childNode; ///
115
115
 
116
116
  lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens);
@@ -237,6 +237,38 @@ export default class NonTerminalNode {
237
237
 
238
238
  forEachChildNode(callback) { this.childNodes.forEach(callback); }
239
239
 
240
+ forwardsSomeChildNode(callback) { return forwardsSome(this.childNodes, callback); }
241
+
242
+ backwardsSomeChildNode(callback) { return backwardsSome(this.childNodes, callback); }
243
+
244
+ setChildNodesParentNode(childNodes) {
245
+ if (childNodes === undefined) {
246
+ childNodes = [
247
+ ...this.childNodes
248
+ ];
249
+ }
250
+
251
+ const parentNode = this;
252
+
253
+ childNodes.forEach((childNode) => {
254
+ childNode.setParentNode(parentNode);
255
+ });
256
+ }
257
+
258
+ resetChildNodesParentNode(childNodes) {
259
+ if (childNodes === undefined) {
260
+ childNodes = [
261
+ ...this.childNodes
262
+ ];
263
+ }
264
+
265
+ const parentNode = null;
266
+
267
+ childNodes.forEach((childNode) => {
268
+ childNode.setParentNode(parentNode);
269
+ });
270
+ }
271
+
240
272
  addChildNode(addedChildNode, offset) {
241
273
  const addedChildNodes = [
242
274
  addedChildNode
@@ -246,10 +278,10 @@ export default class NonTerminalNode {
246
278
  }
247
279
 
248
280
  addChildNodes(addedChildNodes, offset) {
249
- const start = offset, ///
281
+ const startIndex = offset, ///
250
282
  deleteCount = 0;
251
283
 
252
- this.spliceChildNodes(start, deleteCount, ...addedChildNodes);
284
+ this.spliceChildNodes(startIndex, deleteCount, ...addedChildNodes);
253
285
  }
254
286
 
255
287
  removeChildNode(removedChildNode) {
@@ -279,11 +311,11 @@ export default class NonTerminalNode {
279
311
 
280
312
  const firstReplacedChildNode = first(removedChildNodes),
281
313
  firstIndex = this.childNodes.indexOf(firstReplacedChildNode),
282
- start = firstIndex, ///
314
+ startIndex = firstIndex, ///
283
315
  deleteCount = removedChildNodesLength, ///
284
316
  addedChildNodes = [];
285
317
 
286
- removedChildNodes = this.spliceChildNodes(start, deleteCount, addedChildNodes);
318
+ removedChildNodes = this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);
287
319
 
288
320
  return removedChildNodes;
289
321
  }
@@ -300,14 +332,14 @@ export default class NonTerminalNode {
300
332
  const replacedChildNodesLength = replacedChildNodes.length,
301
333
  firstReplacedChildNode = first(replacedChildNodes),
302
334
  firstIndex = this.childNodes.indexOf(firstReplacedChildNode),
303
- start = firstIndex, ///
335
+ startIndex = firstIndex, ///
304
336
  deleteCount = replacedChildNodesLength; ///
305
337
 
306
- this.spliceChildNodes(start, deleteCount, replacementChildNodes);
338
+ this.spliceChildNodes(startIndex, deleteCount, replacementChildNodes);
307
339
  }
308
340
 
309
- spliceChildNodes(start, deleteCount, addedChildNodes = []) {
310
- const removedChildNodes = this.childNodes.splice(start, deleteCount, ...addedChildNodes);
341
+ spliceChildNodes(startIndex, deleteCount, addedChildNodes = []) {
342
+ const removedChildNodes = this.childNodes.splice(startIndex, deleteCount, ...addedChildNodes);
311
343
 
312
344
  this.resetChildNodesParentNode(removedChildNodes);
313
345
 
@@ -316,32 +348,10 @@ export default class NonTerminalNode {
316
348
  return removedChildNodes;
317
349
  }
318
350
 
319
- setChildNodesParentNode(childNodes) {
320
- if (childNodes === undefined) {
321
- childNodes = [
322
- ...this.childNodes
323
- ];
324
- }
325
-
326
- const parentNode = this;
351
+ sliceChildNodes(startIndex, endIndex) {
352
+ const childNodes = this.childNodes.slice(startIndex, endIndex);
327
353
 
328
- childNodes.forEach((childNode) => {
329
- childNode.setParentNode(parentNode);
330
- });
331
- }
332
-
333
- resetChildNodesParentNode(childNodes) {
334
- if (childNodes === undefined) {
335
- childNodes = [
336
- ...this.childNodes
337
- ];
338
- }
339
-
340
- const parentNode = null;
341
-
342
- childNodes.forEach((childNode) => {
343
- childNode.setParentNode(parentNode);
344
- });
354
+ return childNodes;
345
355
  }
346
356
 
347
357
  match(node, depth = Infinity, exactly = false) {