occam-dom 5.2.22 → 5.2.24

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/node.js CHANGED
@@ -248,6 +248,7 @@ var Node = /*#__PURE__*/ function() {
248
248
  parentNode,
249
249
  childNodes
250
250
  ].concat(_to_consumable_array(remainingArguments)));
251
+ node.setChildNodesParentNode();
251
252
  return node;
252
253
  }
253
254
  }
@@ -256,4 +257,4 @@ var Node = /*#__PURE__*/ function() {
256
257
  }();
257
258
  Object.assign(Node.prototype, _occamparsers.nodeMixins);
258
259
 
259
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/node.js"],"sourcesContent":["\"use strict\";\n\nimport { nodeMixins } from \"occam-parsers\";\n\nimport NodeParseTree from \"./parseTree/node\";\n\nimport { EMPTY_STRING } from \"./constants\";\n\nexport default class Node {\n  constructor(outerNode, parentNode, childNodes) {\n    this.outerNode = outerNode;\n    this.parentNode = parentNode;\n    this.childNodes = childNodes;\n  }\n\n  getOuterNode() {\n    return this.outerNode;\n  }\n\n  getParentNode() {\n    return this.parentNode;\n  }\n\n  getChildNodes() {\n    return this.childNodes;\n  }\n\n  setOuterNode(outerNode) {\n    this.outerNode = outerNode;\n  }\n\n  setParentNode(parentNode) {\n    this.parentNode = parentNode;\n  }\n\n  setChildNodes(childNodes) {\n    const startIndex = 0,\n          deleteCount = Infinity,\n          addedChildNodes = childNodes;  ///\n\n    this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);\n  }\n\n  destroy() {\n    this.outerNode = null;\n\n    super.destroy();\n  }\n\n  asString() {\n    let string = EMPTY_STRING;\n\n    if (this.outerNode !== null) {\n      const nodeTerminalNode = this.outerNode.isTerminalNode();\n\n      if (nodeTerminalNode) {\n        const terminalNode = this.outerNode,\n              type = terminalNode.getType(),\n              content = terminalNode.getContent();\n\n        string = `\"${content}\" [${type}]`;\n      } else {\n        const nonTerminalNode = this.outerNode,\n              ruleName = nonTerminalNode.getRuleName();\n\n        string = ruleName;  ///\n      }\n    }\n\n    return string;\n  }\n\n  asParseTree() {\n    const node = this,  ///\n          nodeParseTree = NodeParseTree.fromNode(node),\n          parseTree = nodeParseTree;  ///\n\n    return parseTree;\n  }\n\n  static fromNothing(Class, ...remainingArguments) {\n    if (Class === undefined) {\n      Class = Node; ///\n    }\n\n    const outerNode = null,\n          parentNode = null,\n          childNodes = [],\n          node = new Class(outerNode, parentNode, childNodes, ...remainingArguments);\n\n    return node;\n  }\n\n  static fromOuterNode(Class, outerNode, ...remainingArguments) {\n    if (outerNode === undefined) {\n      outerNode = Class;  ///\n\n      Class = Node; ///\n    }\n\n    const parentNode = null,\n          childNodes = [],\n          node = new Class(outerNode, parentNode, childNodes, ...remainingArguments);\n\n    return node;\n  }\n\n  static fromChildNodes(Class, childNodes, ...remainingArguments) {\n    if (childNodes === undefined) {\n      childNodes = Class;  ///\n\n      Class = Node; ///\n    }\n\n    const outerNode = null,\n          parentNode = null,\n          node = new Class(outerNode, parentNode, childNodes, ...remainingArguments);\n\n    return node;\n  }\n}\n\nObject.assign(Node.prototype, nodeMixins);\n"],"names":["Node","outerNode","parentNode","childNodes","getOuterNode","getParentNode","getChildNodes","setOuterNode","setParentNode","setChildNodes","startIndex","deleteCount","Infinity","addedChildNodes","spliceChildNodes","destroy","asString","string","EMPTY_STRING","nodeTerminalNode","isTerminalNode","terminalNode","type","getType","content","getContent","nonTerminalNode","ruleName","getRuleName","asParseTree","node","nodeParseTree","NodeParseTree","fromNode","parseTree","fromNothing","Class","remainingArguments","undefined","fromOuterNode","fromChildNodes","Object","assign","prototype","nodeMixins"],"mappings":"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"}
260
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/node.js"],"sourcesContent":["\"use strict\";\n\nimport { nodeMixins } from \"occam-parsers\";\n\nimport NodeParseTree from \"./parseTree/node\";\n\nimport { EMPTY_STRING } from \"./constants\";\n\nexport default class Node {\n  constructor(outerNode, parentNode, childNodes) {\n    this.outerNode = outerNode;\n    this.parentNode = parentNode;\n    this.childNodes = childNodes;\n  }\n\n  getOuterNode() {\n    return this.outerNode;\n  }\n\n  getParentNode() {\n    return this.parentNode;\n  }\n\n  getChildNodes() {\n    return this.childNodes;\n  }\n\n  setOuterNode(outerNode) {\n    this.outerNode = outerNode;\n  }\n\n  setParentNode(parentNode) {\n    this.parentNode = parentNode;\n  }\n\n  setChildNodes(childNodes) {\n    const startIndex = 0,\n          deleteCount = Infinity,\n          addedChildNodes = childNodes;  ///\n\n    this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);\n  }\n\n  destroy() {\n    this.outerNode = null;\n\n    super.destroy();\n  }\n\n  asString() {\n    let string = EMPTY_STRING;\n\n    if (this.outerNode !== null) {\n      const nodeTerminalNode = this.outerNode.isTerminalNode();\n\n      if (nodeTerminalNode) {\n        const terminalNode = this.outerNode,\n              type = terminalNode.getType(),\n              content = terminalNode.getContent();\n\n        string = `\"${content}\" [${type}]`;\n      } else {\n        const nonTerminalNode = this.outerNode,\n              ruleName = nonTerminalNode.getRuleName();\n\n        string = ruleName;  ///\n      }\n    }\n\n    return string;\n  }\n\n  asParseTree() {\n    const node = this,  ///\n          nodeParseTree = NodeParseTree.fromNode(node),\n          parseTree = nodeParseTree;  ///\n\n    return parseTree;\n  }\n\n  static fromNothing(Class, ...remainingArguments) {\n    if (Class === undefined) {\n      Class = Node; ///\n    }\n\n    const outerNode = null,\n          parentNode = null,\n          childNodes = [],\n          node = new Class(outerNode, parentNode, childNodes, ...remainingArguments);\n\n    return node;\n  }\n\n  static fromOuterNode(Class, outerNode, ...remainingArguments) {\n    if (outerNode === undefined) {\n      outerNode = Class;  ///\n\n      Class = Node; ///\n    }\n\n    const parentNode = null,\n          childNodes = [],\n          node = new Class(outerNode, parentNode, childNodes, ...remainingArguments);\n\n    return node;\n  }\n\n  static fromChildNodes(Class, childNodes, ...remainingArguments) {\n    if (childNodes === undefined) {\n      childNodes = Class;  ///\n\n      Class = Node; ///\n    }\n\n    const outerNode = null,\n          parentNode = null,\n          node = new Class(outerNode, parentNode, childNodes, ...remainingArguments);\n\n    node.setChildNodesParentNode();\n\n    return node;\n  }\n}\n\nObject.assign(Node.prototype, nodeMixins);\n"],"names":["Node","outerNode","parentNode","childNodes","getOuterNode","getParentNode","getChildNodes","setOuterNode","setParentNode","setChildNodes","startIndex","deleteCount","Infinity","addedChildNodes","spliceChildNodes","destroy","asString","string","EMPTY_STRING","nodeTerminalNode","isTerminalNode","terminalNode","type","getType","content","getContent","nonTerminalNode","ruleName","getRuleName","asParseTree","node","nodeParseTree","NodeParseTree","fromNode","parseTree","fromNothing","Class","remainingArguments","undefined","fromOuterNode","fromChildNodes","setChildNodesParentNode","Object","assign","prototype","nodeMixins"],"mappings":"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"}
@@ -12,6 +12,9 @@ _export(exports, {
12
12
  default: function() {
13
13
  return _default;
14
14
  },
15
+ isLessThan: function() {
16
+ return isLessThan;
17
+ },
15
18
  topmostNodeFromOuterNodes: function() {
16
19
  return topmostNodeFromOuterNodes;
17
20
  }
@@ -22,6 +25,22 @@ function _interop_require_default(obj) {
22
25
  default: obj
23
26
  };
24
27
  }
28
+ function isLessThan(nodeA, nodeB) {
29
+ var lessThan = null;
30
+ var nodeAAncestorNodes = ancestorNodesFromNode(nodeA), nodeBAncestorNodes = ancestorNodesFromNode(nodeB), nodeAAncestorNodesLength = nodeAAncestorNodes.length, nodeBAncestorNodesLength = nodeBAncestorNodes.length, minimumAncestorNodesLength = Math.min(nodeAAncestorNodesLength, nodeBAncestorNodesLength);
31
+ for(var index = 0; index < minimumAncestorNodesLength; index++){
32
+ var nodeAAncestorNode = nodeAAncestorNodes[index], nodeBAncestorNode = nodeBAncestorNodes[index];
33
+ if (nodeAAncestorNode !== nodeBAncestorNode) {
34
+ var parentIndex = index - 1, nodeAAncestorNodeParentNode = nodeAAncestorNodes[parentIndex], parentNode = nodeAAncestorNodeParentNode, childNodeA = nodeAAncestorNode, childNodeB = nodeBAncestorNode, indexA = parentNode.indexOfChildNode(childNodeA), indexB = parentNode.indexOfChildNode(childNodeB);
35
+ lessThan = indexA < indexB;
36
+ break;
37
+ }
38
+ }
39
+ if (lessThan === null) {
40
+ lessThan = nodeAAncestorNodesLength < nodeBAncestorNodesLength;
41
+ }
42
+ return lessThan;
43
+ }
25
44
  function topmostNodeFromOuterNodes(ClassFromOuterNode, outerNodes) {
26
45
  if (outerNodes === undefined) {
27
46
  outerNodes = ClassFromOuterNode; ///
@@ -48,6 +67,7 @@ function topmostNodeFromOuterNodes(ClassFromOuterNode, outerNodes) {
48
67
  return topmostNode;
49
68
  }
50
69
  var _default = {
70
+ isLessThan: isLessThan,
51
71
  topmostNodeFromOuterNodes: topmostNodeFromOuterNodes
52
72
  };
53
73
  function orderNodes(nodes) {
@@ -56,22 +76,6 @@ function orderNodes(nodes) {
56
76
  return result;
57
77
  });
58
78
  }
59
- function isLessThan(nodeA, nodeB) {
60
- var lessThan = null;
61
- var nodeAAncestorNodes = ancestorNodesFromNode(nodeA), nodeBAncestorNodes = ancestorNodesFromNode(nodeB), nodeAAncestorNodesLength = nodeAAncestorNodes.length, nodeBAncestorNodesLength = nodeBAncestorNodes.length, minimumAncestorNodesLength = Math.min(nodeAAncestorNodesLength, nodeBAncestorNodesLength);
62
- for(var index = 0; index < minimumAncestorNodesLength; index++){
63
- var nodeAAncestorNode = nodeAAncestorNodes[index], nodeBAncestorNode = nodeBAncestorNodes[index];
64
- if (nodeAAncestorNode !== nodeBAncestorNode) {
65
- var parentIndex = index - 1, nodeAAncestorNodeParentNode = nodeAAncestorNodes[parentIndex], parentNode = nodeAAncestorNodeParentNode, childNodeA = nodeAAncestorNode, childNodeB = nodeBAncestorNode, indexA = parentNode.indexOfChildNode(childNodeA), indexB = parentNode.indexOfChildNode(childNodeB);
66
- lessThan = indexA < indexB;
67
- break;
68
- }
69
- }
70
- if (lessThan === null) {
71
- lessThan = nodeAAncestorNodesLength < nodeBAncestorNodesLength;
72
- }
73
- return lessThan;
74
- }
75
79
  function ancestorNodesFromNode(node) {
76
80
  var ancestorNodes = node.getAncestorNodes();
77
81
  ancestorNodes.unshift(node);
@@ -79,4 +83,4 @@ function ancestorNodesFromNode(node) {
79
83
  return ancestorNodes;
80
84
  }
81
85
 
82
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsaXRpZXMvbm9kZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IE5vZGUgZnJvbSBcIi4uL25vZGVcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIHRvcG1vc3ROb2RlRnJvbU91dGVyTm9kZXMoQ2xhc3NGcm9tT3V0ZXJOb2RlLCBvdXRlck5vZGVzKSB7XG4gIGlmIChvdXRlck5vZGVzID09PSB1bmRlZmluZWQpIHtcbiAgICBvdXRlck5vZGVzID0gQ2xhc3NGcm9tT3V0ZXJOb2RlOyAvLy9cblxuICAgIENsYXNzRnJvbU91dGVyTm9kZSA9IChvdXRlck5vZGUpID0+IE5vZGU7ICAvLy9cbiAgfVxuXG4gIGNvbnN0IG5vZGVzID0gb3V0ZXJOb2RlczsgLy8vXG5cbiAgb3JkZXJOb2Rlcyhub2Rlcyk7XG5cbiAgY29uc3Qgb3V0ZXJOb2RlID0gbnVsbCxcbiAgICAgICAgQ2xhc3MgPSBDbGFzc0Zyb21PdXRlck5vZGUob3V0ZXJOb2RlKSxcbiAgICAgICAgdG9wbW9zdE5vZGUgPSBDbGFzcy5mcm9tTm90aGluZygpLFxuICAgICAgICBvdXRlck5vZGVUb05vZGVNYXAgPSBuZXcgV2Vha01hcCgpO1xuXG4gIG91dGVyTm9kZXMuZm9yRWFjaCgob3V0ZXJOb2RlKSA9PiB7XG4gICAgbGV0IHBhcmVudE5vZGUgPSB0b3Btb3N0Tm9kZTsgLy8vXG5cbiAgICBvdXRlck5vZGUuc29tZUFuY2VzdG9yTm9kZSgoYW5jZXN0b3JOb2RlKSA9PiB7XG4gICAgICBjb25zdCBvdXRlck5vZGUgPSBhbmNlc3Rvck5vZGUsIC8vL1xuICAgICAgICAgICAgbm9kZSA9IG91dGVyTm9kZVRvTm9kZU1hcC5nZXQob3V0ZXJOb2RlKSB8fCBudWxsO1xuXG4gICAgICBpZiAobm9kZSAhPT0gbnVsbCkge1xuICAgICAgICBwYXJlbnROb2RlID0gbm9kZTsgIC8vL1xuXG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgY29uc3QgQ2xhc3MgPSBDbGFzc0Zyb21PdXRlck5vZGUob3V0ZXJOb2RlKSxcbiAgICAgICAgICBub2RlID0gQ2xhc3MuZnJvbU91dGVyTm9kZShvdXRlck5vZGUpLFxuICAgICAgICAgIGFwcGVuZGVkQ2hpbGROb2RlID0gbm9kZTsgLy8vXG5cbiAgICBwYXJlbnROb2RlLmFwcGVuZENoaWxkTm9kZShhcHBlbmRlZENoaWxkTm9kZSk7XG5cbiAgICBvdXRlck5vZGVUb05vZGVNYXAuc2V0KG91dGVyTm9kZSwgbm9kZSk7XG4gIH0pO1xuXG4gIHJldHVybiB0b3Btb3N0Tm9kZTtcbn1cblxuZXhwb3J0IGRlZmF1bHQge1xuICB0b3Btb3N0Tm9kZUZyb21PdXRlck5vZGVzXG59O1xuXG5mdW5jdGlvbiBvcmRlck5vZGVzKG5vZGVzKSB7XG4gIG5vZGVzLnNvcnQoKG5vZGVBLCBub2RlQikgPT4ge1xuICAgIGNvbnN0IG5vZGVBTGVzc1RoYW5Ob2RlQiA9IGlzTGVzc1RoYW4obm9kZUEsIG5vZGVCKSxcbiAgICAgICAgICByZXN1bHQgPSBub2RlQUxlc3NUaGFuTm9kZUIgP1xuICAgICAgICAgICAgICAgICAgICAgLTEgOlxuICAgICAgICAgICAgICAgICAgICAgICArMTtcblxuICAgIHJldHVybiByZXN1bHQ7XG4gIH0pO1xufVxuXG5mdW5jdGlvbiBpc0xlc3NUaGFuKG5vZGVBLCBub2RlQikge1xuICBsZXQgbGVzc1RoYW4gPSBudWxsO1xuXG4gIGNvbnN0IG5vZGVBQW5jZXN0b3JOb2RlcyA9IGFuY2VzdG9yTm9kZXNGcm9tTm9kZShub2RlQSksXG4gICAgICAgIG5vZGVCQW5jZXN0b3JOb2RlcyA9IGFuY2VzdG9yTm9kZXNGcm9tTm9kZShub2RlQiksXG4gICAgICAgIG5vZGVBQW5jZXN0b3JOb2Rlc0xlbmd0aCA9IG5vZGVBQW5jZXN0b3JOb2Rlcy5sZW5ndGgsXG4gICAgICAgIG5vZGVCQW5jZXN0b3JOb2Rlc0xlbmd0aCA9IG5vZGVCQW5jZXN0b3JOb2Rlcy5sZW5ndGgsXG4gICAgICAgIG1pbmltdW1BbmNlc3Rvck5vZGVzTGVuZ3RoID0gTWF0aC5taW4obm9kZUFBbmNlc3Rvck5vZGVzTGVuZ3RoLCBub2RlQkFuY2VzdG9yTm9kZXNMZW5ndGgpO1xuXG4gIGZvciAobGV0IGluZGV4ID0gMDsgaW5kZXggPCBtaW5pbXVtQW5jZXN0b3JOb2Rlc0xlbmd0aDsgaW5kZXgrKykge1xuICAgIGNvbnN0IG5vZGVBQW5jZXN0b3JOb2RlID0gbm9kZUFBbmNlc3Rvck5vZGVzW2luZGV4XSxcbiAgICAgICAgICBub2RlQkFuY2VzdG9yTm9kZSA9IG5vZGVCQW5jZXN0b3JOb2Rlc1tpbmRleF07XG5cbiAgICBpZiAobm9kZUFBbmNlc3Rvck5vZGUgIT09IG5vZGVCQW5jZXN0b3JOb2RlKSB7XG4gICAgICBjb25zdCBwYXJlbnRJbmRleCA9IGluZGV4IC0gMSxcbiAgICAgICAgICAgIG5vZGVBQW5jZXN0b3JOb2RlUGFyZW50Tm9kZSA9IG5vZGVBQW5jZXN0b3JOb2Rlc1twYXJlbnRJbmRleF0sXG4gICAgICAgICAgICBwYXJlbnROb2RlID0gbm9kZUFBbmNlc3Rvck5vZGVQYXJlbnROb2RlLCAvLy9cbiAgICAgICAgICAgIGNoaWxkTm9kZUEgPSBub2RlQUFuY2VzdG9yTm9kZSwgLy8vXG4gICAgICAgICAgICBjaGlsZE5vZGVCID0gbm9kZUJBbmNlc3Rvck5vZGUsIC8vL1xuICAgICAgICAgICAgaW5kZXhBID0gcGFyZW50Tm9kZS5pbmRleE9mQ2hpbGROb2RlKGNoaWxkTm9kZUEpLFxuICAgICAgICAgICAgaW5kZXhCID0gcGFyZW50Tm9kZS5pbmRleE9mQ2hpbGROb2RlKGNoaWxkTm9kZUIpO1xuXG4gICAgICBsZXNzVGhhbiA9IChpbmRleEEgPCBpbmRleEIpO1xuXG4gICAgICBicmVhaztcbiAgICB9XG4gIH1cblxuICBpZiAobGVzc1RoYW4gPT09IG51bGwpIHtcbiAgICBsZXNzVGhhbiA9IChub2RlQUFuY2VzdG9yTm9kZXNMZW5ndGggPCBub2RlQkFuY2VzdG9yTm9kZXNMZW5ndGgpO1xuICB9XG5cbiAgcmV0dXJuIGxlc3NUaGFuO1xufVxuXG5mdW5jdGlvbiBhbmNlc3Rvck5vZGVzRnJvbU5vZGUobm9kZSkge1xuICBjb25zdCBhbmNlc3Rvck5vZGVzID0gbm9kZS5nZXRBbmNlc3Rvck5vZGVzKCk7XG5cbiAgYW5jZXN0b3JOb2Rlcy51bnNoaWZ0KG5vZGUpO1xuXG4gIGFuY2VzdG9yTm9kZXMucmV2ZXJzZSgpO1xuXG4gIHJldHVybiBhbmNlc3Rvck5vZGVzO1xufVxuIl0sIm5hbWVzIjpbInRvcG1vc3ROb2RlRnJvbU91dGVyTm9kZXMiLCJDbGFzc0Zyb21PdXRlck5vZGUiLCJvdXRlck5vZGVzIiwidW5kZWZpbmVkIiwib3V0ZXJOb2RlIiwiTm9kZSIsIm5vZGVzIiwib3JkZXJOb2RlcyIsIkNsYXNzIiwidG9wbW9zdE5vZGUiLCJmcm9tTm90aGluZyIsIm91dGVyTm9kZVRvTm9kZU1hcCIsIldlYWtNYXAiLCJmb3JFYWNoIiwicGFyZW50Tm9kZSIsInNvbWVBbmNlc3Rvck5vZGUiLCJhbmNlc3Rvck5vZGUiLCJub2RlIiwiZ2V0IiwiZnJvbU91dGVyTm9kZSIsImFwcGVuZGVkQ2hpbGROb2RlIiwiYXBwZW5kQ2hpbGROb2RlIiwic2V0Iiwic29ydCIsIm5vZGVBIiwibm9kZUIiLCJub2RlQUxlc3NUaGFuTm9kZUIiLCJpc0xlc3NUaGFuIiwicmVzdWx0IiwibGVzc1RoYW4iLCJub2RlQUFuY2VzdG9yTm9kZXMiLCJhbmNlc3Rvck5vZGVzRnJvbU5vZGUiLCJub2RlQkFuY2VzdG9yTm9kZXMiLCJub2RlQUFuY2VzdG9yTm9kZXNMZW5ndGgiLCJsZW5ndGgiLCJub2RlQkFuY2VzdG9yTm9kZXNMZW5ndGgiLCJtaW5pbXVtQW5jZXN0b3JOb2Rlc0xlbmd0aCIsIk1hdGgiLCJtaW4iLCJpbmRleCIsIm5vZGVBQW5jZXN0b3JOb2RlIiwibm9kZUJBbmNlc3Rvck5vZGUiLCJwYXJlbnRJbmRleCIsIm5vZGVBQW5jZXN0b3JOb2RlUGFyZW50Tm9kZSIsImNoaWxkTm9kZUEiLCJjaGlsZE5vZGVCIiwiaW5kZXhBIiwiaW5kZXhPZkNoaWxkTm9kZSIsImluZGV4QiIsImFuY2VzdG9yTm9kZXMiLCJnZXRBbmNlc3Rvck5vZGVzIiwidW5zaGlmdCIsInJldmVyc2UiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7OztJQThDQSxPQUVFO2VBRkY7O0lBMUNnQkEseUJBQXlCO2VBQXpCQTs7OzJEQUZDOzs7Ozs7QUFFVixTQUFTQSwwQkFBMEJDLGtCQUFrQixFQUFFQyxVQUFVO0lBQ3RFLElBQUlBLGVBQWVDLFdBQVc7UUFDNUJELGFBQWFELG9CQUFvQixHQUFHO1FBRXBDQSxxQkFBcUIsU0FBQ0c7bUJBQWNDLGFBQUk7V0FBRyxHQUFHO0lBQ2hEO0lBRUEsSUFBTUMsUUFBUUosWUFBWSxHQUFHO0lBRTdCSyxXQUFXRDtJQUVYLElBQU1GLFlBQVksTUFDWkksUUFBUVAsbUJBQW1CRyxZQUMzQkssY0FBY0QsTUFBTUUsV0FBVyxJQUMvQkMscUJBQXFCLElBQUlDO0lBRS9CVixXQUFXVyxPQUFPLENBQUMsU0FBQ1Q7UUFDbEIsSUFBSVUsYUFBYUwsYUFBYSxHQUFHO1FBRWpDTCxVQUFVVyxnQkFBZ0IsQ0FBQyxTQUFDQztZQUMxQixJQUFNWixjQUFZWSxjQUNaQyxPQUFPTixtQkFBbUJPLEdBQUcsQ0FBQ2QsZ0JBQWM7WUFFbEQsSUFBSWEsU0FBUyxNQUFNO2dCQUNqQkgsYUFBYUcsTUFBTyxHQUFHO2dCQUV2QixPQUFPO1lBQ1Q7UUFDRjtRQUVBLElBQU1ULFFBQVFQLG1CQUFtQkcsWUFDM0JhLE9BQU9ULE1BQU1XLGFBQWEsQ0FBQ2YsWUFDM0JnQixvQkFBb0JILE1BQU0sR0FBRztRQUVuQ0gsV0FBV08sZUFBZSxDQUFDRDtRQUUzQlQsbUJBQW1CVyxHQUFHLENBQUNsQixXQUFXYTtJQUNwQztJQUVBLE9BQU9SO0FBQ1Q7SUFFQSxXQUFlO0lBQ2JULDJCQUFBQTtBQUNGO0FBRUEsU0FBU08sV0FBV0QsS0FBSztJQUN2QkEsTUFBTWlCLElBQUksQ0FBQyxTQUFDQyxPQUFPQztRQUNqQixJQUFNQyxxQkFBcUJDLFdBQVdILE9BQU9DLFFBQ3ZDRyxTQUFTRixxQkFDRSxDQUFDLElBQ0MsQ0FBQztRQUVwQixPQUFPRTtJQUNUO0FBQ0Y7QUFFQSxTQUFTRCxXQUFXSCxLQUFLLEVBQUVDLEtBQUs7SUFDOUIsSUFBSUksV0FBVztJQUVmLElBQU1DLHFCQUFxQkMsc0JBQXNCUCxRQUMzQ1EscUJBQXFCRCxzQkFBc0JOLFFBQzNDUSwyQkFBMkJILG1CQUFtQkksTUFBTSxFQUNwREMsMkJBQTJCSCxtQkFBbUJFLE1BQU0sRUFDcERFLDZCQUE2QkMsS0FBS0MsR0FBRyxDQUFDTCwwQkFBMEJFO0lBRXRFLElBQUssSUFBSUksUUFBUSxHQUFHQSxRQUFRSCw0QkFBNEJHLFFBQVM7UUFDL0QsSUFBTUMsb0JBQW9CVixrQkFBa0IsQ0FBQ1MsTUFBTSxFQUM3Q0Usb0JBQW9CVCxrQkFBa0IsQ0FBQ08sTUFBTTtRQUVuRCxJQUFJQyxzQkFBc0JDLG1CQUFtQjtZQUMzQyxJQUFNQyxjQUFjSCxRQUFRLEdBQ3RCSSw4QkFBOEJiLGtCQUFrQixDQUFDWSxZQUFZLEVBQzdENUIsYUFBYTZCLDZCQUNiQyxhQUFhSixtQkFDYkssYUFBYUosbUJBQ2JLLFNBQVNoQyxXQUFXaUMsZ0JBQWdCLENBQUNILGFBQ3JDSSxTQUFTbEMsV0FBV2lDLGdCQUFnQixDQUFDRjtZQUUzQ2hCLFdBQVlpQixTQUFTRTtZQUVyQjtRQUNGO0lBQ0Y7SUFFQSxJQUFJbkIsYUFBYSxNQUFNO1FBQ3JCQSxXQUFZSSwyQkFBMkJFO0lBQ3pDO0lBRUEsT0FBT047QUFDVDtBQUVBLFNBQVNFLHNCQUFzQmQsSUFBSTtJQUNqQyxJQUFNZ0MsZ0JBQWdCaEMsS0FBS2lDLGdCQUFnQjtJQUUzQ0QsY0FBY0UsT0FBTyxDQUFDbEM7SUFFdEJnQyxjQUFjRyxPQUFPO0lBRXJCLE9BQU9IO0FBQ1QifQ==
86
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsaXRpZXMvbm9kZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IE5vZGUgZnJvbSBcIi4uL25vZGVcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGlzTGVzc1RoYW4obm9kZUEsIG5vZGVCKSB7XG4gIGxldCBsZXNzVGhhbiA9IG51bGw7XG5cbiAgY29uc3Qgbm9kZUFBbmNlc3Rvck5vZGVzID0gYW5jZXN0b3JOb2Rlc0Zyb21Ob2RlKG5vZGVBKSxcbiAgICBub2RlQkFuY2VzdG9yTm9kZXMgPSBhbmNlc3Rvck5vZGVzRnJvbU5vZGUobm9kZUIpLFxuICAgIG5vZGVBQW5jZXN0b3JOb2Rlc0xlbmd0aCA9IG5vZGVBQW5jZXN0b3JOb2Rlcy5sZW5ndGgsXG4gICAgbm9kZUJBbmNlc3Rvck5vZGVzTGVuZ3RoID0gbm9kZUJBbmNlc3Rvck5vZGVzLmxlbmd0aCxcbiAgICBtaW5pbXVtQW5jZXN0b3JOb2Rlc0xlbmd0aCA9IE1hdGgubWluKG5vZGVBQW5jZXN0b3JOb2Rlc0xlbmd0aCwgbm9kZUJBbmNlc3Rvck5vZGVzTGVuZ3RoKTtcblxuICBmb3IgKGxldCBpbmRleCA9IDA7IGluZGV4IDwgbWluaW11bUFuY2VzdG9yTm9kZXNMZW5ndGg7IGluZGV4KyspIHtcbiAgICBjb25zdCBub2RlQUFuY2VzdG9yTm9kZSA9IG5vZGVBQW5jZXN0b3JOb2Rlc1tpbmRleF0sXG4gICAgICBub2RlQkFuY2VzdG9yTm9kZSA9IG5vZGVCQW5jZXN0b3JOb2Rlc1tpbmRleF07XG5cbiAgICBpZiAobm9kZUFBbmNlc3Rvck5vZGUgIT09IG5vZGVCQW5jZXN0b3JOb2RlKSB7XG4gICAgICBjb25zdCBwYXJlbnRJbmRleCA9IGluZGV4IC0gMSxcbiAgICAgICAgbm9kZUFBbmNlc3Rvck5vZGVQYXJlbnROb2RlID0gbm9kZUFBbmNlc3Rvck5vZGVzW3BhcmVudEluZGV4XSxcbiAgICAgICAgcGFyZW50Tm9kZSA9IG5vZGVBQW5jZXN0b3JOb2RlUGFyZW50Tm9kZSwgLy8vXG4gICAgICAgIGNoaWxkTm9kZUEgPSBub2RlQUFuY2VzdG9yTm9kZSwgLy8vXG4gICAgICAgIGNoaWxkTm9kZUIgPSBub2RlQkFuY2VzdG9yTm9kZSwgLy8vXG4gICAgICAgIGluZGV4QSA9IHBhcmVudE5vZGUuaW5kZXhPZkNoaWxkTm9kZShjaGlsZE5vZGVBKSxcbiAgICAgICAgaW5kZXhCID0gcGFyZW50Tm9kZS5pbmRleE9mQ2hpbGROb2RlKGNoaWxkTm9kZUIpO1xuXG4gICAgICBsZXNzVGhhbiA9IChpbmRleEEgPCBpbmRleEIpO1xuXG4gICAgICBicmVhaztcbiAgICB9XG4gIH1cblxuICBpZiAobGVzc1RoYW4gPT09IG51bGwpIHtcbiAgICBsZXNzVGhhbiA9IChub2RlQUFuY2VzdG9yTm9kZXNMZW5ndGggPCBub2RlQkFuY2VzdG9yTm9kZXNMZW5ndGgpO1xuICB9XG5cbiAgcmV0dXJuIGxlc3NUaGFuO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdG9wbW9zdE5vZGVGcm9tT3V0ZXJOb2RlcyhDbGFzc0Zyb21PdXRlck5vZGUsIG91dGVyTm9kZXMpIHtcbiAgaWYgKG91dGVyTm9kZXMgPT09IHVuZGVmaW5lZCkge1xuICAgIG91dGVyTm9kZXMgPSBDbGFzc0Zyb21PdXRlck5vZGU7IC8vL1xuXG4gICAgQ2xhc3NGcm9tT3V0ZXJOb2RlID0gKG91dGVyTm9kZSkgPT4gTm9kZTsgIC8vL1xuICB9XG5cbiAgY29uc3Qgbm9kZXMgPSBvdXRlck5vZGVzOyAvLy9cblxuICBvcmRlck5vZGVzKG5vZGVzKTtcblxuICBjb25zdCBvdXRlck5vZGUgPSBudWxsLFxuICAgICAgICBDbGFzcyA9IENsYXNzRnJvbU91dGVyTm9kZShvdXRlck5vZGUpLFxuICAgICAgICB0b3Btb3N0Tm9kZSA9IENsYXNzLmZyb21Ob3RoaW5nKCksXG4gICAgICAgIG91dGVyTm9kZVRvTm9kZU1hcCA9IG5ldyBXZWFrTWFwKCk7XG5cbiAgb3V0ZXJOb2Rlcy5mb3JFYWNoKChvdXRlck5vZGUpID0+IHtcbiAgICBsZXQgcGFyZW50Tm9kZSA9IHRvcG1vc3ROb2RlOyAvLy9cblxuICAgIG91dGVyTm9kZS5zb21lQW5jZXN0b3JOb2RlKChhbmNlc3Rvck5vZGUpID0+IHtcbiAgICAgIGNvbnN0IG91dGVyTm9kZSA9IGFuY2VzdG9yTm9kZSwgLy8vXG4gICAgICAgICAgICBub2RlID0gb3V0ZXJOb2RlVG9Ob2RlTWFwLmdldChvdXRlck5vZGUpIHx8IG51bGw7XG5cbiAgICAgIGlmIChub2RlICE9PSBudWxsKSB7XG4gICAgICAgIHBhcmVudE5vZGUgPSBub2RlOyAgLy8vXG5cbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICB9XG4gICAgfSk7XG5cbiAgICBjb25zdCBDbGFzcyA9IENsYXNzRnJvbU91dGVyTm9kZShvdXRlck5vZGUpLFxuICAgICAgICAgIG5vZGUgPSBDbGFzcy5mcm9tT3V0ZXJOb2RlKG91dGVyTm9kZSksXG4gICAgICAgICAgYXBwZW5kZWRDaGlsZE5vZGUgPSBub2RlOyAvLy9cblxuICAgIHBhcmVudE5vZGUuYXBwZW5kQ2hpbGROb2RlKGFwcGVuZGVkQ2hpbGROb2RlKTtcblxuICAgIG91dGVyTm9kZVRvTm9kZU1hcC5zZXQob3V0ZXJOb2RlLCBub2RlKTtcbiAgfSk7XG5cbiAgcmV0dXJuIHRvcG1vc3ROb2RlO1xufVxuXG5leHBvcnQgZGVmYXVsdCB7XG4gIGlzTGVzc1RoYW4sXG4gIHRvcG1vc3ROb2RlRnJvbU91dGVyTm9kZXNcbn07XG5cbmZ1bmN0aW9uIG9yZGVyTm9kZXMobm9kZXMpIHtcbiAgbm9kZXMuc29ydCgobm9kZUEsIG5vZGVCKSA9PiB7XG4gICAgY29uc3Qgbm9kZUFMZXNzVGhhbk5vZGVCID0gaXNMZXNzVGhhbihub2RlQSwgbm9kZUIpLFxuICAgICAgICAgIHJlc3VsdCA9IG5vZGVBTGVzc1RoYW5Ob2RlQiA/XG4gICAgICAgICAgICAgICAgICAgICAtMSA6XG4gICAgICAgICAgICAgICAgICAgICAgICsxO1xuXG4gICAgcmV0dXJuIHJlc3VsdDtcbiAgfSk7XG59XG5cbmZ1bmN0aW9uIGFuY2VzdG9yTm9kZXNGcm9tTm9kZShub2RlKSB7XG4gIGNvbnN0IGFuY2VzdG9yTm9kZXMgPSBub2RlLmdldEFuY2VzdG9yTm9kZXMoKTtcblxuICBhbmNlc3Rvck5vZGVzLnVuc2hpZnQobm9kZSk7XG5cbiAgYW5jZXN0b3JOb2Rlcy5yZXZlcnNlKCk7XG5cbiAgcmV0dXJuIGFuY2VzdG9yTm9kZXM7XG59XG4iXSwibmFtZXMiOlsiaXNMZXNzVGhhbiIsInRvcG1vc3ROb2RlRnJvbU91dGVyTm9kZXMiLCJub2RlQSIsIm5vZGVCIiwibGVzc1RoYW4iLCJub2RlQUFuY2VzdG9yTm9kZXMiLCJhbmNlc3Rvck5vZGVzRnJvbU5vZGUiLCJub2RlQkFuY2VzdG9yTm9kZXMiLCJub2RlQUFuY2VzdG9yTm9kZXNMZW5ndGgiLCJsZW5ndGgiLCJub2RlQkFuY2VzdG9yTm9kZXNMZW5ndGgiLCJtaW5pbXVtQW5jZXN0b3JOb2Rlc0xlbmd0aCIsIk1hdGgiLCJtaW4iLCJpbmRleCIsIm5vZGVBQW5jZXN0b3JOb2RlIiwibm9kZUJBbmNlc3Rvck5vZGUiLCJwYXJlbnRJbmRleCIsIm5vZGVBQW5jZXN0b3JOb2RlUGFyZW50Tm9kZSIsInBhcmVudE5vZGUiLCJjaGlsZE5vZGVBIiwiY2hpbGROb2RlQiIsImluZGV4QSIsImluZGV4T2ZDaGlsZE5vZGUiLCJpbmRleEIiLCJDbGFzc0Zyb21PdXRlck5vZGUiLCJvdXRlck5vZGVzIiwidW5kZWZpbmVkIiwib3V0ZXJOb2RlIiwiTm9kZSIsIm5vZGVzIiwib3JkZXJOb2RlcyIsIkNsYXNzIiwidG9wbW9zdE5vZGUiLCJmcm9tTm90aGluZyIsIm91dGVyTm9kZVRvTm9kZU1hcCIsIldlYWtNYXAiLCJmb3JFYWNoIiwic29tZUFuY2VzdG9yTm9kZSIsImFuY2VzdG9yTm9kZSIsIm5vZGUiLCJnZXQiLCJmcm9tT3V0ZXJOb2RlIiwiYXBwZW5kZWRDaGlsZE5vZGUiLCJhcHBlbmRDaGlsZE5vZGUiLCJzZXQiLCJzb3J0Iiwibm9kZUFMZXNzVGhhbk5vZGVCIiwicmVzdWx0IiwiYW5jZXN0b3JOb2RlcyIsImdldEFuY2VzdG9yTm9kZXMiLCJ1bnNoaWZ0IiwicmV2ZXJzZSJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7O0lBaUZBLE9BR0U7ZUFIRjs7SUE3RWdCQSxVQUFVO2VBQVZBOztJQW1DQUMseUJBQXlCO2VBQXpCQTs7OzJEQXJDQzs7Ozs7O0FBRVYsU0FBU0QsV0FBV0UsS0FBSyxFQUFFQyxLQUFLO0lBQ3JDLElBQUlDLFdBQVc7SUFFZixJQUFNQyxxQkFBcUJDLHNCQUFzQkosUUFDL0NLLHFCQUFxQkQsc0JBQXNCSCxRQUMzQ0ssMkJBQTJCSCxtQkFBbUJJLE1BQU0sRUFDcERDLDJCQUEyQkgsbUJBQW1CRSxNQUFNLEVBQ3BERSw2QkFBNkJDLEtBQUtDLEdBQUcsQ0FBQ0wsMEJBQTBCRTtJQUVsRSxJQUFLLElBQUlJLFFBQVEsR0FBR0EsUUFBUUgsNEJBQTRCRyxRQUFTO1FBQy9ELElBQU1DLG9CQUFvQlYsa0JBQWtCLENBQUNTLE1BQU0sRUFDakRFLG9CQUFvQlQsa0JBQWtCLENBQUNPLE1BQU07UUFFL0MsSUFBSUMsc0JBQXNCQyxtQkFBbUI7WUFDM0MsSUFBTUMsY0FBY0gsUUFBUSxHQUMxQkksOEJBQThCYixrQkFBa0IsQ0FBQ1ksWUFBWSxFQUM3REUsYUFBYUQsNkJBQ2JFLGFBQWFMLG1CQUNiTSxhQUFhTCxtQkFDYk0sU0FBU0gsV0FBV0ksZ0JBQWdCLENBQUNILGFBQ3JDSSxTQUFTTCxXQUFXSSxnQkFBZ0IsQ0FBQ0Y7WUFFdkNqQixXQUFZa0IsU0FBU0U7WUFFckI7UUFDRjtJQUNGO0lBRUEsSUFBSXBCLGFBQWEsTUFBTTtRQUNyQkEsV0FBWUksMkJBQTJCRTtJQUN6QztJQUVBLE9BQU9OO0FBQ1Q7QUFFTyxTQUFTSCwwQkFBMEJ3QixrQkFBa0IsRUFBRUMsVUFBVTtJQUN0RSxJQUFJQSxlQUFlQyxXQUFXO1FBQzVCRCxhQUFhRCxvQkFBb0IsR0FBRztRQUVwQ0EscUJBQXFCLFNBQUNHO21CQUFjQyxhQUFJO1dBQUcsR0FBRztJQUNoRDtJQUVBLElBQU1DLFFBQVFKLFlBQVksR0FBRztJQUU3QkssV0FBV0Q7SUFFWCxJQUFNRixZQUFZLE1BQ1pJLFFBQVFQLG1CQUFtQkcsWUFDM0JLLGNBQWNELE1BQU1FLFdBQVcsSUFDL0JDLHFCQUFxQixJQUFJQztJQUUvQlYsV0FBV1csT0FBTyxDQUFDLFNBQUNUO1FBQ2xCLElBQUlULGFBQWFjLGFBQWEsR0FBRztRQUVqQ0wsVUFBVVUsZ0JBQWdCLENBQUMsU0FBQ0M7WUFDMUIsSUFBTVgsY0FBWVcsY0FDWkMsT0FBT0wsbUJBQW1CTSxHQUFHLENBQUNiLGdCQUFjO1lBRWxELElBQUlZLFNBQVMsTUFBTTtnQkFDakJyQixhQUFhcUIsTUFBTyxHQUFHO2dCQUV2QixPQUFPO1lBQ1Q7UUFDRjtRQUVBLElBQU1SLFFBQVFQLG1CQUFtQkcsWUFDM0JZLE9BQU9SLE1BQU1VLGFBQWEsQ0FBQ2QsWUFDM0JlLG9CQUFvQkgsTUFBTSxHQUFHO1FBRW5DckIsV0FBV3lCLGVBQWUsQ0FBQ0Q7UUFFM0JSLG1CQUFtQlUsR0FBRyxDQUFDakIsV0FBV1k7SUFDcEM7SUFFQSxPQUFPUDtBQUNUO0lBRUEsV0FBZTtJQUNiakMsWUFBQUE7SUFDQUMsMkJBQUFBO0FBQ0Y7QUFFQSxTQUFTOEIsV0FBV0QsS0FBSztJQUN2QkEsTUFBTWdCLElBQUksQ0FBQyxTQUFDNUMsT0FBT0M7UUFDakIsSUFBTTRDLHFCQUFxQi9DLFdBQVdFLE9BQU9DLFFBQ3ZDNkMsU0FBU0QscUJBQ0UsQ0FBQyxJQUNDLENBQUM7UUFFcEIsT0FBT0M7SUFDVDtBQUNGO0FBRUEsU0FBUzFDLHNCQUFzQmtDLElBQUk7SUFDakMsSUFBTVMsZ0JBQWdCVCxLQUFLVSxnQkFBZ0I7SUFFM0NELGNBQWNFLE9BQU8sQ0FBQ1g7SUFFdEJTLGNBQWNHLE9BQU87SUFFckIsT0FBT0g7QUFDVCJ9
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "occam-dom",
3
3
  "author": "James Smith",
4
- "version": "5.2.22",
4
+ "version": "5.2.24",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/occam-dom",
7
7
  "description": "Occam's DOM related functionality.",
package/src/node.js CHANGED
@@ -116,6 +116,8 @@ export default class Node {
116
116
  parentNode = null,
117
117
  node = new Class(outerNode, parentNode, childNodes, ...remainingArguments);
118
118
 
119
+ node.setChildNodesParentNode();
120
+
119
121
  return node;
120
122
  }
121
123
  }
@@ -2,6 +2,41 @@
2
2
 
3
3
  import Node from "../node";
4
4
 
5
+ export function isLessThan(nodeA, nodeB) {
6
+ let lessThan = null;
7
+
8
+ const nodeAAncestorNodes = ancestorNodesFromNode(nodeA),
9
+ nodeBAncestorNodes = ancestorNodesFromNode(nodeB),
10
+ nodeAAncestorNodesLength = nodeAAncestorNodes.length,
11
+ nodeBAncestorNodesLength = nodeBAncestorNodes.length,
12
+ minimumAncestorNodesLength = Math.min(nodeAAncestorNodesLength, nodeBAncestorNodesLength);
13
+
14
+ for (let index = 0; index < minimumAncestorNodesLength; index++) {
15
+ const nodeAAncestorNode = nodeAAncestorNodes[index],
16
+ nodeBAncestorNode = nodeBAncestorNodes[index];
17
+
18
+ if (nodeAAncestorNode !== nodeBAncestorNode) {
19
+ const parentIndex = index - 1,
20
+ nodeAAncestorNodeParentNode = nodeAAncestorNodes[parentIndex],
21
+ parentNode = nodeAAncestorNodeParentNode, ///
22
+ childNodeA = nodeAAncestorNode, ///
23
+ childNodeB = nodeBAncestorNode, ///
24
+ indexA = parentNode.indexOfChildNode(childNodeA),
25
+ indexB = parentNode.indexOfChildNode(childNodeB);
26
+
27
+ lessThan = (indexA < indexB);
28
+
29
+ break;
30
+ }
31
+ }
32
+
33
+ if (lessThan === null) {
34
+ lessThan = (nodeAAncestorNodesLength < nodeBAncestorNodesLength);
35
+ }
36
+
37
+ return lessThan;
38
+ }
39
+
5
40
  export function topmostNodeFromOuterNodes(ClassFromOuterNode, outerNodes) {
6
41
  if (outerNodes === undefined) {
7
42
  outerNodes = ClassFromOuterNode; ///
@@ -45,6 +80,7 @@ export function topmostNodeFromOuterNodes(ClassFromOuterNode, outerNodes) {
45
80
  }
46
81
 
47
82
  export default {
83
+ isLessThan,
48
84
  topmostNodeFromOuterNodes
49
85
  };
50
86
 
@@ -59,41 +95,6 @@ function orderNodes(nodes) {
59
95
  });
60
96
  }
61
97
 
62
- function isLessThan(nodeA, nodeB) {
63
- let lessThan = null;
64
-
65
- const nodeAAncestorNodes = ancestorNodesFromNode(nodeA),
66
- nodeBAncestorNodes = ancestorNodesFromNode(nodeB),
67
- nodeAAncestorNodesLength = nodeAAncestorNodes.length,
68
- nodeBAncestorNodesLength = nodeBAncestorNodes.length,
69
- minimumAncestorNodesLength = Math.min(nodeAAncestorNodesLength, nodeBAncestorNodesLength);
70
-
71
- for (let index = 0; index < minimumAncestorNodesLength; index++) {
72
- const nodeAAncestorNode = nodeAAncestorNodes[index],
73
- nodeBAncestorNode = nodeBAncestorNodes[index];
74
-
75
- if (nodeAAncestorNode !== nodeBAncestorNode) {
76
- const parentIndex = index - 1,
77
- nodeAAncestorNodeParentNode = nodeAAncestorNodes[parentIndex],
78
- parentNode = nodeAAncestorNodeParentNode, ///
79
- childNodeA = nodeAAncestorNode, ///
80
- childNodeB = nodeBAncestorNode, ///
81
- indexA = parentNode.indexOfChildNode(childNodeA),
82
- indexB = parentNode.indexOfChildNode(childNodeB);
83
-
84
- lessThan = (indexA < indexB);
85
-
86
- break;
87
- }
88
- }
89
-
90
- if (lessThan === null) {
91
- lessThan = (nodeAAncestorNodesLength < nodeBAncestorNodesLength);
92
- }
93
-
94
- return lessThan;
95
- }
96
-
97
98
  function ancestorNodesFromNode(node) {
98
99
  const ancestorNodes = node.getAncestorNodes();
99
100