necessary 14.0.7 → 14.1.0

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/README.md CHANGED
@@ -692,7 +692,7 @@ pathWithoutTopmostDirectoryNameFromPath("root/etc/init.conf"); // returns 'etc/i
692
692
  - `sixth()`
693
693
  - `seventh()`
694
694
  - `eighth()`
695
- - `nineth()`
695
+ - `ninth()`
696
696
  - `firstLast()`
697
697
  - `secondLast()`
698
698
  - `thirdLast()`
@@ -701,7 +701,7 @@ pathWithoutTopmostDirectoryNameFromPath("root/etc/init.conf"); // returns 'etc/i
701
701
  - `sixthLast()`
702
702
  - `seventhLast()`
703
703
  - `eighthLast()`
704
- - `ninethLast()`
704
+ - `ninthLast()`
705
705
  - `last()`
706
706
  - `head()`
707
707
  - `tail()`
@@ -714,6 +714,7 @@ pathWithoutTopmostDirectoryNameFromPath("root/etc/init.conf"); // returns 'etc/i
714
714
  - `copy()`
715
715
  - `merge()`
716
716
  - `match()`
717
+ - `correlate()`
717
718
  - `find()`
718
719
  - `replace()`
719
720
  - `splice()`
@@ -723,6 +724,7 @@ pathWithoutTopmostDirectoryNameFromPath("root/etc/init.conf"); // returns 'etc/i
723
724
  - `patch()`
724
725
  - `compress()`
725
726
  - `combine()`
727
+ - `reverse()`
726
728
  - `augment()`
727
729
  - `separate()`
728
730
  - `forwardsFind()`
@@ -776,6 +778,12 @@ merge([1, 2, 3], [4, 5, 6, 7]); // the first array argument becomes [1, 2, 3, 4,
776
778
  match([1, 2, 3], [-1, -2, -3], (valueA, valueB) => (valueA === -valueB)); // returns true
777
779
  ```
778
780
 
781
+ * The `correlate()` works similarly to the `match()` function, however it does not require the elements to be in order nor does it require the arrays to be of the same length. It is asymmetric in the sense that the second array argument can contain additional elements that are not matched. Elements can match once only, however.
782
+
783
+ ```
784
+ correlate([1, 2, 3], [-4, -2, -3, -1], (valueA, valueB) => (valueA === -valueB)); // returns true
785
+ ```
786
+
779
787
  * The `find()` function is like its native counterpart, however it returns an array of all the elements for which the callback function returns a truthy value, rather than just the first:
780
788
 
781
789
  ```
@@ -830,6 +838,12 @@ compress([1, 2, 1], (element1, element2) => (element1 === element2)); // the arr
830
838
  combine([1, 2, 1], [2, 3], (element1, element2) => (element1 === element2)); // returns [1, 2, 3]
831
839
  ```
832
840
 
841
+ * The `reverse()` function returns the array argument reversed, as opposed to its native counterpart which reverses an array in place
842
+
843
+ ```
844
+ reverse([1, 2, 3]); // returns [3, 2, 1]
845
+ ```
846
+
833
847
  * The `augment()` function appends each of the elements of the second array argument to the first array argument whenever the callback returns a truthy value:
834
848
 
835
849
  ```
