occam-parsers 23.0.59 → 23.0.61

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.
@@ -350,19 +350,21 @@ var NonTerminalNode = /*#__PURE__*/ function() {
350
350
  return parseTree;
351
351
  }
352
352
  },
353
+ {
354
+ key: "cloneChildNodes",
355
+ value: function cloneChildNodes() {
356
+ var parentNode = this, childNodes = this.childNodes.map(function(childNode) {
357
+ childNode = childNode.clone(parentNode); ///
358
+ return childNode;
359
+ });
360
+ return childNodes;
361
+ }
362
+ },
353
363
  {
354
364
  key: "clone",
355
365
  value: function clone() {
356
- for(var _len = arguments.length, remainingArguments = new Array(_len), _key = 0; _key < _len; _key++){
357
- remainingArguments[_key] = arguments[_key];
358
- }
359
- var Class = this.constructor, ruleName = this.ruleName, parentNode = null, childNodes = cloneChildNodes(this.childNodes), opacity = this.opacity, precedence = this.precedence, nonTerminalNode = _construct(Class, [
360
- ruleName,
361
- parentNode,
362
- childNodes,
363
- opacity,
364
- precedence
365
- ].concat(_to_consumable_array(remainingArguments)));
366
+ var parentNode = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : null;
367
+ var Class = this.constructor, ruleName = this.ruleName, childNodes = this.cloneChildNodes(), opacity = this.opacity, precedence = this.precedence, nonTerminalNode = new Class(ruleName, parentNode, childNodes, opacity, precedence);
366
368
  return nonTerminalNode;
367
369
  }
368
370
  }
@@ -392,12 +394,5 @@ var NonTerminalNode = /*#__PURE__*/ function() {
392
394
  ]);
393
395
  return NonTerminalNode;
394
396
  }();
395
- function cloneChildNodes(childNodes) {
396
- childNodes = childNodes.map(function(childNode) {
397
- childNode = childNode.clone(); ///
398
- return childNode;
399
- });
400
- return childNodes;
401
- }
402
397
 
