occam-parsers 23.0.92 → 23.0.94
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/example.js +13 -1
- package/lib/node/nonTerminal.js +13 -1
- package/package.json +3 -3
- package/src/node/nonTerminal.js +4 -0
package/lib/node/nonTerminal.js
CHANGED
|
@@ -338,12 +338,24 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
338
338
|
return this.childNodes.some(callback);
|
|
339
339
|
}
|
|
340
340
|
},
|
|
341
|
+
{
|
|
342
|
+
key: "findChildNode",
|
|
343
|
+
value: function findChildNode(callback) {
|
|
344
|
+
return this.childNodes.find(callback);
|
|
345
|
+
}
|
|
346
|
+
},
|
|
341
347
|
{
|
|
342
348
|
key: "everyChildNode",
|
|
343
349
|
value: function everyChildNode(callback) {
|
|
344
350
|
return this.childNodes.every(callback);
|
|
345
351
|
}
|
|
346
352
|
},
|
|
353
|
+
{
|
|
354
|
+
key: "filterChildNode",
|
|
355
|
+
value: function filterChildNode(callback) {
|
|
356
|
+
return this.childNodes.filter(callback);
|
|
357
|
+
}
|
|
358
|
+
},
|
|
347
359
|
{
|
|
348
360
|
key: "reduceChildNode",
|
|
349
361
|
value: function reduceChildNode(callback, initialValue) {
|
|
@@ -572,4 +584,4 @@ function cloneChildNodes(childNodes) {
|
|
|
572
584
|
return childNodes;
|
|
573
585
|
}
|
|
574
586
|
|
|
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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"}
|
|
587
|
+
//# 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  findChildNode(callback) { return this.childNodes.find(callback); }\n\n  everyChildNode(callback) { return this.childNodes.every(callback); }\n\n  filterChildNode(callback) { return this.childNodes.filter(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","findChildNode","find","everyChildNode","every","filterChildNode","filter","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.
|
|
4
|
+
"version": "23.0.94",
|
|
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.
|
|
20
|
-
"easy-with-style": "^3.0.
|
|
19
|
+
"easy-layout": "^6.0.225",
|
|
20
|
+
"easy-with-style": "^3.0.456",
|
|
21
21
|
"esbuild": "^0.9.6",
|
|
22
22
|
"express": "^4.17.1",
|
|
23
23
|
"juxtapose": "^4.0.117",
|
package/src/node/nonTerminal.js
CHANGED
|
@@ -231,8 +231,12 @@ export default class NonTerminalNode {
|
|
|
231
231
|
|
|
232
232
|
someChildNode(callback) { return this.childNodes.some(callback); }
|
|
233
233
|
|
|
234
|
+
findChildNode(callback) { return this.childNodes.find(callback); }
|
|
235
|
+
|
|
234
236
|
everyChildNode(callback) { return this.childNodes.every(callback); }
|
|
235
237
|
|
|
238
|
+
filterChildNode(callback) { return this.childNodes.filter(callback); }
|
|
239
|
+
|
|
236
240
|
reduceChildNode(callback, initialValue) { return this.childNodes.reduce(callback, initialValue); }
|
|
237
241
|
|
|
238
242
|
forEachChildNode(callback) { this.childNodes.forEach(callback); }
|