occam-languages 0.0.206 → 0.0.207

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/lib/index.js CHANGED
@@ -30,6 +30,9 @@ _export(exports, {
30
30
  get ForwardPass () {
31
31
  return _forward.default;
32
32
  },
33
+ get ForwardZipPass () {
34
+ return _forwardZip.default;
35
+ },
33
36
  get Log () {
34
37
  return _log.default;
35
38
  },
@@ -75,6 +78,7 @@ const _zip = /*#__PURE__*/ _interop_require_default(require("./pass/zip"));
75
78
  const _async = /*#__PURE__*/ _interop_require_default(require("./pass/async"));
76
79
  const _simple = /*#__PURE__*/ _interop_require_default(require("./pass/simple"));
77
80
  const _forward = /*#__PURE__*/ _interop_require_default(require("./pass/forward"));
81
+ const _forwardZip = /*#__PURE__*/ _interop_require_default(require("./pass/forwardZip"));
78
82
  const _equivalence = /*#__PURE__*/ _interop_require_default(require("./pass/equivalence"));
79
83
  const _node = /*#__PURE__*/ _interop_require_default(require("./utilities/node"));
80
84
  const _query = /*#__PURE__*/ _interop_require_default(require("./utilities/query"));
@@ -88,4 +92,4 @@ function _interop_require_default(obj) {
88
92
  };
89
93
  }
90
94
 
91
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuZXhwb3J0IHsgZGVmYXVsdCBhcyBMb2cgfSBmcm9tIFwiLi9sb2dcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgRWxlbWVudCB9IGZyb20gXCIuL2VsZW1lbnRcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgQ29udGV4dCB9IGZyb20gXCIuL2NvbnRleHRcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgQnJlYWtQb2ludCB9IGZyb20gXCIuL2JyZWFrUG9pbnRcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgRmlsZUNvbnRleHQgfSBmcm9tIFwiLi9jb250ZXh0L2ZpbGVcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgUmVsZWFzZUNvbnRleHQgfSBmcm9tIFwiLi9jb250ZXh0L3JlbGVhc2VcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgTm9uVGVybWluYWxOb2RlIH0gZnJvbSBcIi4vbm9uVGVybWluYWxOb2RlXCI7XG5cbmV4cG9ydCB7IGRlZmF1bHQgYXMgWmlwUGFzcyB9IGZyb20gXCIuL3Bhc3MvemlwXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEFzeW5jUGFzcyB9IGZyb20gXCIuL3Bhc3MvYXN5bmNcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgU2ltcGxlUGFzcyB9IGZyb20gXCIuL3Bhc3Mvc2ltcGxlXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEZvcndhcmRQYXNzIH0gZnJvbSBcIi4vcGFzcy9mb3J3YXJkXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEVxdWl2YWxlbmNlUGFzcyB9IGZyb20gXCIuL3Bhc3MvZXF1aXZhbGVuY2VcIjtcblxuZXhwb3J0IHsgZGVmYXVsdCBhcyBub2RlVXRpbGl0aWVzIH0gZnJvbSBcIi4vdXRpbGl0aWVzL25vZGVcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgcXVlcnlVdGlsaXRpZXMgfSBmcm9tIFwiLi91dGlsaXRpZXMvcXVlcnlcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgZmlsZUNvbnRleHRVdGlsaXRpZXMgfSBmcm9tIFwiLi91dGlsaXRpZXMvZmlsZUNvbnRleHRcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgdmVyaWZpY2F0aW9uVXRpbGl0aWVzIH0gZnJvbSBcIi4vdXRpbGl0aWVzL3ZlcmlmaWNhdGlvblwiO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBhc3luY2hyb25vdXNVdGlsaXRpZXMgfSBmcm9tIFwiLi91dGlsaXRpZXMvYXN5bmNocm9ub3VzXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIHJlbGVhc2VDb250ZXh0VXRpbGl0aWVzIH0gZnJvbSBcIi4vdXRpbGl0aWVzL3JlbGVhc2VDb250ZXh0XCI7XG4iXSwibmFtZXMiOlsiQXN5bmNQYXNzIiwiQnJlYWtQb2ludCIsIkNvbnRleHQiLCJFbGVtZW50IiwiRXF1aXZhbGVuY2VQYXNzIiwiRmlsZUNvbnRleHQiLCJGb3J3YXJkUGFzcyIsIkxvZyIsIk5vblRlcm1pbmFsTm9kZSIsIlJlbGVhc2VDb250ZXh0IiwiU2ltcGxlUGFzcyIsIlppcFBhc3MiLCJhc3luY2hyb25vdXNVdGlsaXRpZXMiLCJmaWxlQ29udGV4dFV0aWxpdGllcyIsIm5vZGVVdGlsaXRpZXMiLCJxdWVyeVV0aWxpdGllcyIsInJlbGVhc2VDb250ZXh0VXRpbGl0aWVzIiwidmVyaWZpY2F0aW9uVXRpbGl0aWVzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7UUFXb0JBO2VBQUFBLGNBQVM7O1FBTlRDO2VBQUFBLG1CQUFVOztRQURWQztlQUFBQSxnQkFBTzs7UUFEUEM7ZUFBQUEsZ0JBQU87O1FBV1BDO2VBQUFBLG9CQUFlOztRQVJmQztlQUFBQSxhQUFXOztRQU9YQztlQUFBQSxnQkFBVzs7UUFYWEM7ZUFBQUEsWUFBRzs7UUFNSEM7ZUFBQUEsd0JBQWU7O1FBRGZDO2VBQUFBLGdCQUFjOztRQUtkQztlQUFBQSxlQUFVOztRQUZWQztlQUFBQSxZQUFPOztRQVVQQztlQUFBQSxxQkFBcUI7O1FBRnJCQztlQUFBQSxvQkFBb0I7O1FBRnBCQztlQUFBQSxhQUFhOztRQUNiQztlQUFBQSxjQUFjOztRQUlkQztlQUFBQSx1QkFBdUI7O1FBRnZCQztlQUFBQSxxQkFBcUI7Ozs0REFqQlY7Z0VBQ0k7Z0VBQ0E7bUVBQ0c7NkRBQ0M7Z0VBQ0c7d0VBQ0M7NERBRVI7OERBQ0U7K0RBQ0M7Z0VBQ0M7b0VBQ0k7NkRBRUY7OERBQ0M7b0VBQ007cUVBQ0M7cUVBQ0E7dUVBQ0UifQ==
95
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuZXhwb3J0IHsgZGVmYXVsdCBhcyBMb2cgfSBmcm9tIFwiLi9sb2dcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgRWxlbWVudCB9IGZyb20gXCIuL2VsZW1lbnRcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgQ29udGV4dCB9IGZyb20gXCIuL2NvbnRleHRcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgQnJlYWtQb2ludCB9IGZyb20gXCIuL2JyZWFrUG9pbnRcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgRmlsZUNvbnRleHQgfSBmcm9tIFwiLi9jb250ZXh0L2ZpbGVcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgUmVsZWFzZUNvbnRleHQgfSBmcm9tIFwiLi9jb250ZXh0L3JlbGVhc2VcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgTm9uVGVybWluYWxOb2RlIH0gZnJvbSBcIi4vbm9uVGVybWluYWxOb2RlXCI7XG5cbmV4cG9ydCB7IGRlZmF1bHQgYXMgWmlwUGFzcyB9IGZyb20gXCIuL3Bhc3MvemlwXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEFzeW5jUGFzcyB9IGZyb20gXCIuL3Bhc3MvYXN5bmNcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgU2ltcGxlUGFzcyB9IGZyb20gXCIuL3Bhc3Mvc2ltcGxlXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEZvcndhcmRQYXNzIH0gZnJvbSBcIi4vcGFzcy9mb3J3YXJkXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEZvcndhcmRaaXBQYXNzIH0gZnJvbSBcIi4vcGFzcy9mb3J3YXJkWmlwXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEVxdWl2YWxlbmNlUGFzcyB9IGZyb20gXCIuL3Bhc3MvZXF1aXZhbGVuY2VcIjtcblxuZXhwb3J0IHsgZGVmYXVsdCBhcyBub2RlVXRpbGl0aWVzIH0gZnJvbSBcIi4vdXRpbGl0aWVzL25vZGVcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgcXVlcnlVdGlsaXRpZXMgfSBmcm9tIFwiLi91dGlsaXRpZXMvcXVlcnlcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgZmlsZUNvbnRleHRVdGlsaXRpZXMgfSBmcm9tIFwiLi91dGlsaXRpZXMvZmlsZUNvbnRleHRcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgdmVyaWZpY2F0aW9uVXRpbGl0aWVzIH0gZnJvbSBcIi4vdXRpbGl0aWVzL3ZlcmlmaWNhdGlvblwiO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBhc3luY2hyb25vdXNVdGlsaXRpZXMgfSBmcm9tIFwiLi91dGlsaXRpZXMvYXN5bmNocm9ub3VzXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIHJlbGVhc2VDb250ZXh0VXRpbGl0aWVzIH0gZnJvbSBcIi4vdXRpbGl0aWVzL3JlbGVhc2VDb250ZXh0XCI7XG4iXSwibmFtZXMiOlsiQXN5bmNQYXNzIiwiQnJlYWtQb2ludCIsIkNvbnRleHQiLCJFbGVtZW50IiwiRXF1aXZhbGVuY2VQYXNzIiwiRmlsZUNvbnRleHQiLCJGb3J3YXJkUGFzcyIsIkZvcndhcmRaaXBQYXNzIiwiTG9nIiwiTm9uVGVybWluYWxOb2RlIiwiUmVsZWFzZUNvbnRleHQiLCJTaW1wbGVQYXNzIiwiWmlwUGFzcyIsImFzeW5jaHJvbm91c1V0aWxpdGllcyIsImZpbGVDb250ZXh0VXRpbGl0aWVzIiwibm9kZVV0aWxpdGllcyIsInF1ZXJ5VXRpbGl0aWVzIiwicmVsZWFzZUNvbnRleHRVdGlsaXRpZXMiLCJ2ZXJpZmljYXRpb25VdGlsaXRpZXMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7OztRQVdvQkE7ZUFBQUEsY0FBUzs7UUFOVEM7ZUFBQUEsbUJBQVU7O1FBRFZDO2VBQUFBLGdCQUFPOztRQURQQztlQUFBQSxnQkFBTzs7UUFZUEM7ZUFBQUEsb0JBQWU7O1FBVGZDO2VBQUFBLGFBQVc7O1FBT1hDO2VBQUFBLGdCQUFXOztRQUNYQztlQUFBQSxtQkFBYzs7UUFaZEM7ZUFBQUEsWUFBRzs7UUFNSEM7ZUFBQUEsd0JBQWU7O1FBRGZDO2VBQUFBLGdCQUFjOztRQUtkQztlQUFBQSxlQUFVOztRQUZWQztlQUFBQSxZQUFPOztRQVdQQztlQUFBQSxxQkFBcUI7O1FBRnJCQztlQUFBQSxvQkFBb0I7O1FBRnBCQztlQUFBQSxhQUFhOztRQUNiQztlQUFBQSxjQUFjOztRQUlkQztlQUFBQSx1QkFBdUI7O1FBRnZCQztlQUFBQSxxQkFBcUI7Ozs0REFsQlY7Z0VBQ0k7Z0VBQ0E7bUVBQ0c7NkRBQ0M7Z0VBQ0c7d0VBQ0M7NERBRVI7OERBQ0U7K0RBQ0M7Z0VBQ0M7bUVBQ0c7b0VBQ0M7NkRBRUY7OERBQ0M7b0VBQ007cUVBQ0M7cUVBQ0E7dUVBQ0UifQ==
@@ -17,19 +17,13 @@ class EquivalencePass {
17
17
  return success;
18
18
  }
19
19
  descend(leftChildNodes, rightChildNodes, ...remainingArguments) {
20
- let descended = false;
21
- const leftChildNodesLength = leftChildNodes.length, rightChildNodesLength = rightChildNodes.length;
22
- if (leftChildNodesLength === rightChildNodesLength) {
23
- const leftTerminalNodeMap = (0, _pass.terminalNodeMapFromNodes)(leftChildNodes), rightTerminalNodeMap = (0, _pass.terminalNodeMapFromNodes)(rightChildNodes), terminalNodeMapsEqual = (0, _pass.areTerminalNodeMapsEqual)(leftTerminalNodeMap, rightTerminalNodeMap);
24
- if (terminalNodeMapsEqual) {
25
- descended = leftChildNodes.every((leftChildNode, index)=>{
26
- const rightChildNode = rightChildNodes[index], leftNode = leftChildNode, rightNode = rightChildNode, visited = this.visitNode(leftNode, rightNode, ...remainingArguments);
27
- if (visited) {
28
- return true;
29
- }
30
- });
20
+ let descended;
21
+ descended = leftChildNodes.every((leftChildNode, index)=>{
22
+ const rightChildNode = rightChildNodes[index], leftNode = leftChildNode, rightNode = rightChildNode, visited = this.visitNode(leftNode, rightNode, ...remainingArguments);
23
+ if (visited) {
24
+ return true;
31
25
  }
32
- }
26
+ });
33
27
  return descended;
34
28
  }
35
29
  visitNode(leftNode, rightNode, ...remainingArguments) {
@@ -63,9 +57,12 @@ class EquivalencePass {
63
57
  let visited = false;
64
58
  const leftNonTerminalNodeRuleName = leftNonTerminalNode.getRuleName(), rightNonTerminalNodeRuleName = rightNonTerminalNode.getRuleName(); ///
65
59
  if (leftNonTerminalNodeRuleName === rightNonTerminalNodeRuleName) {
66
- const leftNonTerminalNodeChildNodes = leftNonTerminalNode.getChildNodes(), rightNonTerminalNodeChildNodes = rightNonTerminalNode.getChildNodes(), leftChildNodes = leftNonTerminalNodeChildNodes, rightChildNodes = rightNonTerminalNodeChildNodes, descended = this.descend(leftChildNodes, rightChildNodes, ...remainingArguments);
67
- if (descended) {
68
- visited = true;
60
+ const leftNonTerminalNodeChildNodes = leftNonTerminalNode.getChildNodes(), rightNonTerminalNodeChildNodes = rightNonTerminalNode.getChildNodes(), leftChildNodes = leftNonTerminalNodeChildNodes, rightChildNodes = rightNonTerminalNodeChildNodes, childNodesCongruent = (0, _pass.areChildNodesCongruent)(leftChildNodes, rightChildNodes);
61
+ if (childNodesCongruent) {
62
+ const descended = this.descend(leftChildNodes, rightChildNodes, ...remainingArguments);
63
+ if (descended) {
64
+ visited = true;
65
+ }
69
66
  }
70
67
  }
71
68
  return visited;
@@ -85,4 +82,4 @@ class EquivalencePass {
85
82
  }
86
83
  }
87
84
 
88
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/pass/equivalence.js"],"sourcesContent":["\"use strict\";\n\nimport { nonTerminalNodeQuery, terminalNodeMapFromNodes, areTerminalNodeMapsEqual } from \"../utilities/pass\";\n\nexport default class EquivalencePass {\n  run(leftNode, rightNode, ...remainingArguments) {\n    let success;\n\n    const visited = this.visitNode(leftNode, rightNode, ...remainingArguments);\n\n    success = visited;  ///\n\n    return success;\n  }\n\n  descend(leftChildNodes, rightChildNodes, ...remainingArguments) {\n    let descended = false;\n\n    const leftChildNodesLength = leftChildNodes.length,\n      rightChildNodesLength = rightChildNodes.length;\n\n    if (leftChildNodesLength === rightChildNodesLength) {\n      const leftTerminalNodeMap = terminalNodeMapFromNodes(leftChildNodes),\n            rightTerminalNodeMap = terminalNodeMapFromNodes(rightChildNodes),\n            terminalNodeMapsEqual = areTerminalNodeMapsEqual(leftTerminalNodeMap, rightTerminalNodeMap);\n\n      if (terminalNodeMapsEqual) {\n        descended = leftChildNodes.every((leftChildNode, index) => {\n          const rightChildNode = rightChildNodes[index],\n                leftNode = leftChildNode, ///\n                rightNode = rightChildNode, ///\n                visited = this.visitNode(leftNode, rightNode, ...remainingArguments);\n\n          if (visited) {\n            return true;\n          }\n        });\n      }\n    }\n\n    return descended;\n  }\n\n  visitNode(leftNode, rightNode, ...remainingArguments) {\n    let visited = false;\n\n    const leftNodeTerminalNode = leftNode.isTerminalNode(),\n          rightNodeTerminalNode = rightNode.isTerminalNode(),\n          leftNodeNonTerminalNode = leftNode.isNonTerminalNode(),\n          rightNodeNonTerminalNode = rightNode.isNonTerminalNode();\n\n    if (false) {\n      ///\n    } else if (leftNodeTerminalNode && rightNodeTerminalNode) {\n      const leftTerminalNode = leftNode,  ///\n            rightTerminalNode = rightNode;  ///\n\n      visited = this.visitTerminalNode(leftTerminalNode, rightTerminalNode, ...remainingArguments);\n    } else if (leftNodeNonTerminalNode && rightNodeNonTerminalNode) {\n      const leftNonTerminalNode = leftNode,  ///\n            rightNonTerminalNode = rightNode; ///\n\n      visited = this.visitNonTerminalNode(leftNonTerminalNode, rightNonTerminalNode, ...remainingArguments);\n    }\n\n    return visited;\n  }\n\n  visitTerminalNode(leftTerminalNode, rightTerminalNode, ...remainingArguments) { ///\n    let visited;\n\n    visited = true;\n\n    return visited;\n  }\n\n  visitNonTerminalNode(leftNonTerminalNode, rightNonTerminalNode, ...remainingArguments) {\n    let visited = false;\n\n    let { maps } = this.constructor;\n\n    maps = [ ///\n      ...maps,\n      {\n        leftNodeQuery: nonTerminalNodeQuery,\n        rightNodeQuery: nonTerminalNodeQuery,\n        run: (leftNode, rightNode, ...remainingArguments) => {\n          let visited = false;\n\n          const leftNonTerminalNodeRuleName = leftNonTerminalNode.getRuleName(), ///\n                rightNonTerminalNodeRuleName = rightNonTerminalNode.getRuleName(); ///\n\n          if (leftNonTerminalNodeRuleName === rightNonTerminalNodeRuleName) {\n            const leftNonTerminalNodeChildNodes = leftNonTerminalNode.getChildNodes(),\n                  rightNonTerminalNodeChildNodes = rightNonTerminalNode.getChildNodes(),\n                  leftChildNodes = leftNonTerminalNodeChildNodes, ///\n                  rightChildNodes = rightNonTerminalNodeChildNodes, ///\n                  descended = this.descend(leftChildNodes, rightChildNodes, ...remainingArguments);\n\n            if (descended) {\n              visited = true;\n            }\n          }\n\n          return visited;\n        }\n      }\n    ]\n\n    maps.some((map) => {\n      const { leftNodeQuery, rightNodeQuery, run } = map;\n\n      const leftNode = leftNodeQuery(leftNonTerminalNode),  ///\n            rightNode = rightNodeQuery(rightNonTerminalNode);  ///\n\n      if ((leftNode !== null) && (rightNode !== null)) {\n        const success = run(leftNode, rightNode, ...remainingArguments);\n\n        visited = success;  ///\n\n        return true;\n      }\n    });\n\n    return visited;\n  }\n}\n"],"names":["EquivalencePass","run","leftNode","rightNode","remainingArguments","success","visited","visitNode","descend","leftChildNodes","rightChildNodes","descended","leftChildNodesLength","length","rightChildNodesLength","leftTerminalNodeMap","terminalNodeMapFromNodes","rightTerminalNodeMap","terminalNodeMapsEqual","areTerminalNodeMapsEqual","every","leftChildNode","index","rightChildNode","leftNodeTerminalNode","isTerminalNode","rightNodeTerminalNode","leftNodeNonTerminalNode","isNonTerminalNode","rightNodeNonTerminalNode","leftTerminalNode","rightTerminalNode","visitTerminalNode","leftNonTerminalNode","rightNonTerminalNode","visitNonTerminalNode","maps","leftNodeQuery","nonTerminalNodeQuery","rightNodeQuery","leftNonTerminalNodeRuleName","getRuleName","rightNonTerminalNodeRuleName","leftNonTerminalNodeChildNodes","getChildNodes","rightNonTerminalNodeChildNodes","some","map"],"mappings":"AAAA;;;;+BAIA;;;eAAqBA;;;sBAFoE;AAE1E,MAAMA;IACnBC,IAAIC,QAAQ,EAAEC,SAAS,EAAE,GAAGC,kBAAkB,EAAE;QAC9C,IAAIC;QAEJ,MAAMC,UAAU,IAAI,CAACC,SAAS,CAACL,UAAUC,cAAcC;QAEvDC,UAAUC,SAAU,GAAG;QAEvB,OAAOD;IACT;IAEAG,QAAQC,cAAc,EAAEC,eAAe,EAAE,GAAGN,kBAAkB,EAAE;QAC9D,IAAIO,YAAY;QAEhB,MAAMC,uBAAuBH,eAAeI,MAAM,EAChDC,wBAAwBJ,gBAAgBG,MAAM;QAEhD,IAAID,yBAAyBE,uBAAuB;YAClD,MAAMC,sBAAsBC,IAAAA,8BAAwB,EAACP,iBAC/CQ,uBAAuBD,IAAAA,8BAAwB,EAACN,kBAChDQ,wBAAwBC,IAAAA,8BAAwB,EAACJ,qBAAqBE;YAE5E,IAAIC,uBAAuB;gBACzBP,YAAYF,eAAeW,KAAK,CAAC,CAACC,eAAeC;oBAC/C,MAAMC,iBAAiBb,eAAe,CAACY,MAAM,EACvCpB,WAAWmB,eACXlB,YAAYoB,gBACZjB,UAAU,IAAI,CAACC,SAAS,CAACL,UAAUC,cAAcC;oBAEvD,IAAIE,SAAS;wBACX,OAAO;oBACT;gBACF;YACF;QACF;QAEA,OAAOK;IACT;IAEAJ,UAAUL,QAAQ,EAAEC,SAAS,EAAE,GAAGC,kBAAkB,EAAE;QACpD,IAAIE,UAAU;QAEd,MAAMkB,uBAAuBtB,SAASuB,cAAc,IAC9CC,wBAAwBvB,UAAUsB,cAAc,IAChDE,0BAA0BzB,SAAS0B,iBAAiB,IACpDC,2BAA2B1B,UAAUyB,iBAAiB;QAE5D,IAAI,OAAO;QACT,GAAG;QACL,OAAO,IAAIJ,wBAAwBE,uBAAuB;YACxD,MAAMI,mBAAmB5B,UACnB6B,oBAAoB5B,WAAY,GAAG;YAEzCG,UAAU,IAAI,CAAC0B,iBAAiB,CAACF,kBAAkBC,sBAAsB3B;QAC3E,OAAO,IAAIuB,2BAA2BE,0BAA0B;YAC9D,MAAMI,sBAAsB/B,UACtBgC,uBAAuB/B,WAAW,GAAG;YAE3CG,UAAU,IAAI,CAAC6B,oBAAoB,CAACF,qBAAqBC,yBAAyB9B;QACpF;QAEA,OAAOE;IACT;IAEA0B,kBAAkBF,gBAAgB,EAAEC,iBAAiB,EAAE,GAAG3B,kBAAkB,EAAE;QAC5E,IAAIE;QAEJA,UAAU;QAEV,OAAOA;IACT;IAEA6B,qBAAqBF,mBAAmB,EAAEC,oBAAoB,EAAE,GAAG9B,kBAAkB,EAAE;QACrF,IAAIE,UAAU;QAEd,IAAI,EAAE8B,IAAI,EAAE,GAAG,IAAI,CAAC,WAAW;QAE/BA,OAAO;eACFA;YACH;gBACEC,eAAeC,0BAAoB;gBACnCC,gBAAgBD,0BAAoB;gBACpCrC,KAAK,CAACC,UAAUC,WAAW,GAAGC;oBAC5B,IAAIE,UAAU;oBAEd,MAAMkC,8BAA8BP,oBAAoBQ,WAAW,IAC7DC,+BAA+BR,qBAAqBO,WAAW,IAAI,GAAG;oBAE5E,IAAID,gCAAgCE,8BAA8B;wBAChE,MAAMC,gCAAgCV,oBAAoBW,aAAa,IACjEC,iCAAiCX,qBAAqBU,aAAa,IACnEnC,iBAAiBkC,+BACjBjC,kBAAkBmC,gCAClBlC,YAAY,IAAI,CAACH,OAAO,CAACC,gBAAgBC,oBAAoBN;wBAEnE,IAAIO,WAAW;4BACbL,UAAU;wBACZ;oBACF;oBAEA,OAAOA;gBACT;YACF;SACD;QAED8B,KAAKU,IAAI,CAAC,CAACC;YACT,MAAM,EAAEV,aAAa,EAAEE,cAAc,EAAEtC,GAAG,EAAE,GAAG8C;YAE/C,MAAM7C,WAAWmC,cAAcJ,sBACzB9B,YAAYoC,eAAeL,uBAAwB,GAAG;YAE5D,IAAI,AAAChC,aAAa,QAAUC,cAAc,MAAO;gBAC/C,MAAME,UAAUJ,IAAIC,UAAUC,cAAcC;gBAE5CE,UAAUD,SAAU,GAAG;gBAEvB,OAAO;YACT;QACF;QAEA,OAAOC;IACT;AACF"}
85
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/pass/equivalence.js"],"sourcesContent":["\"use strict\";\n\nimport { nonTerminalNodeQuery, areChildNodesCongruent } from \"../utilities/pass\";\n\nexport default class EquivalencePass {\n  run(leftNode, rightNode, ...remainingArguments) {\n    let success;\n\n    const visited = this.visitNode(leftNode, rightNode, ...remainingArguments);\n\n    success = visited;  ///\n\n    return success;\n  }\n\n  descend(leftChildNodes, rightChildNodes, ...remainingArguments) {\n    let descended;\n\n    descended = leftChildNodes.every((leftChildNode, index) => {\n      const rightChildNode = rightChildNodes[index],\n            leftNode = leftChildNode, ///\n            rightNode = rightChildNode, ///\n            visited = this.visitNode(leftNode, rightNode, ...remainingArguments);\n\n      if (visited) {\n        return true;\n      }\n    });\n\n    return descended;\n  }\n\n  visitNode(leftNode, rightNode, ...remainingArguments) {\n    let visited = false;\n\n    const leftNodeTerminalNode = leftNode.isTerminalNode(),\n          rightNodeTerminalNode = rightNode.isTerminalNode(),\n          leftNodeNonTerminalNode = leftNode.isNonTerminalNode(),\n          rightNodeNonTerminalNode = rightNode.isNonTerminalNode();\n\n    if (false) {\n      ///\n    } else if (leftNodeTerminalNode && rightNodeTerminalNode) {\n      const leftTerminalNode = leftNode,  ///\n            rightTerminalNode = rightNode;  ///\n\n      visited = this.visitTerminalNode(leftTerminalNode, rightTerminalNode, ...remainingArguments);\n    } else if (leftNodeNonTerminalNode && rightNodeNonTerminalNode) {\n      const leftNonTerminalNode = leftNode,  ///\n            rightNonTerminalNode = rightNode; ///\n\n      visited = this.visitNonTerminalNode(leftNonTerminalNode, rightNonTerminalNode, ...remainingArguments);\n    }\n\n    return visited;\n  }\n\n  visitTerminalNode(leftTerminalNode, rightTerminalNode, ...remainingArguments) { ///\n    let visited;\n\n    visited = true;\n\n    return visited;\n  }\n\n  visitNonTerminalNode(leftNonTerminalNode, rightNonTerminalNode, ...remainingArguments) {\n    let visited = false;\n\n    let { maps } = this.constructor;\n\n    maps = [ ///\n      ...maps,\n      {\n        leftNodeQuery: nonTerminalNodeQuery,\n        rightNodeQuery: nonTerminalNodeQuery,\n        run: (leftNode, rightNode, ...remainingArguments) => {\n          let visited = false;\n\n          const leftNonTerminalNodeRuleName = leftNonTerminalNode.getRuleName(), ///\n                rightNonTerminalNodeRuleName = rightNonTerminalNode.getRuleName(); ///\n\n          if (leftNonTerminalNodeRuleName === rightNonTerminalNodeRuleName) {\n            const leftNonTerminalNodeChildNodes = leftNonTerminalNode.getChildNodes(),\n                  rightNonTerminalNodeChildNodes = rightNonTerminalNode.getChildNodes(),\n                  leftChildNodes = leftNonTerminalNodeChildNodes, ///\n                  rightChildNodes = rightNonTerminalNodeChildNodes, ///\n                  childNodesCongruent = areChildNodesCongruent(leftChildNodes, rightChildNodes);\n\n            if (childNodesCongruent) {\n              const descended = this.descend(leftChildNodes, rightChildNodes, ...remainingArguments);\n\n              if (descended) {\n                visited = true;\n              }\n            }\n          }\n\n          return visited;\n        }\n      }\n    ]\n\n    maps.some((map) => {\n      const { leftNodeQuery, rightNodeQuery, run } = map;\n\n      const leftNode = leftNodeQuery(leftNonTerminalNode),  ///\n            rightNode = rightNodeQuery(rightNonTerminalNode);  ///\n\n      if ((leftNode !== null) && (rightNode !== null)) {\n        const success = run(leftNode, rightNode, ...remainingArguments);\n\n        visited = success;  ///\n\n        return true;\n      }\n    });\n\n    return visited;\n  }\n}\n"],"names":["EquivalencePass","run","leftNode","rightNode","remainingArguments","success","visited","visitNode","descend","leftChildNodes","rightChildNodes","descended","every","leftChildNode","index","rightChildNode","leftNodeTerminalNode","isTerminalNode","rightNodeTerminalNode","leftNodeNonTerminalNode","isNonTerminalNode","rightNodeNonTerminalNode","leftTerminalNode","rightTerminalNode","visitTerminalNode","leftNonTerminalNode","rightNonTerminalNode","visitNonTerminalNode","maps","leftNodeQuery","nonTerminalNodeQuery","rightNodeQuery","leftNonTerminalNodeRuleName","getRuleName","rightNonTerminalNodeRuleName","leftNonTerminalNodeChildNodes","getChildNodes","rightNonTerminalNodeChildNodes","childNodesCongruent","areChildNodesCongruent","some","map"],"mappings":"AAAA;;;;+BAIA;;;eAAqBA;;;sBAFwC;AAE9C,MAAMA;IACnBC,IAAIC,QAAQ,EAAEC,SAAS,EAAE,GAAGC,kBAAkB,EAAE;QAC9C,IAAIC;QAEJ,MAAMC,UAAU,IAAI,CAACC,SAAS,CAACL,UAAUC,cAAcC;QAEvDC,UAAUC,SAAU,GAAG;QAEvB,OAAOD;IACT;IAEAG,QAAQC,cAAc,EAAEC,eAAe,EAAE,GAAGN,kBAAkB,EAAE;QAC9D,IAAIO;QAEJA,YAAYF,eAAeG,KAAK,CAAC,CAACC,eAAeC;YAC/C,MAAMC,iBAAiBL,eAAe,CAACI,MAAM,EACvCZ,WAAWW,eACXV,YAAYY,gBACZT,UAAU,IAAI,CAACC,SAAS,CAACL,UAAUC,cAAcC;YAEvD,IAAIE,SAAS;gBACX,OAAO;YACT;QACF;QAEA,OAAOK;IACT;IAEAJ,UAAUL,QAAQ,EAAEC,SAAS,EAAE,GAAGC,kBAAkB,EAAE;QACpD,IAAIE,UAAU;QAEd,MAAMU,uBAAuBd,SAASe,cAAc,IAC9CC,wBAAwBf,UAAUc,cAAc,IAChDE,0BAA0BjB,SAASkB,iBAAiB,IACpDC,2BAA2BlB,UAAUiB,iBAAiB;QAE5D,IAAI,OAAO;QACT,GAAG;QACL,OAAO,IAAIJ,wBAAwBE,uBAAuB;YACxD,MAAMI,mBAAmBpB,UACnBqB,oBAAoBpB,WAAY,GAAG;YAEzCG,UAAU,IAAI,CAACkB,iBAAiB,CAACF,kBAAkBC,sBAAsBnB;QAC3E,OAAO,IAAIe,2BAA2BE,0BAA0B;YAC9D,MAAMI,sBAAsBvB,UACtBwB,uBAAuBvB,WAAW,GAAG;YAE3CG,UAAU,IAAI,CAACqB,oBAAoB,CAACF,qBAAqBC,yBAAyBtB;QACpF;QAEA,OAAOE;IACT;IAEAkB,kBAAkBF,gBAAgB,EAAEC,iBAAiB,EAAE,GAAGnB,kBAAkB,EAAE;QAC5E,IAAIE;QAEJA,UAAU;QAEV,OAAOA;IACT;IAEAqB,qBAAqBF,mBAAmB,EAAEC,oBAAoB,EAAE,GAAGtB,kBAAkB,EAAE;QACrF,IAAIE,UAAU;QAEd,IAAI,EAAEsB,IAAI,EAAE,GAAG,IAAI,CAAC,WAAW;QAE/BA,OAAO;eACFA;YACH;gBACEC,eAAeC,0BAAoB;gBACnCC,gBAAgBD,0BAAoB;gBACpC7B,KAAK,CAACC,UAAUC,WAAW,GAAGC;oBAC5B,IAAIE,UAAU;oBAEd,MAAM0B,8BAA8BP,oBAAoBQ,WAAW,IAC7DC,+BAA+BR,qBAAqBO,WAAW,IAAI,GAAG;oBAE5E,IAAID,gCAAgCE,8BAA8B;wBAChE,MAAMC,gCAAgCV,oBAAoBW,aAAa,IACjEC,iCAAiCX,qBAAqBU,aAAa,IACnE3B,iBAAiB0B,+BACjBzB,kBAAkB2B,gCAClBC,sBAAsBC,IAAAA,4BAAsB,EAAC9B,gBAAgBC;wBAEnE,IAAI4B,qBAAqB;4BACvB,MAAM3B,YAAY,IAAI,CAACH,OAAO,CAACC,gBAAgBC,oBAAoBN;4BAEnE,IAAIO,WAAW;gCACbL,UAAU;4BACZ;wBACF;oBACF;oBAEA,OAAOA;gBACT;YACF;SACD;QAEDsB,KAAKY,IAAI,CAAC,CAACC;YACT,MAAM,EAAEZ,aAAa,EAAEE,cAAc,EAAE9B,GAAG,EAAE,GAAGwC;YAE/C,MAAMvC,WAAW2B,cAAcJ,sBACzBtB,YAAY4B,eAAeL,uBAAwB,GAAG;YAE5D,IAAI,AAACxB,aAAa,QAAUC,cAAc,MAAO;gBAC/C,MAAME,UAAUJ,IAAIC,UAAUC,cAAcC;gBAE5CE,UAAUD,SAAU,GAAG;gBAEvB,OAAO;YACT;QACF;QAEA,OAAOC;IACT;AACF"}
@@ -0,0 +1,96 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "default", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return ForwardZipPass;
9
+ }
10
+ });
11
+ const _pass = require("../utilities/pass");
12
+ class ForwardZipPass {
13
+ run(generalNode, specificNode, ...remainingArguments) {
14
+ let success;
15
+ const visited = this.visitNode(generalNode, specificNode, ...remainingArguments);
16
+ success = visited; ///
17
+ return success;
18
+ }
19
+ descend(index, generalChildNodes, specificChildNodes, ...remainingArguments) {
20
+ let descendedForward = false;
21
+ const descendForward = remainingArguments.pop(), generalChildNodesLength = generalChildNodes.length;
22
+ if (index === generalChildNodesLength) {
23
+ descendedForward = descendForward();
24
+ } else {
25
+ const generalChildNode = generalChildNodes[index], specificChildNode = specificChildNodes[index], generalNode = generalChildNode, specificNode = specificChildNode, visited = this.visitNode(generalNode, specificNode, ...remainingArguments, ()=>{
26
+ remainingArguments.push(descendForward);
27
+ const aheadIndex = index + 1, descendedForward = this.descend(aheadIndex, generalChildNodes, specificChildNodes, ...remainingArguments);
28
+ return descendedForward;
29
+ });
30
+ if (visited) {
31
+ descendedForward = true;
32
+ }
33
+ }
34
+ return descendedForward;
35
+ }
36
+ visitNode(generalNode, specificNode, ...remainingArguments) {
37
+ let visited = false;
38
+ const generalNodeTerminalNode = generalNode.isTerminalNode(), specificNodeTerminalNode = specificNode.isTerminalNode(), generalNodeNonTerminalNode = generalNode.isNonTerminalNode(), specificNodeNonTerminalNode = specificNode.isNonTerminalNode();
39
+ if (false) {
40
+ ///
41
+ } else if (generalNodeTerminalNode && specificNodeTerminalNode) {
42
+ const generalTerminalNode = generalNode, specificTerminalNode = specificNode; ///
43
+ visited = this.visitTerminalNode(generalTerminalNode, specificTerminalNode, ...remainingArguments);
44
+ } else if (generalNodeNonTerminalNode && specificNodeNonTerminalNode) {
45
+ const generalNonTerminalNode = generalNode, specificNonTerminalNode = specificNode; ///
46
+ visited = this.visitNonTerminalNode(generalNonTerminalNode, specificNonTerminalNode, ...remainingArguments);
47
+ }
48
+ return visited;
49
+ }
50
+ visitTerminalNode(generalTerminalNode, specificTerminalNode, ...remainingArguments) {
51
+ let visited = false;
52
+ const descendForward = remainingArguments.pop(), descendedForward = descendForward();
53
+ if (descendedForward) {
54
+ visited = true;
55
+ }
56
+ remainingArguments.push(descendForward);
57
+ return visited;
58
+ }
59
+ visitNonTerminalNode(generalNonTerminalNode, specificNonTerminalNode, ...remainingArguments) {
60
+ let visited = false;
61
+ let { maps } = this.constructor;
62
+ maps = [
63
+ ...maps,
64
+ {
65
+ generalNodeQuery: _pass.nonTerminalNodeQuery,
66
+ specificNodeQuery: _pass.nonTerminalNodeQuery,
67
+ run: (generalNode, specificNode, ...remainingArguments)=>{
68
+ let visited = false;
69
+ const generalNonTerminalNodeRuleName = generalNonTerminalNode.getRuleName(), specificNonTerminalNodeRuleName = specificNonTerminalNode.getRuleName(); ///
70
+ if (generalNonTerminalNodeRuleName === specificNonTerminalNodeRuleName) {
71
+ const index = 0, generalNonTerminalNodeChildNodes = generalNonTerminalNode.getChildNodes(), specificNonTerminalNodeChildNodes = specificNonTerminalNode.getChildNodes(), generalChildNodes = generalNonTerminalNodeChildNodes, specificChildNodes = specificNonTerminalNodeChildNodes, childNodesCongruent = (0, _pass.areChildNodesCongruent)(generalChildNodes, specificChildNodes);
72
+ if (childNodesCongruent) {
73
+ const descended = this.descend(index, generalChildNodes, specificChildNodes, ...remainingArguments);
74
+ if (descended) {
75
+ visited = true;
76
+ }
77
+ }
78
+ }
79
+ return visited;
80
+ }
81
+ }
82
+ ];
83
+ maps.some((map)=>{
84
+ const { generalNodeQuery, specificNodeQuery, run } = map;
85
+ const generalNode = generalNodeQuery(generalNonTerminalNode), specificNode = specificNodeQuery(specificNonTerminalNode); ///
86
+ if (generalNode !== null && specificNode !== null) {
87
+ const success = run(generalNode, specificNode, ...remainingArguments);
88
+ visited = success; ///
89
+ return true;
90
+ }
91
+ });
92
+ return visited;
93
+ }
94
+ }
95
+
96
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/pass/forwardZip.js"],"sourcesContent":["\"use strict\";\n\nimport { nonTerminalNodeQuery, areChildNodesCongruent } from \"../utilities/pass\";\n\nexport default class ForwardZipPass {\n  run(generalNode, specificNode, ...remainingArguments) {\n    let success;\n\n    const visited = this.visitNode(generalNode, specificNode, ...remainingArguments);\n\n    success = visited;  ///\n\n    return success;\n  }\n\n  descend(index, generalChildNodes, specificChildNodes, ...remainingArguments) {\n    let descendedForward = false;\n\n    const descendForward = remainingArguments.pop(),  ///\n          generalChildNodesLength = generalChildNodes.length;\n\n    if (index === generalChildNodesLength) {\n      descendedForward = descendForward();\n    } else {\n      const generalChildNode = generalChildNodes[index],\n            specificChildNode = specificChildNodes[index],\n            generalNode = generalChildNode, ///\n            specificNode = specificChildNode, ///\n            visited = this.visitNode(generalNode, specificNode, ...remainingArguments, () => {\n              remainingArguments.push(descendForward);\n\n              const aheadIndex = index + 1,\n                    descendedForward = this.descend(aheadIndex, generalChildNodes, specificChildNodes, ...remainingArguments);\n\n              return descendedForward;\n            });\n\n      if (visited) {\n        descendedForward = true;\n      }\n    }\n\n    return descendedForward;\n  }\n\n  visitNode(generalNode, specificNode, ...remainingArguments) {\n    let visited = false;\n\n    const generalNodeTerminalNode = generalNode.isTerminalNode(),\n          specificNodeTerminalNode = specificNode.isTerminalNode(),\n          generalNodeNonTerminalNode = generalNode.isNonTerminalNode(),\n          specificNodeNonTerminalNode = specificNode.isNonTerminalNode();\n\n    if (false) {\n      ///\n    } else if (generalNodeTerminalNode && specificNodeTerminalNode) {\n      const generalTerminalNode = generalNode,  ///\n            specificTerminalNode = specificNode;  ///\n\n      visited = this.visitTerminalNode(generalTerminalNode, specificTerminalNode, ...remainingArguments);\n    } else if (generalNodeNonTerminalNode && specificNodeNonTerminalNode) {\n      const generalNonTerminalNode = generalNode,  ///\n            specificNonTerminalNode = specificNode; ///\n\n      visited = this.visitNonTerminalNode(generalNonTerminalNode, specificNonTerminalNode, ...remainingArguments);\n    }\n\n    return visited;\n  }\n\n  visitTerminalNode(generalTerminalNode, specificTerminalNode, ...remainingArguments) {\n    let visited = false;\n\n    const descendForward = remainingArguments.pop(), ///\n          descendedForward = descendForward();\n\n    if (descendedForward) {\n      visited = true;\n    }\n\n    remainingArguments.push(descendForward);\n\n    return visited;\n  }\n\n  visitNonTerminalNode(generalNonTerminalNode, specificNonTerminalNode, ...remainingArguments) {\n    let visited = false;\n\n    let { maps } = this.constructor;\n\n    maps = [ ///\n      ...maps,\n      {\n        generalNodeQuery: nonTerminalNodeQuery,\n        specificNodeQuery: nonTerminalNodeQuery,\n        run: (generalNode, specificNode, ...remainingArguments) => {\n          let visited = false;\n\n          const generalNonTerminalNodeRuleName = generalNonTerminalNode.getRuleName(), ///\n                specificNonTerminalNodeRuleName = specificNonTerminalNode.getRuleName(); ///\n\n          if (generalNonTerminalNodeRuleName === specificNonTerminalNodeRuleName) {\n            const index = 0,\n                  generalNonTerminalNodeChildNodes = generalNonTerminalNode.getChildNodes(),\n                  specificNonTerminalNodeChildNodes = specificNonTerminalNode.getChildNodes(),\n                  generalChildNodes = generalNonTerminalNodeChildNodes, ///\n                  specificChildNodes = specificNonTerminalNodeChildNodes, ///\n                  childNodesCongruent = areChildNodesCongruent(generalChildNodes, specificChildNodes);\n\n            if (childNodesCongruent) {\n              const descended = this.descend(index, generalChildNodes, specificChildNodes, ...remainingArguments);\n\n              if (descended) {\n                visited = true;\n              }\n            }\n          }\n\n          return visited;\n        }\n      }\n    ]\n\n    maps.some((map) => {\n      const { generalNodeQuery, specificNodeQuery, run } = map;\n\n      const generalNode = generalNodeQuery(generalNonTerminalNode),  ///\n        specificNode = specificNodeQuery(specificNonTerminalNode);  ///\n\n      if ((generalNode !== null) && (specificNode !== null)) {\n        const success  = run(generalNode, specificNode, ...remainingArguments);\n\n        visited = success;  ///\n\n        return true;\n      }\n    });\n\n    return visited;\n  }\n}\n"],"names":["ForwardZipPass","run","generalNode","specificNode","remainingArguments","success","visited","visitNode","descend","index","generalChildNodes","specificChildNodes","descendedForward","descendForward","pop","generalChildNodesLength","length","generalChildNode","specificChildNode","push","aheadIndex","generalNodeTerminalNode","isTerminalNode","specificNodeTerminalNode","generalNodeNonTerminalNode","isNonTerminalNode","specificNodeNonTerminalNode","generalTerminalNode","specificTerminalNode","visitTerminalNode","generalNonTerminalNode","specificNonTerminalNode","visitNonTerminalNode","maps","generalNodeQuery","nonTerminalNodeQuery","specificNodeQuery","generalNonTerminalNodeRuleName","getRuleName","specificNonTerminalNodeRuleName","generalNonTerminalNodeChildNodes","getChildNodes","specificNonTerminalNodeChildNodes","childNodesCongruent","areChildNodesCongruent","descended","some","map"],"mappings":"AAAA;;;;+BAIA;;;eAAqBA;;;sBAFwC;AAE9C,MAAMA;IACnBC,IAAIC,WAAW,EAAEC,YAAY,EAAE,GAAGC,kBAAkB,EAAE;QACpD,IAAIC;QAEJ,MAAMC,UAAU,IAAI,CAACC,SAAS,CAACL,aAAaC,iBAAiBC;QAE7DC,UAAUC,SAAU,GAAG;QAEvB,OAAOD;IACT;IAEAG,QAAQC,KAAK,EAAEC,iBAAiB,EAAEC,kBAAkB,EAAE,GAAGP,kBAAkB,EAAE;QAC3E,IAAIQ,mBAAmB;QAEvB,MAAMC,iBAAiBT,mBAAmBU,GAAG,IACvCC,0BAA0BL,kBAAkBM,MAAM;QAExD,IAAIP,UAAUM,yBAAyB;YACrCH,mBAAmBC;QACrB,OAAO;YACL,MAAMI,mBAAmBP,iBAAiB,CAACD,MAAM,EAC3CS,oBAAoBP,kBAAkB,CAACF,MAAM,EAC7CP,cAAce,kBACdd,eAAee,mBACfZ,UAAU,IAAI,CAACC,SAAS,CAACL,aAAaC,iBAAiBC,oBAAoB;gBACzEA,mBAAmBe,IAAI,CAACN;gBAExB,MAAMO,aAAaX,QAAQ,GACrBG,mBAAmB,IAAI,CAACJ,OAAO,CAACY,YAAYV,mBAAmBC,uBAAuBP;gBAE5F,OAAOQ;YACT;YAEN,IAAIN,SAAS;gBACXM,mBAAmB;YACrB;QACF;QAEA,OAAOA;IACT;IAEAL,UAAUL,WAAW,EAAEC,YAAY,EAAE,GAAGC,kBAAkB,EAAE;QAC1D,IAAIE,UAAU;QAEd,MAAMe,0BAA0BnB,YAAYoB,cAAc,IACpDC,2BAA2BpB,aAAamB,cAAc,IACtDE,6BAA6BtB,YAAYuB,iBAAiB,IAC1DC,8BAA8BvB,aAAasB,iBAAiB;QAElE,IAAI,OAAO;QACT,GAAG;QACL,OAAO,IAAIJ,2BAA2BE,0BAA0B;YAC9D,MAAMI,sBAAsBzB,aACtB0B,uBAAuBzB,cAAe,GAAG;YAE/CG,UAAU,IAAI,CAACuB,iBAAiB,CAACF,qBAAqBC,yBAAyBxB;QACjF,OAAO,IAAIoB,8BAA8BE,6BAA6B;YACpE,MAAMI,yBAAyB5B,aACzB6B,0BAA0B5B,cAAc,GAAG;YAEjDG,UAAU,IAAI,CAAC0B,oBAAoB,CAACF,wBAAwBC,4BAA4B3B;QAC1F;QAEA,OAAOE;IACT;IAEAuB,kBAAkBF,mBAAmB,EAAEC,oBAAoB,EAAE,GAAGxB,kBAAkB,EAAE;QAClF,IAAIE,UAAU;QAEd,MAAMO,iBAAiBT,mBAAmBU,GAAG,IACvCF,mBAAmBC;QAEzB,IAAID,kBAAkB;YACpBN,UAAU;QACZ;QAEAF,mBAAmBe,IAAI,CAACN;QAExB,OAAOP;IACT;IAEA0B,qBAAqBF,sBAAsB,EAAEC,uBAAuB,EAAE,GAAG3B,kBAAkB,EAAE;QAC3F,IAAIE,UAAU;QAEd,IAAI,EAAE2B,IAAI,EAAE,GAAG,IAAI,CAAC,WAAW;QAE/BA,OAAO;eACFA;YACH;gBACEC,kBAAkBC,0BAAoB;gBACtCC,mBAAmBD,0BAAoB;gBACvClC,KAAK,CAACC,aAAaC,cAAc,GAAGC;oBAClC,IAAIE,UAAU;oBAEd,MAAM+B,iCAAiCP,uBAAuBQ,WAAW,IACnEC,kCAAkCR,wBAAwBO,WAAW,IAAI,GAAG;oBAElF,IAAID,mCAAmCE,iCAAiC;wBACtE,MAAM9B,QAAQ,GACR+B,mCAAmCV,uBAAuBW,aAAa,IACvEC,oCAAoCX,wBAAwBU,aAAa,IACzE/B,oBAAoB8B,kCACpB7B,qBAAqB+B,mCACrBC,sBAAsBC,IAAAA,4BAAsB,EAAClC,mBAAmBC;wBAEtE,IAAIgC,qBAAqB;4BACvB,MAAME,YAAY,IAAI,CAACrC,OAAO,CAACC,OAAOC,mBAAmBC,uBAAuBP;4BAEhF,IAAIyC,WAAW;gCACbvC,UAAU;4BACZ;wBACF;oBACF;oBAEA,OAAOA;gBACT;YACF;SACD;QAED2B,KAAKa,IAAI,CAAC,CAACC;YACT,MAAM,EAAEb,gBAAgB,EAAEE,iBAAiB,EAAEnC,GAAG,EAAE,GAAG8C;YAErD,MAAM7C,cAAcgC,iBAAiBJ,yBACnC3B,eAAeiC,kBAAkBL,0BAA2B,GAAG;YAEjE,IAAI,AAAC7B,gBAAgB,QAAUC,iBAAiB,MAAO;gBACrD,MAAME,UAAWJ,IAAIC,aAAaC,iBAAiBC;gBAEnDE,UAAUD,SAAU,GAAG;gBAEvB,OAAO;YACT;QACF;QAEA,OAAOC;IACT;AACF"}
package/lib/pass/zip.js CHANGED
@@ -18,20 +18,14 @@ class ZipPass {
18
18
  }
