occam-parsers 23.0.120 → 23.0.122

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.
@@ -163,6 +163,62 @@ function sliceChildNodes(startIndex) {
163
163
  var childNodes = this.childNodes.slice(startIndex, endIndex);
164
164
  return childNodes;
165
165
  }
166
+ function getAncestorNodes() {
167
+ var ancestorNodes = [];
168
+ var ancestorNode = this.parentNode; ///
169
+ while(ancestorNode !== null){
170
+ ancestorNodes.push(ancestorNode);
171
+ var parentNode = ancestorNode.getParentNode();
172
+ ancestorNode = parentNode; ///
173
+ }
174
+ return ancestorNodes;
175
+ }
176
+ function mapAncestorNode(callback) {
177
+ var ancestorNodes = this.getAncestorNodes();
178
+ return ancestorNodes.map(callback);
179
+ }
180
+ function someAncestorNode(callback) {
181
+ var result = false;
182
+ var index = 0, ancestorNode = this.parentNode; ///
183
+ while(ancestorNode !== null){
184
+ result = callback(ancestorNode, index);
185
+ if (result) {
186
+ break;
187
+ }
188
+ var parentNode = node.getParentNode();
189
+ ancestorNode = parentNode; ///
190
+ index++;
191
+ }
192
+ return result;
193
+ }
194
+ function findAncestorNode(callback) {
195
+ var index = 0, ancestorNode = this.parentNode; ///
196
+ while(ancestorNode !== null){
197
+ var result = callback(ancestorNode, index);
198
+ if (result) {
199
+ return ancestorNode;
200
+ }
201
+ var parentNode = node.getParentNode();
202
+ ancestorNode = parentNode; ///
203
+ index++;
204
+ }
205
+ }
206
+ function everyAncestorNode(callback) {
207
+ var ancestorNodes = this.getAncestorNodes();
208
+ return ancestorNodes.every(callback);
209
+ }
210
+ function filterAncestorNode(callback) {
211
+ var ancestorNodes = this.getAncestorNodes();
212
+ return ancestorNodes.filter(callback);
213
+ }
214
+ function reduceAncestorNode(callback, initialValue) {
215
+ var ancestorNodes = this.getAncestorNodes();
216
+ return ancestorNodes.reduce(callback, initialValue);
217
+ }
218
+ function forEachAncestorNode(callback) {
219
+ var ancestorNodes = this.getAncestorNodes();
220
+ ancestorNodes.forEach(callback);
221
+ }
166
222
  var nodeMixins = {
167
223
  getMultiplicity: getMultiplicity,
168
224
  mapChildNode: mapChildNode,
@@ -188,8 +244,16 @@ var nodeMixins = {
188
244
  prependChildNode: prependChildNode,
189
245
  prependChildNodes: prependChildNodes,
190
246
  spliceChildNodes: spliceChildNodes,
191
- sliceChildNodes: sliceChildNodes
247
+ sliceChildNodes: sliceChildNodes,
248
+ getAncestorNodes: getAncestorNodes,
249
+ mapAncestorNode: mapAncestorNode,
250
+ someAncestorNode: someAncestorNode,
251
+ findAncestorNode: findAncestorNode,
252
+ everyAncestorNode: everyAncestorNode,
253
+ filterAncestorNode: filterAncestorNode,
254
+ reduceAncestorNode: reduceAncestorNode,
255
+ forEachAncestorNode: forEachAncestorNode
192
256
  };
193
257
  var _default = nodeMixins;
194
258
 
195
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/mixins/node.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\n\nconst { first, forwardsSome, backwardsSome } = arrayUtilities;\n\nfunction getMultiplicity() {\n  const childNodesLength = this.childNodes.length,\n        multiplicity = childNodesLength;  ///\n\n  return multiplicity;\n}\n\nfunction mapChildNode(callback) { return this.childNodes.map(callback); }\n\nfunction someChildNode(callback) { return this.childNodes.some(callback); }\n\nfunction findChildNode(callback) { return this.childNodes.find(callback); }\n\nfunction everyChildNode(callback) { return this.childNodes.every(callback); }\n\nfunction filterChildNode(callback) { return this.childNodes.filter(callback); }\n\nfunction reduceChildNode(callback, initialValue) { return this.childNodes.reduce(callback, initialValue); }\n\nfunction forEachChildNode(callback) { this.childNodes.forEach(callback); }\n\nfunction forwardsSomeChildNode(callback) { return forwardsSome(this.childNodes, callback); }\n\nfunction backwardsSomeChildNode(callback) { return backwardsSome(this.childNodes, callback); }\n\nfunction indexOfChildNode(childNode) { return this.childNodes.indexOf(childNode); }\n\nfunction 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\nfunction 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\nfunction addChildNode(addedChildNode, startIndex) {\n  const addedChildNodes = [\n    addedChildNode\n  ];\n\n  this.addChildNodes(addedChildNodes, startIndex);\n}\n\nfunction addChildNodes(addedChildNodes, startIndex) {\n  const deleteCount = 0;\n\n  this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);\n}\n\nfunction removeChildNode(removedChildNode) {\n  let removedChildNodes;\n\n  removedChildNodes = [\n    removedChildNode\n  ];\n\n  removedChildNodes = this.removeChildNodes(removedChildNodes);\n\n  return removedChildNodes;\n}\n\nfunction 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        startIndex = this.childNodes.indexOf(firstReplacedChildNode), ///\n        deleteCount = removedChildNodesLength, ///\n        addedChildNodes = [];\n\n  removedChildNodes = this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);\n\n  return removedChildNodes;\n}\n\nfunction replaceChildNode(replacedChildNode, replacementChildNodes) {\n  const replacedChildNodes = [\n    replacedChildNode\n  ];\n\n  this.replaceChildNodes(replacedChildNodes, replacementChildNodes);\n}\n\nfunction replaceChildNodes(replacedChildNodes, replacementChildNodes) {\n  const replacedChildNodesLength = replacedChildNodes.length,\n        firstReplacedChildNode = first(replacedChildNodes),\n        startIndex = this.childNodes.indexOf(firstReplacedChildNode), ///\n        deleteCount = replacedChildNodesLength; ///\n\n  this.spliceChildNodes(startIndex, deleteCount, replacementChildNodes);\n}\n\nfunction appendChildNode(appendedChildNode) {\n  const appendedChildNodes = [\n    appendedChildNode\n  ];\n\n  this.appendChildNodes(appendedChildNodes);\n}\n\nfunction appendChildNodes(appendedChildNodes) {\n  const addedChildNodes = appendedChildNodes, ///\n        multiplicity = this.getMultiplicity(),\n        startIndex = multiplicity;  ///\n\n  this.addChildNodes(addedChildNodes, startIndex);\n}\n\nfunction prependChildNode(prependedChildNode) {\n  const prependedChildNodes = [\n    prependedChildNode\n  ];\n\n  this.prependChildNodes(prependedChildNodes);\n}\n\nfunction prependChildNodes(prependedChildNodes) {\n  const addedChildNodes = prependedChildNodes,  ///\n        startIndex = 0;\n\n  this.addChildNodes(addedChildNodes, startIndex);\n}\n\nfunction 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\nfunction sliceChildNodes(startIndex, endIndex = Infinity) {\n  const childNodes = this.childNodes.slice(startIndex, endIndex);\n\n  return childNodes;\n}\n\nconst nodeMixins = {\n  getMultiplicity,\n  mapChildNode,\n  someChildNode,\n  findChildNode,\n  everyChildNode,\n  filterChildNode,\n  reduceChildNode,\n  forEachChildNode,\n  forwardsSomeChildNode,\n  backwardsSomeChildNode,\n  indexOfChildNode,\n  setChildNodesParentNode,\n  resetChildNodesParentNode,\n  addChildNode,\n  addChildNodes,\n  removeChildNode,\n  removeChildNodes,\n  replaceChildNode,\n  replaceChildNodes,\n  appendChildNode,\n  appendChildNodes,\n  prependChildNode,\n  prependChildNodes,\n  spliceChildNodes,\n  sliceChildNodes\n};\n\nexport default nodeMixins;\n"],"names":["first","arrayUtilities","forwardsSome","backwardsSome","getMultiplicity","childNodesLength","childNodes","length","multiplicity","mapChildNode","callback","map","someChildNode","some","findChildNode","find","everyChildNode","every","filterChildNode","filter","reduceChildNode","initialValue","reduce","forEachChildNode","forEach","forwardsSomeChildNode","backwardsSomeChildNode","indexOfChildNode","childNode","indexOf","setChildNodesParentNode","undefined","parentNode","setParentNode","resetChildNodesParentNode","addChildNode","addedChildNode","startIndex","addedChildNodes","addChildNodes","deleteCount","spliceChildNodes","removeChildNode","removedChildNode","removedChildNodes","removeChildNodes","removedChildNodesLength","firstReplacedChildNode","replaceChildNode","replacedChildNode","replacementChildNodes","replacedChildNodes","replaceChildNodes","replacedChildNodesLength","appendChildNode","appendedChildNode","appendedChildNodes","appendChildNodes","prependChildNode","prependedChildNode","prependedChildNodes","prependChildNodes","splice","sliceChildNodes","endIndex","Infinity","slice","nodeMixins"],"mappings":"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"}
259
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/mixins/node.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\n\nconst { first, forwardsSome, backwardsSome } = arrayUtilities;\n\nfunction getMultiplicity() {\n  const childNodesLength = this.childNodes.length,\n        multiplicity = childNodesLength;  ///\n\n  return multiplicity;\n}\n\nfunction mapChildNode(callback) { return this.childNodes.map(callback); }\n\nfunction someChildNode(callback) { return this.childNodes.some(callback); }\n\nfunction findChildNode(callback) { return this.childNodes.find(callback); }\n\nfunction everyChildNode(callback) { return this.childNodes.every(callback); }\n\nfunction filterChildNode(callback) { return this.childNodes.filter(callback); }\n\nfunction reduceChildNode(callback, initialValue) { return this.childNodes.reduce(callback, initialValue); }\n\nfunction forEachChildNode(callback) { this.childNodes.forEach(callback); }\n\nfunction forwardsSomeChildNode(callback) { return forwardsSome(this.childNodes, callback); }\n\nfunction backwardsSomeChildNode(callback) { return backwardsSome(this.childNodes, callback); }\n\nfunction indexOfChildNode(childNode) { return this.childNodes.indexOf(childNode); }\n\nfunction 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\nfunction 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\nfunction addChildNode(addedChildNode, startIndex) {\n  const addedChildNodes = [\n    addedChildNode\n  ];\n\n  this.addChildNodes(addedChildNodes, startIndex);\n}\n\nfunction addChildNodes(addedChildNodes, startIndex) {\n  const deleteCount = 0;\n\n  this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);\n}\n\nfunction removeChildNode(removedChildNode) {\n  let removedChildNodes;\n\n  removedChildNodes = [\n    removedChildNode\n  ];\n\n  removedChildNodes = this.removeChildNodes(removedChildNodes);\n\n  return removedChildNodes;\n}\n\nfunction 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        startIndex = this.childNodes.indexOf(firstReplacedChildNode), ///\n        deleteCount = removedChildNodesLength, ///\n        addedChildNodes = [];\n\n  removedChildNodes = this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);\n\n  return removedChildNodes;\n}\n\nfunction replaceChildNode(replacedChildNode, replacementChildNodes) {\n  const replacedChildNodes = [\n    replacedChildNode\n  ];\n\n  this.replaceChildNodes(replacedChildNodes, replacementChildNodes);\n}\n\nfunction replaceChildNodes(replacedChildNodes, replacementChildNodes) {\n  const replacedChildNodesLength = replacedChildNodes.length,\n        firstReplacedChildNode = first(replacedChildNodes),\n        startIndex = this.childNodes.indexOf(firstReplacedChildNode), ///\n        deleteCount = replacedChildNodesLength; ///\n\n  this.spliceChildNodes(startIndex, deleteCount, replacementChildNodes);\n}\n\nfunction appendChildNode(appendedChildNode) {\n  const appendedChildNodes = [\n    appendedChildNode\n  ];\n\n  this.appendChildNodes(appendedChildNodes);\n}\n\nfunction appendChildNodes(appendedChildNodes) {\n  const addedChildNodes = appendedChildNodes, ///\n        multiplicity = this.getMultiplicity(),\n        startIndex = multiplicity;  ///\n\n  this.addChildNodes(addedChildNodes, startIndex);\n}\n\nfunction prependChildNode(prependedChildNode) {\n  const prependedChildNodes = [\n    prependedChildNode\n  ];\n\n  this.prependChildNodes(prependedChildNodes);\n}\n\nfunction prependChildNodes(prependedChildNodes) {\n  const addedChildNodes = prependedChildNodes,  ///\n        startIndex = 0;\n\n  this.addChildNodes(addedChildNodes, startIndex);\n}\n\nfunction 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\nfunction sliceChildNodes(startIndex, endIndex = Infinity) {\n  const childNodes = this.childNodes.slice(startIndex, endIndex);\n\n  return childNodes;\n}\n\nfunction getAncestorNodes() {\n  const ancestorNodes = [];\n\n  let ancestorNode = this.parentNode; ///\n\n  while (ancestorNode !== null) {\n    ancestorNodes.push(ancestorNode);\n\n    const parentNode = ancestorNode.getParentNode();\n\n    ancestorNode = parentNode;  ///\n  }\n\n  return ancestorNodes;\n}\n\nfunction mapAncestorNode(callback) {\n  const ancestorNodes = this.getAncestorNodes();\n\n  return ancestorNodes.map(callback);\n}\n\nfunction someAncestorNode(callback) {\n  let result = false;\n\n  let index = 0,\n      ancestorNode = this.parentNode; ///\n\n  while (ancestorNode !== null) {\n    result = callback(ancestorNode, index);\n\n    if (result) {\n      break;\n    }\n\n    const parentNode = node.getParentNode();\n\n    ancestorNode = parentNode;  ///\n\n    index++;\n  }\n\n  return result;\n}\n\nfunction findAncestorNode(callback) {\n  let index = 0,\n      ancestorNode = this.parentNode; ///\n\n  while (ancestorNode !== null) {\n    const result = callback(ancestorNode, index);\n\n    if (result) {\n      return ancestorNode;\n    }\n\n    const parentNode = node.getParentNode();\n\n    ancestorNode = parentNode;  ///\n\n    index++;\n  }\n}\n\nfunction everyAncestorNode(callback) {\n  const ancestorNodes = this.getAncestorNodes();\n\n  return ancestorNodes.every(callback);\n}\n\nfunction filterAncestorNode(callback) {\n  const ancestorNodes = this.getAncestorNodes();\n\n  return ancestorNodes.filter(callback);\n}\n\nfunction reduceAncestorNode(callback, initialValue) {\n  const ancestorNodes = this.getAncestorNodes();\n\n  return ancestorNodes.reduce(callback, initialValue);\n}\n\nfunction forEachAncestorNode(callback) {\n  const ancestorNodes = this.getAncestorNodes();\n\n  ancestorNodes.forEach(callback);\n}\n\nconst nodeMixins = {\n  getMultiplicity,\n  mapChildNode,\n  someChildNode,\n  findChildNode,\n  everyChildNode,\n  filterChildNode,\n  reduceChildNode,\n  forEachChildNode,\n  forwardsSomeChildNode,\n  backwardsSomeChildNode,\n  indexOfChildNode,\n  setChildNodesParentNode,\n  resetChildNodesParentNode,\n  addChildNode,\n  addChildNodes,\n  removeChildNode,\n  removeChildNodes,\n  replaceChildNode,\n  replaceChildNodes,\n  appendChildNode,\n  appendChildNodes,\n  prependChildNode,\n  prependChildNodes,\n  spliceChildNodes,\n  sliceChildNodes,\n  getAncestorNodes,\n  mapAncestorNode,\n  someAncestorNode,\n  findAncestorNode,\n  everyAncestorNode,\n  filterAncestorNode,\n  reduceAncestorNode,\n  forEachAncestorNode\n};\n\nexport default nodeMixins;\n"],"names":["first","arrayUtilities","forwardsSome","backwardsSome","getMultiplicity","childNodesLength","childNodes","length","multiplicity","mapChildNode","callback","map","someChildNode","some","findChildNode","find","everyChildNode","every","filterChildNode","filter","reduceChildNode","initialValue","reduce","forEachChildNode","forEach","forwardsSomeChildNode","backwardsSomeChildNode","indexOfChildNode","childNode","indexOf","setChildNodesParentNode","undefined","parentNode","setParentNode","resetChildNodesParentNode","addChildNode","addedChildNode","startIndex","addedChildNodes","addChildNodes","deleteCount","spliceChildNodes","removeChildNode","removedChildNode","removedChildNodes","removeChildNodes","removedChildNodesLength","firstReplacedChildNode","replaceChildNode","replacedChildNode","replacementChildNodes","replacedChildNodes","replaceChildNodes","replacedChildNodesLength","appendChildNode","appendedChildNode","appendedChildNodes","appendChildNodes","prependChildNode","prependedChildNode","prependedChildNodes","prependChildNodes","splice","sliceChildNodes","endIndex","Infinity","slice","getAncestorNodes","ancestorNodes","ancestorNode","push","getParentNode","mapAncestorNode","someAncestorNode","result","index","node","findAncestorNode","everyAncestorNode","filterAncestorNode","reduceAncestorNode","forEachAncestorNode","nodeMixins"],"mappings":"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"}
@@ -254,19 +254,6 @@ var NonTerminalNode = /*#__PURE__*/ function() {
254
254
  return descendantNodes;
255
255
  }
256
256
  },
257
- {
258
- key: "getAncestorNodes",
259
- value: function getAncestorNodes() {
260
- var ancestorNodes = [];
261
- var parentNode = this.parentNode;
262
- while(parentNode !== null){
263
- var ancestorNode = parentNode; ///
264
- ancestorNodes.push(ancestorNode);
265
- parentNode = parentNode.getParentNode();
266
- }
267
- return ancestorNodes;
268
- }
269
- },
270
257
  {
271
258
  key: "getMultiplicity",
272
259
  value: function getMultiplicity() {
@@ -430,4 +417,4 @@ function cloneChildNodes(childNodes) {
430
417
  }
431
418
  Object.assign(NonTerminalNode.prototype, _node.default);
432
419
 
433
- //# 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 nodeMixins from \"../mixins/node\";\nimport NonTerminalNodeParseTree from \"../parseTree/nonTerminalNode\";\n\nconst { first, match } = 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  setParentNode(parentNode) {\n    this.parentNode = parentNode;\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  setOpacity(opacity) {\n    this.opacity = opacity;\n  }\n\n  setPrecedence(precedence) {\n    this.precedence = precedence;\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  getDescendantNodes(descendantNodes = []) {\n    const descendantNode = this; ///\n\n    descendantNodes.push(descendantNode);\n\n    this.childNodes.forEach((childNode) => {\n      const childNodeNonTerminalNode = childNode.isNonTerminalNode();\n\n      if (childNodeNonTerminalNode) {\n        const nonTerminalNode = childNode;  ///\n\n        nonTerminalNode.getDescendantNodes(descendantNodes);\n      }\n    });\n\n    return descendantNodes;\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  asParseTree(tokens) {\n    const nonTerminalNode = this,  ///\n          nonTerminalNodeParseTree = NonTerminalNodeParseTree.fromNonTerminalNodeAndTokens(nonTerminalNode, tokens),\n          parseTree = nonTerminalNodeParseTree;  ///\n\n    return parseTree;\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  destroy() {\n    this.forEachChildNode((childNode) => {\n      childNode.destroy();\n    });\n\n    this.parentNode = null;\n    this.childNodes = null;\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\nObject.assign(NonTerminalNode.prototype, nodeMixins);\n"],"names":["NonTerminalNode","first","arrayUtilities","match","opaque","opaqueSpecialSymbol","specialSymbols","semiOpaque","semiOpaqueSpecialSymbol","ruleName","parentNode","childNodes","opacity","precedence","getRuleName","getParentNode","getChildNodes","getOpacity","getPrecedence","setRuleName","setParentNode","setChildNodes","startIndex","deleteCount","Infinity","addedChildNodes","spliceChildNodes","setOpacity","setPrecedence","isOpaque","isSemiOpaque","isTransparent","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","getFirstSignificantTokenIndex","tokens","firstSignificantTokenIndex","forwardsSomeChildNode","childNode","node","getLastSignificantTokenIndex","lastSignificantTokenIndex","backwardsSomeChildNode","getSignificantTokens","significantTokens","forEach","getDescendantNodes","descendantNodes","descendantNode","push","childNodeNonTerminalNode","getAncestorNodes","ancestorNodes","ancestorNode","getMultiplicity","childNodesLength","length","multiplicity","isEmpty","empty","isSingular","singular","isLowerPrecedence","lowerPrecedence","firstChildNode","isUnprecedented","unprecedented","some","childNodeLowerPrecedence","asParseTree","nonTerminalNodeParseTree","NonTerminalNodeParseTree","fromNonTerminalNodeAndTokens","parseTree","depth","exactly","matches","nodeNonTerminalNode","nonTerminalNodeRuleName","nonTerminalNodeOpacity","nonTerminalNodePrecedence","nonTerminalNodeChildNodes","nonTerminalNodeChildNode","childNodeMatchesNonTerminalNodeChildNode","rewrite","rewrittenNonTerminalNode","destroy","forEachChildNode","clone","remainingArguments","Class","constructor","cloneChildNodes","setChildNodesParentNode","fromRuleNameChildNodesAndOpacity","undefined","map","Object","assign","prototype","nodeMixins"],"mappings":"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"}
420
+ //# 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 nodeMixins from \"../mixins/node\";\nimport NonTerminalNodeParseTree from \"../parseTree/nonTerminalNode\";\n\nconst { first, match } = 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  setParentNode(parentNode) {\n    this.parentNode = parentNode;\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  setOpacity(opacity) {\n    this.opacity = opacity;\n  }\n\n  setPrecedence(precedence) {\n    this.precedence = precedence;\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  getDescendantNodes(descendantNodes = []) {\n    const descendantNode = this; ///\n\n    descendantNodes.push(descendantNode);\n\n    this.childNodes.forEach((childNode) => {\n      const childNodeNonTerminalNode = childNode.isNonTerminalNode();\n\n      if (childNodeNonTerminalNode) {\n        const nonTerminalNode = childNode;  ///\n\n        nonTerminalNode.getDescendantNodes(descendantNodes);\n      }\n    });\n\n    return descendantNodes;\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  asParseTree(tokens) {\n    const nonTerminalNode = this,  ///\n          nonTerminalNodeParseTree = NonTerminalNodeParseTree.fromNonTerminalNodeAndTokens(nonTerminalNode, tokens),\n          parseTree = nonTerminalNodeParseTree;  ///\n\n    return parseTree;\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  destroy() {\n    this.forEachChildNode((childNode) => {\n      childNode.destroy();\n    });\n\n    this.parentNode = null;\n    this.childNodes = null;\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\nObject.assign(NonTerminalNode.prototype, nodeMixins);\n"],"names":["NonTerminalNode","first","arrayUtilities","match","opaque","opaqueSpecialSymbol","specialSymbols","semiOpaque","semiOpaqueSpecialSymbol","ruleName","parentNode","childNodes","opacity","precedence","getRuleName","getParentNode","getChildNodes","getOpacity","getPrecedence","setRuleName","setParentNode","setChildNodes","startIndex","deleteCount","Infinity","addedChildNodes","spliceChildNodes","setOpacity","setPrecedence","isOpaque","isSemiOpaque","isTransparent","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","getFirstSignificantTokenIndex","tokens","firstSignificantTokenIndex","forwardsSomeChildNode","childNode","node","getLastSignificantTokenIndex","lastSignificantTokenIndex","backwardsSomeChildNode","getSignificantTokens","significantTokens","forEach","getDescendantNodes","descendantNodes","descendantNode","push","childNodeNonTerminalNode","getMultiplicity","childNodesLength","length","multiplicity","isEmpty","empty","isSingular","singular","isLowerPrecedence","lowerPrecedence","firstChildNode","isUnprecedented","unprecedented","some","childNodeLowerPrecedence","asParseTree","nonTerminalNodeParseTree","NonTerminalNodeParseTree","fromNonTerminalNodeAndTokens","parseTree","depth","exactly","matches","nodeNonTerminalNode","nonTerminalNodeRuleName","nonTerminalNodeOpacity","nonTerminalNodePrecedence","nonTerminalNodeChildNodes","nonTerminalNodeChildNode","childNodeMatchesNonTerminalNodeChildNode","rewrite","rewrittenNonTerminalNode","destroy","forEachChildNode","clone","remainingArguments","Class","constructor","cloneChildNodes","setChildNodesParentNode","fromRuleNameChildNodesAndOpacity","undefined","map","Object","assign","prototype","nodeMixins"],"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.120",
4
+ "version": "23.0.122",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/occam-parsers",
7
7
  "description": "Occam's parsers.",
@@ -16,8 +16,8 @@
16
16
  "devDependencies": {
17
17
  "@swc/core": "^1.5.6",
18
18
  "easy": "^23.0.1",
19
- "easy-layout": "^6.0.235",
20
- "easy-with-style": "^3.0.474",
19
+ "easy-layout": "^6.0.236",
20
+ "easy-with-style": "^3.0.476",
21
21
  "esbuild": "^0.9.6",
22
22
  "express": "^4.17.1",
23
23
  "juxtapose": "^4.0.117",
@@ -172,6 +172,94 @@ function sliceChildNodes(startIndex, endIndex = Infinity) {
172
172
  return childNodes;
173
173
  }
174
174
 
175
+ function getAncestorNodes() {
176
+ const ancestorNodes = [];
177
+
178
+ let ancestorNode = this.parentNode; ///
179
+
180
+ while (ancestorNode !== null) {
181
+ ancestorNodes.push(ancestorNode);
182
+
183
+ const parentNode = ancestorNode.getParentNode();
184
+
185
+ ancestorNode = parentNode; ///
186
+ }
187
+
188
+ return ancestorNodes;
189
+ }
190
+
191
+ function mapAncestorNode(callback) {
192
+ const ancestorNodes = this.getAncestorNodes();
193
+
194
+ return ancestorNodes.map(callback);
195
+ }
196
+
197
+ function someAncestorNode(callback) {
198
+ let result = false;
199
+
200
+ let index = 0,
201
+ ancestorNode = this.parentNode; ///
202
+
203
+ while (ancestorNode !== null) {
204
+ result = callback(ancestorNode, index);
205
+
206
+ if (result) {
207
+ break;
208
+ }
209
+
210
+ const parentNode = node.getParentNode();
211
+
212
+ ancestorNode = parentNode; ///
213
+
214
+ index++;
215
+ }
216
+
217
+ return result;
218
+ }
219
+
220
+ function findAncestorNode(callback) {
221
+ let index = 0,
222
+ ancestorNode = this.parentNode; ///
223
+
224
+ while (ancestorNode !== null) {
225
+ const result = callback(ancestorNode, index);
226
+
227
+ if (result) {
228
+ return ancestorNode;
229
+ }
230
+
231
+ const parentNode = node.getParentNode();
232
+
233
+ ancestorNode = parentNode; ///
234
+
235
+ index++;
236
+ }
237
+ }
238
+
239
+ function everyAncestorNode(callback) {
240
+ const ancestorNodes = this.getAncestorNodes();
241
+
242
+ return ancestorNodes.every(callback);
243
+ }
244
+
245
+ function filterAncestorNode(callback) {
246
+ const ancestorNodes = this.getAncestorNodes();
247
+
248
+ return ancestorNodes.filter(callback);
249
+ }
250
+
251
+ function reduceAncestorNode(callback, initialValue) {
252
+ const ancestorNodes = this.getAncestorNodes();
253
+
254
+ return ancestorNodes.reduce(callback, initialValue);
255
+ }
256
+
257
+ function forEachAncestorNode(callback) {
258
+ const ancestorNodes = this.getAncestorNodes();
259
+
260
+ ancestorNodes.forEach(callback);
261
+ }
262
+
175
263
  const nodeMixins = {
176
264
  getMultiplicity,
177
265
  mapChildNode,
@@ -197,7 +285,15 @@ const nodeMixins = {
197
285
  prependChildNode,
198
286
  prependChildNodes,
199
287
  spliceChildNodes,
200
- sliceChildNodes
288
+ sliceChildNodes,
289
+ getAncestorNodes,
290
+ mapAncestorNode,
291
+ someAncestorNode,
292
+ findAncestorNode,
293
+ everyAncestorNode,
294
+ filterAncestorNode,
295
+ reduceAncestorNode,
296
+ forEachAncestorNode
201
297
  };
202
298
 
203
299
  export default nodeMixins;
@@ -150,22 +150,6 @@ export default class NonTerminalNode {
150
150
  return descendantNodes;
151
151
  }
152
152
 
153
- getAncestorNodes() {
154
- const ancestorNodes = [];
155
-
156
- let parentNode = this.parentNode;
157
-
158
- while (parentNode !== null) {
159
- const ancestorNode = parentNode; ///
160
-
161
- ancestorNodes.push(ancestorNode);
162
-
163
- parentNode = parentNode.getParentNode();
164
- }
165
-
166
- return ancestorNodes;
167
- }
168
-
169
153
  getMultiplicity() {
170
154
  const childNodesLength = this.childNodes.length,
171
155
  multiplicity = childNodesLength; ///