@@ -45,6 +45,9 @@ _export(exports, {
45
45
  copy: function() {
46
46
  return copy;
47
47
  },
48
+ correlate: function() {
49
+ return correlate;
50
+ },
48
51
  default: function() {
49
52
  return _default;
50
53
  },
@@ -129,6 +132,9 @@ _export(exports, {
129
132
  replace: function() {
130
133
  return replace;
131
134
  },
135
+ reverse: function() {
136
+ return reverse;
137
+ },
132
138
  second: function() {
133
139
  return second;
134
140
  },
@@ -309,6 +315,21 @@ function match(arrayA, arrayB, callback) {
309
315
  }
310
316
  return matches;
311
317
  }
318
+ function correlate(arrayA, arrayB, callback) {
319
+ arrayB = _to_consumable_array(arrayB);
320
+ var correlates = arrayA.every(function(elementA) {
321
+ var elementB = extract(arrayB, function(elementB) {
322
+ var result = callback(elementA, elementB);
323
+ if (result) {
324
+ return true;
325
+ }
326
+ }) || null;
327
+ if (elementB !== null) {
328
+ return true;
329
+ }
330
+ });
331
+ return correlates;
332
+ }
312
333
  function find(array, callback) {
313
334
  var elements = [];
314
335
  forwardsForEach(array, function(element, index) {
@@ -409,6 +430,10 @@ function combine(arrayA, arrayB, callback) {
409
430
  compress(array, callback);
410
431
  return array;
411
432
  }
433
+ function reverse(array) {
434
+ array = _to_consumable_array(array).reverse();
435
+ return array;
436
+ }
412
437
  function augment(arrayA, arrayB, callback) {
413
438
  arrayB.forEach(function(element, index) {
414
439
  var passed = callback(element, index);
@@ -546,6 +571,7 @@ var _default = {
546
571
  copy: copy,
547
572
  merge: merge,
548
573
  match: match,
574
+ corrlate: corrlate,
549
575
  find: find,
550
576
  replace: replace,
551
577
  splice: splice,
@@ -555,6 +581,7 @@ var _default = {
555
581
  patch: patch,
556
582
  compress: compress,
557
583
  combine: combine,
584
+ reverse: reverse,
558
585
  augment: augment,
559
586
  separate: separate,
560
587
  forwardsFind: forwardsFind,
@@ -569,4 +596,4 @@ var _default = {
569
596
  backwardsForEach: backwardsForEach
570
597
  };
571
598
 
572
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/array.js"],"sourcesContent":["\"use strict\";\n\nexport function first(array) { return array[0];}\n\nexport function second(array) { return array[1]; }\n\nexport function third(array) { return array[2]; }\n\nexport function fourth(array) { return array[3]; }\n\nexport function fifth(array) { return array[4]; }\n\nexport function sixth(array) { return array[5]; }\n\nexport function seventh(array) { return array[6]; }\n\nexport function eighth(array) { return array[7]; }\n\nexport function ninth(array) { return array[8]; }\n\nexport function tenth(array) { return array[9]; }\n\nexport function firstLast(array) { return array[array.length - 1]; }\n\nexport function secondLast(array) { return array[array.length - 2]; }\n\nexport function thirdLast(array) { return array[array.length - 3]; }\n\nexport function fourthLast(array) { return array[array.length - 4]; }\n\nexport function fifthLast(array) { return array[array.length - 5]; }\n\nexport function sixthLast(array) { return array[array.length - 6]; }\n\nexport function seventhLast(array) { return array[array.length - 7]; }\n\nexport function eighthLast(array) { return array[array.length - 8]; }\n\nexport function ninthLast(array) { return array[array.length - 9]; }\n\nexport function last(array) { return array[array.length - 1]; }\n\nexport function head(array) { return array.slice(0, 1); }\n\nexport function tail(array) { return array.slice(1); }\n\nexport function back(array) { return array.slice(array.length - 1); }\n\nexport function front(array) { return array.slice(0, Math.max(1, array.length - 1)); }\n\nexport function push(arrayA, arrayB) { Array.prototype.push.apply(arrayA, arrayB); }\n\nexport function unshift(arrayA, arrayB) { Array.prototype.unshift.apply(arrayA, arrayB); }\n\nexport function concat(arrayA, elementOrArray2) {\n  const arrayB = (elementOrArray2 instanceof Array) ?\n                    elementOrArray2 :\n                     [ elementOrArray2 ];\n  \n  push(arrayA, arrayB);\n}\n\nexport function clear(array) {\n  const start = 0;\n  \n  return array.splice(start);\n}\n\nexport function copy(arrayA, arrayB) {\n  const start = 0,\n        deleteCount = arrayB.length;  ///\n  \n  splice(arrayA, start, deleteCount, arrayB);\n}\n\nexport function merge(arrayA, arrayB) { Array.prototype.push.apply(arrayA, arrayB); }\n\nexport function match(arrayA, arrayB, callback) {\n  let matches = false;\n\n  const arrayALength = arrayA.length,\n        arrayBLength = arrayB.length;\n\n  if (arrayALength === arrayBLength) {\n    matches = arrayA.every((elementA, index) => {\n      const elementB = arrayB[index],\n            passed = callback(elementA, elementB, index);\n\n      if (passed) {\n        return true;\n      }\n    });\n  }\n\n  return matches;\n}\n\nexport function find(array, callback) {\n  const elements = [];\n\n  forwardsForEach(array, (element, index) => {\n    const passed = callback(element, index);\n\n    if (passed) {\n      elements.push(element);\n    }\n  });\n\n  return elements;\n}\n\nexport function replace(array, element, callback) {\n  let start;\n  \n  const found = array.some((element, index) => {\n    const passed = callback(element, index);\n\n    if (passed) {\n      start = index;  ///\n      \n      return true;\n    }\n  });\n  \n  if (found) {\n    const deleteCount = 1;\n\n    array.splice(start, deleteCount, element);\n  }\n\n  return found;\n}\n\nexport function splice(arrayA, start, deleteCount = Infinity, arrayB = []) {\n  const args = [ start, deleteCount, ...arrayB ],\n        deletedElements = Array.prototype.splice.apply(arrayA, args);\n\n  return deletedElements;\n}\n\nexport function filter(array, callback) {\n  const deletedElements = [];\n  \n  backwardsForEach(array, (element, index) => {\n    const passed = callback(element, index);\n\n    if (!passed) {\n      const start = index,  ///\n            deleteCount = 1,\n            deletedElements = array.splice(start, deleteCount),\n            firstDeletedElement = first(deletedElements);\n      \n      deletedElements.unshift(firstDeletedElement);  ///\n    }\n  });\n  \n  return deletedElements;\n}\n\nexport function prune(array, callback) {\n  let deletedElement = undefined;\n  \n  array.some((element, index) => {\n    const passed = callback(element, index);\n\n    if (!passed) {\n      const start = index,  ///\n            deleteCount = 1,\n            deletedElements = array.splice(start, deleteCount),\n            firstDeletedElement = first(deletedElements);\n      \n      deletedElement = firstDeletedElement;  ///\n\n      return true;\n    }\n  });\n  \n  return deletedElement;\n}\n\nexport function extract(array, callback) {\n  let deletedElement = undefined;\n\n  array.some((element, index) => {\n    const passed = callback(element, index);\n\n    if (passed) {\n      const start = index,  ///\n            deleteCount = 1,\n            deletedElements = array.splice(start, deleteCount),\n            firstDeletedElement = first(deletedElements);\n\n      deletedElement = firstDeletedElement;  ///\n\n      return true;\n    }\n  });\n\n  return deletedElement;\n}\n\nexport function patch(array, element, callback) {\n  const found = array.some((element, index) => {\n    const passed = callback(element, index);\n\n    if (passed) {\n      return true;\n    }\n  });\n\n\n  if (found) {\n    array.push(element);\n  }\n\n  return found;\n}\n\nexport function compress(array, callback) {\n  let index1 = 0,\n      length = array.length;\n\n  while (index1 < length) {\n    const elementB = array[index1];\n\n    for (let index2 = length - 1; index2 > index1; index2--) {\n      const elementA = array[index2],\n            passed = callback(elementA, elementB);\n\n      if (passed) {\n        const start = index2, ///\n              deleteCount = 1;\n\n        array.splice(start, deleteCount);\n      }\n    }\n\n    index1++;\n\n    length = array.length;\n  }\n}\n\nexport function combine(arrayA, arrayB, callback) {\n  const array = [\n    ...arrayA,\n    ...arrayB\n  ];\n\n  compress(array, callback);\n\n  return array;\n}\n\nexport function augment(arrayA, arrayB, callback) {\n  arrayB.forEach((element, index) => {\n    const passed = callback(element, index);\n\n    if (passed) {\n      arrayA.push(element);\n    }\n  });\n}\n\nexport function separate(array, arrayA, arrayB, callback) {\n  array.forEach((element, index) => {\n    const passed = callback(element, index);\n\n    passed ?\n      arrayA.push(element) :\n        arrayB.push(element);\n  });\n}\n\nexport function forwardsFind(array, callback) {\n  const arrayLength = array.length;\n\n  for (let index = 0; index < arrayLength; index++) {\n    const element = array[index],\n          passed = callback(element, index);\n\n    if (passed) {\n      return element;\n    }\n  }\n\n  return false;\n}\n\nexport function backwardsFind(array, callback) {\n  const arrayLength = array.length;\n\n  for (let index = arrayLength - 1; index >= 0; index--) {\n    const element = array[index],\n          passed = callback(element, index);\n\n    if (passed) {\n      return element;\n    }\n  }\n\n  return false;\n}\n\nexport function forwardsSome(array, callback) {\n  const arrayLength = array.length;\n\n  for (let index = 0; index < arrayLength; index++) {\n    const element = array[index],\n          passed = callback(element, index);\n    \n    if (passed) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\nexport function backwardsSome(array, callback) {\n  const arrayLength = array.length;\n\n  for (let index = arrayLength - 1; index >= 0; index--) {\n    const element = array[index],\n          passed = callback(element, index);\n\n    if (passed) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\nexport function forwardsEvery(array, callback) {\n  const arrayLength = array.length;\n\n  for (let index = 0; index < arrayLength; index++) {\n    const element = array[index],\n          passed = callback(element, index);\n\n    if (!passed) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nexport function backwardsEvery(array, callback) {\n  const arrayLength = array.length;\n\n  for (let index = arrayLength - 1; index >= 0; index--) {\n    const element = array[index],\n          passed = callback(element, index);\n\n    if (!passed) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nexport function forwardsReduce(array, callback, initialValue) {\n  let value = initialValue; ///\n\n  const arrayLength = array.length;\n\n  for (let index = 0; index < arrayLength; index++) {\n    const element = array[index];\n\n    value = callback(value, element, index);\n  }\n\n  return value;\n}\n\nexport function backwardsReduce(array, callback, initialValue) {\n  let value = initialValue; ///\n\n  const arrayLength = array.length;\n\n  for (let index = arrayLength - 1; index >= 0; index--) {\n    const element = array[index];\n\n    value = callback(value, element, index);\n  }\n\n  return value;\n}\n\nexport function forwardsForEach(array, callback) {\n  const arrayLength = array.length;\n\n  for (let index = 0; index < arrayLength; index++) {\n    const element = array[index];\n\n    callback(element, index);\n  }\n}\n\nexport function backwardsForEach(array, callback) {\n  const arrayLength = array.length;\n\n  for (let index = arrayLength - 1; index >= 0; index--) {\n    const element = array[index];\n\n    callback(element, index);\n  }\n}\n\nexport default {\n  first,\n  second,\n  third,\n  fourth,\n  fifth,\n  sixth,\n  seventh,\n  eighth,\n  ninth,\n  firstLast,\n  secondLast,\n  thirdLast,\n  fourthLast,\n  fifthLast,\n  sixthLast,\n  seventhLast,\n  eighthLast,\n  ninthLast,\n  last,\n  head,\n  tail,\n  back,\n  front,\n  push,\n  unshift,\n  concat,\n  clear,\n  copy,\n  merge,\n  match,\n  find,\n  replace,\n  splice,\n  filter,\n  prune,\n  extract,\n  patch,\n  compress,\n  combine,\n  augment,\n  separate,\n  forwardsFind,\n  backwardsFind,\n  forwardsSome,\n  backwardsSome,\n  forwardsEvery,\n  backwardsEvery,\n  forwardsReduce,\n  backwardsReduce,\n  forwardsForEach,\n  backwardsForEach\n};\n"],"names":["augment","back","backwardsEvery","backwardsFind","backwardsForEach","backwardsReduce","backwardsSome","clear","combine","compress","concat","copy","eighth","eighthLast","extract","fifth","fifthLast","filter","find","first","firstLast","forwardsEvery","forwardsFind","forwardsForEach","forwardsReduce","forwardsSome","fourth","fourthLast","front","head","last","match","merge","ninth","ninthLast","patch","prune","push","replace","second","secondLast","separate","seventh","seventhLast","sixth","sixthLast","splice","tail","tenth","third","thirdLast","unshift","array","length","slice","Math","max","arrayA","arrayB","Array","prototype","apply","elementOrArray2","start","deleteCount","callback","matches","arrayALength","arrayBLength","every","elementA","index","elementB","passed","elements","element","found","some","Infinity","args","deletedElements","firstDeletedElement","deletedElement","undefined","index1","index2","forEach","arrayLength","initialValue","value"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
599
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/array.js"],"sourcesContent":["\"use strict\";\n\nexport function first(array) { return array[0];}\n\nexport function second(array) { return array[1]; }\n\nexport function third(array) { return array[2]; }\n\nexport function fourth(array) { return array[3]; }\n\nexport function fifth(array) { return array[4]; }\n\nexport function sixth(array) { return array[5]; }\n\nexport function seventh(array) { return array[6]; }\n\nexport function eighth(array) { return array[7]; }\n\nexport function ninth(array) { return array[8]; }\n\nexport function tenth(array) { return array[9]; }\n\nexport function firstLast(array) { return array[array.length - 1]; }\n\nexport function secondLast(array) { return array[array.length - 2]; }\n\nexport function thirdLast(array) { return array[array.length - 3]; }\n\nexport function fourthLast(array) { return array[array.length - 4]; }\n\nexport function fifthLast(array) { return array[array.length - 5]; }\n\nexport function sixthLast(array) { return array[array.length - 6]; }\n\nexport function seventhLast(array) { return array[array.length - 7]; }\n\nexport function eighthLast(array) { return array[array.length - 8]; }\n\nexport function ninthLast(array) { return array[array.length - 9]; }\n\nexport function last(array) { return array[array.length - 1]; }\n\nexport function head(array) { return array.slice(0, 1); }\n\nexport function tail(array) { return array.slice(1); }\n\nexport function back(array) { return array.slice(array.length - 1); }\n\nexport function front(array) { return array.slice(0, Math.max(1, array.length - 1)); }\n\nexport function push(arrayA, arrayB) { Array.prototype.push.apply(arrayA, arrayB); }\n\nexport function unshift(arrayA, arrayB) { Array.prototype.unshift.apply(arrayA, arrayB); }\n\nexport function concat(arrayA, elementOrArray2) {\n  const arrayB = (elementOrArray2 instanceof Array) ?\n                    elementOrArray2 :\n                     [ elementOrArray2 ];\n  \n  push(arrayA, arrayB);\n}\n\nexport function clear(array) {\n  const start = 0;\n  \n  return array.splice(start);\n}\n\nexport function copy(arrayA, arrayB) {\n  const start = 0,\n        deleteCount = arrayB.length;  ///\n  \n  splice(arrayA, start, deleteCount, arrayB);\n}\n\nexport function merge(arrayA, arrayB) { Array.prototype.push.apply(arrayA, arrayB); }\n\nexport function match(arrayA, arrayB, callback) {\n  let matches = false;\n\n  const arrayALength = arrayA.length,\n        arrayBLength = arrayB.length;\n\n  if (arrayALength === arrayBLength) {\n    matches = arrayA.every((elementA, index) => {\n      const elementB = arrayB[index],\n            passed = callback(elementA, elementB, index);\n\n      if (passed) {\n        return true;\n      }\n    });\n  }\n\n  return matches;\n}\n\nexport function correlate(arrayA, arrayB, callback) {\n  arrayB = [  ///\n    ...arrayB\n  ];\n\n  const correlates = arrayA.every((elementA) => {\n    const elementB = extract(arrayB, (elementB) => {\n      const result = callback(elementA, elementB);\n\n      if (result) {\n        return true;\n      }\n    }) || null;\n\n    if (elementB !== null) {\n      return true;\n    }\n  });\n\n  return correlates;\n}\n\nexport function find(array, callback) {\n  const elements = [];\n\n  forwardsForEach(array, (element, index) => {\n    const passed = callback(element, index);\n\n    if (passed) {\n      elements.push(element);\n    }\n  });\n\n  return elements;\n}\n\nexport function replace(array, element, callback) {\n  let start;\n  \n  const found = array.some((element, index) => {\n    const passed = callback(element, index);\n\n    if (passed) {\n      start = index;  ///\n      \n      return true;\n    }\n  });\n  \n  if (found) {\n    const deleteCount = 1;\n\n    array.splice(start, deleteCount, element);\n  }\n\n  return found;\n}\n\nexport function splice(arrayA, start, deleteCount = Infinity, arrayB = []) {\n  const args = [ start, deleteCount, ...arrayB ],\n        deletedElements = Array.prototype.splice.apply(arrayA, args);\n\n  return deletedElements;\n}\n\nexport function filter(array, callback) {\n  const deletedElements = [];\n  \n  backwardsForEach(array, (element, index) => {\n    const passed = callback(element, index);\n\n    if (!passed) {\n      const start = index,  ///\n            deleteCount = 1,\n            deletedElements = array.splice(start, deleteCount),\n            firstDeletedElement = first(deletedElements);\n      \n      deletedElements.unshift(firstDeletedElement);  ///\n    }\n  });\n  \n  return deletedElements;\n}\n\nexport function prune(array, callback) {\n  let deletedElement = undefined;\n  \n  array.some((element, index) => {\n    const passed = callback(element, index);\n\n    if (!passed) {\n      const start = index,  ///\n            deleteCount = 1,\n            deletedElements = array.splice(start, deleteCount),\n            firstDeletedElement = first(deletedElements);\n      \n      deletedElement = firstDeletedElement;  ///\n\n      return true;\n    }\n  });\n  \n  return deletedElement;\n}\n\nexport function extract(array, callback) {\n  let deletedElement = undefined;\n\n  array.some((element, index) => {\n    const passed = callback(element, index);\n\n    if (passed) {\n      const start = index,  ///\n            deleteCount = 1,\n            deletedElements = array.splice(start, deleteCount),\n            firstDeletedElement = first(deletedElements);\n\n      deletedElement = firstDeletedElement;  ///\n\n      return true;\n    }\n  });\n\n  return deletedElement;\n}\n\nexport function patch(array, element, callback) {\n  const found = array.some((element, index) => {\n    const passed = callback(element, index);\n\n    if (passed) {\n      return true;\n    }\n  });\n\n\n  if (found) {\n    array.push(element);\n  }\n\n  return found;\n}\n\nexport function compress(array, callback) {\n  let index1 = 0,\n      length = array.length;\n\n  while (index1 < length) {\n    const elementB = array[index1];\n\n    for (let index2 = length - 1; index2 > index1; index2--) {\n      const elementA = array[index2],\n            passed = callback(elementA, elementB);\n\n      if (passed) {\n        const start = index2, ///\n              deleteCount = 1;\n\n        array.splice(start, deleteCount);\n      }\n    }\n\n    index1++;\n\n    length = array.length;\n  }\n}\n\nexport function combine(arrayA, arrayB, callback) {\n  const array = [\n    ...arrayA,\n    ...arrayB\n  ];\n\n  compress(array, callback);\n\n  return array;\n}\n\nexport function reverse(array) {\n  array = [ ///\n    ...array\n  ].reverse();\n\n  return array;\n}\n\nexport function augment(arrayA, arrayB, callback) {\n  arrayB.forEach((element, index) => {\n    const passed = callback(element, index);\n\n    if (passed) {\n      arrayA.push(element);\n    }\n  });\n}\n\nexport function separate(array, arrayA, arrayB, callback) {\n  array.forEach((element, index) => {\n    const passed = callback(element, index);\n\n    passed ?\n      arrayA.push(element) :\n        arrayB.push(element);\n  });\n}\n\nexport function forwardsFind(array, callback) {\n  const arrayLength = array.length;\n\n  for (let index = 0; index < arrayLength; index++) {\n    const element = array[index],\n          passed = callback(element, index);\n\n    if (passed) {\n      return element;\n    }\n  }\n\n  return false;\n}\n\nexport function backwardsFind(array, callback) {\n  const arrayLength = array.length;\n\n  for (let index = arrayLength - 1; index >= 0; index--) {\n    const element = array[index],\n          passed = callback(element, index);\n\n    if (passed) {\n      return element;\n    }\n  }\n\n  return false;\n}\n\nexport function forwardsSome(array, callback) {\n  const arrayLength = array.length;\n\n  for (let index = 0; index < arrayLength; index++) {\n    const element = array[index],\n          passed = callback(element, index);\n    \n    if (passed) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\nexport function backwardsSome(array, callback) {\n  const arrayLength = array.length;\n\n  for (let index = arrayLength - 1; index >= 0; index--) {\n    const element = array[index],\n          passed = callback(element, index);\n\n    if (passed) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\nexport function forwardsEvery(array, callback) {\n  const arrayLength = array.length;\n\n  for (let index = 0; index < arrayLength; index++) {\n    const element = array[index],\n          passed = callback(element, index);\n\n    if (!passed) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nexport function backwardsEvery(array, callback) {\n  const arrayLength = array.length;\n\n  for (let index = arrayLength - 1; index >= 0; index--) {\n    const element = array[index],\n          passed = callback(element, index);\n\n    if (!passed) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nexport function forwardsReduce(array, callback, initialValue) {\n  let value = initialValue; ///\n\n  const arrayLength = array.length;\n\n  for (let index = 0; index < arrayLength; index++) {\n    const element = array[index];\n\n    value = callback(value, element, index);\n  }\n\n  return value;\n}\n\nexport function backwardsReduce(array, callback, initialValue) {\n  let value = initialValue; ///\n\n  const arrayLength = array.length;\n\n  for (let index = arrayLength - 1; index >= 0; index--) {\n    const element = array[index];\n\n    value = callback(value, element, index);\n  }\n\n  return value;\n}\n\nexport function forwardsForEach(array, callback) {\n  const arrayLength = array.length;\n\n  for (let index = 0; index < arrayLength; index++) {\n    const element = array[index];\n\n    callback(element, index);\n  }\n}\n\nexport function backwardsForEach(array, callback) {\n  const arrayLength = array.length;\n\n  for (let index = arrayLength - 1; index >= 0; index--) {\n    const element = array[index];\n\n    callback(element, index);\n  }\n}\n\nexport default {\n  first,\n  second,\n  third,\n  fourth,\n  fifth,\n  sixth,\n  seventh,\n  eighth,\n  ninth,\n  firstLast,\n  secondLast,\n  thirdLast,\n  fourthLast,\n  fifthLast,\n  sixthLast,\n  seventhLast,\n  eighthLast,\n  ninthLast,\n  last,\n  head,\n  tail,\n  back,\n  front,\n  push,\n  unshift,\n  concat,\n  clear,\n  copy,\n  merge,\n  match,\n  corrlate,\n  find,\n  replace,\n  splice,\n  filter,\n  prune,\n  extract,\n  patch,\n  compress,\n  combine,\n  reverse,\n  augment,\n  separate,\n  forwardsFind,\n  backwardsFind,\n  forwardsSome,\n  backwardsSome,\n  forwardsEvery,\n  backwardsEvery,\n  forwardsReduce,\n  backwardsReduce,\n  forwardsForEach,\n  backwardsForEach\n};\n"],"names":["augment","back","backwardsEvery","backwardsFind","backwardsForEach","backwardsReduce","backwardsSome","clear","combine","compress","concat","copy","correlate","eighth","eighthLast","extract","fifth","fifthLast","filter","find","first","firstLast","forwardsEvery","forwardsFind","forwardsForEach","forwardsReduce","forwardsSome","fourth","fourthLast","front","head","last","match","merge","ninth","ninthLast","patch","prune","push","replace","reverse","second","secondLast","separate","seventh","seventhLast","sixth","sixthLast","splice","tail","tenth","third","thirdLast","unshift","array","length","slice","Math","max","arrayA","arrayB","Array","prototype","apply","elementOrArray2","start","deleteCount","callback","matches","arrayALength","arrayBLength","every","elementA","index","elementB","passed","correlates","result","elements","element","found","some","Infinity","args","deletedElements","firstDeletedElement","deletedElement","undefined","index1","index2","forEach","arrayLength","initialValue","value","corrlate"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA;;;;;;;;;;;IA4RgBA,OAAO;eAAPA;;IA9OAC,IAAI;eAAJA;;IA6UAC,cAAc;eAAdA;;IA5DAC,aAAa;eAAbA;;IAiHAC,gBAAgB;eAAhBA;;IAxBAC,eAAe;eAAfA;;IA3DAC,aAAa;eAAbA;;IA/RAC,KAAK;eAALA;;IA2MAC,OAAO;eAAPA;;IAzBAC,QAAQ;eAARA;;IA1LAC,MAAM;eAANA;;IAcAC,IAAI;eAAJA;;IA6BAC,SAAS;eAATA;;IAyVhB,OAsDE;eAtDF;;IA1agBC,MAAM;eAANA;;IAoBAC,UAAU;eAAVA;;IAsKAC,OAAO;eAAPA;;IAhMAC,KAAK;eAALA;;IAoBAC,SAAS;eAATA;;IAoIAC,MAAM;eAANA;;IA3CAC,IAAI;eAAJA;;IArHAC,KAAK;eAALA;;IAoBAC,SAAS;eAATA;;IAsVAC,aAAa;eAAbA;;IA5DAC,YAAY;eAAZA;;IAsHAC,eAAe;eAAfA;;IA5BAC,cAAc;eAAdA;;IA5DAC,YAAY;eAAZA;;IAtUAC,MAAM;eAANA;;IAoBAC,UAAU;eAAVA;;IAoBAC,KAAK;eAALA;;IANAC,IAAI;eAAJA;;IAFAC,IAAI;eAAJA;;IAqCAC,KAAK;eAALA;;IAFAC,KAAK;eAALA;;IAzDAC,KAAK;eAALA;;IAoBAC,SAAS;eAATA;;IAyLAC,KAAK;eAALA;;IA1CAC,KAAK;eAALA;;IAnIAC,IAAI;eAAJA;;IAmFAC,OAAO;eAAPA;;IA+IAC,OAAO;eAAPA;;IAhRAC,MAAM;eAANA;;IAoBAC,UAAU;eAAVA;;IA8QAC,QAAQ;eAARA;;IAxRAC,OAAO;eAAPA;;IAoBAC,WAAW;eAAXA;;IAtBAC,KAAK;eAALA;;IAoBAC,SAAS;eAATA;;IA2HAC,MAAM;eAANA;;IA/GAC,IAAI;eAAJA;;IAxBAC,KAAK;eAALA;;IAdAC,KAAK;eAALA;;IAoBAC,SAAS;eAATA;;IA0BAC,OAAO;eAAPA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAlDT,SAASjC,MAAMkC,KAAK;IAAI,OAAOA,KAAK,CAAC,EAAE;AAAC;AAExC,SAASb,OAAOa,KAAK;IAAI,OAAOA,KAAK,CAAC,EAAE;AAAE;AAE1C,SAASH,MAAMG,KAAK;IAAI,OAAOA,KAAK,CAAC,EAAE;AAAE;AAEzC,SAAS3B,OAAO2B,KAAK;IAAI,OAAOA,KAAK,CAAC,EAAE;AAAE;AAE1C,SAAStC,MAAMsC,KAAK;IAAI,OAAOA,KAAK,CAAC,EAAE;AAAE;AAEzC,SAASR,MAAMQ,KAAK;IAAI,OAAOA,KAAK,CAAC,EAAE;AAAE;AAEzC,SAASV,QAAQU,KAAK;IAAI,OAAOA,KAAK,CAAC,EAAE;AAAE;AAE3C,SAASzC,OAAOyC,KAAK;IAAI,OAAOA,KAAK,CAAC,EAAE;AAAE;AAE1C,SAASpB,MAAMoB,KAAK;IAAI,OAAOA,KAAK,CAAC,EAAE;AAAE;AAEzC,SAASJ,MAAMI,KAAK;IAAI,OAAOA,KAAK,CAAC,EAAE;AAAE;AAEzC,SAASjC,UAAUiC,KAAK;IAAI,OAAOA,KAAK,CAACA,MAAMC,MAAM,GAAG,EAAE;AAAE;AAE5D,SAASb,WAAWY,KAAK;IAAI,OAAOA,KAAK,CAACA,MAAMC,MAAM,GAAG,EAAE;AAAE;AAE7D,SAASH,UAAUE,KAAK;IAAI,OAAOA,KAAK,CAACA,MAAMC,MAAM,GAAG,EAAE;AAAE;AAE5D,SAAS3B,WAAW0B,KAAK;IAAI,OAAOA,KAAK,CAACA,MAAMC,MAAM,GAAG,EAAE;AAAE;AAE7D,SAAStC,UAAUqC,KAAK;IAAI,OAAOA,KAAK,CAACA,MAAMC,MAAM,GAAG,EAAE;AAAE;AAE5D,SAASR,UAAUO,KAAK;IAAI,OAAOA,KAAK,CAACA,MAAMC,MAAM,GAAG,EAAE;AAAE;AAE5D,SAASV,YAAYS,KAAK;IAAI,OAAOA,KAAK,CAACA,MAAMC,MAAM,GAAG,EAAE;AAAE;AAE9D,SAASzC,WAAWwC,KAAK;IAAI,OAAOA,KAAK,CAACA,MAAMC,MAAM,GAAG,EAAE;AAAE;AAE7D,SAASpB,UAAUmB,KAAK;IAAI,OAAOA,KAAK,CAACA,MAAMC,MAAM,GAAG,EAAE;AAAE;AAE5D,SAASxB,KAAKuB,KAAK;IAAI,OAAOA,KAAK,CAACA,MAAMC,MAAM,GAAG,EAAE;AAAE;AAEvD,SAASzB,KAAKwB,KAAK;IAAI,OAAOA,MAAME,KAAK,CAAC,GAAG;AAAI;AAEjD,SAASP,KAAKK,KAAK;IAAI,OAAOA,MAAME,KAAK,CAAC;AAAI;AAE9C,SAASvD,KAAKqD,KAAK;IAAI,OAAOA,MAAME,KAAK,CAACF,MAAMC,MAAM,GAAG;AAAI;AAE7D,SAAS1B,MAAMyB,KAAK;IAAI,OAAOA,MAAME,KAAK,CAAC,GAAGC,KAAKC,GAAG,CAAC,GAAGJ,MAAMC,MAAM,GAAG;AAAK;AAE9E,SAASjB,KAAKqB,MAAM,EAAEC,MAAM;IAAIC,MAAMC,SAAS,CAACxB,IAAI,CAACyB,KAAK,CAACJ,QAAQC;AAAS;AAE5E,SAASP,QAAQM,MAAM,EAAEC,MAAM;IAAIC,MAAMC,SAAS,CAACT,OAAO,CAACU,KAAK,CAACJ,QAAQC;AAAS;AAElF,SAASlD,OAAOiD,MAAM,EAAEK,eAAe;IAC5C,IAAMJ,SAAS,AAACI,AAAe,YAAfA,iBAA2BH,SACzBG,kBACC;QAAEA;KAAiB;IAEtC1B,KAAKqB,QAAQC;AACf;AAEO,SAASrD,MAAM+C,KAAK;IACzB,IAAMW,QAAQ;IAEd,OAAOX,MAAMN,MAAM,CAACiB;AACtB;AAEO,SAAStD,KAAKgD,MAAM,EAAEC,MAAM;IACjC,IAAMK,QAAQ,GACRC,cAAcN,OAAOL,MAAM,EAAG,GAAG;IAEvCP,OAAOW,QAAQM,OAAOC,aAAaN;AACrC;AAEO,SAAS3B,MAAM0B,MAAM,EAAEC,MAAM;IAAIC,MAAMC,SAAS,CAACxB,IAAI,CAACyB,KAAK,CAACJ,QAAQC;AAAS;AAE7E,SAAS5B,MAAM2B,MAAM,EAAEC,MAAM,EAAEO,QAAQ;IAC5C,IAAIC,UAAU;IAEd,IAAMC,eAAeV,OAAOJ,MAAM,EAC5Be,eAAeV,OAAOL,MAAM;IAElC,IAAIc,iBAAiBC,cAAc;QACjCF,UAAUT,OAAOY,KAAK,CAAC,SAACC,UAAUC;YAChC,IAAMC,WAAWd,MAAM,CAACa,MAAM,EACxBE,SAASR,SAASK,UAAUE,UAAUD;YAE5C,IAAIE,QAAQ;gBACV,OAAO;YACT;QACF;IACF;IAEA,OAAOP;AACT;AAEO,SAASxD,UAAU+C,MAAM,EAAEC,MAAM,EAAEO,QAAQ;IAChDP,SACE,qBAAGA;IAGL,IAAMgB,aAAajB,OAAOY,KAAK,CAAC,SAACC;QAC/B,IAAME,WAAW3D,QAAQ6C,QAAQ,SAACc;YAChC,IAAMG,SAASV,SAASK,UAAUE;YAElC,IAAIG,QAAQ;gBACV,OAAO;YACT;QACF,MAAM;QAEN,IAAIH,aAAa,MAAM;YACrB,OAAO;QACT;IACF;IAEA,OAAOE;AACT;AAEO,SAASzD,KAAKmC,KAAK,EAAEa,QAAQ;IAClC,IAAMW,WAAW,EAAE;IAEnBtD,gBAAgB8B,OAAO,SAACyB,SAASN;QAC/B,IAAME,SAASR,SAASY,SAASN;QAEjC,IAAIE,QAAQ;YACVG,SAASxC,IAAI,CAACyC;QAChB;IACF;IAEA,OAAOD;AACT;AAEO,SAASvC,QAAQe,KAAK,EAAEyB,OAAO,EAAEZ,QAAQ;IAC9C,IAAIF;IAEJ,IAAMe,QAAQ1B,MAAM2B,IAAI,CAAC,SAACF,SAASN;QACjC,IAAME,SAASR,SAASY,SAASN;QAEjC,IAAIE,QAAQ;YACVV,QAAQQ,OAAQ,GAAG;YAEnB,OAAO;QACT;IACF;IAEA,IAAIO,OAAO;QACT,IAAMd,cAAc;QAEpBZ,MAAMN,MAAM,CAACiB,OAAOC,aAAaa;IACnC;IAEA,OAAOC;AACT;AAEO,SAAShC,OAAOW,MAAM,EAAEM,KAAK;QAAEC,cAAAA,iEAAcgB,UAAUtB,SAAAA,iEAAS,EAAE;IACvE,IAAMuB,OAAO;QAAElB;QAAOC;KAAwB,CAAjC,OAAsB,qBAAGN,UAChCwB,kBAAkBvB,MAAMC,SAAS,CAACd,MAAM,CAACe,KAAK,CAACJ,QAAQwB;IAE7D,OAAOC;AACT;AAEO,SAASlE,OAAOoC,KAAK,EAAEa,QAAQ;IACpC,IAAMiB,kBAAkB,EAAE;IAE1BhF,iBAAiBkD,OAAO,SAACyB,SAASN;QAChC,IAAME,SAASR,SAASY,SAASN;QAEjC,IAAI,CAACE,QAAQ;YACX,IAAMV,QAAQQ,OACRP,cAAc,GACdkB,kBAAkB9B,MAAMN,MAAM,CAACiB,OAAOC,cACtCmB,sBAAsBjE,MAAMgE;YAElCA,gBAAgB/B,OAAO,CAACgC,sBAAuB,GAAG;QACpD;IACF;IAEA,OAAOD;AACT;AAEO,SAAS/C,MAAMiB,KAAK,EAAEa,QAAQ;IACnC,IAAImB,iBAAiBC;IAErBjC,MAAM2B,IAAI,CAAC,SAACF,SAASN;QACnB,IAAME,SAASR,SAASY,SAASN;QAEjC,IAAI,CAACE,QAAQ;YACX,IAAMV,QAAQQ,OACRP,cAAc,GACdkB,kBAAkB9B,MAAMN,MAAM,CAACiB,OAAOC,cACtCmB,sBAAsBjE,MAAMgE;YAElCE,iBAAiBD,qBAAsB,GAAG;YAE1C,OAAO;QACT;IACF;IAEA,OAAOC;AACT;AAEO,SAASvE,QAAQuC,KAAK,EAAEa,QAAQ;IACrC,IAAImB,iBAAiBC;IAErBjC,MAAM2B,IAAI,CAAC,SAACF,SAASN;QACnB,IAAME,SAASR,SAASY,SAASN;QAEjC,IAAIE,QAAQ;YACV,IAAMV,QAAQQ,OACRP,cAAc,GACdkB,kBAAkB9B,MAAMN,MAAM,CAACiB,OAAOC,cACtCmB,sBAAsBjE,MAAMgE;YAElCE,iBAAiBD,qBAAsB,GAAG;YAE1C,OAAO;QACT;IACF;IAEA,OAAOC;AACT;AAEO,SAASlD,MAAMkB,KAAK,EAAEyB,OAAO,EAAEZ,QAAQ;IAC5C,IAAMa,QAAQ1B,MAAM2B,IAAI,CAAC,SAACF,SAASN;QACjC,IAAME,SAASR,SAASY,SAASN;QAEjC,IAAIE,QAAQ;YACV,OAAO;QACT;IACF;IAGA,IAAIK,OAAO;QACT1B,MAAMhB,IAAI,CAACyC;IACb;IAEA,OAAOC;AACT;AAEO,SAASvE,SAAS6C,KAAK,EAAEa,QAAQ;IACtC,IAAIqB,SAAS,GACTjC,SAASD,MAAMC,MAAM;IAEzB,MAAOiC,SAASjC,OAAQ;QACtB,IAAMmB,WAAWpB,KAAK,CAACkC,OAAO;QAE9B,IAAK,IAAIC,SAASlC,SAAS,GAAGkC,SAASD,QAAQC,SAAU;YACvD,IAAMjB,WAAWlB,KAAK,CAACmC,OAAO,EACxBd,SAASR,SAASK,UAAUE;YAElC,IAAIC,QAAQ;gBACV,IAAMV,QAAQwB,QACRvB,cAAc;gBAEpBZ,MAAMN,MAAM,CAACiB,OAAOC;YACtB;QACF;QAEAsB;QAEAjC,SAASD,MAAMC,MAAM;IACvB;AACF;AAEO,SAAS/C,QAAQmD,MAAM,EAAEC,MAAM,EAAEO,QAAQ;IAC9C,IAAMb,QAAQ,AACZ,qBAAGK,eACH,qBAAGC;IAGLnD,SAAS6C,OAAOa;IAEhB,OAAOb;AACT;AAEO,SAASd,QAAQc,KAAK;IAC3BA,QAAQ,AACN,qBAAGA,OACHd,OAAO;IAET,OAAOc;AACT;AAEO,SAAStD,QAAQ2D,MAAM,EAAEC,MAAM,EAAEO,QAAQ;IAC9CP,OAAO8B,OAAO,CAAC,SAACX,SAASN;QACvB,IAAME,SAASR,SAASY,SAASN;QAEjC,IAAIE,QAAQ;YACVhB,OAAOrB,IAAI,CAACyC;QACd;IACF;AACF;AAEO,SAASpC,SAASW,KAAK,EAAEK,MAAM,EAAEC,MAAM,EAAEO,QAAQ;IACtDb,MAAMoC,OAAO,CAAC,SAACX,SAASN;QACtB,IAAME,SAASR,SAASY,SAASN;QAEjCE,SACEhB,OAAOrB,IAAI,CAACyC,WACVnB,OAAOtB,IAAI,CAACyC;IAClB;AACF;AAEO,SAASxD,aAAa+B,KAAK,EAAEa,QAAQ;IAC1C,IAAMwB,cAAcrC,MAAMC,MAAM;IAEhC,IAAK,IAAIkB,QAAQ,GAAGA,QAAQkB,aAAalB,QAAS;QAChD,IAAMM,UAAUzB,KAAK,CAACmB,MAAM,EACtBE,SAASR,SAASY,SAASN;QAEjC,IAAIE,QAAQ;YACV,OAAOI;QACT;IACF;IAEA,OAAO;AACT;AAEO,SAAS5E,cAAcmD,KAAK,EAAEa,QAAQ;IAC3C,IAAMwB,cAAcrC,MAAMC,MAAM;IAEhC,IAAK,IAAIkB,QAAQkB,cAAc,GAAGlB,SAAS,GAAGA,QAAS;QACrD,IAAMM,UAAUzB,KAAK,CAACmB,MAAM,EACtBE,SAASR,SAASY,SAASN;QAEjC,IAAIE,QAAQ;YACV,OAAOI;QACT;IACF;IAEA,OAAO;AACT;AAEO,SAASrD,aAAa4B,KAAK,EAAEa,QAAQ;IAC1C,IAAMwB,cAAcrC,MAAMC,MAAM;IAEhC,IAAK,IAAIkB,QAAQ,GAAGA,QAAQkB,aAAalB,QAAS;QAChD,IAAMM,UAAUzB,KAAK,CAACmB,MAAM,EACtBE,SAASR,SAASY,SAASN;QAEjC,IAAIE,QAAQ;YACV,OAAO;QACT;IACF;IAEA,OAAO;AACT;AAEO,SAASrE,cAAcgD,KAAK,EAAEa,QAAQ;IAC3C,IAAMwB,cAAcrC,MAAMC,MAAM;IAEhC,IAAK,IAAIkB,QAAQkB,cAAc,GAAGlB,SAAS,GAAGA,QAAS;QACrD,IAAMM,UAAUzB,KAAK,CAACmB,MAAM,EACtBE,SAASR,SAASY,SAASN;QAEjC,IAAIE,QAAQ;YACV,OAAO;QACT;IACF;IAEA,OAAO;AACT;AAEO,SAASrD,cAAcgC,KAAK,EAAEa,QAAQ;IAC3C,IAAMwB,cAAcrC,MAAMC,MAAM;IAEhC,IAAK,IAAIkB,QAAQ,GAAGA,QAAQkB,aAAalB,QAAS;QAChD,IAAMM,UAAUzB,KAAK,CAACmB,MAAM,EACtBE,SAASR,SAASY,SAASN;QAEjC,IAAI,CAACE,QAAQ;YACX,OAAO;QACT;IACF;IAEA,OAAO;AACT;AAEO,SAASzE,eAAeoD,KAAK,EAAEa,QAAQ;IAC5C,IAAMwB,cAAcrC,MAAMC,MAAM;IAEhC,IAAK,IAAIkB,QAAQkB,cAAc,GAAGlB,SAAS,GAAGA,QAAS;QACrD,IAAMM,UAAUzB,KAAK,CAACmB,MAAM,EACtBE,SAASR,SAASY,SAASN;QAEjC,IAAI,CAACE,QAAQ;YACX,OAAO;QACT;IACF;IAEA,OAAO;AACT;AAEO,SAASlD,eAAe6B,KAAK,EAAEa,QAAQ,EAAEyB,YAAY;IAC1D,IAAIC,QAAQD,cAAc,GAAG;IAE7B,IAAMD,cAAcrC,MAAMC,MAAM;IAEhC,IAAK,IAAIkB,QAAQ,GAAGA,QAAQkB,aAAalB,QAAS;QAChD,IAAMM,UAAUzB,KAAK,CAACmB,MAAM;QAE5BoB,QAAQ1B,SAAS0B,OAAOd,SAASN;IACnC;IAEA,OAAOoB;AACT;AAEO,SAASxF,gBAAgBiD,KAAK,EAAEa,QAAQ,EAAEyB,YAAY;IAC3D,IAAIC,QAAQD,cAAc,GAAG;IAE7B,IAAMD,cAAcrC,MAAMC,MAAM;IAEhC,IAAK,IAAIkB,QAAQkB,cAAc,GAAGlB,SAAS,GAAGA,QAAS;QACrD,IAAMM,UAAUzB,KAAK,CAACmB,MAAM;QAE5BoB,QAAQ1B,SAAS0B,OAAOd,SAASN;IACnC;IAEA,OAAOoB;AACT;AAEO,SAASrE,gBAAgB8B,KAAK,EAAEa,QAAQ;IAC7C,IAAMwB,cAAcrC,MAAMC,MAAM;IAEhC,IAAK,IAAIkB,QAAQ,GAAGA,QAAQkB,aAAalB,QAAS;QAChD,IAAMM,UAAUzB,KAAK,CAACmB,MAAM;QAE5BN,SAASY,SAASN;IACpB;AACF;AAEO,SAASrE,iBAAiBkD,KAAK,EAAEa,QAAQ;IAC9C,IAAMwB,cAAcrC,MAAMC,MAAM;IAEhC,IAAK,IAAIkB,QAAQkB,cAAc,GAAGlB,SAAS,GAAGA,QAAS;QACrD,IAAMM,UAAUzB,KAAK,CAACmB,MAAM;QAE5BN,SAASY,SAASN;IACpB;AACF;IAEA,WAAe;IACbrD,OAAAA;IACAqB,QAAAA;IACAU,OAAAA;IACAxB,QAAAA;IACAX,OAAAA;IACA8B,OAAAA;IACAF,SAAAA;IACA/B,QAAAA;IACAqB,OAAAA;IACAb,WAAAA;IACAqB,YAAAA;IACAU,WAAAA;IACAxB,YAAAA;IACAX,WAAAA;IACA8B,WAAAA;IACAF,aAAAA;IACA/B,YAAAA;IACAqB,WAAAA;IACAJ,MAAAA;IACAD,MAAAA;IACAmB,MAAAA;IACAhD,MAAAA;IACA4B,OAAAA;IACAS,MAAAA;IACAe,SAAAA;IACA3C,QAAAA;IACAH,OAAAA;IACAI,MAAAA;IACAsB,OAAAA;IACAD,OAAAA;IACA8D,UAAAA;IACA3E,MAAAA;IACAoB,SAAAA;IACAS,QAAAA;IACA9B,QAAAA;IACAmB,OAAAA;IACAtB,SAAAA;IACAqB,OAAAA;IACA3B,UAAAA;IACAD,SAAAA;IACAgC,SAAAA;IACAxC,SAAAA;IACA2C,UAAAA;IACApB,cAAAA;IACApB,eAAAA;IACAuB,cAAAA;IACApB,eAAAA;IACAgB,eAAAA;IACApB,gBAAAA;IACAuB,gBAAAA;IACApB,iBAAAA;IACAmB,iBAAAA;IACApB,kBAAAA;AACF"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "necessary",
3
3
  "author": "James Smith",
4
- "version": "14.0.7",
4
+ "version": "14.1.0",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/necessary",
7
7
  "description": "A collection of utility functions.",
@@ -95,6 +95,28 @@ export function match(arrayA, arrayB, callback) {
95
95
  return matches;
96
96
  }
97
97
 
98
+ export function correlate(arrayA, arrayB, callback) {
99
+ arrayB = [ ///
100
+ ...arrayB
101
+ ];
102
+
103
+ const correlates = arrayA.every((elementA) => {
104
+ const elementB = extract(arrayB, (elementB) => {
105
+ const result = callback(elementA, elementB);
106
+
107
+ if (result) {
108
+ return true;
109
+ }
110
+ }) || null;
111
+
112
+ if (elementB !== null) {
113
+ return true;
114
+ }
115
+ });
116
+
117
+ return correlates;
118
+ }
119
+
98
120
  export function find(array, callback) {
99
121
  const elements = [];
100
122
 
@@ -252,6 +274,14 @@ export function combine(arrayA, arrayB, callback) {
252
274
  return array;
253
275
  }
254
276
 
277
+ export function reverse(array) {
278
+ array = [ ///
279
+ ...array
280
+ ].reverse();
281
+
282
+ return array;
283
+ }
284
+
255
285
  export function augment(arrayA, arrayB, callback) {
256
286
  arrayB.forEach((element, index) => {
257
287
  const passed = callback(element, index);
@@ -441,6 +471,7 @@ export default {
441
471
  copy,
442
472
  merge,
443
473
  match,
474
+ corrlate,
444
475
  find,
445
476
  replace,
446
477
  splice,
@@ -450,6 +481,7 @@ export default {
450
481
  patch,
451
482
  compress,
452
483
  combine,
484
+ reverse,
453
485
  augment,
454
486
  separate,
455
487
  forwardsFind,