19
19
  descend(generalChildNodes, specificChildNodes, ...remainingArguments) {
20
20
  let descended = false;
21
- const generalChildNodesLength = generalChildNodes.length, specificChildNodesLength = specificChildNodes.length;
22
- if (generalChildNodesLength === specificChildNodesLength) {
23
- const specificTerminalNodeMap = (0, _pass.terminalNodeMapFromNodes)(specificChildNodes), generalTerminalNodeMap = (0, _pass.terminalNodeMapFromNodes)(generalChildNodes), terminalNodeMapsEqual = (0, _pass.areTerminalNodeMapsEqual)(generalTerminalNodeMap, specificTerminalNodeMap);
24
- if (terminalNodeMapsEqual) {
25
- const visited = generalChildNodes.every((generalChildNode, index)=>{
26
- const specificChildNode = specificChildNodes[index], specificNode = specificChildNode, generalNode = generalChildNode, visited = this.visitNode(generalNode, specificNode, ...remainingArguments);
27
- if (visited) {
28
- return true;
29
- }
30
- });
31
- if (visited) {
32
- descended = true;
33
- }
21
+ const visited = generalChildNodes.every((generalChildNode, index)=>{
22
+ const specificChildNode = specificChildNodes[index], specificNode = specificChildNode, generalNode = generalChildNode, visited = this.visitNode(generalNode, specificNode, ...remainingArguments);
23
+ if (visited) {
24
+ return true;
34
25
  }
26
+ });
27
+ if (visited) {
28
+ descended = true;
35
29
  }
36
30
  return descended;
37
31
  }
@@ -66,9 +60,12 @@ class ZipPass {
66
60
  let visited = false;
67
61
  const generalNonTerminalNodeRuleName = generalNonTerminalNode.getRuleName(), specificNonTerminalNodeRuleName = specificNonTerminalNode.getRuleName(); ///
68
62
  if (generalNonTerminalNodeRuleName === specificNonTerminalNodeRuleName) {
69
- const generalNonTerminalNodeChildNodes = generalNonTerminalNode.getChildNodes(), specificNonTerminalNodeChildNodes = specificNonTerminalNode.getChildNodes(), generalChildNodes = generalNonTerminalNodeChildNodes, specificChildNodes = specificNonTerminalNodeChildNodes, descended = this.descend(generalChildNodes, specificChildNodes, ...remainingArguments);
70
- if (descended) {
71
- visited = true;
63
+ const generalNonTerminalNodeChildNodes = generalNonTerminalNode.getChildNodes(), specificNonTerminalNodeChildNodes = specificNonTerminalNode.getChildNodes(), generalChildNodes = generalNonTerminalNodeChildNodes, specificChildNodes = specificNonTerminalNodeChildNodes, childNodesCongruent = (0, _pass.areChildNodesCongruent)(generalChildNodes, specificChildNodes);
64
+ if (childNodesCongruent) {
65
+ const descended = this.descend(generalChildNodes, specificChildNodes, ...remainingArguments);
66
+ if (descended) {
67
+ visited = true;
68
+ }
72
69
  }
73
70
  }
74
71
  return visited;
@@ -88,4 +85,4 @@ class ZipPass {
88
85
  }
89
86
  }
90
87
 
91
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/pass/zip.js"],"sourcesContent":["\"use strict\";\n\nimport { nonTerminalNodeQuery, terminalNodeMapFromNodes, areTerminalNodeMapsEqual } from \"../utilities/pass\";\n\nexport default class ZipPass {\n  run(generalNode, specificNode, ...remainingArguments) {\n    let success;\n\n    const visited = this.visitNode(generalNode, specificNode, ...remainingArguments);\n\n    success = visited;  ///\n\n    return success;\n  }\n\n  descend(generalChildNodes, specificChildNodes, ...remainingArguments) {\n    let descended = false;\n\n    const generalChildNodesLength = generalChildNodes.length,\n          specificChildNodesLength = specificChildNodes.length;\n\n    if (generalChildNodesLength === specificChildNodesLength) {\n      const specificTerminalNodeMap = terminalNodeMapFromNodes(specificChildNodes),\n            generalTerminalNodeMap = terminalNodeMapFromNodes(generalChildNodes),\n            terminalNodeMapsEqual = areTerminalNodeMapsEqual(generalTerminalNodeMap, specificTerminalNodeMap);\n\n      if (terminalNodeMapsEqual) {\n        const visited = generalChildNodes.every((generalChildNode, index) => {\n          const specificChildNode = specificChildNodes[index],\n                specificNode = specificChildNode, ///\n                generalNode = generalChildNode, ///\n                visited = this.visitNode(generalNode, specificNode, ...remainingArguments);\n\n          if (visited) {\n            return true;\n          }\n        });\n\n        if (visited) {\n          descended = true;\n        }\n      }\n    }\n\n    return descended;\n  }\n\n  visitNode(generalNode, specificNode, ...remainingArguments) {\n    let visited = false;\n\n    const generalNodeTerminalNode = generalNode.isTerminalNode(),\n          specificNodeTerminalNode = specificNode.isTerminalNode(),\n          generalNodeNonTerminalNode = generalNode.isNonTerminalNode(),\n          specificNodeNonTerminalNode = specificNode.isNonTerminalNode();\n\n    if (false) {\n      ///\n    } else if (generalNodeTerminalNode && specificNodeTerminalNode) {\n      const generalTerminalNode = generalNode,  ///\n            specificTerminalNode = specificNode;  ///\n\n      visited = this.visitTerminalNode(generalTerminalNode, specificTerminalNode, ...remainingArguments);\n    } else if (generalNodeNonTerminalNode && specificNodeNonTerminalNode) {\n      const generalNonTerminalNode = generalNode,  ///\n            specificNonTerminalNode = specificNode; ///\n\n      visited = this.visitNonTerminalNode(generalNonTerminalNode, specificNonTerminalNode, ...remainingArguments);\n    }\n\n    return visited;\n  }\n\n  visitTerminalNode(generalTerminalNode, specificTerminalNode, ...remainingArguments) { ///\n    let visited;\n\n    visited = true;\n\n    return visited;\n  }\n\n  visitNonTerminalNode(generalNonTerminalNode, specificNonTerminalNode, ...remainingArguments) {\n    let visited = false;\n\n    let { maps } = this.constructor;\n\n    maps = [ ///\n      ...maps,\n      {\n        generalNodeQuery: nonTerminalNodeQuery,\n        specificNodeQuery: nonTerminalNodeQuery,\n        run: (generalNode, specificNode, ...remainingArguments) => {\n          let visited = false;\n\n          const generalNonTerminalNodeRuleName = generalNonTerminalNode.getRuleName(), ///\n                specificNonTerminalNodeRuleName = specificNonTerminalNode.getRuleName(); ///\n\n          if (generalNonTerminalNodeRuleName === specificNonTerminalNodeRuleName) {\n            const generalNonTerminalNodeChildNodes = generalNonTerminalNode.getChildNodes(),\n                  specificNonTerminalNodeChildNodes = specificNonTerminalNode.getChildNodes(),\n                  generalChildNodes = generalNonTerminalNodeChildNodes, ///\n                  specificChildNodes = specificNonTerminalNodeChildNodes, ///\n                  descended = this.descend(generalChildNodes, specificChildNodes, ...remainingArguments);\n\n            if (descended) {\n              visited = true;\n            }\n          }\n\n          return visited;\n        }\n      }\n    ]\n\n    maps.some((map) => {\n      const { generalNodeQuery, specificNodeQuery, run } = map;\n\n      const generalNode = generalNodeQuery(generalNonTerminalNode),  ///\n            specificNode = specificNodeQuery(specificNonTerminalNode);  ///\n\n      if ((generalNode !== null) && (specificNode !== null)) {\n        const success  = run(generalNode, specificNode, ...remainingArguments);\n\n        visited = success;  ///\n\n        return true;\n      }\n    });\n\n    return visited;\n  }\n}\n"],"names":["ZipPass","run","generalNode","specificNode","remainingArguments","success","visited","visitNode","descend","generalChildNodes","specificChildNodes","descended","generalChildNodesLength","length","specificChildNodesLength","specificTerminalNodeMap","terminalNodeMapFromNodes","generalTerminalNodeMap","terminalNodeMapsEqual","areTerminalNodeMapsEqual","every","generalChildNode","index","specificChildNode","generalNodeTerminalNode","isTerminalNode","specificNodeTerminalNode","generalNodeNonTerminalNode","isNonTerminalNode","specificNodeNonTerminalNode","generalTerminalNode","specificTerminalNode","visitTerminalNode","generalNonTerminalNode","specificNonTerminalNode","visitNonTerminalNode","maps","generalNodeQuery","nonTerminalNodeQuery","specificNodeQuery","generalNonTerminalNodeRuleName","getRuleName","specificNonTerminalNodeRuleName","generalNonTerminalNodeChildNodes","getChildNodes","specificNonTerminalNodeChildNodes","some","map"],"mappings":"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"}
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/pass/zip.js"],"sourcesContent":["\"use strict\";\n\nimport { nonTerminalNodeQuery, areChildNodesCongruent } from \"../utilities/pass\";\n\nexport default class ZipPass {\n  run(generalNode, specificNode, ...remainingArguments) {\n    let success;\n\n    const visited = this.visitNode(generalNode, specificNode, ...remainingArguments);\n\n    success = visited;  ///\n\n    return success;\n  }\n\n  descend(generalChildNodes, specificChildNodes, ...remainingArguments) {\n    let descended = false;\n\n    const visited = generalChildNodes.every((generalChildNode, index) => {\n      const specificChildNode = specificChildNodes[index],\n            specificNode = specificChildNode, ///\n            generalNode = generalChildNode, ///\n            visited = this.visitNode(generalNode, specificNode, ...remainingArguments);\n\n      if (visited) {\n        return true;\n      }\n    });\n\n    if (visited) {\n      descended = true;\n    }\n\n\n    return descended;\n  }\n\n  visitNode(generalNode, specificNode, ...remainingArguments) {\n    let visited = false;\n\n    const generalNodeTerminalNode = generalNode.isTerminalNode(),\n          specificNodeTerminalNode = specificNode.isTerminalNode(),\n          generalNodeNonTerminalNode = generalNode.isNonTerminalNode(),\n          specificNodeNonTerminalNode = specificNode.isNonTerminalNode();\n\n    if (false) {\n      ///\n    } else if (generalNodeTerminalNode && specificNodeTerminalNode) {\n      const generalTerminalNode = generalNode,  ///\n            specificTerminalNode = specificNode;  ///\n\n      visited = this.visitTerminalNode(generalTerminalNode, specificTerminalNode, ...remainingArguments);\n    } else if (generalNodeNonTerminalNode && specificNodeNonTerminalNode) {\n      const generalNonTerminalNode = generalNode,  ///\n            specificNonTerminalNode = specificNode; ///\n\n      visited = this.visitNonTerminalNode(generalNonTerminalNode, specificNonTerminalNode, ...remainingArguments);\n    }\n\n    return visited;\n  }\n\n  visitTerminalNode(generalTerminalNode, specificTerminalNode, ...remainingArguments) { ///\n    let visited;\n\n    visited = true;\n\n    return visited;\n  }\n\n  visitNonTerminalNode(generalNonTerminalNode, specificNonTerminalNode, ...remainingArguments) {\n    let visited = false;\n\n    let { maps } = this.constructor;\n\n    maps = [ ///\n      ...maps,\n      {\n        generalNodeQuery: nonTerminalNodeQuery,\n        specificNodeQuery: nonTerminalNodeQuery,\n        run: (generalNode, specificNode, ...remainingArguments) => {\n          let visited = false;\n\n          const generalNonTerminalNodeRuleName = generalNonTerminalNode.getRuleName(), ///\n                specificNonTerminalNodeRuleName = specificNonTerminalNode.getRuleName(); ///\n\n          if (generalNonTerminalNodeRuleName === specificNonTerminalNodeRuleName) {\n            const generalNonTerminalNodeChildNodes = generalNonTerminalNode.getChildNodes(),\n                  specificNonTerminalNodeChildNodes = specificNonTerminalNode.getChildNodes(),\n                  generalChildNodes = generalNonTerminalNodeChildNodes, ///\n                  specificChildNodes = specificNonTerminalNodeChildNodes, ///\n                  childNodesCongruent = areChildNodesCongruent(generalChildNodes, specificChildNodes);\n\n            if (childNodesCongruent) {\n              const descended = this.descend(generalChildNodes, specificChildNodes, ...remainingArguments);\n\n              if (descended) {\n                visited = true;\n              }\n            }\n          }\n\n          return visited;\n        }\n      }\n    ]\n\n    maps.some((map) => {\n      const { generalNodeQuery, specificNodeQuery, run } = map;\n\n      const generalNode = generalNodeQuery(generalNonTerminalNode),  ///\n            specificNode = specificNodeQuery(specificNonTerminalNode);  ///\n\n      if ((generalNode !== null) && (specificNode !== null)) {\n        const success  = run(generalNode, specificNode, ...remainingArguments);\n\n        visited = success;  ///\n\n        return true;\n      }\n    });\n\n    return visited;\n  }\n}\n"],"names":["ZipPass","run","generalNode","specificNode","remainingArguments","success","visited","visitNode","descend","generalChildNodes","specificChildNodes","descended","every","generalChildNode","index","specificChildNode","generalNodeTerminalNode","isTerminalNode","specificNodeTerminalNode","generalNodeNonTerminalNode","isNonTerminalNode","specificNodeNonTerminalNode","generalTerminalNode","specificTerminalNode","visitTerminalNode","generalNonTerminalNode","specificNonTerminalNode","visitNonTerminalNode","maps","generalNodeQuery","nonTerminalNodeQuery","specificNodeQuery","generalNonTerminalNodeRuleName","getRuleName","specificNonTerminalNodeRuleName","generalNonTerminalNodeChildNodes","getChildNodes","specificNonTerminalNodeChildNodes","childNodesCongruent","areChildNodesCongruent","some","map"],"mappings":"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"}
@@ -9,26 +9,34 @@ function _export(target, all) {
9
9
  });