403
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/node/nonTerminal.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\nimport { specialSymbols } from \"occam-lexers\";\n\nimport NonTerminalNodeParseTree from \"../parseTree/nonTerminalNode\";\n\nconst { first, match, forwardsSome, backwardsSome } = arrayUtilities,\n      { opaque: opaqueSpecialSymbol , semiOpaque: semiOpaqueSpecialSymbol } = specialSymbols;\n\nexport default class NonTerminalNode {\n  constructor(ruleName, parentNode, childNodes, opacity, precedence) {\n    this.ruleName = ruleName;\n    this.parentNode = parentNode;\n    this.childNodes = childNodes;\n    this.opacity = opacity;\n    this.precedence = precedence;\n  }\n\n  getRuleName() {\n    return this.ruleName;\n  }\n\n  getParentNode() {\n    return this.parentNode;\n  }\n\n  getChildNodes() {\n    return this.childNodes;\n  }\n\n  getOpacity() {\n    return this.opacity;\n  }\n\n  getPrecedence() {\n    return this.precedence;\n  }\n\n  setRuleName(ruleName) {\n    this.ruleName = ruleName;\n  }\n\n  setChildNodes(childNodes) {\n    this.childNodes = childNodes;\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 opaque = (this.opacity === semiOpaqueSpecialSymbol);\n\n    return opaque;\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  isLowerPrecedence(ruleName, precedence) {\n    let lowerPrecedence;\n\n    if (false) {\n      ///\n    } else if (this.precedence === null) {\n      lowerPrecedence = false;\n    } else if (this.precedence === Infinity) {\n      const firstChildNode = first(this.childNodes);\n\n      lowerPrecedence = firstChildNode.isLowerPrecedence(ruleName, precedence);\n    } else {\n      lowerPrecedence = ((this.ruleName === ruleName) && (this.precedence < precedence));\n    }\n\n    return lowerPrecedence;\n  }\n\n  getFirstSignificantTokenIndex(tokens) {\n    let firstSignificantTokenIndex;\n\n    forwardsSome(this.childNodes, (childNode) => {\n      const node = childNode; ///\n\n      firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens);\n\n      if (firstSignificantTokenIndex !== null) {\n        return true;\n      }\n    });\n\n    return firstSignificantTokenIndex;\n  }\n\n  getLastSignificantTokenIndex(tokens) {\n    let lastSignificantTokenIndex;\n\n    backwardsSome(this.childNodes, (childNode) => {\n      const node = childNode; ///\n\n      lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens);\n\n      if (lastSignificantTokenIndex !== null) {\n        return true;\n      }\n    });\n\n    return lastSignificantTokenIndex;\n  }\n\n  getSignificantTokens(significantTokens = []) {\n    this.childNodes.forEach((childNode) => {\n      childNode.getSignificantTokens(significantTokens);\n    });\n\n    return significantTokens;\n  }\n\n  getAncestorNodes() {\n    const ancestorNodes = [];\n\n    let parentNode = this.parentNode;\n\n    while (parentNode !== null) {\n      const ancestorNode = parentNode;  ///\n\n      ancestorNodes.push(ancestorNode);\n\n      parentNode = parentNode.getParentNode();\n    }\n\n    return ancestorNodes;\n  }\n\n  isUnprecedented() {\n    let unprecedented = false;\n\n    if (this.precedence !== null) {\n      unprecedented = this.childNodes.some((childNode) => {  ///\n        const childNodeLowerPrecedence = childNode.isLowerPrecedence(this.ruleName, this.precedence);\n\n        if (childNodeLowerPrecedence) {\n          return true;\n        }\n      });\n    }\n\n    return unprecedented;\n  }\n\n  isIncludedIn(node) {\n    let includedIn = false;\n\n    if (this === node) {\n      includedIn = true;\n    } else {\n      const nodeNonTerminalNode = node.isNonTerminalNode();\n\n      if (nodeNonTerminalNode) {\n        const nonTerminalNode = node, ///\n              childNodes = nonTerminalNode.getChildNodes();\n\n        includedIn = childNodes.some((childNode) => {\n          const includedInChildNode = this.isIncludedIn(childNode);\n\n          if (includedInChildNode) {\n            return true;\n          }\n        });\n      }\n    }\n\n    return includedIn;\n  }\n\n  isEmpty() {\n    const childNodesLength = this.childNodes.length,\n          empty = (childNodesLength === 0);\n\n    return empty;\n  }\n\n  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          ruleName = this.ruleName,\n          parentNode = null,\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    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    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}"],"names":["NonTerminalNode","first","arrayUtilities","match","forwardsSome","backwardsSome","opaque","opaqueSpecialSymbol","specialSymbols","semiOpaque","semiOpaqueSpecialSymbol","ruleName","parentNode","childNodes","opacity","precedence","getRuleName","getParentNode","getChildNodes","getOpacity","getPrecedence","setRuleName","setChildNodes","setParentNode","setPrecedence","setOpacity","isOpaque","isSemiOpaque","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","isLowerPrecedence","lowerPrecedence","Infinity","firstChildNode","getFirstSignificantTokenIndex","tokens","firstSignificantTokenIndex","childNode","node","getLastSignificantTokenIndex","lastSignificantTokenIndex","getSignificantTokens","significantTokens","forEach","getAncestorNodes","ancestorNodes","ancestorNode","push","isUnprecedented","unprecedented","some","childNodeLowerPrecedence","isIncludedIn","includedIn","nodeNonTerminalNode","includedInChildNode","isEmpty","childNodesLength","length","empty","depth","exactly","matches","nonTerminalNodeRuleName","nonTerminalNodeOpacity","nonTerminalNodePrecedence","nonTerminalNodeChildNodes","nonTerminalNodeChildNode","childNodeMatchesNonTerminalNodeChildNode","rewrite","rewrittenNonTerminalNode","asParseTree","nonTerminalNodeParseTree","NonTerminalNodeParseTree","fromNonTerminalNodeAndTokens","parseTree","clone","remainingArguments","Class","constructor","cloneChildNodes","fromRuleNameChildNodesAndOpacity","undefined","map"],"mappings":"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"}
398
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/node/nonTerminal.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\nimport { specialSymbols } from \"occam-lexers\";\n\nimport NonTerminalNodeParseTree from \"../parseTree/nonTerminalNode\";\n\nconst { first, match, forwardsSome, backwardsSome } = arrayUtilities,\n      { opaque: opaqueSpecialSymbol , semiOpaque: semiOpaqueSpecialSymbol } = specialSymbols;\n\nexport default class NonTerminalNode {\n  constructor(ruleName, parentNode, childNodes, opacity, precedence) {\n    this.ruleName = ruleName;\n    this.parentNode = parentNode;\n    this.childNodes = childNodes;\n    this.opacity = opacity;\n    this.precedence = precedence;\n  }\n\n  getRuleName() {\n    return this.ruleName;\n  }\n\n  getParentNode() {\n    return this.parentNode;\n  }\n\n  getChildNodes() {\n    return this.childNodes;\n  }\n\n  getOpacity() {\n    return this.opacity;\n  }\n\n  getPrecedence() {\n    return this.precedence;\n  }\n\n  setRuleName(ruleName) {\n    this.ruleName = ruleName;\n  }\n\n  setChildNodes(childNodes) {\n    this.childNodes = childNodes;\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 opaque = (this.opacity === semiOpaqueSpecialSymbol);\n\n    return opaque;\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  isLowerPrecedence(ruleName, precedence) {\n    let lowerPrecedence;\n\n    if (false) {\n      ///\n    } else if (this.precedence === null) {\n      lowerPrecedence = false;\n    } else if (this.precedence === Infinity) {\n      const firstChildNode = first(this.childNodes);\n\n      lowerPrecedence = firstChildNode.isLowerPrecedence(ruleName, precedence);\n    } else {\n      lowerPrecedence = ((this.ruleName === ruleName) && (this.precedence < precedence));\n    }\n\n    return lowerPrecedence;\n  }\n\n  getFirstSignificantTokenIndex(tokens) {\n    let firstSignificantTokenIndex;\n\n    forwardsSome(this.childNodes, (childNode) => {\n      const node = childNode; ///\n\n      firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens);\n\n      if (firstSignificantTokenIndex !== null) {\n        return true;\n      }\n    });\n\n    return firstSignificantTokenIndex;\n  }\n\n  getLastSignificantTokenIndex(tokens) {\n    let lastSignificantTokenIndex;\n\n    backwardsSome(this.childNodes, (childNode) => {\n      const node = childNode; ///\n\n      lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens);\n\n      if (lastSignificantTokenIndex !== null) {\n        return true;\n      }\n    });\n\n    return lastSignificantTokenIndex;\n  }\n\n  getSignificantTokens(significantTokens = []) {\n    this.childNodes.forEach((childNode) => {\n      childNode.getSignificantTokens(significantTokens);\n    });\n\n    return significantTokens;\n  }\n\n  getAncestorNodes() {\n    const ancestorNodes = [];\n\n    let parentNode = this.parentNode;\n\n    while (parentNode !== null) {\n      const ancestorNode = parentNode;  ///\n\n      ancestorNodes.push(ancestorNode);\n\n      parentNode = parentNode.getParentNode();\n    }\n\n    return ancestorNodes;\n  }\n\n  isUnprecedented() {\n    let unprecedented = false;\n\n    if (this.precedence !== null) {\n      unprecedented = this.childNodes.some((childNode) => {  ///\n        const childNodeLowerPrecedence = childNode.isLowerPrecedence(this.ruleName, this.precedence);\n\n        if (childNodeLowerPrecedence) {\n          return true;\n        }\n      });\n    }\n\n    return unprecedented;\n  }\n\n  isIncludedIn(node) {\n    let includedIn = false;\n\n    if (this === node) {\n      includedIn = true;\n    } else {\n      const nodeNonTerminalNode = node.isNonTerminalNode();\n\n      if (nodeNonTerminalNode) {\n        const nonTerminalNode = node, ///\n              childNodes = nonTerminalNode.getChildNodes();\n\n        includedIn = childNodes.some((childNode) => {\n          const includedInChildNode = this.isIncludedIn(childNode);\n\n          if (includedInChildNode) {\n            return true;\n          }\n        });\n      }\n    }\n\n    return includedIn;\n  }\n\n  isEmpty() {\n    const childNodesLength = this.childNodes.length,\n          empty = (childNodesLength === 0);\n\n    return empty;\n  }\n\n  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  cloneChildNodes() {\n    const parentNode = this,  ///\n          childNodes = this.childNodes.map((childNode) => {\n            childNode = childNode.clone(parentNode);  ///\n\n            return childNode;\n          });\n\n    return childNodes;\n  }\n\n  clone(parentNode = null) {\n    const Class = this.constructor,\n          ruleName = this.ruleName,\n          childNodes = this.cloneChildNodes(),\n          opacity = this.opacity,\n          precedence = this.precedence,\n          nonTerminalNode = new Class(ruleName, parentNode, childNodes, opacity, precedence);\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    return nonTerminalNode;\n  }\n}\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","setParentNode","setPrecedence","setOpacity","isOpaque","isSemiOpaque","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","isLowerPrecedence","lowerPrecedence","Infinity","firstChildNode","getFirstSignificantTokenIndex","tokens","firstSignificantTokenIndex","childNode","node","getLastSignificantTokenIndex","lastSignificantTokenIndex","getSignificantTokens","significantTokens","forEach","getAncestorNodes","ancestorNodes","ancestorNode","push","isUnprecedented","unprecedented","some","childNodeLowerPrecedence","isIncludedIn","includedIn","nodeNonTerminalNode","includedInChildNode","isEmpty","childNodesLength","length","empty","depth","exactly","matches","nonTerminalNodeRuleName","nonTerminalNodeOpacity","nonTerminalNodePrecedence","nonTerminalNodeChildNodes","nonTerminalNodeChildNode","childNodeMatchesNonTerminalNodeChildNode","rewrite","rewrittenNonTerminalNode","asParseTree","nonTerminalNodeParseTree","NonTerminalNodeParseTree","fromNonTerminalNodeAndTokens","parseTree","cloneChildNodes","map","clone","Class","constructor","fromRuleNameChildNodesAndOpacity","remainingArguments","undefined"],"mappings":"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"}
@@ -274,13 +274,8 @@ var TerminalNode = /*#__PURE__*/ function() {
274
274
  {
275
275
  key: "clone",
276
276
  value: function clone() {
277
- for(var _len = arguments.length, remainingArguments = new Array(_len), _key = 0; _key < _len; _key++){
278
- remainingArguments[_key] = arguments[_key];
279
- }
280
- var Class = this.constructor, parentNode = null, significantToken = this.significantToken, terminalNode = _construct(Class, [
281
- parentNode,
282
- significantToken
283
- ].concat(_to_consumable_array(remainingArguments)));
277
+ var parentNode = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : null;
278
+ var Class = this.constructor, significantToken = this.significantToken, terminalNode = new Class(parentNode, significantToken);
284
279
  return terminalNode;
285
280
  }
286
281
  }
@@ -322,4 +317,4 @@ var TerminalNode = /*#__PURE__*/ function() {
322
317
  return TerminalNode;
323
318
  }();
324
319
 
325
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/node/terminal.js"],"sourcesContent":["\"use strict\";\n\nimport TerminalNodeParseTree from \"../parseTree/terminalNode\";\n\nexport default class TerminalNode {\n  constructor(parentNode, significantToken) {\n    this.parentNode = parentNode;\n    this.significantToken = significantToken;\n  }\n\n  getParentNode() {\n    return this.parentNode;\n  }\n\n  getSignificantToken() {\n    return this.significantToken;\n  }\n\n  setParentNode(parentNode) {\n    this.parentNode = parentNode;\n  }\n\n  setSignificantToken(significantToken) {\n    this.significantToken = significantToken;\n  }\n\n  isStartOfContentNode() {\n    const startOfContentNode = false;\n\n    return startOfContentNode;\n  }\n\n  isNoWhitespaceNode() {\n    const noWhitespaceNode = false;\n\n    return noWhitespaceNode;\n  }\n\n  isEpsilonNode() {\n    const epsilonNode = false;\n\n    return epsilonNode;\n  }\n\n  isTerminalNode() {\n    const terminalNode = true;\n    \n    return terminalNode;\n  }\n\n  isNonTerminalNode() {\n    const nonTerminalNode = false;\n\n    return nonTerminalNode;\n  }\n\n  getType() { return this.significantToken.getType(); }\n\n  getContent() { return this.significantToken.getContent(); }\n\n  getPrecedence()  {\n    const precedence = null;\n\n    return precedence;\n  }\n\n  isLowerPrecedence(parentRuleName, parentPrecedence) {\n    const lowerPrecedence = false;\n\n    return lowerPrecedence;\n  }\n\n  getFirstSignificantTokenIndex(tokens) {\n    const significantTokenIndex = this.getSignificantTokenIndex(tokens),\n          firstSignificantTokenIndex = significantTokenIndex; ///\n\n    return firstSignificantTokenIndex;\n  }\n\n  getLastSignificantTokenIndex(tokens) {\n    const significantTokenIndex = this.getSignificantTokenIndex(tokens),\n          lastSignificantTokenIndex = significantTokenIndex; ///\n\n    return lastSignificantTokenIndex;\n  }\n\n  getSignificantTokenIndex(tokens) {\n    let significantTokenIndex = null;\n\n    if (this.significantToken !== null) {\n      significantTokenIndex = tokens.indexOf(this.significantToken);\n    }\n\n    return significantTokenIndex;\n  }\n\n  getSignificantTokens(significantTokens = []) {\n    if (this.significantToken !== null) {\n      significantTokens.push(this.significantToken);\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  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  match(node, depth = Infinity, exactly = false) {\n    let matches = false;\n\n    const nodeTerminalNode = node.isTerminalNode();\n\n    if (nodeTerminalNode) {\n      const terminalNode = node,  ///\n            significantToken = terminalNode.getSignificantToken();\n\n      matches = exactly ?\n                  (this.significantToken === significantToken) :\n                     this.significantToken.match(significantToken);\n    }\n\n    return matches;\n  }\n\n  asParseTree(tokens) {\n    const terminalNode = this,  ///\n          terminalNodeParseTree = TerminalNodeParseTree.fromTerminalNodeAndTokens(terminalNode, tokens),\n          parseTree = terminalNodeParseTree;  ///\n\n    return parseTree;\n  }\n\n  clone(...remainingArguments) {\n    const Class = this.constructor,\n          parentNode = null,\n          significantToken = this.significantToken,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n\n    return terminalNode;\n  }\n\n  static fromNothing(Class, ...remainingArguments) {\n    if (Class === undefined) {\n      Class = TerminalNode; ///\n    }\n\n    const parentNode = null,\n          significantToken = null,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n\n    return terminalNode;\n  }\n\n  static fromSignificantToken(Class, significantToken, ...remainingArguments) {\n    if (significantToken === undefined) {\n      significantToken = Class; ///\n\n      Class = TerminalNode; ///\n    }\n\n    const parentNode = null,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n    \n    return terminalNode;\n  }\n}\n"],"names":["TerminalNode","parentNode","significantToken","getParentNode","getSignificantToken","setParentNode","setSignificantToken","isStartOfContentNode","startOfContentNode","isNoWhitespaceNode","noWhitespaceNode","isEpsilonNode","epsilonNode","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","getType","getContent","getPrecedence","precedence","isLowerPrecedence","parentRuleName","parentPrecedence","lowerPrecedence","getFirstSignificantTokenIndex","tokens","significantTokenIndex","getSignificantTokenIndex","firstSignificantTokenIndex","getLastSignificantTokenIndex","lastSignificantTokenIndex","indexOf","getSignificantTokens","significantTokens","push","getAncestorNodes","ancestorNodes","ancestorNode","isIncludedIn","node","includedIn","nodeNonTerminalNode","childNodes","getChildNodes","some","childNode","includedInChildNode","match","depth","Infinity","exactly","matches","nodeTerminalNode","asParseTree","terminalNodeParseTree","TerminalNodeParseTree","fromTerminalNodeAndTokens","parseTree","clone","remainingArguments","Class","constructor","fromNothing","undefined","fromSignificantToken"],"mappings":"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"}
320
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/node/terminal.js"],"sourcesContent":["\"use strict\";\n\nimport TerminalNodeParseTree from \"../parseTree/terminalNode\";\n\nexport default class TerminalNode {\n  constructor(parentNode, significantToken) {\n    this.parentNode = parentNode;\n    this.significantToken = significantToken;\n  }\n\n  getParentNode() {\n    return this.parentNode;\n  }\n\n  getSignificantToken() {\n    return this.significantToken;\n  }\n\n  setParentNode(parentNode) {\n    this.parentNode = parentNode;\n  }\n\n  setSignificantToken(significantToken) {\n    this.significantToken = significantToken;\n  }\n\n  isStartOfContentNode() {\n    const startOfContentNode = false;\n\n    return startOfContentNode;\n  }\n\n  isNoWhitespaceNode() {\n    const noWhitespaceNode = false;\n\n    return noWhitespaceNode;\n  }\n\n  isEpsilonNode() {\n    const epsilonNode = false;\n\n    return epsilonNode;\n  }\n\n  isTerminalNode() {\n    const terminalNode = true;\n    \n    return terminalNode;\n  }\n\n  isNonTerminalNode() {\n    const nonTerminalNode = false;\n\n    return nonTerminalNode;\n  }\n\n  getType() { return this.significantToken.getType(); }\n\n  getContent() { return this.significantToken.getContent(); }\n\n  getPrecedence()  {\n    const precedence = null;\n\n    return precedence;\n  }\n\n  isLowerPrecedence(parentRuleName, parentPrecedence) {\n    const lowerPrecedence = false;\n\n    return lowerPrecedence;\n  }\n\n  getFirstSignificantTokenIndex(tokens) {\n    const significantTokenIndex = this.getSignificantTokenIndex(tokens),\n          firstSignificantTokenIndex = significantTokenIndex; ///\n\n    return firstSignificantTokenIndex;\n  }\n\n  getLastSignificantTokenIndex(tokens) {\n    const significantTokenIndex = this.getSignificantTokenIndex(tokens),\n          lastSignificantTokenIndex = significantTokenIndex; ///\n\n    return lastSignificantTokenIndex;\n  }\n\n  getSignificantTokenIndex(tokens) {\n    let significantTokenIndex = null;\n\n    if (this.significantToken !== null) {\n      significantTokenIndex = tokens.indexOf(this.significantToken);\n    }\n\n    return significantTokenIndex;\n  }\n\n  getSignificantTokens(significantTokens = []) {\n    if (this.significantToken !== null) {\n      significantTokens.push(this.significantToken);\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  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  match(node, depth = Infinity, exactly = false) {\n    let matches = false;\n\n    const nodeTerminalNode = node.isTerminalNode();\n\n    if (nodeTerminalNode) {\n      const terminalNode = node,  ///\n            significantToken = terminalNode.getSignificantToken();\n\n      matches = exactly ?\n                  (this.significantToken === significantToken) :\n                     this.significantToken.match(significantToken);\n    }\n\n    return matches;\n  }\n\n  asParseTree(tokens) {\n    const terminalNode = this,  ///\n          terminalNodeParseTree = TerminalNodeParseTree.fromTerminalNodeAndTokens(terminalNode, tokens),\n          parseTree = terminalNodeParseTree;  ///\n\n    return parseTree;\n  }\n\n  clone(parentNode = null) {\n    const Class = this.constructor,\n          significantToken = this.significantToken,\n          terminalNode = new Class(parentNode, significantToken);\n\n    return terminalNode;\n  }\n\n  static fromNothing(Class, ...remainingArguments) {\n    if (Class === undefined) {\n      Class = TerminalNode; ///\n    }\n\n    const parentNode = null,\n          significantToken = null,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n\n    return terminalNode;\n  }\n\n  static fromSignificantToken(Class, significantToken, ...remainingArguments) {\n    if (significantToken === undefined) {\n      significantToken = Class; ///\n\n      Class = TerminalNode; ///\n    }\n\n    const parentNode = null,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n    \n    return terminalNode;\n  }\n}\n"],"names":["TerminalNode","parentNode","significantToken","getParentNode","getSignificantToken","setParentNode","setSignificantToken","isStartOfContentNode","startOfContentNode","isNoWhitespaceNode","noWhitespaceNode","isEpsilonNode","epsilonNode","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","getType","getContent","getPrecedence","precedence","isLowerPrecedence","parentRuleName","parentPrecedence","lowerPrecedence","getFirstSignificantTokenIndex","tokens","significantTokenIndex","getSignificantTokenIndex","firstSignificantTokenIndex","getLastSignificantTokenIndex","lastSignificantTokenIndex","indexOf","getSignificantTokens","significantTokens","push","getAncestorNodes","ancestorNodes","ancestorNode","isIncludedIn","node","includedIn","nodeNonTerminalNode","childNodes","getChildNodes","some","childNode","includedInChildNode","match","depth","Infinity","exactly","matches","nodeTerminalNode","asParseTree","terminalNodeParseTree","TerminalNodeParseTree","fromTerminalNodeAndTokens","parseTree","clone","Class","constructor","fromNothing","remainingArguments","undefined","fromSignificantToken"],"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.59",
4
+ "version": "23.0.61",
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.217",
20
- "easy-with-style": "^3.0.440",
19
+ "easy-layout": "^6.0.218",
20
+ "easy-with-style": "^3.0.442",
21
21
  "esbuild": "^0.9.6",
