necessary 14.1.6 → 14.2.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 +11 -0
- package/lib/utilities/array.js +40 -1
- package/package.json +1 -1
- package/src/utilities/array.js +49 -0
package/README.md
CHANGED
|
@@ -715,6 +715,7 @@ pathWithoutTopmostDirectoryNameFromPath("root/etc/init.conf"); // returns 'etc/i
|
|
|
715
715
|
- `merge()`
|
|
716
716
|
- `match()`
|
|
717
717
|
- `correlate()`
|
|
718
|
+
- `resolve()`
|
|
718
719
|
- `find()`
|
|
719
720
|
- `replace()`
|
|
720
721
|
- `splice()`
|
|
@@ -784,6 +785,16 @@ match([1, 2, 3], [-1, -2, -3], (valueA, valueB) => (valueA === -valueB)); // ret
|
|
|
784
785
|
correlate([1, 2, 3], [-4, -2, -3, -1], (valueA, valueB) => (valueA === -valueB)); // returns true
|
|
785
786
|
```
|
|
786
787
|
|
|
788
|
+
* The `resolve()` function repeatedly iterates over the elements of the first array argument, removing them and adding them to the second argument if the callback function returns a truthy value. If the callback function does not return a truthy value for any of the elements of the first array argument or the length of the first array is zero, it terminates.
|
|
789
|
+
|
|
790
|
+
```
|
|
791
|
+
resolve([1, 2, 3], [], (value) => true); // moves the elemnts of the first array argument into the second array argument and returns true
|
|
792
|
+
```
|
|
793
|
+
|
|
794
|
+
The above code snippet is perhaps not very helpful so it is worth explaining this function's utility in the context of a use case. Suppose a compiler has to compile all the files in a given directory. There are inter-dependencies between the files, however, so some files will not compile until their dependents have compiled. If there are orderings of files that allow them to all be compiled, this function will find one of them by trial and error, so to speak. The second array argument will contain the elements according to this ordering.
|
|
795
|
+
|
|
796
|
+
The first array argument is left untouched whether or not the function succeeds. The second array argument may contain elements if it has only been partially successful, however.
|
|
797
|
+
|
|
787
798
|
* 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:
|
|
788
799
|
|
|
789
800
|
```
|
package/lib/utilities/array.js
CHANGED
|
@@ -132,6 +132,9 @@ _export(exports, {
|
|
|
132
132
|
replace: function() {
|
|
133
133
|
return replace;
|
|
134
134
|
},
|
|
135
|
+
resolve: function() {
|
|
136
|
+
return resolve;
|
|
137
|
+
},
|
|
135
138
|
reverse: function() {
|
|
136
139
|
return reverse;
|
|
137
140
|
},
|
|
@@ -330,6 +333,41 @@ function correlate(arrayA, arrayB, callback) {
|
|
|
330
333
|
});
|
|
331
334
|
return correlates;
|
|
332
335
|
}
|
|
336
|
+
function resolve(arrayA, arrayB, callback) {
|
|
337
|
+
var _loop = function() {
|
|
338
|
+
var arrayALength = arrayA.length;
|
|
339
|
+
if (arrayALength === 0) {
|
|
340
|
+
return "break";
|
|
341
|
+
}
|
|
342
|
+
var resolved = false;
|
|
343
|
+
arrayA.forEach(function(elementA) {
|
|
344
|
+
var passed = callback(elementA);
|
|
345
|
+
if (passed) {
|
|
346
|
+
var elementB = elementA; ///
|
|
347
|
+
arrayB.push(elementB);
|
|
348
|
+
resolved = true;
|
|
349
|
+
}
|
|
350
|
+
});
|
|
351
|
+
if (!resolved) {
|
|
352
|
+
return "break";
|
|
353
|
+
}
|
|
354
|
+
filter(arrayA, function(elementA) {
|
|
355
|
+
var arrayBIncludesElementA = arrayB.includes(elementA);
|
|
356
|
+
if (!arrayBIncludesElementA) {
|
|
357
|
+
return true;
|
|
358
|
+
}
|
|
359
|
+
});
|
|
360
|
+
};
|
|
361
|
+
var resolved;
|
|
362
|
+
arrayA = _to_consumable_array(arrayA);
|
|
363
|
+
for(;;){
|
|
364
|
+
var _ret = _loop();
|
|
365
|
+
if (_ret === "break") break;
|
|
366
|
+
}
|
|
367
|
+
var arrayALength = arrayA.length;
|
|
368
|
+
resolved = arrayALength === 0;
|
|
369
|
+
return resolved;
|
|
370
|
+
}
|
|
333
371
|
function find(array, callback) {
|
|
334
372
|
var elements = [];
|
|
335
373
|
forwardsForEach(array, function(element, index) {
|
|
@@ -572,6 +610,7 @@ var _default = {
|
|
|
572
610
|
merge: merge,
|
|
573
611
|
match: match,
|
|
574
612
|
correlate: correlate,
|
|
613
|
+
resolve: resolve,
|
|
575
614
|
find: find,
|
|
576
615
|
replace: replace,
|
|
577
616
|
splice: splice,
|
|
@@ -596,4 +635,4 @@ var _default = {
|
|
|
596
635
|
backwardsForEach: backwardsForEach
|
|
597
636
|
};
|
|
598
637
|
|
|
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  correlate,\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"],"mappings":"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"}
|
|
638
|
+
//# 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 resolve(arrayA, arrayB, callback) {\n  let resolved;\n\n  arrayA = [  ///\n    ...arrayA\n  ];\n\n  for (;;) {\n    const arrayALength = arrayA.length;\n\n    if (arrayALength === 0) {\n      break;\n    }\n\n    let resolved = false;\n\n    arrayA.forEach((elementA) => {\n      const passed = callback(elementA);\n\n      if (passed) {\n        const elementB = elementA;  ///\n\n        arrayB.push(elementB);\n\n        resolved = true;\n      }\n    });\n\n    if (!resolved) {\n      break;\n    }\n\n    filter(arrayA, (elementA) => {\n      const arrayBIncludesElementA = arrayB.includes(elementA);\n\n      if (!arrayBIncludesElementA) {\n        return true;\n      }\n    });\n  }\n\n  const arrayALength = arrayA.length;\n\n  resolved = (arrayALength === 0);\n\n  return resolved;\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  correlate,\n  resolve,\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","resolve","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","resolved","forEach","arrayBIncludesElementA","includes","elements","element","found","some","Infinity","args","deletedElements","firstDeletedElement","deletedElement","undefined","index1","index2","arrayLength","initialValue","value"],"mappings":"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"}
|
package/package.json
CHANGED
package/src/utilities/array.js
CHANGED
|
@@ -117,6 +117,54 @@ export function correlate(arrayA, arrayB, callback) {
|
|
|
117
117
|
return correlates;
|
|
118
118
|
}
|
|
119
119
|
|
|
120
|
+
export function resolve(arrayA, arrayB, callback) {
|
|
121
|
+
let resolved;
|
|
122
|
+
|
|
123
|
+
arrayA = [ ///
|
|
124
|
+
...arrayA
|
|
125
|
+
];
|
|
126
|
+
|
|
127
|
+
for (;;) {
|
|
128
|
+
const arrayALength = arrayA.length;
|
|
129
|
+
|
|
130
|
+
if (arrayALength === 0) {
|
|
131
|
+
break;
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
let resolved = false;
|
|
135
|
+
|
|
136
|
+
arrayA.forEach((elementA) => {
|
|
137
|
+
const passed = callback(elementA);
|
|
138
|
+
|
|
139
|
+
if (passed) {
|
|
140
|
+
const elementB = elementA; ///
|
|
141
|
+
|
|
142
|
+
arrayB.push(elementB);
|
|
143
|
+
|
|
144
|
+
resolved = true;
|
|
145
|
+
}
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
if (!resolved) {
|
|
149
|
+
break;
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
filter(arrayA, (elementA) => {
|
|
153
|
+
const arrayBIncludesElementA = arrayB.includes(elementA);
|
|
154
|
+
|
|
155
|
+
if (!arrayBIncludesElementA) {
|
|
156
|
+
return true;
|
|
157
|
+
}
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
const arrayALength = arrayA.length;
|
|
162
|
+
|
|
163
|
+
resolved = (arrayALength === 0);
|
|
164
|
+
|
|
165
|
+
return resolved;
|
|
166
|
+
}
|
|
167
|
+
|
|
120
168
|
export function find(array, callback) {
|
|
121
169
|
const elements = [];
|
|
122
170
|
|
|
@@ -472,6 +520,7 @@ export default {
|
|
|
472
520
|
merge,
|
|
473
521
|
match,
|
|
474
522
|
correlate,
|
|
523
|
+
resolve,
|
|
475
524
|
find,
|
|
476
525
|
replace,
|
|
477
526
|
splice,
|