10
10
  }
11
11
  _export(exports, {
12
- get areTerminalNodeMapsEqual () {
13
- return areTerminalNodeMapsEqual;
12
+ get areChildNodesCongruent () {
13
+ return areChildNodesCongruent;
14
14
  },
15
15
  get nonTerminalNodeQuery () {
16
16
  return nonTerminalNodeQuery;
17
- },
18
- get terminalNodeMapFromNodes () {
19
- return terminalNodeMapFromNodes;
20
17
  }
21
18
  });
22
19
  const _necessary = require("necessary");
23
20
  const _query = require("../utilities/query");
24
21
  const { match } = _necessary.arrayUtilities;
25
22
  const nonTerminalNodeQuery = (0, _query.nodeQuery)("/*");
26
- function terminalNodeMapFromNodes(nodes) {
23
+ function areChildNodesCongruent(childNodesA, childNodesB) {
24
+ let areChildNodesCongruent = false;
25
+ const childNodesALength = childNodesA.length, childNodesBLength = childNodesB.length;
26
+ if (childNodesALength === childNodesBLength) {
27
+ const specificTerminalNodeMap = terminalNodeMapFromChildNodes(childNodesB), generalTerminalNodeMap = terminalNodeMapFromChildNodes(childNodesA), terminalNodeMapsEqual = areTerminalNodeMapsEqual(generalTerminalNodeMap, specificTerminalNodeMap);
28
+ if (terminalNodeMapsEqual) {
29
+ areChildNodesCongruent = true;
30
+ }
31
+ }
32
+ return areChildNodesCongruent;
33
+ }
34
+ function terminalNodeMapFromChildNodes(childNodes) {
27
35
  const terminalNodeMap = {};
28
- nodes.forEach((node, index)=>{
29
- const nodeTerminalNode = node.isTerminalNode();
30
- if (nodeTerminalNode) {
31
- const terminalNode = node; //
36
+ childNodes.forEach((childNode, index)=>{
37
+ const childNodeTerminalNode = childNode.isTerminalNode();
38
+ if (childNodeTerminalNode) {
39
+ const terminalNode = childNode; //
32
40
  terminalNodeMap[index] = terminalNode;
33
41
  }
34
42
  });
@@ -53,4 +61,4 @@ function areTerminalNodeMapsEqual(generalTerminalNodeMap, specificTerminalNodeMa
53
61
  return terminalNodeMapsEqual;
54
62
  }
55
63
 
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsaXRpZXMvcGFzcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IHsgYXJyYXlVdGlsaXRpZXMgfSBmcm9tIFwibmVjZXNzYXJ5XCI7XG5cbmltcG9ydCB7IG5vZGVRdWVyeSB9IGZyb20gXCIuLi91dGlsaXRpZXMvcXVlcnlcIjtcblxuY29uc3QgeyBtYXRjaCB9ID0gYXJyYXlVdGlsaXRpZXM7XG5cbmV4cG9ydCBjb25zdCBub25UZXJtaW5hbE5vZGVRdWVyeSA9IG5vZGVRdWVyeShcIi8qXCIpO1xuXG5leHBvcnQgZnVuY3Rpb24gdGVybWluYWxOb2RlTWFwRnJvbU5vZGVzKG5vZGVzKSB7XG4gIGNvbnN0IHRlcm1pbmFsTm9kZU1hcCA9IHt9O1xuXG4gIG5vZGVzLmZvckVhY2goKG5vZGUsIGluZGV4KSA9PiB7XG4gICAgY29uc3Qgbm9kZVRlcm1pbmFsTm9kZSA9IG5vZGUuaXNUZXJtaW5hbE5vZGUoKTtcblxuICAgIGlmIChub2RlVGVybWluYWxOb2RlKSB7XG4gICAgICBjb25zdCB0ZXJtaW5hbE5vZGUgPSBub2RlOyAgLy9cblxuICAgICAgdGVybWluYWxOb2RlTWFwW2luZGV4XSA9IHRlcm1pbmFsTm9kZTtcbiAgICB9XG4gIH0pO1xuXG4gIHJldHVybiB0ZXJtaW5hbE5vZGVNYXA7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBhcmVUZXJtaW5hbE5vZGVNYXBzRXF1YWwoZ2VuZXJhbFRlcm1pbmFsTm9kZU1hcCwgc3BlY2lmaWNUZXJtaW5hbE5vZGVNYXApIHtcbiAgbGV0IHRlcm1pbmFsTm9kZU1hcHNFcXVhbCA9IGZhbHNlO1xuXG4gIGNvbnN0IGdlbmVyYWxJbmRleGVzID0gT2JqZWN0LmtleXMoZ2VuZXJhbFRlcm1pbmFsTm9kZU1hcCksIC8vL1xuICAgICAgICBzcGVjaWZpY0luZGV4ZXMgPSBPYmplY3Qua2V5cyhzcGVjaWZpY1Rlcm1pbmFsTm9kZU1hcCksIC8vL1xuICAgICAgICB0ZXJtaW5hbE5vZGVNYXBLZXlzTWF0Y2ggPSBtYXRjaChnZW5lcmFsSW5kZXhlcywgc3BlY2lmaWNJbmRleGVzLCAoZ2VuZXJhbEluZGV4LCBzcGVjaWZpY0luZGV4KSA9PiB7XG4gICAgICAgICAgaWYgKGdlbmVyYWxJbmRleCA9PT0gc3BlY2lmaWNJbmRleCkge1xuICAgICAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICAgICAgfVxuICAgICAgICB9KTtcblxuICBpZiAodGVybWluYWxOb2RlTWFwS2V5c01hdGNoKSB7XG4gICAgY29uc3QgZ2VuZXJhbFRlcm1pbmFsTm9kZXMgPSBPYmplY3QudmFsdWVzKGdlbmVyYWxUZXJtaW5hbE5vZGVNYXApLCAvLy9cbiAgICAgICAgICBzcGVjaWZpY1Rlcm1pbmFsTm9kZXMgPSBPYmplY3QudmFsdWVzKHNwZWNpZmljVGVybWluYWxOb2RlTWFwKSwgLy8vXG4gICAgICAgICAgdGVybWluYWxOb2RlTWFwVmFsdWVzTWF0Y2ggPSBtYXRjaChnZW5lcmFsVGVybWluYWxOb2Rlcywgc3BlY2lmaWNUZXJtaW5hbE5vZGVzLCAoZ2VuZXJhbFRlcm1pbmFsTm9kZSwgc3BlY2lmaWNUZXJtaW5hbE5vZGUpID0+IHtcbiAgICAgICAgICAgIGNvbnN0IGdlbmVyYWxUZXJtaW5hbE5vZGVNYXRjaGVzU3BlY2lmaWNUZXJtaW5hbE5vZGUgPSBnZW5lcmFsVGVybWluYWxOb2RlLm1hdGNoKHNwZWNpZmljVGVybWluYWxOb2RlKTtcblxuICAgICAgICAgICAgaWYgKGdlbmVyYWxUZXJtaW5hbE5vZGVNYXRjaGVzU3BlY2lmaWNUZXJtaW5hbE5vZGUpIHtcbiAgICAgICAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfSk7XG5cbiAgICB0ZXJtaW5hbE5vZGVNYXBzRXF1YWwgPSB0ZXJtaW5hbE5vZGVNYXBWYWx1ZXNNYXRjaDsgLy8vXG4gIH1cblxuICByZXR1cm4gdGVybWluYWxOb2RlTWFwc0VxdWFsO1xufVxuIl0sIm5hbWVzIjpbImFyZVRlcm1pbmFsTm9kZU1hcHNFcXVhbCIsIm5vblRlcm1pbmFsTm9kZVF1ZXJ5IiwidGVybWluYWxOb2RlTWFwRnJvbU5vZGVzIiwibWF0Y2giLCJhcnJheVV0aWxpdGllcyIsIm5vZGVRdWVyeSIsIm5vZGVzIiwidGVybWluYWxOb2RlTWFwIiwiZm9yRWFjaCIsIm5vZGUiLCJpbmRleCIsIm5vZGVUZXJtaW5hbE5vZGUiLCJpc1Rlcm1pbmFsTm9kZSIsInRlcm1pbmFsTm9kZSIsImdlbmVyYWxUZXJtaW5hbE5vZGVNYXAiLCJzcGVjaWZpY1Rlcm1pbmFsTm9kZU1hcCIsInRlcm1pbmFsTm9kZU1hcHNFcXVhbCIsImdlbmVyYWxJbmRleGVzIiwiT2JqZWN0Iiwia2V5cyIsInNwZWNpZmljSW5kZXhlcyIsInRlcm1pbmFsTm9kZU1hcEtleXNNYXRjaCIsImdlbmVyYWxJbmRleCIsInNwZWNpZmljSW5kZXgiLCJnZW5lcmFsVGVybWluYWxOb2RlcyIsInZhbHVlcyIsInNwZWNpZmljVGVybWluYWxOb2RlcyIsInRlcm1pbmFsTm9kZU1hcFZhbHVlc01hdGNoIiwiZ2VuZXJhbFRlcm1pbmFsTm9kZSIsInNwZWNpZmljVGVybWluYWxOb2RlIiwiZ2VuZXJhbFRlcm1pbmFsTm9kZU1hdGNoZXNTcGVjaWZpY1Rlcm1pbmFsTm9kZSJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7O1FBMEJnQkE7ZUFBQUE7O1FBbEJIQztlQUFBQTs7UUFFR0M7ZUFBQUE7OzsyQkFSZTt1QkFFTDtBQUUxQixNQUFNLEVBQUVDLEtBQUssRUFBRSxHQUFHQyx5QkFBYztBQUV6QixNQUFNSCx1QkFBdUJJLElBQUFBLGdCQUFTLEVBQUM7QUFFdkMsU0FBU0gseUJBQXlCSSxLQUFLO0lBQzVDLE1BQU1DLGtCQUFrQixDQUFDO0lBRXpCRCxNQUFNRSxPQUFPLENBQUMsQ0FBQ0MsTUFBTUM7UUFDbkIsTUFBTUMsbUJBQW1CRixLQUFLRyxjQUFjO1FBRTVDLElBQUlELGtCQUFrQjtZQUNwQixNQUFNRSxlQUFlSixNQUFPLEVBQUU7WUFFOUJGLGVBQWUsQ0FBQ0csTUFBTSxHQUFHRztRQUMzQjtJQUNGO0lBRUEsT0FBT047QUFDVDtBQUVPLFNBQVNQLHlCQUF5QmMsc0JBQXNCLEVBQUVDLHVCQUF1QjtJQUN0RixJQUFJQyx3QkFBd0I7SUFFNUIsTUFBTUMsaUJBQWlCQyxPQUFPQyxJQUFJLENBQUNMLHlCQUM3Qk0sa0JBQWtCRixPQUFPQyxJQUFJLENBQUNKLDBCQUM5Qk0sMkJBQTJCbEIsTUFBTWMsZ0JBQWdCRyxpQkFBaUIsQ0FBQ0UsY0FBY0M7UUFDL0UsSUFBSUQsaUJBQWlCQyxlQUFlO1lBQ2xDLE9BQU87UUFDVDtJQUNGO0lBRU4sSUFBSUYsMEJBQTBCO1FBQzVCLE1BQU1HLHVCQUF1Qk4sT0FBT08sTUFBTSxDQUFDWCx5QkFDckNZLHdCQUF3QlIsT0FBT08sTUFBTSxDQUFDViwwQkFDdENZLDZCQUE2QnhCLE1BQU1xQixzQkFBc0JFLHVCQUF1QixDQUFDRSxxQkFBcUJDO1lBQ3BHLE1BQU1DLGlEQUFpREYsb0JBQW9CekIsS0FBSyxDQUFDMEI7WUFFakYsSUFBSUMsZ0RBQWdEO2dCQUNsRCxPQUFPO1lBQ1Q7UUFDRjtRQUVOZCx3QkFBd0JXLDRCQUE0QixHQUFHO0lBQ3pEO0lBRUEsT0FBT1g7QUFDVCJ9
64
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsaXRpZXMvcGFzcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IHsgYXJyYXlVdGlsaXRpZXMgfSBmcm9tIFwibmVjZXNzYXJ5XCI7XG5cbmltcG9ydCB7IG5vZGVRdWVyeSB9IGZyb20gXCIuLi91dGlsaXRpZXMvcXVlcnlcIjtcblxuY29uc3QgeyBtYXRjaCB9ID0gYXJyYXlVdGlsaXRpZXM7XG5cbmV4cG9ydCBjb25zdCBub25UZXJtaW5hbE5vZGVRdWVyeSA9IG5vZGVRdWVyeShcIi8qXCIpO1xuXG5leHBvcnQgZnVuY3Rpb24gYXJlQ2hpbGROb2Rlc0NvbmdydWVudChjaGlsZE5vZGVzQSwgY2hpbGROb2Rlc0IpIHtcbiAgbGV0IGFyZUNoaWxkTm9kZXNDb25ncnVlbnQgPSBmYWxzZTtcblxuICBjb25zdCBjaGlsZE5vZGVzQUxlbmd0aCA9IGNoaWxkTm9kZXNBLmxlbmd0aCxcbiAgICAgICAgY2hpbGROb2Rlc0JMZW5ndGggPSBjaGlsZE5vZGVzQi5sZW5ndGg7XG5cbiAgaWYgKGNoaWxkTm9kZXNBTGVuZ3RoID09PSBjaGlsZE5vZGVzQkxlbmd0aCkge1xuICAgIGNvbnN0IHNwZWNpZmljVGVybWluYWxOb2RlTWFwID0gdGVybWluYWxOb2RlTWFwRnJvbUNoaWxkTm9kZXMoY2hpbGROb2Rlc0IpLFxuICAgICAgICAgIGdlbmVyYWxUZXJtaW5hbE5vZGVNYXAgPSB0ZXJtaW5hbE5vZGVNYXBGcm9tQ2hpbGROb2RlcyhjaGlsZE5vZGVzQSksXG4gICAgICAgICAgdGVybWluYWxOb2RlTWFwc0VxdWFsID0gYXJlVGVybWluYWxOb2RlTWFwc0VxdWFsKGdlbmVyYWxUZXJtaW5hbE5vZGVNYXAsIHNwZWNpZmljVGVybWluYWxOb2RlTWFwKTtcblxuICAgIGlmICh0ZXJtaW5hbE5vZGVNYXBzRXF1YWwpIHtcbiAgICAgIGFyZUNoaWxkTm9kZXNDb25ncnVlbnQgPSB0cnVlO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBhcmVDaGlsZE5vZGVzQ29uZ3J1ZW50O1xufVxuXG5mdW5jdGlvbiB0ZXJtaW5hbE5vZGVNYXBGcm9tQ2hpbGROb2RlcyhjaGlsZE5vZGVzKSB7XG4gIGNvbnN0IHRlcm1pbmFsTm9kZU1hcCA9IHt9O1xuXG4gIGNoaWxkTm9kZXMuZm9yRWFjaCgoY2hpbGROb2RlLCBpbmRleCkgPT4ge1xuICAgIGNvbnN0IGNoaWxkTm9kZVRlcm1pbmFsTm9kZSA9IGNoaWxkTm9kZS5pc1Rlcm1pbmFsTm9kZSgpO1xuXG4gICAgaWYgKGNoaWxkTm9kZVRlcm1pbmFsTm9kZSkge1xuICAgICAgY29uc3QgdGVybWluYWxOb2RlID0gY2hpbGROb2RlOyAgLy9cblxuICAgICAgdGVybWluYWxOb2RlTWFwW2luZGV4XSA9IHRlcm1pbmFsTm9kZTtcbiAgICB9XG4gIH0pO1xuXG4gIHJldHVybiB0ZXJtaW5hbE5vZGVNYXA7XG59XG5cbmZ1bmN0aW9uIGFyZVRlcm1pbmFsTm9kZU1hcHNFcXVhbChnZW5lcmFsVGVybWluYWxOb2RlTWFwLCBzcGVjaWZpY1Rlcm1pbmFsTm9kZU1hcCkge1xuICBsZXQgdGVybWluYWxOb2RlTWFwc0VxdWFsID0gZmFsc2U7XG5cbiAgY29uc3QgZ2VuZXJhbEluZGV4ZXMgPSBPYmplY3Qua2V5cyhnZW5lcmFsVGVybWluYWxOb2RlTWFwKSwgLy8vXG4gICAgICAgIHNwZWNpZmljSW5kZXhlcyA9IE9iamVjdC5rZXlzKHNwZWNpZmljVGVybWluYWxOb2RlTWFwKSwgLy8vXG4gICAgICAgIHRlcm1pbmFsTm9kZU1hcEtleXNNYXRjaCA9IG1hdGNoKGdlbmVyYWxJbmRleGVzLCBzcGVjaWZpY0luZGV4ZXMsIChnZW5lcmFsSW5kZXgsIHNwZWNpZmljSW5kZXgpID0+IHtcbiAgICAgICAgICBpZiAoZ2VuZXJhbEluZGV4ID09PSBzcGVjaWZpY0luZGV4KSB7XG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgICB9XG4gICAgICAgIH0pO1xuXG4gIGlmICh0ZXJtaW5hbE5vZGVNYXBLZXlzTWF0Y2gpIHtcbiAgICBjb25zdCBnZW5lcmFsVGVybWluYWxOb2RlcyA9IE9iamVjdC52YWx1ZXMoZ2VuZXJhbFRlcm1pbmFsTm9kZU1hcCksIC8vL1xuICAgICAgICAgIHNwZWNpZmljVGVybWluYWxOb2RlcyA9IE9iamVjdC52YWx1ZXMoc3BlY2lmaWNUZXJtaW5hbE5vZGVNYXApLCAvLy9cbiAgICAgICAgICB0ZXJtaW5hbE5vZGVNYXBWYWx1ZXNNYXRjaCA9IG1hdGNoKGdlbmVyYWxUZXJtaW5hbE5vZGVzLCBzcGVjaWZpY1Rlcm1pbmFsTm9kZXMsIChnZW5lcmFsVGVybWluYWxOb2RlLCBzcGVjaWZpY1Rlcm1pbmFsTm9kZSkgPT4ge1xuICAgICAgICAgICAgY29uc3QgZ2VuZXJhbFRlcm1pbmFsTm9kZU1hdGNoZXNTcGVjaWZpY1Rlcm1pbmFsTm9kZSA9IGdlbmVyYWxUZXJtaW5hbE5vZGUubWF0Y2goc3BlY2lmaWNUZXJtaW5hbE5vZGUpO1xuXG4gICAgICAgICAgICBpZiAoZ2VuZXJhbFRlcm1pbmFsTm9kZU1hdGNoZXNTcGVjaWZpY1Rlcm1pbmFsTm9kZSkge1xuICAgICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9KTtcblxuICAgIHRlcm1pbmFsTm9kZU1hcHNFcXVhbCA9IHRlcm1pbmFsTm9kZU1hcFZhbHVlc01hdGNoOyAvLy9cbiAgfVxuXG4gIHJldHVybiB0ZXJtaW5hbE5vZGVNYXBzRXF1YWw7XG59XG4iXSwibmFtZXMiOlsiYXJlQ2hpbGROb2Rlc0NvbmdydWVudCIsIm5vblRlcm1pbmFsTm9kZVF1ZXJ5IiwibWF0Y2giLCJhcnJheVV0aWxpdGllcyIsIm5vZGVRdWVyeSIsImNoaWxkTm9kZXNBIiwiY2hpbGROb2Rlc0IiLCJjaGlsZE5vZGVzQUxlbmd0aCIsImxlbmd0aCIsImNoaWxkTm9kZXNCTGVuZ3RoIiwic3BlY2lmaWNUZXJtaW5hbE5vZGVNYXAiLCJ0ZXJtaW5hbE5vZGVNYXBGcm9tQ2hpbGROb2RlcyIsImdlbmVyYWxUZXJtaW5hbE5vZGVNYXAiLCJ0ZXJtaW5hbE5vZGVNYXBzRXF1YWwiLCJhcmVUZXJtaW5hbE5vZGVNYXBzRXF1YWwiLCJjaGlsZE5vZGVzIiwidGVybWluYWxOb2RlTWFwIiwiZm9yRWFjaCIsImNoaWxkTm9kZSIsImluZGV4IiwiY2hpbGROb2RlVGVybWluYWxOb2RlIiwiaXNUZXJtaW5hbE5vZGUiLCJ0ZXJtaW5hbE5vZGUiLCJnZW5lcmFsSW5kZXhlcyIsIk9iamVjdCIsImtleXMiLCJzcGVjaWZpY0luZGV4ZXMiLCJ0ZXJtaW5hbE5vZGVNYXBLZXlzTWF0Y2giLCJnZW5lcmFsSW5kZXgiLCJzcGVjaWZpY0luZGV4IiwiZ2VuZXJhbFRlcm1pbmFsTm9kZXMiLCJ2YWx1ZXMiLCJzcGVjaWZpY1Rlcm1pbmFsTm9kZXMiLCJ0ZXJtaW5hbE5vZGVNYXBWYWx1ZXNNYXRjaCIsImdlbmVyYWxUZXJtaW5hbE5vZGUiLCJzcGVjaWZpY1Rlcm1pbmFsTm9kZSIsImdlbmVyYWxUZXJtaW5hbE5vZGVNYXRjaGVzU3BlY2lmaWNUZXJtaW5hbE5vZGUiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7OztRQVVnQkE7ZUFBQUE7O1FBRkhDO2VBQUFBOzs7MkJBTmtCO3VCQUVMO0FBRTFCLE1BQU0sRUFBRUMsS0FBSyxFQUFFLEdBQUdDLHlCQUFjO0FBRXpCLE1BQU1GLHVCQUF1QkcsSUFBQUEsZ0JBQVMsRUFBQztBQUV2QyxTQUFTSix1QkFBdUJLLFdBQVcsRUFBRUMsV0FBVztJQUM3RCxJQUFJTix5QkFBeUI7SUFFN0IsTUFBTU8sb0JBQW9CRixZQUFZRyxNQUFNLEVBQ3RDQyxvQkFBb0JILFlBQVlFLE1BQU07SUFFNUMsSUFBSUQsc0JBQXNCRSxtQkFBbUI7UUFDM0MsTUFBTUMsMEJBQTBCQyw4QkFBOEJMLGNBQ3hETSx5QkFBeUJELDhCQUE4Qk4sY0FDdkRRLHdCQUF3QkMseUJBQXlCRix3QkFBd0JGO1FBRS9FLElBQUlHLHVCQUF1QjtZQUN6QmIseUJBQXlCO1FBQzNCO0lBQ0Y7SUFFQSxPQUFPQTtBQUNUO0FBRUEsU0FBU1csOEJBQThCSSxVQUFVO0lBQy9DLE1BQU1DLGtCQUFrQixDQUFDO0lBRXpCRCxXQUFXRSxPQUFPLENBQUMsQ0FBQ0MsV0FBV0M7UUFDN0IsTUFBTUMsd0JBQXdCRixVQUFVRyxjQUFjO1FBRXRELElBQUlELHVCQUF1QjtZQUN6QixNQUFNRSxlQUFlSixXQUFZLEVBQUU7WUFFbkNGLGVBQWUsQ0FBQ0csTUFBTSxHQUFHRztRQUMzQjtJQUNGO0lBRUEsT0FBT047QUFDVDtBQUVBLFNBQVNGLHlCQUF5QkYsc0JBQXNCLEVBQUVGLHVCQUF1QjtJQUMvRSxJQUFJRyx3QkFBd0I7SUFFNUIsTUFBTVUsaUJBQWlCQyxPQUFPQyxJQUFJLENBQUNiLHlCQUM3QmMsa0JBQWtCRixPQUFPQyxJQUFJLENBQUNmLDBCQUM5QmlCLDJCQUEyQnpCLE1BQU1xQixnQkFBZ0JHLGlCQUFpQixDQUFDRSxjQUFjQztRQUMvRSxJQUFJRCxpQkFBaUJDLGVBQWU7WUFDbEMsT0FBTztRQUNUO0lBQ0Y7SUFFTixJQUFJRiwwQkFBMEI7UUFDNUIsTUFBTUcsdUJBQXVCTixPQUFPTyxNQUFNLENBQUNuQix5QkFDckNvQix3QkFBd0JSLE9BQU9PLE1BQU0sQ0FBQ3JCLDBCQUN0Q3VCLDZCQUE2Qi9CLE1BQU00QixzQkFBc0JFLHVCQUF1QixDQUFDRSxxQkFBcUJDO1lBQ3BHLE1BQU1DLGlEQUFpREYsb0JBQW9CaEMsS0FBSyxDQUFDaUM7WUFFakYsSUFBSUMsZ0RBQWdEO2dCQUNsRCxPQUFPO1lBQ1Q7UUFDRjtRQUVOdkIsd0JBQXdCb0IsNEJBQTRCLEdBQUc7SUFDekQ7SUFFQSxPQUFPcEI7QUFDVCJ9
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "occam-languages",
3
3
  "author": "James Smith",
4
- "version": "0.0.206",
4
+ "version": "0.0.207",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/occam-languages",
7
7
  "description": "Occam's common language functionality.",
package/src/index.js CHANGED
@@ -12,6 +12,7 @@ export { default as ZipPass } from "./pass/zip";
12
12
  export { default as AsyncPass } from "./pass/async";
13
13
  export { default as SimplePass } from "./pass/simple";
14
14
  export { default as ForwardPass } from "./pass/forward";
15
+ export { default as ForwardZipPass } from "./pass/forwardZip";
15
16
  export { default as EquivalencePass } from "./pass/equivalence";
16
17
 
17
18
  export { default as nodeUtilities } from "./utilities/node";
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
 
3
- import { nonTerminalNodeQuery, terminalNodeMapFromNodes, areTerminalNodeMapsEqual } from "../utilities/pass";
3
+ import { nonTerminalNodeQuery, areChildNodesCongruent } from "../utilities/pass";
4
4
 
5
5
  export default class EquivalencePass {
6
6
  run(leftNode, rightNode, ...remainingArguments) {
@@ -14,29 +14,18 @@ export default class EquivalencePass {
14
14
  }
15
15
 
16
16
  descend(leftChildNodes, rightChildNodes, ...remainingArguments) {
17
- let descended = false;
17
+ let descended;
18
18
 
19
- const leftChildNodesLength = leftChildNodes.length,
20
- rightChildNodesLength = rightChildNodes.length;
19
+ descended = leftChildNodes.every((leftChildNode, index) => {
20
+ const rightChildNode = rightChildNodes[index],
21
+ leftNode = leftChildNode, ///
22
+ rightNode = rightChildNode, ///
23
+ visited = this.visitNode(leftNode, rightNode, ...remainingArguments);
21
24
 
22
- if (leftChildNodesLength === rightChildNodesLength) {
23
- const leftTerminalNodeMap = terminalNodeMapFromNodes(leftChildNodes),
24
- rightTerminalNodeMap = terminalNodeMapFromNodes(rightChildNodes),
25
- terminalNodeMapsEqual = areTerminalNodeMapsEqual(leftTerminalNodeMap, rightTerminalNodeMap);
26
-
27
- if (terminalNodeMapsEqual) {
28
- descended = leftChildNodes.every((leftChildNode, index) => {
29
- const rightChildNode = rightChildNodes[index],
30
- leftNode = leftChildNode, ///
31
- rightNode = rightChildNode, ///
32
- visited = this.visitNode(leftNode, rightNode, ...remainingArguments);
33
-
34
- if (visited) {
35
- return true;
36
- }
37
- });
25
+ if (visited) {
26
+ return true;
38
27
  }
39
- }
28
+ });
40
29
 
41
30
  return descended;
42
31
  }
@@ -95,10 +84,14 @@ export default class EquivalencePass {
95
84
  rightNonTerminalNodeChildNodes = rightNonTerminalNode.getChildNodes(),
96
85
  leftChildNodes = leftNonTerminalNodeChildNodes, ///
97
86
  rightChildNodes = rightNonTerminalNodeChildNodes, ///
98
- descended = this.descend(leftChildNodes, rightChildNodes, ...remainingArguments);
87
+ childNodesCongruent = areChildNodesCongruent(leftChildNodes, rightChildNodes);
88
+
89
+ if (childNodesCongruent) {
90
+ const descended = this.descend(leftChildNodes, rightChildNodes, ...remainingArguments);
99
91
 
100
- if (descended) {
101
- visited = true;
92
+ if (descended) {
93
+ visited = true;
94
+ }
102
95
  }
103
96
  }
104
97
 
@@ -0,0 +1,141 @@
1
+ "use strict";
2
+
3
+ import { nonTerminalNodeQuery, areChildNodesCongruent } from "../utilities/pass";
4
+
5
+ export default class ForwardZipPass {
6
+ run(generalNode, specificNode, ...remainingArguments) {
7
+ let success;
8
+
9
+ const visited = this.visitNode(generalNode, specificNode, ...remainingArguments);
10
+
11
+ success = visited; ///
12
+
13
+ return success;
14
+ }
15
+
16
+ descend(index, generalChildNodes, specificChildNodes, ...remainingArguments) {
17
+ let descendedForward = false;
18
+
19
+ const descendForward = remainingArguments.pop(), ///
20
+ generalChildNodesLength = generalChildNodes.length;
21
+
22
+ if (index === generalChildNodesLength) {
23
+ descendedForward = descendForward();
24
+ } else {
25
+ const generalChildNode = generalChildNodes[index],
26
+ specificChildNode = specificChildNodes[index],
27
+ generalNode = generalChildNode, ///
28
+ specificNode = specificChildNode, ///
29
+ visited = this.visitNode(generalNode, specificNode, ...remainingArguments, () => {
30
+ remainingArguments.push(descendForward);
31
+
32
+ const aheadIndex = index + 1,
33
+ descendedForward = this.descend(aheadIndex, generalChildNodes, specificChildNodes, ...remainingArguments);
34
+
35
+ return descendedForward;
36
+ });
37
+
38
+ if (visited) {
39
+ descendedForward = true;
40
+ }
41
+ }
42
+
43
+ return descendedForward;
44
+ }
45
+
46
+ visitNode(generalNode, specificNode, ...remainingArguments) {
47
+ let visited = false;
48
+
49
+ const generalNodeTerminalNode = generalNode.isTerminalNode(),
50
+ specificNodeTerminalNode = specificNode.isTerminalNode(),
51
+ generalNodeNonTerminalNode = generalNode.isNonTerminalNode(),
52
+ specificNodeNonTerminalNode = specificNode.isNonTerminalNode();
53
+
54
+ if (false) {
55
+ ///
56
+ } else if (generalNodeTerminalNode && specificNodeTerminalNode) {
57
+ const generalTerminalNode = generalNode, ///
58
+ specificTerminalNode = specificNode; ///
59
+
60
+ visited = this.visitTerminalNode(generalTerminalNode, specificTerminalNode, ...remainingArguments);
61
+ } else if (generalNodeNonTerminalNode && specificNodeNonTerminalNode) {
62
+ const generalNonTerminalNode = generalNode, ///
63
+ specificNonTerminalNode = specificNode; ///
64
+
65
+ visited = this.visitNonTerminalNode(generalNonTerminalNode, specificNonTerminalNode, ...remainingArguments);
66
+ }
67
+
68
+ return visited;
69
+ }
70
+
71
+ visitTerminalNode(generalTerminalNode, specificTerminalNode, ...remainingArguments) {
72
+ let visited = false;
73
+
74
+ const descendForward = remainingArguments.pop(), ///
75
+ descendedForward = descendForward();
76
+
77
+ if (descendedForward) {
78
+ visited = true;
79
+ }
80
+
81
+ remainingArguments.push(descendForward);
82
+
83
+ return visited;
84
+ }
85
+
86
+ visitNonTerminalNode(generalNonTerminalNode, specificNonTerminalNode, ...remainingArguments) {
87
+ let visited = false;
88
+
89
+ let { maps } = this.constructor;
90
+
91
+ maps = [ ///
92
+ ...maps,
93
+ {
94
+ generalNodeQuery: nonTerminalNodeQuery,
95
+ specificNodeQuery: nonTerminalNodeQuery,
96
+ run: (generalNode, specificNode, ...remainingArguments) => {
97
+ let visited = false;
98
+
99
+ const generalNonTerminalNodeRuleName = generalNonTerminalNode.getRuleName(), ///
100
+ specificNonTerminalNodeRuleName = specificNonTerminalNode.getRuleName(); ///
101
+
102
+ if (generalNonTerminalNodeRuleName === specificNonTerminalNodeRuleName) {
103
+ const index = 0,
104
+ generalNonTerminalNodeChildNodes = generalNonTerminalNode.getChildNodes(),
105
+ specificNonTerminalNodeChildNodes = specificNonTerminalNode.getChildNodes(),
106
+ generalChildNodes = generalNonTerminalNodeChildNodes, ///
107
+ specificChildNodes = specificNonTerminalNodeChildNodes, ///
108
+ childNodesCongruent = areChildNodesCongruent(generalChildNodes, specificChildNodes);
109
+
110
+ if (childNodesCongruent) {
111
+ const descended = this.descend(index, generalChildNodes, specificChildNodes, ...remainingArguments);
112
+
113
+ if (descended) {
114
+ visited = true;
115
+ }
116
+ }
117
+ }
118
+
119
+ return visited;
120
+ }
121
+ }
122
+ ]
123
+
124
+ maps.some((map) => {
125
+ const { generalNodeQuery, specificNodeQuery, run } = map;
126
+
127
+ const generalNode = generalNodeQuery(generalNonTerminalNode), ///
128
+ specificNode = specificNodeQuery(specificNonTerminalNode); ///
129
+
130
+ if ((generalNode !== null) && (specificNode !== null)) {
131
+ const success = run(generalNode, specificNode, ...remainingArguments);
132
+
133
+ visited = success; ///
134
+
135
+ return true;
136
+ }
137
+ });
138
+
139
+ return visited;
140
+ }
141
+ }
package/src/pass/zip.js CHANGED
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
 
3
- import { nonTerminalNodeQuery, terminalNodeMapFromNodes, areTerminalNodeMapsEqual } from "../utilities/pass";
3
+ import { nonTerminalNodeQuery, areChildNodesCongruent } from "../utilities/pass";
4
4
 
5
5
  export default class ZipPass {
6
6
  run(generalNode, specificNode, ...remainingArguments) {
@@ -16,32 +16,22 @@ export default class ZipPass {
16
16
  descend(generalChildNodes, specificChildNodes, ...remainingArguments) {
17
17
  let descended = false;
18
18
 
19
- const generalChildNodesLength = generalChildNodes.length,
20
- specificChildNodesLength = specificChildNodes.length;
19
+ const visited = generalChildNodes.every((generalChildNode, index) => {
20
+ const specificChildNode = specificChildNodes[index],
21
+ specificNode = specificChildNode, ///
22
+ generalNode = generalChildNode, ///
23
+ visited = this.visitNode(generalNode, specificNode, ...remainingArguments);
21
24
 
22
- if (generalChildNodesLength === specificChildNodesLength) {
23
- const specificTerminalNodeMap = terminalNodeMapFromNodes(specificChildNodes),
24
- generalTerminalNodeMap = terminalNodeMapFromNodes(generalChildNodes),
25
- terminalNodeMapsEqual = areTerminalNodeMapsEqual(generalTerminalNodeMap, specificTerminalNodeMap);
26
-
27
- if (terminalNodeMapsEqual) {
28
- const visited = generalChildNodes.every((generalChildNode, index) => {
29
- const specificChildNode = specificChildNodes[index],
30
- specificNode = specificChildNode, ///
31
- generalNode = generalChildNode, ///
32
- visited = this.visitNode(generalNode, specificNode, ...remainingArguments);
33
-
34
- if (visited) {
35
- return true;
36
- }
37
- });
38
-
39
- if (visited) {
40
- descended = true;
41
- }
25
+ if (visited) {
26
+ return true;
42
27
  }
28
+ });
29
+
30
+ if (visited) {
31
+ descended = true;
43
32
  }
44
33
 
34
+
45
35
  return descended;
46
36
  }
47
37
 
@@ -99,10 +89,14 @@ export default class ZipPass {
99
89
  specificNonTerminalNodeChildNodes = specificNonTerminalNode.getChildNodes(),
100
90
  generalChildNodes = generalNonTerminalNodeChildNodes, ///
101
91
  specificChildNodes = specificNonTerminalNodeChildNodes, ///
102
- descended = this.descend(generalChildNodes, specificChildNodes, ...remainingArguments);
92
+ childNodesCongruent = areChildNodesCongruent(generalChildNodes, specificChildNodes);
93
+
94
+ if (childNodesCongruent) {
95
+ const descended = this.descend(generalChildNodes, specificChildNodes, ...remainingArguments);
103
96
 
104
- if (descended) {
105
- visited = true;
97
+ if (descended) {
98
+ visited = true;
99
+ }
106
100
  }
107
101
  }
108
102
 
@@ -8,14 +8,33 @@ const { match } = arrayUtilities;
8
8
 
9
9
  export const nonTerminalNodeQuery = nodeQuery("/*");
10
10
 
11
- export function terminalNodeMapFromNodes(nodes) {
11
+ export function areChildNodesCongruent(childNodesA, childNodesB) {
12
+ let areChildNodesCongruent = false;
13
+
14
+ const childNodesALength = childNodesA.length,
15
+ childNodesBLength = childNodesB.length;
16
+
17
+ if (childNodesALength === childNodesBLength) {
18
+ const specificTerminalNodeMap = terminalNodeMapFromChildNodes(childNodesB),
19
+ generalTerminalNodeMap = terminalNodeMapFromChildNodes(childNodesA),
20
+ terminalNodeMapsEqual = areTerminalNodeMapsEqual(generalTerminalNodeMap, specificTerminalNodeMap);
21
+
22
+ if (terminalNodeMapsEqual) {
23
+ areChildNodesCongruent = true;
24
+ }
25
+ }
26
+
27
+ return areChildNodesCongruent;
28
+ }
29
+
30
+ function terminalNodeMapFromChildNodes(childNodes) {
12
31
  const terminalNodeMap = {};
13
32
 
14
- nodes.forEach((node, index) => {
15
- const nodeTerminalNode = node.isTerminalNode();
33
+ childNodes.forEach((childNode, index) => {
34
+ const childNodeTerminalNode = childNode.isTerminalNode();
16
35
 
17
- if (nodeTerminalNode) {
18
- const terminalNode = node; //
36
+ if (childNodeTerminalNode) {
37
+ const terminalNode = childNode; //
19
38
 
20
39
  terminalNodeMap[index] = terminalNode;
21
40
  }
@@ -24,7 +43,7 @@ export function terminalNodeMapFromNodes(nodes) {
24
43
  return terminalNodeMap;
25
44
  }
26
45
 
27
- export function areTerminalNodeMapsEqual(generalTerminalNodeMap, specificTerminalNodeMap) {
46
+ function areTerminalNodeMapsEqual(generalTerminalNodeMap, specificTerminalNodeMap) {
28
47
  let terminalNodeMapsEqual = false;
29
48
 
30
49
  const generalIndexes = Object.keys(generalTerminalNodeMap), ///