occam-languages 0.0.205 → 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 +5 -1
- package/lib/pass/equivalence.js +13 -16
- package/lib/pass/forwardZip.js +96 -0
- package/lib/pass/zip.js +14 -17
- package/lib/utilities/pass.js +19 -11
- package/package.json +1 -1
- package/src/index.js +1 -0
- package/src/pass/equivalence.js +17 -24
- package/src/pass/forwardZip.js +141 -0
- package/src/pass/zip.js +20 -26
- package/src/utilities/pass.js +25 -6
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,
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuZXhwb3J0IHsgZGVmYXVsdCBhcyBMb2cgfSBmcm9tIFwiLi9sb2dcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgRWxlbWVudCB9IGZyb20gXCIuL2VsZW1lbnRcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgQ29udGV4dCB9IGZyb20gXCIuL2NvbnRleHRcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgQnJlYWtQb2ludCB9IGZyb20gXCIuL2JyZWFrUG9pbnRcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgRmlsZUNvbnRleHQgfSBmcm9tIFwiLi9jb250ZXh0L2ZpbGVcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgUmVsZWFzZUNvbnRleHQgfSBmcm9tIFwiLi9jb250ZXh0L3JlbGVhc2VcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgTm9uVGVybWluYWxOb2RlIH0gZnJvbSBcIi4vbm9uVGVybWluYWxOb2RlXCI7XG5cbmV4cG9ydCB7IGRlZmF1bHQgYXMgWmlwUGFzcyB9IGZyb20gXCIuL3Bhc3MvemlwXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEFzeW5jUGFzcyB9IGZyb20gXCIuL3Bhc3MvYXN5bmNcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgU2ltcGxlUGFzcyB9IGZyb20gXCIuL3Bhc3Mvc2ltcGxlXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEZvcndhcmRQYXNzIH0gZnJvbSBcIi4vcGFzcy9mb3J3YXJkXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEZvcndhcmRaaXBQYXNzIH0gZnJvbSBcIi4vcGFzcy9mb3J3YXJkWmlwXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEVxdWl2YWxlbmNlUGFzcyB9IGZyb20gXCIuL3Bhc3MvZXF1aXZhbGVuY2VcIjtcblxuZXhwb3J0IHsgZGVmYXVsdCBhcyBub2RlVXRpbGl0aWVzIH0gZnJvbSBcIi4vdXRpbGl0aWVzL25vZGVcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgcXVlcnlVdGlsaXRpZXMgfSBmcm9tIFwiLi91dGlsaXRpZXMvcXVlcnlcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgZmlsZUNvbnRleHRVdGlsaXRpZXMgfSBmcm9tIFwiLi91dGlsaXRpZXMvZmlsZUNvbnRleHRcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgdmVyaWZpY2F0aW9uVXRpbGl0aWVzIH0gZnJvbSBcIi4vdXRpbGl0aWVzL3ZlcmlmaWNhdGlvblwiO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBhc3luY2hyb25vdXNVdGlsaXRpZXMgfSBmcm9tIFwiLi91dGlsaXRpZXMvYXN5bmNocm9ub3VzXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIHJlbGVhc2VDb250ZXh0VXRpbGl0aWVzIH0gZnJvbSBcIi4vdXRpbGl0aWVzL3JlbGVhc2VDb250ZXh0XCI7XG4iXSwibmFtZXMiOlsiQXN5bmNQYXNzIiwiQnJlYWtQb2ludCIsIkNvbnRleHQiLCJFbGVtZW50IiwiRXF1aXZhbGVuY2VQYXNzIiwiRmlsZUNvbnRleHQiLCJGb3J3YXJkUGFzcyIsIkZvcndhcmRaaXBQYXNzIiwiTG9nIiwiTm9uVGVybWluYWxOb2RlIiwiUmVsZWFzZUNvbnRleHQiLCJTaW1wbGVQYXNzIiwiWmlwUGFzcyIsImFzeW5jaHJvbm91c1V0aWxpdGllcyIsImZpbGVDb250ZXh0VXRpbGl0aWVzIiwibm9kZVV0aWxpdGllcyIsInF1ZXJ5VXRpbGl0aWVzIiwicmVsZWFzZUNvbnRleHRVdGlsaXRpZXMiLCJ2ZXJpZmljYXRpb25VdGlsaXRpZXMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7OztRQVdvQkE7ZUFBQUEsY0FBUzs7UUFOVEM7ZUFBQUEsbUJBQVU7O1FBRFZDO2VBQUFBLGdCQUFPOztRQURQQztlQUFBQSxnQkFBTzs7UUFZUEM7ZUFBQUEsb0JBQWU7O1FBVGZDO2VBQUFBLGFBQVc7O1FBT1hDO2VBQUFBLGdCQUFXOztRQUNYQztlQUFBQSxtQkFBYzs7UUFaZEM7ZUFBQUEsWUFBRzs7UUFNSEM7ZUFBQUEsd0JBQWU7O1FBRGZDO2VBQUFBLGdCQUFjOztRQUtkQztlQUFBQSxlQUFVOztRQUZWQztlQUFBQSxZQUFPOztRQVdQQztlQUFBQSxxQkFBcUI7O1FBRnJCQztlQUFBQSxvQkFBb0I7O1FBRnBCQztlQUFBQSxhQUFhOztRQUNiQztlQUFBQSxjQUFjOztRQUlkQztlQUFBQSx1QkFBdUI7O1FBRnZCQztlQUFBQSxxQkFBcUI7Ozs0REFsQlY7Z0VBQ0k7Z0VBQ0E7bUVBQ0c7NkRBQ0M7Z0VBQ0c7d0VBQ0M7NERBRVI7OERBQ0U7K0RBQ0M7Z0VBQ0M7bUVBQ0c7b0VBQ0M7NkRBRUY7OERBQ0M7b0VBQ007cUVBQ0M7cUVBQ0E7dUVBQ0UifQ==
|
package/lib/pass/equivalence.js
CHANGED
|
@@ -17,19 +17,13 @@ class EquivalencePass {
|
|
|
17
17
|
return success;
|
|
18
18
|
}
|
|
19
19
|
descend(leftChildNodes, rightChildNodes, ...remainingArguments) {
|
|
20
|
-
let descended
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
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,
|
|
67
|
-
if (
|
|
68
|
-
|
|
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,
|
|
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
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
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,
|
|
70
|
-
if (
|
|
71
|
-
|
|
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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"}
|
package/lib/utilities/pass.js
CHANGED
|
@@ -9,26 +9,34 @@ function _export(target, all) {
|
|
|
9
9
|
});
|
|
10
10
|
}
|
|
11
11
|
_export(exports, {
|
|
12
|
-
get
|
|
13
|
-
return
|
|
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
|
|
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
|
-
|
|
29
|
-
const
|
|
30
|
-
if (
|
|
31
|
-
const terminalNode =
|
|
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,
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsaXRpZXMvcGFzcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IHsgYXJyYXlVdGlsaXRpZXMgfSBmcm9tIFwibmVjZXNzYXJ5XCI7XG5cbmltcG9ydCB7IG5vZGVRdWVyeSB9IGZyb20gXCIuLi91dGlsaXRpZXMvcXVlcnlcIjtcblxuY29uc3QgeyBtYXRjaCB9ID0gYXJyYXlVdGlsaXRpZXM7XG5cbmV4cG9ydCBjb25zdCBub25UZXJtaW5hbE5vZGVRdWVyeSA9IG5vZGVRdWVyeShcIi8qXCIpO1xuXG5leHBvcnQgZnVuY3Rpb24gYXJlQ2hpbGROb2Rlc0NvbmdydWVudChjaGlsZE5vZGVzQSwgY2hpbGROb2Rlc0IpIHtcbiAgbGV0IGFyZUNoaWxkTm9kZXNDb25ncnVlbnQgPSBmYWxzZTtcblxuICBjb25zdCBjaGlsZE5vZGVzQUxlbmd0aCA9IGNoaWxkTm9kZXNBLmxlbmd0aCxcbiAgICAgICAgY2hpbGROb2Rlc0JMZW5ndGggPSBjaGlsZE5vZGVzQi5sZW5ndGg7XG5cbiAgaWYgKGNoaWxkTm9kZXNBTGVuZ3RoID09PSBjaGlsZE5vZGVzQkxlbmd0aCkge1xuICAgIGNvbnN0IHNwZWNpZmljVGVybWluYWxOb2RlTWFwID0gdGVybWluYWxOb2RlTWFwRnJvbUNoaWxkTm9kZXMoY2hpbGROb2Rlc0IpLFxuICAgICAgICAgIGdlbmVyYWxUZXJtaW5hbE5vZGVNYXAgPSB0ZXJtaW5hbE5vZGVNYXBGcm9tQ2hpbGROb2RlcyhjaGlsZE5vZGVzQSksXG4gICAgICAgICAgdGVybWluYWxOb2RlTWFwc0VxdWFsID0gYXJlVGVybWluYWxOb2RlTWFwc0VxdWFsKGdlbmVyYWxUZXJtaW5hbE5vZGVNYXAsIHNwZWNpZmljVGVybWluYWxOb2RlTWFwKTtcblxuICAgIGlmICh0ZXJtaW5hbE5vZGVNYXBzRXF1YWwpIHtcbiAgICAgIGFyZUNoaWxkTm9kZXNDb25ncnVlbnQgPSB0cnVlO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBhcmVDaGlsZE5vZGVzQ29uZ3J1ZW50O1xufVxuXG5mdW5jdGlvbiB0ZXJtaW5hbE5vZGVNYXBGcm9tQ2hpbGROb2RlcyhjaGlsZE5vZGVzKSB7XG4gIGNvbnN0IHRlcm1pbmFsTm9kZU1hcCA9IHt9O1xuXG4gIGNoaWxkTm9kZXMuZm9yRWFjaCgoY2hpbGROb2RlLCBpbmRleCkgPT4ge1xuICAgIGNvbnN0IGNoaWxkTm9kZVRlcm1pbmFsTm9kZSA9IGNoaWxkTm9kZS5pc1Rlcm1pbmFsTm9kZSgpO1xuXG4gICAgaWYgKGNoaWxkTm9kZVRlcm1pbmFsTm9kZSkge1xuICAgICAgY29uc3QgdGVybWluYWxOb2RlID0gY2hpbGROb2RlOyAgLy9cblxuICAgICAgdGVybWluYWxOb2RlTWFwW2luZGV4XSA9IHRlcm1pbmFsTm9kZTtcbiAgICB9XG4gIH0pO1xuXG4gIHJldHVybiB0ZXJtaW5hbE5vZGVNYXA7XG59XG5cbmZ1bmN0aW9uIGFyZVRlcm1pbmFsTm9kZU1hcHNFcXVhbChnZW5lcmFsVGVybWluYWxOb2RlTWFwLCBzcGVjaWZpY1Rlcm1pbmFsTm9kZU1hcCkge1xuICBsZXQgdGVybWluYWxOb2RlTWFwc0VxdWFsID0gZmFsc2U7XG5cbiAgY29uc3QgZ2VuZXJhbEluZGV4ZXMgPSBPYmplY3Qua2V5cyhnZW5lcmFsVGVybWluYWxOb2RlTWFwKSwgLy8vXG4gICAgICAgIHNwZWNpZmljSW5kZXhlcyA9IE9iamVjdC5rZXlzKHNwZWNpZmljVGVybWluYWxOb2RlTWFwKSwgLy8vXG4gICAgICAgIHRlcm1pbmFsTm9kZU1hcEtleXNNYXRjaCA9IG1hdGNoKGdlbmVyYWxJbmRleGVzLCBzcGVjaWZpY0luZGV4ZXMsIChnZW5lcmFsSW5kZXgsIHNwZWNpZmljSW5kZXgpID0+IHtcbiAgICAgICAgICBpZiAoZ2VuZXJhbEluZGV4ID09PSBzcGVjaWZpY0luZGV4KSB7XG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgICB9XG4gICAgICAgIH0pO1xuXG4gIGlmICh0ZXJtaW5hbE5vZGVNYXBLZXlzTWF0Y2gpIHtcbiAgICBjb25zdCBnZW5lcmFsVGVybWluYWxOb2RlcyA9IE9iamVjdC52YWx1ZXMoZ2VuZXJhbFRlcm1pbmFsTm9kZU1hcCksIC8vL1xuICAgICAgICAgIHNwZWNpZmljVGVybWluYWxOb2RlcyA9IE9iamVjdC52YWx1ZXMoc3BlY2lmaWNUZXJtaW5hbE5vZGVNYXApLCAvLy9cbiAgICAgICAgICB0ZXJtaW5hbE5vZGVNYXBWYWx1ZXNNYXRjaCA9IG1hdGNoKGdlbmVyYWxUZXJtaW5hbE5vZGVzLCBzcGVjaWZpY1Rlcm1pbmFsTm9kZXMsIChnZW5lcmFsVGVybWluYWxOb2RlLCBzcGVjaWZpY1Rlcm1pbmFsTm9kZSkgPT4ge1xuICAgICAgICAgICAgY29uc3QgZ2VuZXJhbFRlcm1pbmFsTm9kZU1hdGNoZXNTcGVjaWZpY1Rlcm1pbmFsTm9kZSA9IGdlbmVyYWxUZXJtaW5hbE5vZGUubWF0Y2goc3BlY2lmaWNUZXJtaW5hbE5vZGUpO1xuXG4gICAgICAgICAgICBpZiAoZ2VuZXJhbFRlcm1pbmFsTm9kZU1hdGNoZXNTcGVjaWZpY1Rlcm1pbmFsTm9kZSkge1xuICAgICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9KTtcblxuICAgIHRlcm1pbmFsTm9kZU1hcHNFcXVhbCA9IHRlcm1pbmFsTm9kZU1hcFZhbHVlc01hdGNoOyAvLy9cbiAgfVxuXG4gIHJldHVybiB0ZXJtaW5hbE5vZGVNYXBzRXF1YWw7XG59XG4iXSwibmFtZXMiOlsiYXJlQ2hpbGROb2Rlc0NvbmdydWVudCIsIm5vblRlcm1pbmFsTm9kZVF1ZXJ5IiwibWF0Y2giLCJhcnJheVV0aWxpdGllcyIsIm5vZGVRdWVyeSIsImNoaWxkTm9kZXNBIiwiY2hpbGROb2Rlc0IiLCJjaGlsZE5vZGVzQUxlbmd0aCIsImxlbmd0aCIsImNoaWxkTm9kZXNCTGVuZ3RoIiwic3BlY2lmaWNUZXJtaW5hbE5vZGVNYXAiLCJ0ZXJtaW5hbE5vZGVNYXBGcm9tQ2hpbGROb2RlcyIsImdlbmVyYWxUZXJtaW5hbE5vZGVNYXAiLCJ0ZXJtaW5hbE5vZGVNYXBzRXF1YWwiLCJhcmVUZXJtaW5hbE5vZGVNYXBzRXF1YWwiLCJjaGlsZE5vZGVzIiwidGVybWluYWxOb2RlTWFwIiwiZm9yRWFjaCIsImNoaWxkTm9kZSIsImluZGV4IiwiY2hpbGROb2RlVGVybWluYWxOb2RlIiwiaXNUZXJtaW5hbE5vZGUiLCJ0ZXJtaW5hbE5vZGUiLCJnZW5lcmFsSW5kZXhlcyIsIk9iamVjdCIsImtleXMiLCJzcGVjaWZpY0luZGV4ZXMiLCJ0ZXJtaW5hbE5vZGVNYXBLZXlzTWF0Y2giLCJnZW5lcmFsSW5kZXgiLCJzcGVjaWZpY0luZGV4IiwiZ2VuZXJhbFRlcm1pbmFsTm9kZXMiLCJ2YWx1ZXMiLCJzcGVjaWZpY1Rlcm1pbmFsTm9kZXMiLCJ0ZXJtaW5hbE5vZGVNYXBWYWx1ZXNNYXRjaCIsImdlbmVyYWxUZXJtaW5hbE5vZGUiLCJzcGVjaWZpY1Rlcm1pbmFsTm9kZSIsImdlbmVyYWxUZXJtaW5hbE5vZGVNYXRjaGVzU3BlY2lmaWNUZXJtaW5hbE5vZGUiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7OztRQVVnQkE7ZUFBQUE7O1FBRkhDO2VBQUFBOzs7MkJBTmtCO3VCQUVMO0FBRTFCLE1BQU0sRUFBRUMsS0FBSyxFQUFFLEdBQUdDLHlCQUFjO0FBRXpCLE1BQU1GLHVCQUF1QkcsSUFBQUEsZ0JBQVMsRUFBQztBQUV2QyxTQUFTSix1QkFBdUJLLFdBQVcsRUFBRUMsV0FBVztJQUM3RCxJQUFJTix5QkFBeUI7SUFFN0IsTUFBTU8sb0JBQW9CRixZQUFZRyxNQUFNLEVBQ3RDQyxvQkFBb0JILFlBQVlFLE1BQU07SUFFNUMsSUFBSUQsc0JBQXNCRSxtQkFBbUI7UUFDM0MsTUFBTUMsMEJBQTBCQyw4QkFBOEJMLGNBQ3hETSx5QkFBeUJELDhCQUE4Qk4sY0FDdkRRLHdCQUF3QkMseUJBQXlCRix3QkFBd0JGO1FBRS9FLElBQUlHLHVCQUF1QjtZQUN6QmIseUJBQXlCO1FBQzNCO0lBQ0Y7SUFFQSxPQUFPQTtBQUNUO0FBRUEsU0FBU1csOEJBQThCSSxVQUFVO0lBQy9DLE1BQU1DLGtCQUFrQixDQUFDO0lBRXpCRCxXQUFXRSxPQUFPLENBQUMsQ0FBQ0MsV0FBV0M7UUFDN0IsTUFBTUMsd0JBQXdCRixVQUFVRyxjQUFjO1FBRXRELElBQUlELHVCQUF1QjtZQUN6QixNQUFNRSxlQUFlSixXQUFZLEVBQUU7WUFFbkNGLGVBQWUsQ0FBQ0csTUFBTSxHQUFHRztRQUMzQjtJQUNGO0lBRUEsT0FBT047QUFDVDtBQUVBLFNBQVNGLHlCQUF5QkYsc0JBQXNCLEVBQUVGLHVCQUF1QjtJQUMvRSxJQUFJRyx3QkFBd0I7SUFFNUIsTUFBTVUsaUJBQWlCQyxPQUFPQyxJQUFJLENBQUNiLHlCQUM3QmMsa0JBQWtCRixPQUFPQyxJQUFJLENBQUNmLDBCQUM5QmlCLDJCQUEyQnpCLE1BQU1xQixnQkFBZ0JHLGlCQUFpQixDQUFDRSxjQUFjQztRQUMvRSxJQUFJRCxpQkFBaUJDLGVBQWU7WUFDbEMsT0FBTztRQUNUO0lBQ0Y7SUFFTixJQUFJRiwwQkFBMEI7UUFDNUIsTUFBTUcsdUJBQXVCTixPQUFPTyxNQUFNLENBQUNuQix5QkFDckNvQix3QkFBd0JSLE9BQU9PLE1BQU0sQ0FBQ3JCLDBCQUN0Q3VCLDZCQUE2Qi9CLE1BQU00QixzQkFBc0JFLHVCQUF1QixDQUFDRSxxQkFBcUJDO1lBQ3BHLE1BQU1DLGlEQUFpREYsb0JBQW9CaEMsS0FBSyxDQUFDaUM7WUFFakYsSUFBSUMsZ0RBQWdEO2dCQUNsRCxPQUFPO1lBQ1Q7UUFDRjtRQUVOdkIsd0JBQXdCb0IsNEJBQTRCLEdBQUc7SUFDekQ7SUFFQSxPQUFPcEI7QUFDVCJ9
|
package/package.json
CHANGED
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";
|
package/src/pass/equivalence.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
import { nonTerminalNodeQuery,
|
|
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
|
|
17
|
+
let descended;
|
|
18
18
|
|
|
19
|
-
|
|
20
|
-
|
|
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
|
-
|
|
23
|
-
|
|
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
|
-
|
|
87
|
+
childNodesCongruent = areChildNodesCongruent(leftChildNodes, rightChildNodes);
|
|
88
|
+
|
|
89
|
+
if (childNodesCongruent) {
|
|
90
|
+
const descended = this.descend(leftChildNodes, rightChildNodes, ...remainingArguments);
|
|
99
91
|
|
|
100
|
-
|
|
101
|
-
|
|
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,
|
|
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
|
|
20
|
-
|
|
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
|
-
|
|
23
|
-
|
|
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
|
-
|
|
92
|
+
childNodesCongruent = areChildNodesCongruent(generalChildNodes, specificChildNodes);
|
|
93
|
+
|
|
94
|
+
if (childNodesCongruent) {
|
|
95
|
+
const descended = this.descend(generalChildNodes, specificChildNodes, ...remainingArguments);
|
|
103
96
|
|
|
104
|
-
|
|
105
|
-
|
|
97
|
+
if (descended) {
|
|
98
|
+
visited = true;
|
|
99
|
+
}
|
|
106
100
|
}
|
|
107
101
|
}
|
|
108
102
|
|
package/src/utilities/pass.js
CHANGED
|
@@ -8,14 +8,33 @@ const { match } = arrayUtilities;
|
|
|
8
8
|
|
|
9
9
|
export const nonTerminalNodeQuery = nodeQuery("/*");
|
|
10
10
|
|
|
11
|
-
export function
|
|
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
|
-
|
|
15
|
-
const
|
|
33
|
+
childNodes.forEach((childNode, index) => {
|
|
34
|
+
const childNodeTerminalNode = childNode.isTerminalNode();
|
|
16
35
|
|
|
17
|
-
if (
|
|
18
|
-
const terminalNode =
|
|
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
|
-
|
|
46
|
+
function areTerminalNodeMapsEqual(generalTerminalNodeMap, specificTerminalNodeMap) {
|
|
28
47
|
let terminalNodeMapsEqual = false;
|
|
29
48
|
|
|
30
49
|
const generalIndexes = Object.keys(generalTerminalNodeMap), ///
|