occam-parsers 23.0.115 → 23.0.116

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
@@ -39,6 +39,9 @@ _export(exports, {
39
39
  TerminalNode: function() {
40
40
  return _terminal.default;
41
41
  },
42
+ nodeMixins: function() {
43
+ return _node.default;
44
+ },
42
45
  parserUtilities: function() {
43
46
  return _parser3.default;
44
47
  },
@@ -52,6 +55,7 @@ _export(exports, {
52
55
  var _parser = /*#__PURE__*/ _interop_require_default(require("./bnf/parser"));
53
56
  var _parser1 = /*#__PURE__*/ _interop_require_default(require("./basic/parser"));
54
57
  var _parser2 = /*#__PURE__*/ _interop_require_default(require("./common/parser"));
58
+ var _node = /*#__PURE__*/ _interop_require_default(require("./mixins/node"));
55
59
  var _rules = /*#__PURE__*/ _interop_require_default(require("./utilities/rules"));
56
60
  var _parser3 = /*#__PURE__*/ _interop_require_default(require("./utilities/parser"));
57
61
  var _rule = /*#__PURE__*/ _interop_require_default(require("./rule"));
@@ -68,4 +72,4 @@ function _interop_require_default(obj) {
68
72
  };
69
73
  }
70
74
 
71
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuZXhwb3J0IHsgZGVmYXVsdCBhcyBCTkZQYXJzZXIgfSBmcm9tIFwiLi9ibmYvcGFyc2VyXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEJhc2ljUGFyc2VyIH0gZnJvbSBcIi4vYmFzaWMvcGFyc2VyXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIENvbW1vblBhcnNlciB9IGZyb20gXCIuL2NvbW1vbi9wYXJzZXJcIjtcblxuZXhwb3J0IHsgZGVmYXVsdCBhcyBydWxlc1V0aWxpdGllcyB9IGZyb20gXCIuL3V0aWxpdGllcy9ydWxlc1wiO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBwYXJzZXJVdGlsaXRpZXMgfSBmcm9tIFwiLi91dGlsaXRpZXMvcGFyc2VyXCI7XG5cbmV4cG9ydCB7IGRlZmF1bHQgYXMgUnVsZSB9IGZyb20gXCIuL3J1bGVcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgUGFydHMgfSBmcm9tIFwiLi9wYXJ0c1wiO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBwYXJ0VHlwZXMgfSBmcm9tIFwiLi9wYXJ0VHlwZXNcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgUGFydENob2ljZSB9IGZyb20gXCIuL3BhcnRDaG9pY2VcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgRGVmaW5pdGlvbiB9IGZyb20gXCIuL2RlZmluaXRpb25cIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgRXBzaWxvbk5vZGUgfSBmcm9tIFwiLi9ub2RlL3Rlcm1pbmFsL2Vwc2lsb25cIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgVGVybWluYWxOb2RlIH0gZnJvbSBcIi4vbm9kZS90ZXJtaW5hbFwiO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBOb25UZXJtaW5hbE5vZGUgfSBmcm9tIFwiLi9ub2RlL25vblRlcm1pbmFsXCI7XG4iXSwibmFtZXMiOlsiQk5GUGFyc2VyIiwiQmFzaWNQYXJzZXIiLCJDb21tb25QYXJzZXIiLCJEZWZpbml0aW9uIiwiRXBzaWxvbk5vZGUiLCJOb25UZXJtaW5hbE5vZGUiLCJQYXJ0Q2hvaWNlIiwiUGFydHMiLCJSdWxlIiwiVGVybWluYWxOb2RlIiwicGFyc2VyVXRpbGl0aWVzIiwicGFydFR5cGVzIiwicnVsZXNVdGlsaXRpZXMiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7OztJQUVvQkEsU0FBUztlQUFUQSxlQUFTOztJQUNUQyxXQUFXO2VBQVhBLGdCQUFXOztJQUNYQyxZQUFZO2VBQVpBLGdCQUFZOztJQVNaQyxVQUFVO2VBQVZBLG1CQUFVOztJQUNWQyxXQUFXO2VBQVhBLGdCQUFXOztJQUVYQyxlQUFlO2VBQWZBLG9CQUFlOztJQUpmQyxVQUFVO2VBQVZBLG1CQUFVOztJQUZWQyxLQUFLO2VBQUxBLGNBQUs7O0lBRExDLElBQUk7ZUFBSkEsYUFBSTs7SUFNSkMsWUFBWTtlQUFaQSxpQkFBWTs7SUFSWkMsZUFBZTtlQUFmQSxnQkFBZTs7SUFJZkMsU0FBUztlQUFUQSxrQkFBUzs7SUFMVEMsY0FBYztlQUFkQSxjQUFjOzs7NkRBSkc7OERBQ0U7OERBQ0M7NERBRUU7OERBQ0M7MkRBRVg7NERBQ0M7Z0VBQ0k7aUVBQ0M7aUVBQ0E7OERBQ0M7K0RBQ0M7a0VBQ0cifQ==
75
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuZXhwb3J0IHsgZGVmYXVsdCBhcyBCTkZQYXJzZXIgfSBmcm9tIFwiLi9ibmYvcGFyc2VyXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEJhc2ljUGFyc2VyIH0gZnJvbSBcIi4vYmFzaWMvcGFyc2VyXCI7XG5leHBvcnQgeyBkZWZhdWx0IGFzIENvbW1vblBhcnNlciB9IGZyb20gXCIuL2NvbW1vbi9wYXJzZXJcIjtcblxuZXhwb3J0IHsgZGVmYXVsdCBhcyBub2RlTWl4aW5zIH0gZnJvbSBcIi4vbWl4aW5zL25vZGVcIjtcblxuZXhwb3J0IHsgZGVmYXVsdCBhcyBydWxlc1V0aWxpdGllcyB9IGZyb20gXCIuL3V0aWxpdGllcy9ydWxlc1wiO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBwYXJzZXJVdGlsaXRpZXMgfSBmcm9tIFwiLi91dGlsaXRpZXMvcGFyc2VyXCI7XG5cbmV4cG9ydCB7IGRlZmF1bHQgYXMgUnVsZSB9IGZyb20gXCIuL3J1bGVcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgUGFydHMgfSBmcm9tIFwiLi9wYXJ0c1wiO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBwYXJ0VHlwZXMgfSBmcm9tIFwiLi9wYXJ0VHlwZXNcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgUGFydENob2ljZSB9IGZyb20gXCIuL3BhcnRDaG9pY2VcIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgRGVmaW5pdGlvbiB9IGZyb20gXCIuL2RlZmluaXRpb25cIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgRXBzaWxvbk5vZGUgfSBmcm9tIFwiLi9ub2RlL3Rlcm1pbmFsL2Vwc2lsb25cIjtcbmV4cG9ydCB7IGRlZmF1bHQgYXMgVGVybWluYWxOb2RlIH0gZnJvbSBcIi4vbm9kZS90ZXJtaW5hbFwiO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBOb25UZXJtaW5hbE5vZGUgfSBmcm9tIFwiLi9ub2RlL25vblRlcm1pbmFsXCI7XG4iXSwibmFtZXMiOlsiQk5GUGFyc2VyIiwiQmFzaWNQYXJzZXIiLCJDb21tb25QYXJzZXIiLCJEZWZpbml0aW9uIiwiRXBzaWxvbk5vZGUiLCJOb25UZXJtaW5hbE5vZGUiLCJQYXJ0Q2hvaWNlIiwiUGFydHMiLCJSdWxlIiwiVGVybWluYWxOb2RlIiwibm9kZU1peGlucyIsInBhcnNlclV0aWxpdGllcyIsInBhcnRUeXBlcyIsInJ1bGVzVXRpbGl0aWVzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7SUFFb0JBLFNBQVM7ZUFBVEEsZUFBUzs7SUFDVEMsV0FBVztlQUFYQSxnQkFBVzs7SUFDWEMsWUFBWTtlQUFaQSxnQkFBWTs7SUFXWkMsVUFBVTtlQUFWQSxtQkFBVTs7SUFDVkMsV0FBVztlQUFYQSxnQkFBVzs7SUFFWEMsZUFBZTtlQUFmQSxvQkFBZTs7SUFKZkMsVUFBVTtlQUFWQSxtQkFBVTs7SUFGVkMsS0FBSztlQUFMQSxjQUFLOztJQURMQyxJQUFJO2VBQUpBLGFBQUk7O0lBTUpDLFlBQVk7ZUFBWkEsaUJBQVk7O0lBWFpDLFVBQVU7ZUFBVkEsYUFBVTs7SUFHVkMsZUFBZTtlQUFmQSxnQkFBZTs7SUFJZkMsU0FBUztlQUFUQSxrQkFBUzs7SUFMVEMsY0FBYztlQUFkQSxjQUFjOzs7NkRBTkc7OERBQ0U7OERBQ0M7MkRBRUY7NERBRUk7OERBQ0M7MkRBRVg7NERBQ0M7Z0VBQ0k7aUVBQ0M7aUVBQ0E7OERBQ0M7K0RBQ0M7a0VBQ0cifQ==
@@ -0,0 +1,195 @@
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 _default;
9
+ }
10
+ });
11
+ var _necessary = require("necessary");
12
+ function _array_like_to_array(arr, len) {
13
+ if (len == null || len > arr.length) len = arr.length;
14
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
15
+ return arr2;
16
+ }
17
+ function _array_without_holes(arr) {
18
+ if (Array.isArray(arr)) return _array_like_to_array(arr);
19
+ }
20
+ function _iterable_to_array(iter) {
21
+ if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
22
+ }
23
+ function _non_iterable_spread() {
24
+ throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
25
+ }
26
+ function _to_consumable_array(arr) {
27
+ return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();
28
+ }
29
+ function _unsupported_iterable_to_array(o, minLen) {
30
+ if (!o) return;
31
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
32
+ var n = Object.prototype.toString.call(o).slice(8, -1);
33
+ if (n === "Object" && o.constructor) n = o.constructor.name;
34
+ if (n === "Map" || n === "Set") return Array.from(n);
35
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
36
+ }
37
+ var first = _necessary.arrayUtilities.first, forwardsSome = _necessary.arrayUtilities.forwardsSome, backwardsSome = _necessary.arrayUtilities.backwardsSome;
38
+ function getMultiplicity() {
39
+ var childNodesLength = this.childNodes.length, multiplicity = childNodesLength; ///
40
+ return multiplicity;
41
+ }
42
+ function mapChildNode(callback) {
43
+ return this.childNodes.map(callback);
44
+ }
45
+ function someChildNode(callback) {
46
+ return this.childNodes.some(callback);
47
+ }
48
+ function findChildNode(callback) {
49
+ return this.childNodes.find(callback);
50
+ }
51
+ function everyChildNode(callback) {
52
+ return this.childNodes.every(callback);
53
+ }
54
+ function filterChildNode(callback) {
55
+ return this.childNodes.filter(callback);
56
+ }
57
+ function reduceChildNode(callback, initialValue) {
58
+ return this.childNodes.reduce(callback, initialValue);
59
+ }
60
+ function forEachChildNode(callback) {
61
+ this.childNodes.forEach(callback);
62
+ }
63
+ function forwardsSomeChildNode(callback) {
64
+ return forwardsSome(this.childNodes, callback);
65
+ }
66
+ function backwardsSomeChildNode(callback) {
67
+ return backwardsSome(this.childNodes, callback);
68
+ }
69
+ function indexOfChildNode(childNode) {
70
+ return this.childNodes.indexOf(childNode);
71
+ }
72
+ function setChildNodesParentNode(childNodes) {
73
+ if (childNodes === undefined) {
74
+ childNodes = _to_consumable_array(this.childNodes);
75
+ }
76
+ var parentNode = this;
77
+ childNodes.forEach(function(childNode) {
78
+ childNode.setParentNode(parentNode);
79
+ });
80
+ }
81
+ function resetChildNodesParentNode(childNodes) {
82
+ if (childNodes === undefined) {
83
+ childNodes = _to_consumable_array(this.childNodes);
84
+ }
85
+ var parentNode = null;
86
+ childNodes.forEach(function(childNode) {
87
+ childNode.setParentNode(parentNode);
88
+ });
89
+ }
90
+ function addChildNode(addedChildNode, startIndex) {
91
+ var addedChildNodes = [
92
+ addedChildNode
93
+ ];
94
+ this.addChildNodes(addedChildNodes, startIndex);
95
+ }
96
+ function addChildNodes(addedChildNodes, startIndex) {
97
+ var deleteCount = 0;
98
+ this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);
99
+ }
100
+ function removeChildNode(removedChildNode) {
101
+ var removedChildNodes;
102
+ removedChildNodes = [
103
+ removedChildNode
104
+ ];
105
+ removedChildNodes = this.removeChildNodes(removedChildNodes);
106
+ return removedChildNodes;
107
+ }
108
+ function removeChildNodes(removedChildNodes) {
109
+ if (removedChildNodes === undefined) {
110
+ removedChildNodes = _to_consumable_array(this.childNodes);
111
+ }
112
+ var removedChildNodesLength = removedChildNodes.length;
113
+ if (removedChildNodesLength === 0) {
114
+ return;
115
+ }
116
+ var firstReplacedChildNode = first(removedChildNodes), firstIndex = this.childNodes.indexOf(firstReplacedChildNode), startIndex = firstIndex, deleteCount = removedChildNodesLength, addedChildNodes = [];
117
+ removedChildNodes = this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);
118
+ return removedChildNodes;
119
+ }
120
+ function replaceChildNode(replacedChildNode, replacementChildNodes) {
121
+ var replacedChildNodes = [
122
+ replacedChildNode
123
+ ];
124
+ this.replaceChildNodes(replacedChildNodes, replacementChildNodes);
125
+ }
126
+ function replaceChildNodes(replacedChildNodes, replacementChildNodes) {
127
+ var replacedChildNodesLength = replacedChildNodes.length, firstReplacedChildNode = first(replacedChildNodes), firstIndex = this.childNodes.indexOf(firstReplacedChildNode), startIndex = firstIndex, deleteCount = replacedChildNodesLength; ///
128
+ this.spliceChildNodes(startIndex, deleteCount, replacementChildNodes);
129
+ }
130
+ function appendChildNode(appendedChildNode) {
131
+ var appendedChildNodes = [
132
+ appendedChildNode
133
+ ];
134
+ this.appendChildNodes(appendedChildNodes);
135
+ }
136
+ function appendChildNodes(appendedChildNodes) {
137
+ var addedChildNodes = appendedChildNodes, multiplicity = this.getMultiplicity(), startIndex = multiplicity; ///
138
+ this.addChildNodes(addedChildNodes, startIndex);
139
+ }
140
+ function prependChildNode(prependedChildNode) {
141
+ var prependedChildNodes = [
142
+ prependedChildNode
143
+ ];
144
+ this.prependChildNodes(prependedChildNodes);
145
+ }
146
+ function prependChildNodes(prependedChildNodes) {
147
+ var addedChildNodes = prependedChildNodes, startIndex = 0;
148
+ this.addChildNodes(addedChildNodes, startIndex);
149
+ }
150
+ function spliceChildNodes(startIndex, deleteCount) {
151
+ var addedChildNodes = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : [];
152
+ var _this_childNodes;
153
+ var removedChildNodes = (_this_childNodes = this.childNodes).splice.apply(_this_childNodes, [
154
+ startIndex,
155
+ deleteCount
156
+ ].concat(_to_consumable_array(addedChildNodes)));
157
+ this.resetChildNodesParentNode(removedChildNodes);
158
+ this.setChildNodesParentNode(addedChildNodes);
159
+ return removedChildNodes;
160
+ }
161
+ function sliceChildNodes(startIndex) {
162
+ var endIndex = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : Infinity;
163
+ var childNodes = this.childNodes.slice(startIndex, endIndex);
164
+ return childNodes;
165
+ }
166
+ var nodeMixins = {
167
+ getMultiplicity: getMultiplicity,
168
+ mapChildNode: mapChildNode,
169
+ someChildNode: someChildNode,
170
+ findChildNode: findChildNode,
171
+ everyChildNode: everyChildNode,
172
+ filterChildNode: filterChildNode,
173
+ reduceChildNode: reduceChildNode,
174
+ forEachChildNode: forEachChildNode,
175
+ forwardsSomeChildNode: forwardsSomeChildNode,
176
+ backwardsSomeChildNode: backwardsSomeChildNode,
177
+ indexOfChildNode: indexOfChildNode,
178
+ setChildNodesParentNode: setChildNodesParentNode,
179
+ resetChildNodesParentNode: resetChildNodesParentNode,
180
+ addChildNode: addChildNode,
181
+ addChildNodes: addChildNodes,
182
+ removeChildNode: removeChildNode,
183
+ removeChildNodes: removeChildNodes,
184
+ replaceChildNode: replaceChildNode,
185
+ replaceChildNodes: replaceChildNodes,
186
+ appendChildNode: appendChildNode,
187
+ appendChildNodes: appendChildNodes,
188
+ prependChildNode: prependChildNode,
189
+ prependChildNodes: prependChildNodes,
190
+ spliceChildNodes: spliceChildNodes,
191
+ sliceChildNodes: sliceChildNodes
192
+ };
193
+ var _default = nodeMixins;
194
+
195
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/mixins/node.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\n\nconst { first, forwardsSome, backwardsSome } = arrayUtilities;\n\nfunction getMultiplicity() {\n  const childNodesLength = this.childNodes.length,\n        multiplicity = childNodesLength;  ///\n\n  return multiplicity;\n}\n\nfunction mapChildNode(callback) { return this.childNodes.map(callback); }\n\nfunction someChildNode(callback) { return this.childNodes.some(callback); }\n\nfunction findChildNode(callback) { return this.childNodes.find(callback); }\n\nfunction everyChildNode(callback) { return this.childNodes.every(callback); }\n\nfunction filterChildNode(callback) { return this.childNodes.filter(callback); }\n\nfunction reduceChildNode(callback, initialValue) { return this.childNodes.reduce(callback, initialValue); }\n\nfunction forEachChildNode(callback) { this.childNodes.forEach(callback); }\n\nfunction forwardsSomeChildNode(callback) { return forwardsSome(this.childNodes, callback); }\n\nfunction backwardsSomeChildNode(callback) { return backwardsSome(this.childNodes, callback); }\n\nfunction indexOfChildNode(childNode) { return this.childNodes.indexOf(childNode); }\n\nfunction setChildNodesParentNode(childNodes) {\n  if (childNodes === undefined) {\n    childNodes = [\n      ...this.childNodes\n    ];\n  }\n\n  const parentNode = this;\n\n  childNodes.forEach((childNode) => {\n    childNode.setParentNode(parentNode);\n  });\n}\n\nfunction resetChildNodesParentNode(childNodes) {\n  if (childNodes === undefined) {\n    childNodes = [\n      ...this.childNodes\n    ];\n  }\n\n  const parentNode = null;\n\n  childNodes.forEach((childNode) => {\n    childNode.setParentNode(parentNode);\n  });\n}\n\nfunction addChildNode(addedChildNode, startIndex) {\n  const addedChildNodes = [\n    addedChildNode\n  ];\n\n  this.addChildNodes(addedChildNodes, startIndex);\n}\n\nfunction addChildNodes(addedChildNodes, startIndex) {\n  const deleteCount = 0;\n\n  this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);\n}\n\nfunction removeChildNode(removedChildNode) {\n  let removedChildNodes;\n\n  removedChildNodes = [\n    removedChildNode\n  ];\n\n  removedChildNodes = this.removeChildNodes(removedChildNodes);\n\n  return removedChildNodes;\n}\n\nfunction removeChildNodes(removedChildNodes) {\n  if (removedChildNodes === undefined) {\n    removedChildNodes = [\n      ...this.childNodes\n    ];\n  }\n\n  const removedChildNodesLength = removedChildNodes.length;\n\n  if (removedChildNodesLength === 0) {\n    return;\n  }\n\n  const firstReplacedChildNode = first(removedChildNodes),\n        firstIndex = this.childNodes.indexOf(firstReplacedChildNode),\n        startIndex = firstIndex, ///\n        deleteCount = removedChildNodesLength, ///\n        addedChildNodes = [];\n\n  removedChildNodes = this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);\n\n  return removedChildNodes;\n}\n\nfunction replaceChildNode(replacedChildNode, replacementChildNodes) {\n  const replacedChildNodes = [\n    replacedChildNode\n  ];\n\n  this.replaceChildNodes(replacedChildNodes, replacementChildNodes);\n}\n\nfunction replaceChildNodes(replacedChildNodes, replacementChildNodes) {\n  const replacedChildNodesLength = replacedChildNodes.length,\n        firstReplacedChildNode = first(replacedChildNodes),\n        firstIndex = this.childNodes.indexOf(firstReplacedChildNode),\n        startIndex = firstIndex, ///\n        deleteCount = replacedChildNodesLength; ///\n\n  this.spliceChildNodes(startIndex, deleteCount, replacementChildNodes);\n}\n\nfunction appendChildNode(appendedChildNode) {\n  const appendedChildNodes = [\n    appendedChildNode\n  ];\n\n  this.appendChildNodes(appendedChildNodes);\n}\n\nfunction appendChildNodes(appendedChildNodes) {\n  const addedChildNodes = appendedChildNodes, ///\n        multiplicity = this.getMultiplicity(),\n        startIndex = multiplicity;  ///\n\n  this.addChildNodes(addedChildNodes, startIndex);\n}\n\nfunction prependChildNode(prependedChildNode) {\n  const prependedChildNodes = [\n    prependedChildNode\n  ];\n\n  this.prependChildNodes(prependedChildNodes);\n}\n\nfunction prependChildNodes(prependedChildNodes) {\n  const addedChildNodes = prependedChildNodes,  ///\n        startIndex = 0;\n\n  this.addChildNodes(addedChildNodes, startIndex);\n}\n\nfunction spliceChildNodes(startIndex, deleteCount, addedChildNodes = []) {\n  const removedChildNodes = this.childNodes.splice(startIndex, deleteCount, ...addedChildNodes);\n\n  this.resetChildNodesParentNode(removedChildNodes);\n\n  this.setChildNodesParentNode(addedChildNodes);\n\n  return removedChildNodes;\n}\n\nfunction sliceChildNodes(startIndex, endIndex = Infinity) {\n  const childNodes = this.childNodes.slice(startIndex, endIndex);\n\n  return childNodes;\n}\n\nconst nodeMixins = {\n  getMultiplicity,\n  mapChildNode,\n  someChildNode,\n  findChildNode,\n  everyChildNode,\n  filterChildNode,\n  reduceChildNode,\n  forEachChildNode,\n  forwardsSomeChildNode,\n  backwardsSomeChildNode,\n  indexOfChildNode,\n  setChildNodesParentNode,\n  resetChildNodesParentNode,\n  addChildNode,\n  addChildNodes,\n  removeChildNode,\n  removeChildNodes,\n  replaceChildNode,\n  replaceChildNodes,\n  appendChildNode,\n  appendChildNodes,\n  prependChildNode,\n  prependChildNodes,\n  spliceChildNodes,\n  sliceChildNodes\n};\n\nexport default nodeMixins;\n"],"names":["first","arrayUtilities","forwardsSome","backwardsSome","getMultiplicity","childNodesLength","childNodes","length","multiplicity","mapChildNode","callback","map","someChildNode","some","findChildNode","find","everyChildNode","every","filterChildNode","filter","reduceChildNode","initialValue","reduce","forEachChildNode","forEach","forwardsSomeChildNode","backwardsSomeChildNode","indexOfChildNode","childNode","indexOf","setChildNodesParentNode","undefined","parentNode","setParentNode","resetChildNodesParentNode","addChildNode","addedChildNode","startIndex","addedChildNodes","addChildNodes","deleteCount","spliceChildNodes","removeChildNode","removedChildNode","removedChildNodes","removeChildNodes","removedChildNodesLength","firstReplacedChildNode","firstIndex","replaceChildNode","replacedChildNode","replacementChildNodes","replacedChildNodes","replaceChildNodes","replacedChildNodesLength","appendChildNode","appendedChildNode","appendedChildNodes","appendChildNodes","prependChildNode","prependedChildNode","prependedChildNodes","prependChildNodes","splice","sliceChildNodes","endIndex","Infinity","slice","nodeMixins"],"mappings":"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"}
@@ -10,6 +10,7 @@ Object.defineProperty(exports, "default", {
10
10
  });
11
11
  var _necessary = require("necessary");
12
12
  var _occamlexers = require("occam-lexers");
13
+ var _node = /*#__PURE__*/ _interop_require_default(require("../mixins/node"));
13
14
  var _nonTerminalNode = /*#__PURE__*/ _interop_require_default(require("../parseTree/nonTerminalNode"));
14
15
  function _array_like_to_array(arr, len) {
15
16
  if (len == null || len > arr.length) len = arr.length;
@@ -92,7 +93,7 @@ function _is_native_reflect_construct() {
92
93
  return !!result;
93
94
  })();
94
95
  }
