occam-parsers 23.0.136 → 23.0.138
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/example.js +401 -276
- package/lib/mixins/node.js +99 -5
- package/lib/node/nonTerminal.js +7 -17
- package/lib/node/terminal.js +43 -3
- package/package.json +3 -3
- package/src/mixins/node.js +145 -4
- package/src/node/nonTerminal.js +4 -18
- package/src/node/terminal.js +45 -2
package/lib/mixins/node.js
CHANGED
|
@@ -34,7 +34,7 @@ function _unsupported_iterable_to_array(o, minLen) {
|
|
|
34
34
|
if (n === "Map" || n === "Set") return Array.from(n);
|
|
35
35
|
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
|
|
36
36
|
}
|
|
37
|
-
var first = _necessary.arrayUtilities.first, forwardsSome = _necessary.arrayUtilities.forwardsSome, backwardsSome = _necessary.arrayUtilities.backwardsSome;
|
|
37
|
+
var push = _necessary.arrayUtilities.push, first = _necessary.arrayUtilities.first, forwardsSome = _necessary.arrayUtilities.forwardsSome, backwardsSome = _necessary.arrayUtilities.backwardsSome;
|
|
38
38
|
function getMultiplicity() {
|
|
39
39
|
var childNodesLength = this.childNodes.length, multiplicity = childNodesLength; ///
|
|
40
40
|
return multiplicity;
|
|
@@ -201,10 +201,22 @@ function findAncestorNode(callback) {
|
|
|
201
201
|
ancestorNode = parentNode; ///
|
|
202
202
|
index++;
|
|
203
203
|
}
|
|
204
|
+
ancestorNode = undefined;
|
|
205
|
+
return ancestorNode;
|
|
204
206
|
}
|
|
205
207
|
function everyAncestorNode(callback) {
|
|
206
|
-
var
|
|
207
|
-
|
|
208
|
+
var result = true;
|
|
209
|
+
var index = 0, ancestorNode = this.parentNode; ///
|
|
210
|
+
while(ancestorNode !== null){
|
|
211
|
+
result = callback(ancestorNode, index);
|
|
212
|
+
if (!result) {
|
|
213
|
+
break;
|
|
214
|
+
}
|
|
215
|
+
var parentNode = ancestorNode.getParentNode();
|
|
216
|
+
ancestorNode = parentNode; ///
|
|
217
|
+
index++;
|
|
218
|
+
}
|
|
219
|
+
return result;
|
|
208
220
|
}
|
|
209
221
|
function filterAncestorNode(callback) {
|
|
210
222
|
var ancestorNodes = this.getAncestorNodes();
|
|
@@ -218,6 +230,80 @@ function forEachAncestorNode(callback) {
|
|
|
218
230
|
var ancestorNodes = this.getAncestorNodes();
|
|
219
231
|
ancestorNodes.forEach(callback);
|
|
220
232
|
}
|
|
233
|
+
function getDescendantNodes() {
|
|
234
|
+
var descendantNodes = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : [];
|
|
235
|
+
push(descendantNodes, this.childNodes);
|
|
236
|
+
this.forEachChildNode(function(childNode) {
|
|
237
|
+
childNode.getDescendantNodes(descendantNodes);
|
|
238
|
+
});
|
|
239
|
+
return descendantNodes;
|
|
240
|
+
}
|
|
241
|
+
function mapDescendantNode(callback) {
|
|
242
|
+
var descendantNodes = this.getDescendantNodes();
|
|
243
|
+
return descendantNodes.map(callback);
|
|
244
|
+
}
|
|
245
|
+
function someDescendantNode(callback) {
|
|
246
|
+
var result = false;
|
|
247
|
+
var childNodesLength = this.childNodes.length;
|
|
248
|
+
for(var index = 0; index < childNodesLength; index++){
|
|
249
|
+
var childNode = this.childNodes[index], descendantNode = childNode; ///
|
|
250
|
+
result = callback(descendantNode);
|
|
251
|
+
if (result) {
|
|
252
|
+
break;
|
|
253
|
+
}
|
|
254
|
+
result = childNode.someDescendantNode(callback);
|
|
255
|
+
if (result) {
|
|
256
|
+
break;
|
|
257
|
+
}
|
|
258
|
+
}
|
|
259
|
+
return result;
|
|
260
|
+
}
|
|
261
|
+
function findDescendantNode(callback) {
|
|
262
|
+
var descendantNode = undefined;
|
|
263
|
+
var childNodesLength = this.childNodes.length;
|
|
264
|
+
for(var index = 0; index < childNodesLength; index++){
|
|
265
|
+
var result = void 0;
|
|
266
|
+
var childNode = this.childNodes[index];
|
|
267
|
+
descendantNode = childNode; ///
|
|
268
|
+
result = callback(descendantNode);
|
|
269
|
+
if (result) {
|
|
270
|
+
break;
|
|
271
|
+
}
|
|
272
|
+
descendantNode = childNode.findDescendantNode(callback);
|
|
273
|
+
if (descendantNode !== undefined) {
|
|
274
|
+
break;
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
return descendantNode;
|
|
278
|
+
}
|
|
279
|
+
function everyDescendantNode(callback) {
|
|
280
|
+
var result = true;
|
|
281
|
+
var childNodesLength = this.childNodes.length;
|
|
282
|
+
for(var index = 0; index < childNodesLength; index++){
|
|
283
|
+
var childNode = this.childNodes[index], descendantNode = childNode; ///
|
|
284
|
+
result = callback(descendantNode);
|
|
285
|
+
if (!result) {
|
|
286
|
+
break;
|
|
287
|
+
}
|
|
288
|
+
result = childNode.everyDescendantNode(callback);
|
|
289
|
+
if (!result) {
|
|
290
|
+
break;
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
return result;
|
|
294
|
+
}
|
|
295
|
+
function filterDescendantNode(callback) {
|
|
296
|
+
var descendantNodes = this.getDescendantNodes();
|
|
297
|
+
return descendantNodes.filter(callback);
|
|
298
|
+
}
|
|
299
|
+
function reduceDescendantNode(callback, initialValue) {
|
|
300
|
+
var descendantNodes = this.getDescendantNodes();
|
|
301
|
+
return descendantNodes.reduce(callback, initialValue);
|
|
302
|
+
}
|
|
303
|
+
function forEachDescendantNode(callback) {
|
|
304
|
+
var descendantNodes = this.getDescendantNodes();
|
|
305
|
+
descendantNodes.forEach(callback);
|
|
306
|
+
}
|
|
221
307
|
var nodeMixins = {
|
|
222
308
|
getMultiplicity: getMultiplicity,
|
|
223
309
|
mapChildNode: mapChildNode,
|
|
@@ -251,8 +337,16 @@ var nodeMixins = {
|
|
|
251
337
|
everyAncestorNode: everyAncestorNode,
|
|
252
338
|
filterAncestorNode: filterAncestorNode,
|
|
253
339
|
reduceAncestorNode: reduceAncestorNode,
|
|
254
|
-
forEachAncestorNode: forEachAncestorNode
|
|
340
|
+
forEachAncestorNode: forEachAncestorNode,
|
|
341
|
+
getDescendantNodes: getDescendantNodes,
|
|
342
|
+
mapDescendantNode: mapDescendantNode,
|
|
343
|
+
someDescendantNode: someDescendantNode,
|
|
344
|
+
findDescendantNode: findDescendantNode,
|
|
345
|
+
everyDescendantNode: everyDescendantNode,
|
|
346
|
+
filterDescendantNode: filterDescendantNode,
|
|
347
|
+
reduceDescendantNode: reduceDescendantNode,
|
|
348
|
+
forEachDescendantNode: forEachDescendantNode
|
|
255
349
|
};
|
|
256
350
|
var _default = nodeMixins;
|
|
257
351
|
|
|
258
|
-
//# 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    const firstReplacedChildNode = first(removedChildNodes),\n          startIndex = this.childNodes.indexOf(firstReplacedChildNode), ///\n          deleteCount = removedChildNodesLength, ///\n          addedChildNodes = [];\n\n    removedChildNodes = this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);\n  }\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        startIndex = this.childNodes.indexOf(firstReplacedChildNode), ///\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\nfunction getAncestorNodes() {\n  const ancestorNodes = [];\n\n  let ancestorNode = this.parentNode; ///\n\n  while (ancestorNode !== null) {\n    ancestorNodes.push(ancestorNode);\n\n    const parentNode = ancestorNode.getParentNode();\n\n    ancestorNode = parentNode;  ///\n  }\n\n  return ancestorNodes;\n}\n\nfunction mapAncestorNode(callback) {\n  const ancestorNodes = this.getAncestorNodes();\n\n  return ancestorNodes.map(callback);\n}\n\nfunction someAncestorNode(callback) {\n  let result = false;\n\n  let index = 0,\n      ancestorNode = this.parentNode; ///\n\n  while (ancestorNode !== null) {\n    result = callback(ancestorNode, index);\n\n    if (result) {\n      break;\n    }\n\n    const parentNode = ancestorNode.getParentNode();\n\n    ancestorNode = parentNode;  ///\n\n    index++;\n  }\n\n  return result;\n}\n\nfunction findAncestorNode(callback) {\n  let index = 0,\n      ancestorNode = this.parentNode; ///\n\n  while (ancestorNode !== null) {\n    const result = callback(ancestorNode, index);\n\n    if (result) {\n      return ancestorNode;\n    }\n\n    const parentNode = ancestorNode.getParentNode();\n\n    ancestorNode = parentNode;  ///\n\n    index++;\n  }\n}\n\nfunction everyAncestorNode(callback) {\n  const ancestorNodes = this.getAncestorNodes();\n\n  return ancestorNodes.every(callback);\n}\n\nfunction filterAncestorNode(callback) {\n  const ancestorNodes = this.getAncestorNodes();\n\n  return ancestorNodes.filter(callback);\n}\n\nfunction reduceAncestorNode(callback, initialValue) {\n  const ancestorNodes = this.getAncestorNodes();\n\n  return ancestorNodes.reduce(callback, initialValue);\n}\n\nfunction forEachAncestorNode(callback) {\n  const ancestorNodes = this.getAncestorNodes();\n\n  ancestorNodes.forEach(callback);\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  getAncestorNodes,\n  mapAncestorNode,\n  someAncestorNode,\n  findAncestorNode,\n  everyAncestorNode,\n  filterAncestorNode,\n  reduceAncestorNode,\n  forEachAncestorNode\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","replaceChildNode","replacedChildNode","replacementChildNodes","replacedChildNodes","replaceChildNodes","replacedChildNodesLength","appendChildNode","appendedChildNode","appendedChildNodes","appendChildNodes","prependChildNode","prependedChildNode","prependedChildNodes","prependChildNodes","splice","sliceChildNodes","endIndex","Infinity","slice","getAncestorNodes","ancestorNodes","ancestorNode","push","getParentNode","mapAncestorNode","someAncestorNode","result","index","findAncestorNode","everyAncestorNode","filterAncestorNode","reduceAncestorNode","forEachAncestorNode","nodeMixins"],"mappings":"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"}
|
|
352
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/mixins/node.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\n\nconst { push, 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    const firstReplacedChildNode = first(removedChildNodes),\n          startIndex = this.childNodes.indexOf(firstReplacedChildNode), ///\n          deleteCount = removedChildNodesLength, ///\n          addedChildNodes = [];\n\n    removedChildNodes = this.spliceChildNodes(startIndex, deleteCount, addedChildNodes);\n  }\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        startIndex = this.childNodes.indexOf(firstReplacedChildNode), ///\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\nfunction getAncestorNodes() {\n  const ancestorNodes = [];\n\n  let ancestorNode = this.parentNode; ///\n\n  while (ancestorNode !== null) {\n    ancestorNodes.push(ancestorNode);\n\n    const parentNode = ancestorNode.getParentNode();\n\n    ancestorNode = parentNode;  ///\n  }\n\n  return ancestorNodes;\n}\n\nfunction mapAncestorNode(callback) {\n  const ancestorNodes = this.getAncestorNodes();\n\n  return ancestorNodes.map(callback);\n}\n\nfunction someAncestorNode(callback) {\n  let result = false;\n\n  let index = 0,\n      ancestorNode = this.parentNode; ///\n\n  while (ancestorNode !== null) {\n    result = callback(ancestorNode, index);\n\n    if (result) {\n      break;\n    }\n\n    const parentNode = ancestorNode.getParentNode();\n\n    ancestorNode = parentNode;  ///\n\n    index++;\n  }\n\n  return result;\n}\n\nfunction findAncestorNode(callback) {\n  let index = 0,\n      ancestorNode = this.parentNode; ///\n\n  while (ancestorNode !== null) {\n    const result = callback(ancestorNode, index);\n\n    if (result) {\n      return ancestorNode;\n    }\n\n    const parentNode = ancestorNode.getParentNode();\n\n    ancestorNode = parentNode;  ///\n\n    index++;\n  }\n\n  ancestorNode = undefined;\n\n  return ancestorNode;\n}\n\nfunction everyAncestorNode(callback) {\n  let result = true;\n\n  let index = 0,\n      ancestorNode = this.parentNode; ///\n\n  while (ancestorNode !== null) {\n    result = callback(ancestorNode, index);\n\n    if (!result) {\n      break;\n    }\n\n    const parentNode = ancestorNode.getParentNode();\n\n    ancestorNode = parentNode;  ///\n\n    index++;\n  }\n\n  return result;\n}\n\nfunction filterAncestorNode(callback) {\n  const ancestorNodes = this.getAncestorNodes();\n\n  return ancestorNodes.filter(callback);\n}\n\nfunction reduceAncestorNode(callback, initialValue) {\n  const ancestorNodes = this.getAncestorNodes();\n\n  return ancestorNodes.reduce(callback, initialValue);\n}\n\nfunction forEachAncestorNode(callback) {\n  const ancestorNodes = this.getAncestorNodes();\n\n  ancestorNodes.forEach(callback);\n}\n\nfunction getDescendantNodes(descendantNodes = []) {\n  push(descendantNodes, this.childNodes);\n\n  this.forEachChildNode((childNode) => {\n    childNode.getDescendantNodes(descendantNodes);\n  });\n\n  return descendantNodes;\n}\n\nfunction mapDescendantNode(callback) {\n  const descendantNodes = this.getDescendantNodes();\n\n  return descendantNodes.map(callback);\n}\n\nfunction someDescendantNode(callback) {\n  let result = false;\n\n  const childNodesLength = this.childNodes.length;\n\n  for (let index = 0; index < childNodesLength; index++) {\n    const childNode = this.childNodes[index],\n          descendantNode = childNode; ///\n\n    result = callback(descendantNode);\n\n    if (result) {\n      break;\n    }\n\n    result = childNode.someDescendantNode(callback);\n\n    if (result) {\n      break;\n    }\n  }\n\n  return result;\n}\n\nfunction findDescendantNode(callback) {\n  let descendantNode = undefined;\n\n  const childNodesLength = this.childNodes.length;\n\n  for (let index = 0; index < childNodesLength; index++) {\n    let result;\n\n    const childNode = this.childNodes[index];\n\n    descendantNode = childNode; ///\n\n    result = callback(descendantNode);\n\n    if (result) {\n      break;\n    }\n\n    descendantNode = childNode.findDescendantNode(callback);\n\n    if (descendantNode !== undefined) {\n      break;\n    }\n  }\n\n  return descendantNode;\n}\n\nfunction everyDescendantNode(callback) {\n  let result = true;\n\n  const childNodesLength = this.childNodes.length;\n\n  for (let index = 0; index < childNodesLength; index++) {\n    const childNode = this.childNodes[index],\n          descendantNode = childNode; ///\n\n    result = callback(descendantNode);\n\n    if (!result) {\n      break;\n    }\n\n    result = childNode.everyDescendantNode(callback);\n\n    if (!result) {\n      break;\n    }\n  }\n\n  return result;\n}\n\nfunction filterDescendantNode(callback) {\n  const descendantNodes = this.getDescendantNodes();\n\n  return descendantNodes.filter(callback);\n}\n\nfunction reduceDescendantNode(callback, initialValue) {\n  const descendantNodes = this.getDescendantNodes();\n\n  return descendantNodes.reduce(callback, initialValue);\n}\n\nfunction forEachDescendantNode(callback) {\n  const descendantNodes = this.getDescendantNodes();\n\n  descendantNodes.forEach(callback);\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  getAncestorNodes,\n  mapAncestorNode,\n  someAncestorNode,\n  findAncestorNode,\n  everyAncestorNode,\n  filterAncestorNode,\n  reduceAncestorNode,\n  forEachAncestorNode,\n  getDescendantNodes,\n  mapDescendantNode,\n  someDescendantNode,\n  findDescendantNode,\n  everyDescendantNode,\n  filterDescendantNode,\n  reduceDescendantNode,\n  forEachDescendantNode\n};\n\nexport default nodeMixins;\n"],"names":["push","arrayUtilities","first","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","replaceChildNode","replacedChildNode","replacementChildNodes","replacedChildNodes","replaceChildNodes","replacedChildNodesLength","appendChildNode","appendedChildNode","appendedChildNodes","appendChildNodes","prependChildNode","prependedChildNode","prependedChildNodes","prependChildNodes","splice","sliceChildNodes","endIndex","Infinity","slice","getAncestorNodes","ancestorNodes","ancestorNode","getParentNode","mapAncestorNode","someAncestorNode","result","index","findAncestorNode","everyAncestorNode","filterAncestorNode","reduceAncestorNode","forEachAncestorNode","getDescendantNodes","descendantNodes","mapDescendantNode","someDescendantNode","descendantNode","findDescendantNode","everyDescendantNode","filterDescendantNode","reduceDescendantNode","forEachDescendantNode","nodeMixins"],"mappings":"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"}
|
package/lib/node/nonTerminal.js
CHANGED
|
@@ -200,6 +200,12 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
200
200
|
return nonTerminalNode;
|
|
201
201
|
}
|
|
202
202
|
},
|
|
203
|
+
{
|
|
204
|
+
key: "getDescendantNodes",
|
|
205
|
+
value: function getDescendantNodes(descendantNodes) {
|
|
206
|
+
return descendantNodes;
|
|
207
|
+
}
|
|
208
|
+
},
|
|
203
209
|
{
|
|
204
210
|
key: "getFirstSignificantTokenIndex",
|
|
205
211
|
value: function getFirstSignificantTokenIndex(tokens) {
|
|
@@ -238,22 +244,6 @@ var NonTerminalNode = /*#__PURE__*/ function() {
|
|
|
238
244
|
return significantTokens;
|
|
239
245
|
}
|
|
240
246
|
},
|
|
241
|
-
{
|
|
242
|
-
key: "getDescendantNodes",
|
|
243
|
-
value: function getDescendantNodes() {
|
|
244
|
-
var descendantNodes = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : [];
|
|
245
|
-
var descendantNode = this; ///
|
|
246
|
-
descendantNodes.push(descendantNode);
|
|
247
|
-
this.childNodes.forEach(function(childNode) {
|
|
248
|
-
var childNodeNonTerminalNode = childNode.isNonTerminalNode();
|
|
249
|
-
if (childNodeNonTerminalNode) {
|
|
250
|
-
var nonTerminalNode = childNode; ///
|
|
251
|
-
nonTerminalNode.getDescendantNodes(descendantNodes);
|
|
252
|
-
}
|
|
253
|
-
});
|
|
254
|
-
return descendantNodes;
|
|
255
|
-
}
|
|
256
|
-
},
|
|
257
247
|
{
|
|
258
248
|
key: "getMultiplicity",
|
|
259
249
|
value: function getMultiplicity() {
|
|
@@ -417,4 +407,4 @@ function cloneChildNodes(childNodes) {
|
|
|
417
407
|
return childNodes;
|
|
418
408
|
}
|
|
419
409
|
|
|
420
|
-
//# 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  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\nObject.assign(NonTerminalNode.prototype, nodeMixins);\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","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","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","Object","assign","prototype","nodeMixins","map"],"mappings":"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"}
|
|
410
|
+
//# 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  getDescendantNodes(descendantNodes) {\n    return descendantNodes;\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  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\nObject.assign(NonTerminalNode.prototype, nodeMixins);\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","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","getDescendantNodes","descendantNodes","getFirstSignificantTokenIndex","tokens","firstSignificantTokenIndex","forwardsSomeChildNode","childNode","node","getLastSignificantTokenIndex","lastSignificantTokenIndex","backwardsSomeChildNode","getSignificantTokens","significantTokens","forEach","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","Object","assign","prototype","nodeMixins","map"],"mappings":"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"}
|
package/lib/node/terminal.js
CHANGED
|
@@ -266,13 +266,25 @@ var TerminalNode = /*#__PURE__*/ function() {
|
|
|
266
266
|
ancestorNode = parentNode; ///
|
|
267
267
|
index++;
|
|
268
268
|
}
|
|
269
|
+
ancestorNode = undefined;
|
|
270
|
+
return ancestorNode;
|
|
269
271
|
}
|
|
270
272
|
},
|
|
271
273
|
{
|
|
272
274
|
key: "everyAncestorNode",
|
|
273
275
|
value: function everyAncestorNode(callback) {
|
|
274
|
-
var
|
|
275
|
-
|
|
276
|
+
var result = true;
|
|
277
|
+
var index = 0, ancestorNode = this.parentNode; ///
|
|
278
|
+
while(ancestorNode !== null){
|
|
279
|
+
result = callback(ancestorNode, index);
|
|
280
|
+
if (!result) {
|
|
281
|
+
break;
|
|
282
|
+
}
|
|
283
|
+
var parentNode = ancestorNode.getParentNode();
|
|
284
|
+
ancestorNode = parentNode; ///
|
|
285
|
+
index++;
|
|
286
|
+
}
|
|
287
|
+
return result;
|
|
276
288
|
}
|
|
277
289
|
},
|
|
278
290
|
{
|
|
@@ -296,6 +308,34 @@ var TerminalNode = /*#__PURE__*/ function() {
|
|
|
296
308
|
ancestorNodes.forEach(callback);
|
|
297
309
|
}
|
|
298
310
|
},
|
|
311
|
+
{
|
|
312
|
+
key: "getDescendantNodes",
|
|
313
|
+
value: function getDescendantNodes() {
|
|
314
|
+
var descendantNodes = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : [];
|
|
315
|
+
return descendantNodes;
|
|
316
|
+
}
|
|
317
|
+
},
|
|
318
|
+
{
|
|
319
|
+
key: "someDescendantNode",
|
|
320
|
+
value: function someDescendantNode(callback) {
|
|
321
|
+
var result = false;
|
|
322
|
+
return result;
|
|
323
|
+
}
|
|
324
|
+
},
|
|
325
|
+
{
|
|
326
|
+
key: "findDescendantNode",
|
|
327
|
+
value: function findDescendantNode(callback) {
|
|
328
|
+
var descendantNode = undefined;
|
|
329
|
+
return descendantNode;
|
|
330
|
+
}
|
|
331
|
+
},
|
|
332
|
+
{
|
|
333
|
+
key: "everyDescendantNode",
|
|
334
|
+
value: function everyDescendantNode(callback) {
|
|
335
|
+
var result = true;
|
|
336
|
+
return result;
|
|
337
|
+
}
|
|
338
|
+
},
|
|
299
339
|
{
|
|
300
340
|
key: "asParseTree",
|
|
301
341
|
value: function asParseTree(tokens) {
|
|
@@ -374,4 +414,4 @@ var TerminalNode = /*#__PURE__*/ function() {
|
|
|
374
414
|
return TerminalNode;
|
|
375
415
|
}();
|
|
376
416
|
|
|
377
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/node/terminal.js"],"sourcesContent":["\"use strict\";\n\nimport TerminalNodeParseTree from \"../parseTree/terminalNode\";\n\nexport default class TerminalNode {\n  constructor(parentNode, significantToken) {\n    this.parentNode = parentNode;\n    this.significantToken = significantToken;\n  }\n\n  getParentNode() {\n    return this.parentNode;\n  }\n\n  getSignificantToken() {\n    return this.significantToken;\n  }\n\n  setParentNode(parentNode) {\n    this.parentNode = parentNode;\n  }\n\n  setSignificantToken(significantToken) {\n    this.significantToken = significantToken;\n  }\n\n  isStartOfContentNode() {\n    const startOfContentNode = false;\n\n    return startOfContentNode;\n  }\n\n  isNoWhitespaceNode() {\n    const noWhitespaceNode = false;\n\n    return noWhitespaceNode;\n  }\n\n  isEpsilonNode() {\n    const epsilonNode = false;\n\n    return epsilonNode;\n  }\n\n  isTerminalNode() {\n    const terminalNode = true;\n    \n    return terminalNode;\n  }\n\n  isNonTerminalNode() {\n    const nonTerminalNode = false;\n\n    return nonTerminalNode;\n  }\n\n  getType() { return this.significantToken.getType(); }\n\n  getContent() { return this.significantToken.getContent(); }\n\n  getPrecedence()  {\n    const precedence = null;\n\n    return precedence;\n  }\n\n  isLowerPrecedence(parentRuleName, parentPrecedence) {\n    const lowerPrecedence = false;\n\n    return lowerPrecedence;\n  }\n\n  getFirstSignificantTokenIndex(tokens) {\n    const significantTokenIndex = this.getSignificantTokenIndex(tokens),\n          firstSignificantTokenIndex = significantTokenIndex; ///\n\n    return firstSignificantTokenIndex;\n  }\n\n  getLastSignificantTokenIndex(tokens) {\n    const significantTokenIndex = this.getSignificantTokenIndex(tokens),\n          lastSignificantTokenIndex = significantTokenIndex; ///\n\n    return lastSignificantTokenIndex;\n  }\n\n  getSignificantTokenIndex(tokens) {\n    let significantTokenIndex = null;\n\n    if (this.significantToken !== null) {\n      significantTokenIndex = tokens.indexOf(this.significantToken);\n    }\n\n    return significantTokenIndex;\n  }\n\n  getSignificantTokens(significantTokens = []) {\n    if (this.significantToken !== null) {\n      significantTokens.push(this.significantToken);\n    }\n\n    return significantTokens;\n  }\n\n  getAncestorNodes() {\n    const ancestorNodes = [];\n\n    let ancestorNode = this.parentNode; ///\n\n    while (ancestorNode !== null) {\n      ancestorNodes.push(ancestorNode);\n\n      const parentNode = ancestorNode.getParentNode();\n\n      ancestorNode = parentNode;  ///\n    }\n\n    return ancestorNodes;\n  }\n\n  mapAncestorNode(callback) {\n    const ancestorNodes = this.getAncestorNodes();\n\n    return ancestorNodes.map(callback);\n  }\n\n  someAncestorNode(callback) {\n    let result = false;\n\n    let index = 0,\n        ancestorNode = this.parentNode; ///\n\n    while (ancestorNode !== null) {\n      result = callback(ancestorNode, index);\n\n      if (result) {\n        break;\n      }\n\n      const parentNode = ancestorNode.getParentNode();\n\n      ancestorNode = parentNode;  ///\n\n      index++;\n    }\n\n    return result;\n  }\n\n  findAncestorNode(callback) {\n    let index = 0,\n        ancestorNode = this.parentNode; ///\n\n    while (ancestorNode !== null) {\n      const result = callback(ancestorNode, index);\n\n      if (result) {\n        return ancestorNode;\n      }\n\n      const parentNode = ancestorNode.getParentNode();\n\n      ancestorNode = parentNode;  ///\n\n      index++;\n    }\n  }\n\n  everyAncestorNode(callback) {\n    const ancestorNodes = this.getAncestorNodes();\n\n    return ancestorNodes.every(callback);\n  }\n\n  filterAncestorNode(callback) {\n    const ancestorNodes = this.getAncestorNodes();\n\n    return ancestorNodes.filter(callback);\n  }\n\n  reduceAncestorNode(callback, initialValue) {\n    const ancestorNodes = this.getAncestorNodes();\n\n    return ancestorNodes.reduce(callback, initialValue);\n  }\n\n  forEachAncestorNode(callback) {\n    const ancestorNodes = this.getAncestorNodes();\n\n    ancestorNodes.forEach(callback);\n  }\n\n  asParseTree(tokens) {\n    const terminalNode = this,  ///\n          terminalNodeParseTree = TerminalNodeParseTree.fromTerminalNodeAndTokens(terminalNode, tokens),\n          parseTree = terminalNodeParseTree;  ///\n\n    return parseTree;\n  }\n\n  match(node, depth = Infinity, exactly = false) {\n    let matches = false;\n\n    const nodeTerminalNode = node.isTerminalNode();\n\n    if (nodeTerminalNode) {\n      const terminalNode = node,  ///\n            significantToken = terminalNode.getSignificantToken();\n\n      matches = exactly ?\n                  (this.significantToken === significantToken) :\n                     this.significantToken.match(significantToken);\n    }\n\n    return matches;\n  }\n\n  clone(...remainingArguments) {\n    const Class = this.constructor,\n          parentNode = null,\n          significantToken = this.significantToken,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n\n    return terminalNode;\n  }\n\n  destroy() {\n    this.parentNode = null;\n    this.significantToken = null;\n  }\n\n  static fromNothing(Class, ...remainingArguments) {\n    if (Class === undefined) {\n      Class = TerminalNode; ///\n    }\n\n    const parentNode = null,\n          significantToken = null,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n\n    return terminalNode;\n  }\n\n  static fromSignificantToken(Class, significantToken, ...remainingArguments) {\n    if (significantToken === undefined) {\n      significantToken = Class; ///\n\n      Class = TerminalNode; ///\n    }\n\n    const parentNode = null,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n    \n    return terminalNode;\n  }\n}\n"],"names":["TerminalNode","parentNode","significantToken","getParentNode","getSignificantToken","setParentNode","setSignificantToken","isStartOfContentNode","startOfContentNode","isNoWhitespaceNode","noWhitespaceNode","isEpsilonNode","epsilonNode","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","getType","getContent","getPrecedence","precedence","isLowerPrecedence","parentRuleName","parentPrecedence","lowerPrecedence","getFirstSignificantTokenIndex","tokens","significantTokenIndex","getSignificantTokenIndex","firstSignificantTokenIndex","getLastSignificantTokenIndex","lastSignificantTokenIndex","indexOf","getSignificantTokens","significantTokens","push","getAncestorNodes","ancestorNodes","ancestorNode","mapAncestorNode","callback","map","someAncestorNode","result","index","findAncestorNode","everyAncestorNode","every","filterAncestorNode","filter","reduceAncestorNode","initialValue","reduce","forEachAncestorNode","forEach","asParseTree","terminalNodeParseTree","TerminalNodeParseTree","fromTerminalNodeAndTokens","parseTree","match","node","depth","Infinity","exactly","matches","nodeTerminalNode","clone","remainingArguments","Class","constructor","destroy","fromNothing","undefined","fromSignificantToken"],"mappings":"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"}
|
|
417
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/node/terminal.js"],"sourcesContent":["\"use strict\";\n\nimport TerminalNodeParseTree from \"../parseTree/terminalNode\";\n\nexport default class TerminalNode {\n  constructor(parentNode, significantToken) {\n    this.parentNode = parentNode;\n    this.significantToken = significantToken;\n  }\n\n  getParentNode() {\n    return this.parentNode;\n  }\n\n  getSignificantToken() {\n    return this.significantToken;\n  }\n\n  setParentNode(parentNode) {\n    this.parentNode = parentNode;\n  }\n\n  setSignificantToken(significantToken) {\n    this.significantToken = significantToken;\n  }\n\n  isStartOfContentNode() {\n    const startOfContentNode = false;\n\n    return startOfContentNode;\n  }\n\n  isNoWhitespaceNode() {\n    const noWhitespaceNode = false;\n\n    return noWhitespaceNode;\n  }\n\n  isEpsilonNode() {\n    const epsilonNode = false;\n\n    return epsilonNode;\n  }\n\n  isTerminalNode() {\n    const terminalNode = true;\n    \n    return terminalNode;\n  }\n\n  isNonTerminalNode() {\n    const nonTerminalNode = false;\n\n    return nonTerminalNode;\n  }\n\n  getType() { return this.significantToken.getType(); }\n\n  getContent() { return this.significantToken.getContent(); }\n\n  getPrecedence()  {\n    const precedence = null;\n\n    return precedence;\n  }\n\n  isLowerPrecedence(parentRuleName, parentPrecedence) {\n    const lowerPrecedence = false;\n\n    return lowerPrecedence;\n  }\n\n  getFirstSignificantTokenIndex(tokens) {\n    const significantTokenIndex = this.getSignificantTokenIndex(tokens),\n          firstSignificantTokenIndex = significantTokenIndex; ///\n\n    return firstSignificantTokenIndex;\n  }\n\n  getLastSignificantTokenIndex(tokens) {\n    const significantTokenIndex = this.getSignificantTokenIndex(tokens),\n          lastSignificantTokenIndex = significantTokenIndex; ///\n\n    return lastSignificantTokenIndex;\n  }\n\n  getSignificantTokenIndex(tokens) {\n    let significantTokenIndex = null;\n\n    if (this.significantToken !== null) {\n      significantTokenIndex = tokens.indexOf(this.significantToken);\n    }\n\n    return significantTokenIndex;\n  }\n\n  getSignificantTokens(significantTokens = []) {\n    if (this.significantToken !== null) {\n      significantTokens.push(this.significantToken);\n    }\n\n    return significantTokens;\n  }\n\n  getAncestorNodes() {\n    const ancestorNodes = [];\n\n    let ancestorNode = this.parentNode; ///\n\n    while (ancestorNode !== null) {\n      ancestorNodes.push(ancestorNode);\n\n      const parentNode = ancestorNode.getParentNode();\n\n      ancestorNode = parentNode;  ///\n    }\n\n    return ancestorNodes;\n  }\n\n  mapAncestorNode(callback) {\n    const ancestorNodes = this.getAncestorNodes();\n\n    return ancestorNodes.map(callback);\n  }\n\n  someAncestorNode(callback) {\n    let result = false;\n\n    let index = 0,\n        ancestorNode = this.parentNode; ///\n\n    while (ancestorNode !== null) {\n      result = callback(ancestorNode, index);\n\n      if (result) {\n        break;\n      }\n\n      const parentNode = ancestorNode.getParentNode();\n\n      ancestorNode = parentNode;  ///\n\n      index++;\n    }\n\n    return result;\n  }\n\n  findAncestorNode(callback) {\n    let index = 0,\n        ancestorNode = this.parentNode; ///\n\n    while (ancestorNode !== null) {\n      const result = callback(ancestorNode, index);\n\n      if (result) {\n        return ancestorNode;\n      }\n\n      const parentNode = ancestorNode.getParentNode();\n\n      ancestorNode = parentNode;  ///\n\n      index++;\n    }\n\n    ancestorNode = undefined;\n\n    return ancestorNode;\n  }\n\n  everyAncestorNode(callback) {\n    let result = true;\n\n    let index = 0,\n        ancestorNode = this.parentNode; ///\n\n    while (ancestorNode !== null) {\n      result = callback(ancestorNode, index);\n\n      if (!result) {\n        break;\n      }\n\n      const parentNode = ancestorNode.getParentNode();\n\n      ancestorNode = parentNode;  ///\n\n      index++;\n    }\n\n    return result;\n  }\n\n  filterAncestorNode(callback) {\n    const ancestorNodes = this.getAncestorNodes();\n\n    return ancestorNodes.filter(callback);\n  }\n\n  reduceAncestorNode(callback, initialValue) {\n    const ancestorNodes = this.getAncestorNodes();\n\n    return ancestorNodes.reduce(callback, initialValue);\n  }\n\n  forEachAncestorNode(callback) {\n    const ancestorNodes = this.getAncestorNodes();\n\n    ancestorNodes.forEach(callback);\n  }\n\n  getDescendantNodes(descendantNodes = []) {\n    return descendantNodes;\n  }\n\n  someDescendantNode(callback) {\n    const result = false;\n\n    return result;\n  }\n\n  findDescendantNode(callback) {\n    let descendantNode = undefined;\n\n    return descendantNode;\n  }\n\n  everyDescendantNode(callback) {\n    let result = true;\n\n    return result;\n  }\n\n  asParseTree(tokens) {\n    const terminalNode = this,  ///\n          terminalNodeParseTree = TerminalNodeParseTree.fromTerminalNodeAndTokens(terminalNode, tokens),\n          parseTree = terminalNodeParseTree;  ///\n\n    return parseTree;\n  }\n\n  match(node, depth = Infinity, exactly = false) {\n    let matches = false;\n\n    const nodeTerminalNode = node.isTerminalNode();\n\n    if (nodeTerminalNode) {\n      const terminalNode = node,  ///\n            significantToken = terminalNode.getSignificantToken();\n\n      matches = exactly ?\n                  (this.significantToken === significantToken) :\n                     this.significantToken.match(significantToken);\n    }\n\n    return matches;\n  }\n\n  clone(...remainingArguments) {\n    const Class = this.constructor,\n          parentNode = null,\n          significantToken = this.significantToken,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n\n    return terminalNode;\n  }\n\n  destroy() {\n    this.parentNode = null;\n    this.significantToken = null;\n  }\n\n  static fromNothing(Class, ...remainingArguments) {\n    if (Class === undefined) {\n      Class = TerminalNode; ///\n    }\n\n    const parentNode = null,\n          significantToken = null,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n\n    return terminalNode;\n  }\n\n  static fromSignificantToken(Class, significantToken, ...remainingArguments) {\n    if (significantToken === undefined) {\n      significantToken = Class; ///\n\n      Class = TerminalNode; ///\n    }\n\n    const parentNode = null,\n          terminalNode = new Class(parentNode, significantToken, ...remainingArguments);\n    \n    return terminalNode;\n  }\n}\n"],"names":["TerminalNode","parentNode","significantToken","getParentNode","getSignificantToken","setParentNode","setSignificantToken","isStartOfContentNode","startOfContentNode","isNoWhitespaceNode","noWhitespaceNode","isEpsilonNode","epsilonNode","isTerminalNode","terminalNode","isNonTerminalNode","nonTerminalNode","getType","getContent","getPrecedence","precedence","isLowerPrecedence","parentRuleName","parentPrecedence","lowerPrecedence","getFirstSignificantTokenIndex","tokens","significantTokenIndex","getSignificantTokenIndex","firstSignificantTokenIndex","getLastSignificantTokenIndex","lastSignificantTokenIndex","indexOf","getSignificantTokens","significantTokens","push","getAncestorNodes","ancestorNodes","ancestorNode","mapAncestorNode","callback","map","someAncestorNode","result","index","findAncestorNode","undefined","everyAncestorNode","filterAncestorNode","filter","reduceAncestorNode","initialValue","reduce","forEachAncestorNode","forEach","getDescendantNodes","descendantNodes","someDescendantNode","findDescendantNode","descendantNode","everyDescendantNode","asParseTree","terminalNodeParseTree","TerminalNodeParseTree","fromTerminalNodeAndTokens","parseTree","match","node","depth","Infinity","exactly","matches","nodeTerminalNode","clone","remainingArguments","Class","constructor","destroy","fromNothing","fromSignificantToken"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "occam-parsers",
|
|
3
3
|
"author": "James Smith",
|
|
4
|
-
"version": "23.0.
|
|
4
|
+
"version": "23.0.138",
|
|
5
5
|
"license": "MIT, Anti-996",
|
|
6
6
|
"homepage": "https://github.com/djalbat/occam-parsers",
|
|
7
7
|
"description": "Occam's parsers.",
|
|
@@ -16,8 +16,8 @@
|
|
|
16
16
|
"devDependencies": {
|
|
17
17
|
"@swc/core": "^1.5.6",
|
|
18
18
|
"easy": "^23.0.1",
|
|
19
|
-
"easy-layout": "^6.0.
|
|
20
|
-
"easy-with-style": "^3.0.
|
|
19
|
+
"easy-layout": "^6.0.242",
|
|
20
|
+
"easy-with-style": "^3.0.488",
|
|
21
21
|
"esbuild": "^0.9.6",
|
|
22
22
|
"express": "^4.17.1",
|
|
23
23
|
"juxtapose": "^4.0.117",
|