22
22
  "express": "^4.17.1",
23
23
  "juxtapose": "^4.0.117",
@@ -257,14 +257,24 @@ export default class NonTerminalNode {
257
257
  return parseTree;
258
258
  }
259
259
 
260
- clone(...remainingArguments) {
260
+ cloneChildNodes() {
261
+ const parentNode = this, ///
262
+ childNodes = this.childNodes.map((childNode) => {
263
+ childNode = childNode.clone(parentNode); ///
264
+
265
+ return childNode;
266
+ });
267
+
268
+ return childNodes;
269
+ }
270
+
271
+ clone(parentNode = null) {
261
272
  const Class = this.constructor,
262
273
  ruleName = this.ruleName,
263
- parentNode = null,
264
- childNodes = cloneChildNodes(this.childNodes),
274
+ childNodes = this.cloneChildNodes(),
265
275
  opacity = this.opacity,
266
276
  precedence = this.precedence,
267
- nonTerminalNode = new Class(ruleName, parentNode, childNodes, opacity, precedence, ...remainingArguments);
277
+ nonTerminalNode = new Class(ruleName, parentNode, childNodes, opacity, precedence);
268
278
 
269
279
  return nonTerminalNode;
270
280
  }
@@ -288,12 +298,3 @@ export default class NonTerminalNode {
288
298
  }
289
299
  }
290
300
 
291
- function cloneChildNodes(childNodes) {
292
- childNodes = childNodes.map((childNode) => { ///
293
- childNode = childNode.clone(); ///
294
-
295
- return childNode;
296
- });
297
-
298
- return childNodes;
299
- }
@@ -168,11 +168,10 @@ export default class TerminalNode {
168
168
  return parseTree;
169
169
  }
170
170
 
171
- clone(...remainingArguments) {
171
+ clone(parentNode = null) {
172
172
  const Class = this.constructor,
173
- parentNode = null,
174
173
  significantToken = this.significantToken,
175
- terminalNode = new Class(parentNode, significantToken, ...remainingArguments);
174
+ terminalNode = new Class(parentNode, significantToken);
176
175
 
177
176
  return terminalNode;
178
177
  }