occam-parsers 23.0.61 → 23.0.62

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -142,7 +142,16 @@ var NonTerminalNode = /*#__PURE__*/ function() {
142
142
  {
143
143
  key: "setChildNodes",
144
144
  value: function setChildNodes(childNodes) {
145
+ var parentNode;
146
+ parentNode = null;
147
+ this.childNodes.forEach(function(childNode) {
148
+ childNode.setParentNode(parentNode);
149
+ });
145
150
  this.childNodes = childNodes;
151
+ parentNode = this;
152
+ this.childNodes.forEach(function(childNode) {
153
+ childNode.setParentNode(parentNode);
154
+ });
146
155
  }
147
156
  },
148
157
  {
@@ -343,6 +352,26 @@ var NonTerminalNode = /*#__PURE__*/ function() {
343
352
  return rewrittenNonTerminalNode;
344
353
  }
345
354
  },
355
+ {
356
+ key: "replaceChildNodes",
357
+ value: function replaceChildNodes(replacedChildNodes, replacementChildNodes) {
358
+ var _this_childNodes;
359
+ var replacedChildNodesLength = replacedChildNodes.length, firstReplacedChildNode = first(replacedChildNodes), firstIndex = this.childNodes.indexOf(firstReplacedChildNode), start = firstIndex, deleteCount = replacedChildNodesLength; ///
360
+ (_this_childNodes = this.childNodes).splice.apply(_this_childNodes, [
361
+ start,
362
+ deleteCount
363
+ ].concat(_to_consumable_array(replacementChildNodes)));
364
+ var parentNode;
365
+ parentNode = null;
366
+ replacedChildNodes.forEach(function(replacedChildNode) {
367
+ replacedChildNode.setParentNode(parentNode);
368
+ });
369
+ parentNode = this;
370
+ replacementChildNodes.forEach(function(replacementChildNode) {
371
+ replacementChildNode.setParentNode(parentNode);
372
+ });
373
+ }
374
+ },
346
375
  {
347
376
  key: "asParseTree",
348
377
  value: function asParseTree(tokens) {
@@ -395,4 +424,4 @@ var NonTerminalNode = /*#__PURE__*/ function() {
395
424
  return NonTerminalNode;
396
425
  }();
397
426
 
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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"}
427
+ //# 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    let parentNode;\n\n    parentNode = null;\n\n    this.childNodes.forEach((childNode) => {\n      childNode.setParentNode(parentNode);\n    });\n\n    this.childNodes = childNodes;\n\n    parentNode = this;\n\n    this.childNodes.forEach((childNode) => {\n      childNode.setParentNode(parentNode);\n    });\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  replaceChildNodes(replacedChildNodes, replacementChildNodes) {\n    const replacedChildNodesLength = replacedChildNodes.length,\n          firstReplacedChildNode = first(replacedChildNodes),\n          firstIndex = this.childNodes.indexOf(firstReplacedChildNode),\n          start = firstIndex, ///\n          deleteCount = replacedChildNodesLength; ///\n\n    this.childNodes.splice(start, deleteCount, ...replacementChildNodes);\n\n    let parentNode;\n\n    parentNode = null;\n\n    replacedChildNodes.forEach((replacedChildNode) => {\n      replacedChildNode.setParentNode(parentNode);\n    });\n\n    parentNode = this;\n\n    replacementChildNodes.forEach((replacementChildNode) => {\n      replacementChildNode.setParentNode(parentNode);\n    });\n  }\n\n  asParseTree(tokens) {\n    const nonTerminalNode = this,  ///\n          nonTerminalNodeParseTree = NonTerminalNodeParseTree.fromNonTerminalNodeAndTokens(nonTerminalNode, tokens),\n          parseTree = nonTerminalNodeParseTree;  ///\n\n    return parseTree;\n  }\n\n  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","forEach","childNode","setParentNode","setPrecedence","setOpacity","isOpaque","isSemiOpaque","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","isLowerPrecedence","lowerPrecedence","Infinity","firstChildNode","getFirstSignificantTokenIndex","tokens","firstSignificantTokenIndex","node","getLastSignificantTokenIndex","lastSignificantTokenIndex","getSignificantTokens","significantTokens","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","replaceChildNodes","replacedChildNodes","replacementChildNodes","replacedChildNodesLength","firstReplacedChildNode","firstIndex","indexOf","start","deleteCount","splice","replacedChildNode","replacementChildNode","asParseTree","nonTerminalNodeParseTree","NonTerminalNodeParseTree","fromNonTerminalNodeAndTokens","parseTree","cloneChildNodes","map","clone","Class","constructor","fromRuleNameChildNodesAndOpacity","remainingArguments","undefined"],"mappings":"AAAA;;;;;;;eAUqBA;;;yBARU;2BACA;sEAEM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAErC,IAAQC,QAA8CC,yBAAc,CAA5DD,OAAOE,QAAuCD,yBAAc,CAArDC,OAAOC,eAAgCF,yBAAc,CAA9CE,cAAcC,gBAAkBH,yBAAc,CAAhCG,eAC5BC,AAAQC,sBAA8DC,2BAAc,CAApFF,QAA8BG,AAAYC,0BAA4BF,2BAAc,CAAtDC;AAEvB,IAAA,AAAMT,gCAAN;aAAMA,gBACPW,QAAQ,EAAEC,UAAU,EAAEC,UAAU,EAAEC,OAAO,EAAEC,UAAU;gCAD9Cf;QAEjB,IAAI,CAACW,QAAQ,GAAGA;QAChB,IAAI,CAACC,UAAU,GAAGA;QAClB,IAAI,CAACC,UAAU,GAAGA;QAClB,IAAI,CAACC,OAAO,GAAGA;QACf,IAAI,CAACC,UAAU,GAAGA;;kBANDf;;YASnBgB,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACL,QAAQ;YACtB;;;YAEAM,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACL,UAAU;YACxB;;;YAEAM,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACL,UAAU;YACxB;;;YAEAM,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACL,OAAO;YACrB;;;YAEAM,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACL,UAAU;YACxB;;;YAEAM,KAAAA;mBAAAA,SAAAA,YAAYV,QAAQ;gBAClB,IAAI,CAACA,QAAQ,GAAGA;YAClB;;;YAEAW,KAAAA;mBAAAA,SAAAA,cAAcT,UAAU;gBACtB,IAAID;gBAEJA,aAAa;gBAEb,IAAI,CAACC,UAAU,CAACU,OAAO,CAAC,SAACC;oBACvBA,UAAUC,aAAa,CAACb;gBAC1B;gBAEA,IAAI,CAACC,UAAU,GAAGA;gBAElBD,aAAa,IAAI;gBAEjB,IAAI,CAACC,UAAU,CAACU,OAAO,CAAC,SAACC;oBACvBA,UAAUC,aAAa,CAACb;gBAC1B;YACF;;;YAEAa,KAAAA;mBAAAA,SAAAA,cAAcb,UAAU;gBACtB,IAAI,CAACA,UAAU,GAAGA;YACpB;;;YAEAc,KAAAA;mBAAAA,SAAAA,cAAcX,UAAU;gBACtB,IAAI,CAACA,UAAU,GAAGA;YACpB;;;YAEAY,KAAAA;mBAAAA,SAAAA,WAAWb,OAAO;gBAChB,IAAI,CAACA,OAAO,GAAGA;YACjB;;;YAEAc,KAAAA;mBAAAA,SAAAA;gBACE,IAAMtB,SAAU,IAAI,CAACQ,OAAO,KAAKP;gBAEjC,OAAOD;YACT;;;YAEAuB,KAAAA;mBAAAA,SAAAA;gBACE,IAAMvB,SAAU,IAAI,CAACQ,OAAO,KAAKJ;gBAEjC,OAAOJ;YACT;;;YAEAwB,KAAAA;mBAAAA,SAAAA;gBACE,IAAMC,eAAe;gBAErB,OAAOA;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA;gBACE,IAAMC,kBAAkB;gBAExB,OAAOA;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA,kBAAkBvB,QAAQ,EAAEI,UAAU;gBACpC,IAAIoB;gBAEJ,IAAI,OAAO;gBACT,GAAG;gBACL,OAAO,IAAI,IAAI,CAACpB,UAAU,KAAK,MAAM;oBACnCoB,kBAAkB;gBACpB,OAAO,IAAI,IAAI,CAACpB,UAAU,KAAKqB,UAAU;oBACvC,IAAMC,iBAAiBpC,MAAM,IAAI,CAACY,UAAU;oBAE5CsB,kBAAkBE,eAAeH,iBAAiB,CAACvB,UAAUI;gBAC/D,OAAO;oBACLoB,kBAAmB,AAAC,IAAI,CAACxB,QAAQ,KAAKA,YAAc,IAAI,CAACI,UAAU,GAAGA;gBACxE;gBAEA,OAAOoB;YACT;;;YAEAG,KAAAA;mBAAAA,SAAAA,8BAA8BC,MAAM;gBAClC,IAAIC;gBAEJpC,aAAa,IAAI,CAACS,UAAU,EAAE,SAACW;oBAC7B,IAAMiB,OAAOjB,WAAW,GAAG;oBAE3BgB,6BAA6BC,KAAKH,6BAA6B,CAACC;oBAEhE,IAAIC,+BAA+B,MAAM;wBACvC,OAAO;oBACT;gBACF;gBAEA,OAAOA;YACT;;;YAEAE,KAAAA;mBAAAA,SAAAA,6BAA6BH,MAAM;gBACjC,IAAII;gBAEJtC,cAAc,IAAI,CAACQ,UAAU,EAAE,SAACW;oBAC9B,IAAMiB,OAAOjB,WAAW,GAAG;oBAE3BmB,4BAA4BF,KAAKC,4BAA4B,CAACH;oBAE9D,IAAII,8BAA8B,MAAM;wBACtC,OAAO;oBACT;gBACF;gBAEA,OAAOA;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA;oBAAqBC,oBAAAA,iEAAoB,EAAE;gBACzC,IAAI,CAAChC,UAAU,CAACU,OAAO,CAAC,SAACC;oBACvBA,UAAUoB,oBAAoB,CAACC;gBACjC;gBAEA,OAAOA;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA;gBACE,IAAMC,gBAAgB,EAAE;gBAExB,IAAInC,aAAa,IAAI,CAACA,UAAU;gBAEhC,MAAOA,eAAe,KAAM;oBAC1B,IAAMoC,eAAepC,YAAa,GAAG;oBAErCmC,cAAcE,IAAI,CAACD;oBAEnBpC,aAAaA,WAAWK,aAAa;gBACvC;gBAEA,OAAO8B;YACT;;;YAEAG,KAAAA;mBAAAA,SAAAA;;gBACE,IAAIC,gBAAgB;gBAEpB,IAAI,IAAI,CAACpC,UAAU,KAAK,MAAM;oBAC5BoC,gBAAgB,IAAI,CAACtC,UAAU,CAACuC,IAAI,CAAC,SAAC5B;wBACpC,IAAM6B,2BAA2B7B,UAAUU,iBAAiB,CAAC,MAAKvB,QAAQ,EAAE,MAAKI,UAAU;wBAE3F,IAAIsC,0BAA0B;4BAC5B,OAAO;wBACT;oBACF;gBACF;gBAEA,OAAOF;YACT;;;YAEAG,KAAAA;mBAAAA,SAAAA,aAAab,IAAI;;gBACf,IAAIc,aAAa;gBAEjB,IAAI,IAAI,KAAKd,MAAM;oBACjBc,aAAa;gBACf,OAAO;oBACL,IAAMC,sBAAsBf,KAAKT,iBAAiB;oBAElD,IAAIwB,qBAAqB;wBACvB,IAAMvB,kBAAkBQ,MAClB5B,aAAaoB,gBAAgBf,aAAa;wBAEhDqC,aAAa1C,WAAWuC,IAAI,CAAC,SAAC5B;4BAC5B,IAAMiC,sBAAsB,MAAKH,YAAY,CAAC9B;4BAE9C,IAAIiC,qBAAqB;gCACvB,OAAO;4BACT;wBACF;oBACF;gBACF;gBAEA,OAAOF;YACT;;;YAEAG,KAAAA;mBAAAA,SAAAA;gBACE,IAAMC,mBAAmB,IAAI,CAAC9C,UAAU,CAAC+C,MAAM,EACzCC,QAASF,qBAAqB;gBAEpC,OAAOE;YACT;;;YAEA1D,KAAAA;mBAAAA,SAAAA,OAAMsC,IAAI;oBAAEqB,QAAAA,iEAAQ1B,UAAU2B,UAAAA,iEAAU;gBACtC,IAAIC,UAAU;gBAEd,IAAMR,sBAAsBf,KAAKT,iBAAiB;gBAElD,IAAIwB,qBAAqB;oBACvB,IAAMvB,kBAAkBQ,MAClBwB,0BAA0BhC,gBAAgBjB,WAAW;oBAE3D,IAAI,IAAI,CAACL,QAAQ,KAAKsD,yBAAyB;wBAC7C,IAAMC,yBAAyBjC,gBAAgBd,UAAU;wBAEzD,IAAI,IAAI,CAACL,OAAO,KAAKoD,wBAAwB;4BAC3C,IAAMnD,aAAa,IAAI,CAACK,aAAa,IAC/B+C,4BAA4BlC,gBAAgBb,aAAa;4BAE/D,IAAIL,eAAeoD,2BAA2B;gCAC5CL;gCAEA,IAAIA,UAAU,GAAG;oCACfE,UAAU;gCACZ,OAAO;oCACL,IAAMI,4BAA4BnC,gBAAgBf,aAAa;oCAE/D8C,UAAU7D,MAAM,IAAI,CAACU,UAAU,EAAEuD,2BAA2B,SAAC5C,WAAW6C;wCACtE,IAAMC,2CAA2C9C,UAAUrB,KAAK,CAACkE,0BAA0BP,OAAOC;wCAElG,IAAIO,0CAA0C;4CAC5C,OAAO;wCACT;oCACF;gCACF;4BACF;wBACF;oBACF;gBACF;gBAEA,OAAON;YACT;;;YAEAO,KAAAA;mBAAAA,SAAAA;gBACE,IAAMC,2BAA2B;gBAEjC,OAAOA;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA,kBAAkBC,kBAAkB,EAAEC,qBAAqB;oBAOzD;gBANA,IAAMC,2BAA2BF,mBAAmBd,MAAM,EACpDiB,yBAAyB5E,MAAMyE,qBAC/BI,aAAa,IAAI,CAACjE,UAAU,CAACkE,OAAO,CAACF,yBACrCG,QAAQF,YACRG,cAAcL,0BAA0B,GAAG;gBAEjD,CAAA,mBAAA,IAAI,CAAC/D,UAAU,EAACqE,MAAM,OAAtB,kBAAA;oBAAuBF;oBAAOC;iBAAsC,CAApE,OAA2C,qBAAGN;gBAE9C,IAAI/D;gBAEJA,aAAa;gBAEb8D,mBAAmBnD,OAAO,CAAC,SAAC4D;oBAC1BA,kBAAkB1D,aAAa,CAACb;gBAClC;gBAEAA,aAAa,IAAI;gBAEjB+D,sBAAsBpD,OAAO,CAAC,SAAC6D;oBAC7BA,qBAAqB3D,aAAa,CAACb;gBACrC;YACF;;;YAEAyE,KAAAA;mBAAAA,SAAAA,YAAY9C,MAAM;gBAChB,IAAMN,kBAAkB,IAAI,EACtBqD,2BAA2BC,wBAAwB,CAACC,4BAA4B,CAACvD,iBAAiBM,SAClGkD,YAAYH,0BAA2B,GAAG;gBAEhD,OAAOG;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA;gBACE,IAAM9E,aAAa,IAAI,EACjBC,aAAa,IAAI,CAACA,UAAU,CAAC8E,GAAG,CAAC,SAACnE;oBAChCA,YAAYA,UAAUoE,KAAK,CAAChF,aAAc,GAAG;oBAE7C,OAAOY;gBACT;gBAEN,OAAOX;YACT;;;YAEA+E,KAAAA;mBAAAA,SAAAA;oBAAMhF,aAAAA,iEAAa;gBACjB,IAAMiF,QAAQ,IAAI,CAACC,WAAW,EACxBnF,WAAW,IAAI,CAACA,QAAQ,EACxBE,aAAa,IAAI,CAAC6E,eAAe,IACjC5E,UAAU,IAAI,CAACA,OAAO,EACtBC,aAAa,IAAI,CAACA,UAAU,EAC5BkB,kBAAkB,IAAI4D,MAAMlF,UAAUC,YAAYC,YAAYC,SAASC;gBAE7E,OAAOkB;YACT;;;;YAEO8D,KAAAA;mBAAP,SAAOA,iCAAiCF,KAAK,EAAElF,QAAQ,EAAEE,UAAU,EAAEC,OAAO;gBAAE,IAAA,IAAA,OAAA,UAAA,QAAA,AAAGkF,qBAAH,UAAA,OAAA,IAAA,OAAA,QAAA,OAAA,GAAA,OAAA,MAAA;oBAAGA,mBAAH,OAAA,KAAA,SAAA,CAAA,KAAqB;;gBACjG,IAAIlF,YAAYmF,WAAW;oBACzBnF,UAAUD,YAAY,GAAG;oBAEzBA,aAAaF,UAAW,GAAG;oBAE3BA,WAAWkF,OAAO,GAAG;oBAErBA,QA7Te7F,iBA6TW,GAAG;gBAC/B;gBAEA,IAAMY,aAAa,MACbG,aAAa,MACbkB,kBAAkB,WAAI4D,OAAJ;oBAAUlF;oBAAUC;oBAAYC;oBAAYC;oBAASC;iBAAkC,CAAvF,OAAiE,qBAAGiF;gBAE5F,OAAO/D;YACT;;;WArUmBjC"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "occam-parsers",
3
3
  "author": "James Smith",
4
- "version": "23.0.61",
4
+ "version": "23.0.62",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/occam-parsers",
7
7
  "description": "Occam's parsers.",
@@ -42,7 +42,21 @@ export default class NonTerminalNode {
42
42
  }
43
43
 
44
44
  setChildNodes(childNodes) {
45
+ let parentNode;
46
+
47
+ parentNode = null;
48
+
49
+ this.childNodes.forEach((childNode) => {
50
+ childNode.setParentNode(parentNode);
51
+ });
52
+
45
53
  this.childNodes = childNodes;
54
+
55
+ parentNode = this;
56
+
57
+ this.childNodes.forEach((childNode) => {
58
+ childNode.setParentNode(parentNode);
59
+ });
46
60
  }
47
61
 
48
62
  setParentNode(parentNode) {
@@ -249,6 +263,30 @@ export default class NonTerminalNode {
249
263
  return rewrittenNonTerminalNode;
250
264
  }
251
265
 
266
+ replaceChildNodes(replacedChildNodes, replacementChildNodes) {
267
+ const replacedChildNodesLength = replacedChildNodes.length,
268
+ firstReplacedChildNode = first(replacedChildNodes),
269
+ firstIndex = this.childNodes.indexOf(firstReplacedChildNode),
270
+ start = firstIndex, ///
271
+ deleteCount = replacedChildNodesLength; ///
272
+
273
+ this.childNodes.splice(start, deleteCount, ...replacementChildNodes);
274
+
275
+ let parentNode;
276
+
277
+ parentNode = null;
278
+
279
+ replacedChildNodes.forEach((replacedChildNode) => {
280
+ replacedChildNode.setParentNode(parentNode);
281
+ });
282
+
283
+ parentNode = this;
284
+
285
+ replacementChildNodes.forEach((replacementChildNode) => {
286
+ replacementChildNode.setParentNode(parentNode);
287
+ });
288
+ }
289
+
252
290
  asParseTree(tokens) {
253
291
  const nonTerminalNode = this, ///
254
292
  nonTerminalNodeParseTree = NonTerminalNodeParseTree.fromNonTerminalNodeAndTokens(nonTerminalNode, tokens),