95
- var first = _necessary.arrayUtilities.first, match = _necessary.arrayUtilities.match, forwardsSome = _necessary.arrayUtilities.forwardsSome, backwardsSome = _necessary.arrayUtilities.backwardsSome, opaqueSpecialSymbol = _occamlexers.specialSymbols.opaque, semiOpaqueSpecialSymbol = _occamlexers.specialSymbols.semiOpaque;
96
+ var first = _necessary.arrayUtilities.first, match = _necessary.arrayUtilities.match, opaqueSpecialSymbol = _occamlexers.specialSymbols.opaque, semiOpaqueSpecialSymbol = _occamlexers.specialSymbols.semiOpaque;
96
97
  var NonTerminalNode = /*#__PURE__*/ function() {
97
98
  function NonTerminalNode(ruleName, parentNode, childNodes, opacity, precedence) {
98
99
  _class_call_check(this, NonTerminalNode);
@@ -139,6 +140,12 @@ var NonTerminalNode = /*#__PURE__*/ function() {
139
140
  this.ruleName = ruleName;
140
141
  }
141
142
  },
143
+ {
144
+ key: "setParentNode",
145
+ value: function setParentNode(parentNode) {
146
+ this.parentNode = parentNode;
147
+ }
148
+ },
142
149
  {
143
150
  key: "setChildNodes",
144
151
  value: function setChildNodes(childNodes) {
@@ -147,9 +154,9 @@ var NonTerminalNode = /*#__PURE__*/ function() {
147
154
  }
148
155
  },
149
156
  {
150
- key: "setParentNode",
151
- value: function setParentNode(parentNode) {
152
- this.parentNode = parentNode;
157
+ key: "setOpacity",
158
+ value: function setOpacity(opacity) {
159
+ this.opacity = opacity;
153
160
  }
154
161
  },
155
162
  {
@@ -158,12 +165,6 @@ var NonTerminalNode = /*#__PURE__*/ function() {
158
165
  this.precedence = precedence;
159
166
  }
160
167
  },
161
- {
162
- key: "setOpacity",
163
- value: function setOpacity(opacity) {
164
- this.opacity = opacity;
165
- }
166
- },
167
168
  {
168
169
  key: "isOpaque",
169
170
  value: function isOpaque() {
@@ -321,167 +322,10 @@ var NonTerminalNode = /*#__PURE__*/ function() {
321
322
  }
322
323
  },
323
324
  {
324
- key: "mapChildNode",
325
- value: function mapChildNode(callback) {
326
- return this.childNodes.map(callback);
327
- }
328
- },
329
- {
330
- key: "someChildNode",
331
- value: function someChildNode(callback) {
332
- return this.childNodes.some(callback);
333
- }
334
- },
335
- {
336
- key: "findChildNode",
337
- value: function findChildNode(callback) {
338
- return this.childNodes.find(callback);
339
- }
340
- },
341
- {
342
- key: "everyChildNode",
343
- value: function everyChildNode(callback) {
344
- return this.childNodes.every(callback);
345
- }
346
- },
347
- {
348
- key: "filterChildNode",
349
- value: function filterChildNode(callback) {
350
- return this.childNodes.filter(callback);
351
- }
352
- },
353
- {
354
- key: "reduceChildNode",
355
- value: function reduceChildNode(callback, initialValue) {
356
- return this.childNodes.reduce(callback, initialValue);
357
- }
358
- },
359
- {
360
- key: "forEachChildNode",
361
- value: function forEachChildNode(callback) {
362
- this.childNodes.forEach(callback);
363
- }
364
- },
365
- {
366
- key: "forwardsSomeChildNode",
367
- value: function forwardsSomeChildNode(callback) {
368
- return forwardsSome(this.childNodes, callback);
369
- }
370
- },
371
- {
372
- key: "backwardsSomeChildNode",
373
- value: function backwardsSomeChildNode(callback) {
374
- return backwardsSome(this.childNodes, callback);
375
- }
376
- },
377
- {
378
- key: "indexOfChildNode",
379
- value: function indexOfChildNode(childNode) {
380
- return this.childNodes.indexOf(childNode);
381
- }
382
- },
383
- {
384
- key: "setChildNodesParentNode",
385
- value: function setChildNodesParentNode(childNodes) {
386
- if (childNodes === undefined) {
387
- childNodes = _to_consumable_array(this.childNodes);
388
- }
389
- var parentNode = this;
390
- childNodes.forEach(function(childNode) {
391
- childNode.setParentNode(parentNode);
392
- });
393
- }
394
- },
395
- {
396
- key: "resetChildNodesParentNode",
397
- value: function resetChildNodesParentNode(childNodes) {
398
- if (childNodes === undefined) {
399
- childNodes = _to_consumable_array(this.childNodes);
400
- }
401
- var parentNode = null;
402
- childNodes.forEach(function(childNode) {
403
- childNode.setParentNode(parentNode);
404
- });
405
- }
406
- },
407
- {
408
- key: "addChildNode",
409
- value: function addChildNode(addedChildNode, startIndex) {
410
- var addedChildNodes = [
411
- addedChildNode
412
- ];
413
- this.addChildNodes(addedChildNodes, startIndex);
414
- }
415
- },
416
- {
417
- key: "addChildNodes",
418
- value: function addChildNodes(addedChildNodes, startIndex) {
419
- var deleteCount = 0;
420
- this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);
421
- }
422
- },
423
- {
424
- key: "removeChildNode",
425
- value: function removeChildNode(removedChildNode) {
426
- var removedChildNodes;
427
- removedChildNodes = [
428
- removedChildNode
429
- ];
430
- removedChildNodes = this.removeChildNodes(removedChildNodes);
431
- return removedChildNodes;
432
- }
433
- },
434
- {
435
- key: "removeChildNodes",
436
- value: function removeChildNodes(removedChildNodes) {
437
- if (removedChildNodes === undefined) {
438
- removedChildNodes = _to_consumable_array(this.childNodes);
439
- }
440
- var removedChildNodesLength = removedChildNodes.length;
441
- if (removedChildNodesLength === 0) {
442
- return;
443
- }
444
- var firstReplacedChildNode = first(removedChildNodes), firstIndex = this.childNodes.indexOf(firstReplacedChildNode), startIndex = firstIndex, deleteCount = removedChildNodesLength, addedChildNodes = [];
445
- removedChildNodes = this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);
446
- return removedChildNodes;
447
- }
448
- },
449
- {
450
- key: "replaceChildNode",
451
- value: function replaceChildNode(replacedChildNode, replacementChildNodes) {
452
- var replacedChildNodes = [
453
- replacedChildNode
454
- ];
455
- this.replaceChildNodes(replacedChildNodes, replacementChildNodes);
456
- }
457
- },
458
- {
459
- key: "replaceChildNodes",
460
- value: function replaceChildNodes(replacedChildNodes, replacementChildNodes) {
461
- var replacedChildNodesLength = replacedChildNodes.length, firstReplacedChildNode = first(replacedChildNodes), firstIndex = this.childNodes.indexOf(firstReplacedChildNode), startIndex = firstIndex, deleteCount = replacedChildNodesLength; ///
462
- this.spliceChildNodes(startIndex, deleteCount, replacementChildNodes);
463
- }
464
- },
465
- {
466
- key: "spliceChildNodes",
467
- value: function spliceChildNodes(startIndex, deleteCount) {
468
- var addedChildNodes = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : [];
469
- var _this_childNodes;
470
- var removedChildNodes = (_this_childNodes = this.childNodes).splice.apply(_this_childNodes, [
471
- startIndex,
472
- deleteCount
473
- ].concat(_to_consumable_array(addedChildNodes)));
474
- this.resetChildNodesParentNode(removedChildNodes);
475
- this.setChildNodesParentNode(addedChildNodes);
476
- return removedChildNodes;
477
- }
478
- },
479
- {
480
- key: "sliceChildNodes",
481
- value: function sliceChildNodes(startIndex) {
482
- var endIndex = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : Infinity;
483
- var childNodes = this.childNodes.slice(startIndex, endIndex);
484
- return childNodes;
325
+ key: "asParseTree",
326
+ value: function asParseTree(tokens) {
327
+ var nonTerminalNode = this, nonTerminalNodeParseTree = _nonTerminalNode.default.fromNonTerminalNodeAndTokens(nonTerminalNode, tokens), parseTree = nonTerminalNodeParseTree; ///
328
+ return parseTree;
485
329
  }
486
330
  },
487
331
  {
@@ -524,10 +368,13 @@ var NonTerminalNode = /*#__PURE__*/ function() {
524
368
  }
525
369
  },
526
370
  {
527
- key: "asParseTree",
528
- value: function asParseTree(tokens) {
529
- var nonTerminalNode = this, nonTerminalNodeParseTree = _nonTerminalNode.default.fromNonTerminalNodeAndTokens(nonTerminalNode, tokens), parseTree = nonTerminalNodeParseTree; ///
530
- return parseTree;
371
+ key: "destroy",
372
+ value: function destroy() {
373
+ this.forEachChildNode(function(childNode) {
374
+ childNode.destroy();
375
+ });
376
+ this.parentNode = null;
377
+ this.childNodes = null;
531
378
  }
532
379
  },
533
380
  {
@@ -581,5 +428,6 @@ function cloneChildNodes(childNodes) {
581
428
  });
582
429
  return childNodes;
583
430
  }
431
+ Object.assign(NonTerminalNode.prototype, _node.default);
584
432
 
585
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/node/nonTerminal.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\nimport { specialSymbols } from \"occam-lexers\";\n\nimport NonTerminalNodeParseTree from \"../parseTree/nonTerminalNode\";\n\nconst { first, match, forwardsSome, backwardsSome } = arrayUtilities,\n      { opaque: opaqueSpecialSymbol , semiOpaque: semiOpaqueSpecialSymbol } = specialSymbols;\n\nexport default class NonTerminalNode {\n  constructor(ruleName, parentNode, childNodes, opacity, precedence) {\n    this.ruleName = ruleName;\n    this.parentNode = parentNode;\n    this.childNodes = childNodes;\n    this.opacity = opacity;\n    this.precedence = precedence;\n  }\n\n  getRuleName() {\n    return this.ruleName;\n  }\n\n  getParentNode() {\n    return this.parentNode;\n  }\n\n  getChildNodes() {\n    return this.childNodes;\n  }\n\n  getOpacity() {\n    return this.opacity;\n  }\n\n  getPrecedence() {\n    return this.precedence;\n  }\n\n  setRuleName(ruleName) {\n    this.ruleName = ruleName;\n  }\n\n  setChildNodes(childNodes) {\n    const startIndex = 0,\n          deleteCount = Infinity,\n          addedChildNodes = childNodes;  ///\n\n    this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);\n  }\n\n  setParentNode(parentNode) {\n    this.parentNode = parentNode;\n  }\n\n  setPrecedence(precedence) {\n    this.precedence = precedence;\n  }\n\n  setOpacity(opacity) {\n    this.opacity = opacity;\n  }\n\n  isOpaque() {\n    const opaque = (this.opacity === opaqueSpecialSymbol);\n\n    return opaque;\n  }\n\n  isSemiOpaque() {\n    const semiOpaque = (this.opacity === semiOpaqueSpecialSymbol);\n\n    return semiOpaque;\n  }\n\n  isTransparent() {\n    const semiOpaque = (this.opacity === null);\n\n    return semiOpaque;\n  }\n\n  isTerminalNode() {\n    const terminalNode = false;\n\n    return terminalNode;\n  }\n\n  isNonTerminalNode() {\n    const nonTerminalNode = true;\n\n    return nonTerminalNode;\n  }\n\n  getFirstSignificantTokenIndex(tokens) {\n    let firstSignificantTokenIndex;\n\n    this.forwardsSomeChildNode((childNode) => {\n      const node = childNode; ///\n\n      firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens);\n\n      if (firstSignificantTokenIndex !== null) {\n        return true;\n      }\n    });\n\n    return firstSignificantTokenIndex;\n  }\n\n  getLastSignificantTokenIndex(tokens) {\n    let lastSignificantTokenIndex;\n\n    this.backwardsSomeChildNode((childNode) => {\n      const node = childNode; ///\n\n      lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens);\n\n      if (lastSignificantTokenIndex !== null) {\n        return true;\n      }\n    });\n\n    return lastSignificantTokenIndex;\n  }\n\n  getSignificantTokens(significantTokens = []) {\n    this.childNodes.forEach((childNode) => {\n      childNode.getSignificantTokens(significantTokens);\n    });\n\n    return significantTokens;\n  }\n\n  getDescendantNodes(descendantNodes = []) {\n    const descendantNode = this; ///\n\n    descendantNodes.push(descendantNode);\n\n    this.childNodes.forEach((childNode) => {\n      const childNodeNonTerminalNode = childNode.isNonTerminalNode();\n\n      if (childNodeNonTerminalNode) {\n        const nonTerminalNode = childNode;  ///\n\n        nonTerminalNode.getDescendantNodes(descendantNodes);\n      }\n    });\n\n    return descendantNodes;\n  }\n\n  getAncestorNodes() {\n    const ancestorNodes = [];\n\n    let parentNode = this.parentNode;\n\n    while (parentNode !== null) {\n      const ancestorNode = parentNode;  ///\n\n      ancestorNodes.push(ancestorNode);\n\n      parentNode = parentNode.getParentNode();\n    }\n\n    return ancestorNodes;\n  }\n\n  getMultiplicity() {\n    const childNodesLength = this.childNodes.length,\n          multiplicity = childNodesLength;  ///\n\n    return multiplicity;\n  }\n\n  isEmpty() {\n    const multiplicity = this.getMultiplicity(),\n          empty = (multiplicity === 0);\n\n    return empty;\n  }\n\n  isSingular() {\n    const multiplicity = this.getMultiplicity(),\n          singular = (multiplicity === 1);\n\n    return singular;\n  }\n\n  isLowerPrecedence(ruleName, precedence) {\n    let lowerPrecedence;\n\n    if (false) {\n      ///\n    } else if (this.precedence === null) {\n      lowerPrecedence = false;\n    } else if (this.precedence === Infinity) {\n      const firstChildNode = first(this.childNodes);\n\n      lowerPrecedence = firstChildNode.isLowerPrecedence(ruleName, precedence);\n    } else {\n      lowerPrecedence = ((this.ruleName === ruleName) && (this.precedence < precedence));\n    }\n\n    return lowerPrecedence;\n  }\n\n  isUnprecedented() {\n    let unprecedented = false;\n\n    if (this.precedence !== null) {\n      unprecedented = this.childNodes.some((childNode) => {  ///\n        const childNodeLowerPrecedence = childNode.isLowerPrecedence(this.ruleName, this.precedence);\n\n        if (childNodeLowerPrecedence) {\n          return true;\n        }\n      });\n    }\n\n    return unprecedented;\n  }\n\n  mapChildNode(callback) { return this.childNodes.map(callback); }\n\n  someChildNode(callback) { return this.childNodes.some(callback); }\n\n  findChildNode(callback) { return this.childNodes.find(callback); }\n\n  everyChildNode(callback) { return this.childNodes.every(callback); }\n\n  filterChildNode(callback) { return this.childNodes.filter(callback); }\n\n  reduceChildNode(callback, initialValue) { return this.childNodes.reduce(callback, initialValue); }\n\n  forEachChildNode(callback) { this.childNodes.forEach(callback); }\n\n  forwardsSomeChildNode(callback) { return forwardsSome(this.childNodes, callback); }\n\n  backwardsSomeChildNode(callback) { return backwardsSome(this.childNodes, callback); }\n\n  indexOfChildNode(childNode) { return this.childNodes.indexOf(childNode); }\n\n  setChildNodesParentNode(childNodes) {\n    if (childNodes === undefined) {\n      childNodes = [\n        ...this.childNodes\n      ];\n    }\n\n    const parentNode = this;\n\n    childNodes.forEach((childNode) => {\n      childNode.setParentNode(parentNode);\n    });\n  }\n\n  resetChildNodesParentNode(childNodes) {\n    if (childNodes === undefined) {\n      childNodes = [\n        ...this.childNodes\n      ];\n    }\n\n    const parentNode = null;\n\n    childNodes.forEach((childNode) => {\n      childNode.setParentNode(parentNode);\n    });\n  }\n\n  addChildNode(addedChildNode, startIndex) {\n    const addedChildNodes = [\n        addedChildNode\n    ];\n\n    this.addChildNodes(addedChildNodes, startIndex);\n  }\n\n  addChildNodes(addedChildNodes, startIndex) {\n    const deleteCount = 0;\n\n    this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);\n  }\n\n  removeChildNode(removedChildNode) {\n    let removedChildNodes;\n\n    removedChildNodes = [\n      removedChildNode\n    ];\n\n    removedChildNodes = this.removeChildNodes(removedChildNodes);\n\n    return removedChildNodes;\n  }\n\n  removeChildNodes(removedChildNodes) {\n    if (removedChildNodes === undefined) {\n      removedChildNodes = [\n        ...this.childNodes\n      ];\n    }\n\n    const removedChildNodesLength = removedChildNodes.length;\n\n    if (removedChildNodesLength === 0) {\n      return;\n    }\n\n    const firstReplacedChildNode = first(removedChildNodes),\n          firstIndex = this.childNodes.indexOf(firstReplacedChildNode),\n          startIndex = firstIndex, ///\n          deleteCount = removedChildNodesLength, ///\n          addedChildNodes = [];\n\n    removedChildNodes = this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);\n\n    return removedChildNodes;\n  }\n\n  replaceChildNode(replacedChildNode, replacementChildNodes) {\n    const replacedChildNodes = [\n      replacedChildNode\n    ];\n\n    this.replaceChildNodes(replacedChildNodes, replacementChildNodes);\n  }\n\n  replaceChildNodes(replacedChildNodes, replacementChildNodes) {\n    const replacedChildNodesLength = replacedChildNodes.length,\n          firstReplacedChildNode = first(replacedChildNodes),\n          firstIndex = this.childNodes.indexOf(firstReplacedChildNode),\n          startIndex = firstIndex, ///\n          deleteCount = replacedChildNodesLength; ///\n\n    this.spliceChildNodes(startIndex, deleteCount, replacementChildNodes);\n  }\n\n  spliceChildNodes(startIndex, deleteCount, addedChildNodes = []) {\n    const removedChildNodes = this.childNodes.splice(startIndex, deleteCount, ...addedChildNodes);\n\n    this.resetChildNodesParentNode(removedChildNodes);\n\n    this.setChildNodesParentNode(addedChildNodes);\n\n    return removedChildNodes;\n  }\n\n  sliceChildNodes(startIndex, endIndex = Infinity) {\n    const childNodes = this.childNodes.slice(startIndex, endIndex);\n\n    return childNodes;\n  }\n\n  match(node, depth = Infinity, exactly = false) {\n    let matches = false;\n\n    const nodeNonTerminalNode = node.isNonTerminalNode();\n\n    if (nodeNonTerminalNode) {\n      const nonTerminalNode = node, ///\n            nonTerminalNodeRuleName = nonTerminalNode.getRuleName();\n\n      if (this.ruleName === nonTerminalNodeRuleName) {\n        const nonTerminalNodeOpacity = nonTerminalNode.getOpacity();\n\n        if (this.opacity === nonTerminalNodeOpacity) {\n          const precedence = this.getPrecedence(),\n                nonTerminalNodePrecedence = nonTerminalNode.getPrecedence();\n\n          if (precedence === nonTerminalNodePrecedence) {\n            depth--;\n\n            if (depth === 0) {\n              matches = true;\n            } else {\n              const nonTerminalNodeChildNodes = nonTerminalNode.getChildNodes();\n\n              matches = match(this.childNodes, nonTerminalNodeChildNodes, (childNode, nonTerminalNodeChildNode) => {\n                const childNodeMatchesNonTerminalNodeChildNode = childNode.match(nonTerminalNodeChildNode, depth, exactly);\n\n                if (childNodeMatchesNonTerminalNodeChildNode) {\n                  return true;\n                }\n              });\n            }\n          }\n        }\n      }\n    }\n\n    return matches;\n  }\n\n  rewrite() {\n    const rewrittenNonTerminalNode = null;\n\n    return rewrittenNonTerminalNode;\n  }\n\n  asParseTree(tokens) {\n    const nonTerminalNode = this,  ///\n          nonTerminalNodeParseTree = NonTerminalNodeParseTree.fromNonTerminalNodeAndTokens(nonTerminalNode, tokens),\n          parseTree = nonTerminalNodeParseTree;  ///\n\n    return parseTree;\n  }\n\n  clone(...remainingArguments) {\n    const Class = this.constructor,\n          parentNode = null,\n          ruleName = this.ruleName,\n          childNodes = cloneChildNodes(this.childNodes),\n          opacity = this.opacity,\n          precedence = this.precedence,\n          nonTerminalNode = new Class(ruleName, parentNode, childNodes, opacity, precedence, ...remainingArguments);\n\n    nonTerminalNode.setChildNodesParentNode();\n\n    return nonTerminalNode;\n  }\n\n  static fromRuleNameChildNodesAndOpacity(Class, ruleName, childNodes, opacity, ...remainingArguments) {\n    if (opacity === undefined) {\n      opacity = childNodes; ///\n\n      childNodes = ruleName;  ///\n\n      ruleName = Class; ///\n\n      Class = NonTerminalNode;  ///\n    }\n\n    const parentNode = null,\n          precedence = null,\n          nonTerminalNode = new Class(ruleName, parentNode, childNodes, opacity, precedence, ...remainingArguments);\n\n    nonTerminalNode.setChildNodesParentNode();\n\n    return nonTerminalNode;\n  }\n}\n\nfunction cloneChildNodes(childNodes) {\n  childNodes = childNodes.map((childNode) => {  ///\n    childNode = childNode.clone();  ///\n\n    return childNode;\n  });\n\n  return childNodes;\n}\n"],"names":["NonTerminalNode","first","arrayUtilities","match","forwardsSome","backwardsSome","opaque","opaqueSpecialSymbol","specialSymbols","semiOpaque","semiOpaqueSpecialSymbol","ruleName","parentNode","childNodes","opacity","precedence","getRuleName","getParentNode","getChildNodes","getOpacity","getPrecedence","setRuleName","setChildNodes","startIndex","deleteCount","Infinity","addedChildNodes","spliceChildNodes","setParentNode","setPrecedence","setOpacity","isOpaque","isSemiOpaque","isTransparent","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","getFirstSignificantTokenIndex","tokens","firstSignificantTokenIndex","forwardsSomeChildNode","childNode","node","getLastSignificantTokenIndex","lastSignificantTokenIndex","backwardsSomeChildNode","getSignificantTokens","significantTokens","forEach","getDescendantNodes","descendantNodes","descendantNode","push","childNodeNonTerminalNode","getAncestorNodes","ancestorNodes","ancestorNode","getMultiplicity","childNodesLength","length","multiplicity","isEmpty","empty","isSingular","singular","isLowerPrecedence","lowerPrecedence","firstChildNode","isUnprecedented","unprecedented","some","childNodeLowerPrecedence","mapChildNode","callback","map","someChildNode","findChildNode","find","everyChildNode","every","filterChildNode","filter","reduceChildNode","initialValue","reduce","forEachChildNode","indexOfChildNode","indexOf","setChildNodesParentNode","undefined","resetChildNodesParentNode","addChildNode","addedChildNode","addChildNodes","removeChildNode","removedChildNode","removedChildNodes","removeChildNodes","removedChildNodesLength","firstReplacedChildNode","firstIndex","replaceChildNode","replacedChildNode","replacementChildNodes","replacedChildNodes","replaceChildNodes","replacedChildNodesLength","splice","sliceChildNodes","endIndex","slice","depth","exactly","matches","nodeNonTerminalNode","nonTerminalNodeRuleName","nonTerminalNodeOpacity","nonTerminalNodePrecedence","nonTerminalNodeChildNodes","nonTerminalNodeChildNode","childNodeMatchesNonTerminalNodeChildNode","rewrite","rewrittenNonTerminalNode","asParseTree","nonTerminalNodeParseTree","NonTerminalNodeParseTree","fromNonTerminalNodeAndTokens","parseTree","clone","remainingArguments","Class","constructor","cloneChildNodes","fromRuleNameChildNodesAndOpacity"],"mappings":"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"}
433
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/node/nonTerminal.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\nimport { specialSymbols } from \"occam-lexers\";\n\nimport nodeMixins from \"../mixins/node\";\nimport NonTerminalNodeParseTree from \"../parseTree/nonTerminalNode\";\n\nconst { first, match } = arrayUtilities,\n      { opaque: opaqueSpecialSymbol , semiOpaque: semiOpaqueSpecialSymbol } = specialSymbols;\n\nexport default class NonTerminalNode {\n  constructor(ruleName, parentNode, childNodes, opacity, precedence) {\n    this.ruleName = ruleName;\n    this.parentNode = parentNode;\n    this.childNodes = childNodes;\n    this.opacity = opacity;\n    this.precedence = precedence;\n  }\n\n  getRuleName() {\n    return this.ruleName;\n  }\n\n  getParentNode() {\n    return this.parentNode;\n  }\n\n  getChildNodes() {\n    return this.childNodes;\n  }\n\n  getOpacity() {\n    return this.opacity;\n  }\n\n  getPrecedence() {\n    return this.precedence;\n  }\n\n  setRuleName(ruleName) {\n    this.ruleName = ruleName;\n  }\n\n  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  setOpacity(opacity) {\n    this.opacity = opacity;\n  }\n\n  setPrecedence(precedence) {\n    this.precedence = precedence;\n  }\n\n  isOpaque() {\n    const opaque = (this.opacity === opaqueSpecialSymbol);\n\n    return opaque;\n  }\n\n  isSemiOpaque() {\n    const semiOpaque = (this.opacity === semiOpaqueSpecialSymbol);\n\n    return semiOpaque;\n  }\n\n  isTransparent() {\n    const semiOpaque = (this.opacity === null);\n\n    return semiOpaque;\n  }\n\n  isTerminalNode() {\n    const terminalNode = false;\n\n    return terminalNode;\n  }\n\n  isNonTerminalNode() {\n    const nonTerminalNode = true;\n\n    return nonTerminalNode;\n  }\n\n  getFirstSignificantTokenIndex(tokens) {\n    let firstSignificantTokenIndex;\n\n    this.forwardsSomeChildNode((childNode) => {\n      const node = childNode; ///\n\n      firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens);\n\n      if (firstSignificantTokenIndex !== null) {\n        return true;\n      }\n    });\n\n    return firstSignificantTokenIndex;\n  }\n\n  getLastSignificantTokenIndex(tokens) {\n    let lastSignificantTokenIndex;\n\n    this.backwardsSomeChildNode((childNode) => {\n      const node = childNode; ///\n\n      lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens);\n\n      if (lastSignificantTokenIndex !== null) {\n        return true;\n      }\n    });\n\n    return lastSignificantTokenIndex;\n  }\n\n  getSignificantTokens(significantTokens = []) {\n    this.childNodes.forEach((childNode) => {\n      childNode.getSignificantTokens(significantTokens);\n    });\n\n    return significantTokens;\n  }\n\n  getDescendantNodes(descendantNodes = []) {\n    const descendantNode = this; ///\n\n    descendantNodes.push(descendantNode);\n\n    this.childNodes.forEach((childNode) => {\n      const childNodeNonTerminalNode = childNode.isNonTerminalNode();\n\n      if (childNodeNonTerminalNode) {\n        const nonTerminalNode = childNode;  ///\n\n        nonTerminalNode.getDescendantNodes(descendantNodes);\n      }\n    });\n\n    return descendantNodes;\n  }\n\n  getAncestorNodes() {\n    const ancestorNodes = [];\n\n    let parentNode = this.parentNode;\n\n    while (parentNode !== null) {\n      const ancestorNode = parentNode;  ///\n\n      ancestorNodes.push(ancestorNode);\n\n      parentNode = parentNode.getParentNode();\n    }\n\n    return ancestorNodes;\n  }\n\n  getMultiplicity() {\n    const childNodesLength = this.childNodes.length,\n          multiplicity = childNodesLength;  ///\n\n    return multiplicity;\n  }\n\n  isEmpty() {\n    const multiplicity = this.getMultiplicity(),\n          empty = (multiplicity === 0);\n\n    return empty;\n  }\n\n  isSingular() {\n    const multiplicity = this.getMultiplicity(),\n          singular = (multiplicity === 1);\n\n    return singular;\n  }\n\n  isLowerPrecedence(ruleName, precedence) {\n    let lowerPrecedence;\n\n    if (false) {\n      ///\n    } else if (this.precedence === null) {\n      lowerPrecedence = false;\n    } else if (this.precedence === Infinity) {\n      const firstChildNode = first(this.childNodes);\n\n      lowerPrecedence = firstChildNode.isLowerPrecedence(ruleName, precedence);\n    } else {\n      lowerPrecedence = ((this.ruleName === ruleName) && (this.precedence < precedence));\n    }\n\n    return lowerPrecedence;\n  }\n\n  isUnprecedented() {\n    let unprecedented = false;\n\n    if (this.precedence !== null) {\n      unprecedented = this.childNodes.some((childNode) => {  ///\n        const childNodeLowerPrecedence = childNode.isLowerPrecedence(this.ruleName, this.precedence);\n\n        if (childNodeLowerPrecedence) {\n          return true;\n        }\n      });\n    }\n\n    return unprecedented;\n  }\n\n  asParseTree(tokens) {\n    const nonTerminalNode = this,  ///\n          nonTerminalNodeParseTree = NonTerminalNodeParseTree.fromNonTerminalNodeAndTokens(nonTerminalNode, tokens),\n          parseTree = nonTerminalNodeParseTree;  ///\n\n    return parseTree;\n  }\n\n  match(node, depth = Infinity, exactly = false) {\n    let matches = false;\n\n    const nodeNonTerminalNode = node.isNonTerminalNode();\n\n    if (nodeNonTerminalNode) {\n      const nonTerminalNode = node, ///\n            nonTerminalNodeRuleName = nonTerminalNode.getRuleName();\n\n      if (this.ruleName === nonTerminalNodeRuleName) {\n        const nonTerminalNodeOpacity = nonTerminalNode.getOpacity();\n\n        if (this.opacity === nonTerminalNodeOpacity) {\n          const precedence = this.getPrecedence(),\n                nonTerminalNodePrecedence = nonTerminalNode.getPrecedence();\n\n          if (precedence === nonTerminalNodePrecedence) {\n            depth--;\n\n            if (depth === 0) {\n              matches = true;\n            } else {\n              const nonTerminalNodeChildNodes = nonTerminalNode.getChildNodes();\n\n              matches = match(this.childNodes, nonTerminalNodeChildNodes, (childNode, nonTerminalNodeChildNode) => {\n                const childNodeMatchesNonTerminalNodeChildNode = childNode.match(nonTerminalNodeChildNode, depth, exactly);\n\n                if (childNodeMatchesNonTerminalNodeChildNode) {\n                  return true;\n                }\n              });\n            }\n          }\n        }\n      }\n    }\n\n    return matches;\n  }\n\n  rewrite() {\n    const rewrittenNonTerminalNode = null;\n\n    return rewrittenNonTerminalNode;\n  }\n\n  destroy() {\n    this.forEachChildNode((childNode) => {\n      childNode.destroy();\n    });\n\n    this.parentNode = null;\n    this.childNodes = null;\n  }\n\n  clone(...remainingArguments) {\n    const Class = this.constructor,\n          parentNode = null,\n          ruleName = this.ruleName,\n          childNodes = cloneChildNodes(this.childNodes),\n          opacity = this.opacity,\n          precedence = this.precedence,\n          nonTerminalNode = new Class(ruleName, parentNode, childNodes, opacity, precedence, ...remainingArguments);\n\n    nonTerminalNode.setChildNodesParentNode();\n\n    return nonTerminalNode;\n  }\n\n  static fromRuleNameChildNodesAndOpacity(Class, ruleName, childNodes, opacity, ...remainingArguments) {\n    if (opacity === undefined) {\n      opacity = childNodes; ///\n\n      childNodes = ruleName;  ///\n\n      ruleName = Class; ///\n\n      Class = NonTerminalNode;  ///\n    }\n\n    const parentNode = null,\n          precedence = null,\n          nonTerminalNode = new Class(ruleName, parentNode, childNodes, opacity, precedence, ...remainingArguments);\n\n    nonTerminalNode.setChildNodesParentNode();\n\n    return nonTerminalNode;\n  }\n}\n\nfunction cloneChildNodes(childNodes) {\n  childNodes = childNodes.map((childNode) => {  ///\n    childNode = childNode.clone();  ///\n\n    return childNode;\n  });\n\n  return childNodes;\n}\n\nObject.assign(NonTerminalNode.prototype, nodeMixins);\n"],"names":["NonTerminalNode","first","arrayUtilities","match","opaque","opaqueSpecialSymbol","specialSymbols","semiOpaque","semiOpaqueSpecialSymbol","ruleName","parentNode","childNodes","opacity","precedence","getRuleName","getParentNode","getChildNodes","getOpacity","getPrecedence","setRuleName","setParentNode","setChildNodes","startIndex","deleteCount","Infinity","addedChildNodes","spliceChildNodes","setOpacity","setPrecedence","isOpaque","isSemiOpaque","isTransparent","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","getFirstSignificantTokenIndex","tokens","firstSignificantTokenIndex","forwardsSomeChildNode","childNode","node","getLastSignificantTokenIndex","lastSignificantTokenIndex","backwardsSomeChildNode","getSignificantTokens","significantTokens","forEach","getDescendantNodes","descendantNodes","descendantNode","push","childNodeNonTerminalNode","getAncestorNodes","ancestorNodes","ancestorNode","getMultiplicity","childNodesLength","length","multiplicity","isEmpty","empty","isSingular","singular","isLowerPrecedence","lowerPrecedence","firstChildNode","isUnprecedented","unprecedented","some","childNodeLowerPrecedence","asParseTree","nonTerminalNodeParseTree","NonTerminalNodeParseTree","fromNonTerminalNodeAndTokens","parseTree","depth","exactly","matches","nodeNonTerminalNode","nonTerminalNodeRuleName","nonTerminalNodeOpacity","nonTerminalNodePrecedence","nonTerminalNodeChildNodes","nonTerminalNodeChildNode","childNodeMatchesNonTerminalNodeChildNode","rewrite","rewrittenNonTerminalNode","destroy","forEachChildNode","clone","remainingArguments","Class","constructor","cloneChildNodes","setChildNodesParentNode","fromRuleNameChildNodesAndOpacity","undefined","map","Object","assign","prototype","nodeMixins"],"mappings":"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"}