necessary 11.3.2 → 11.5.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
@@ -320,6 +320,7 @@ function contentFromResponse(response, callback) {
320
320
  - `readDirectory()`
321
321
  - `readFile()`
322
322
  - `writeFile()`
323
+ - `createFile()`
323
324
  - `appendToFile()`
324
325
  - `createDirectory()`
325
326
  - `renameFile()`
@@ -362,6 +363,12 @@ readFile("root/etc/init.conf"); // returns the content of the 'root/etc/init.con
362
363
  writeFile("root/etc/init.conf", ""); // writes '' to the 'root/etc/init.conf' file
363
364
  ```
364
365
 
366
+ * The `createFile()` creates an empty file. It does not return anything upon success:
367
+
368
+ ```
369
+ createFile("root/etc/init.conf"); // writes '' to the 'root/etc/init.conf' file
370
+ ```
371
+
365
372
  * The `appendToFile()` function takes the content to append file as a second string argument. It will create teh file if necessary and does not return anything upon success:
366
373
 
367
374
  ```
@@ -601,6 +608,7 @@ pathWithoutTopmostDirectoryNameFromPath("root/etc/init.conf"); // returns 'etc/i
601
608
  - `prune()`
602
609
  - `patch()`
603
610
  - `compress()`
611
+ - `combine()`
604
612
  - `augment()`
605
613
  - `separate()`
606
614
  - `forwardsFind()`
@@ -690,6 +698,12 @@ patch([1, 2, 0, -1, -2], 4, (element, index) => (element === 0)); // the array a
690
698
  compress([1, 2, 1], (element1, element2) => (element1 === element2)); // the array argument becomes [1, 2]
691
699
  ```
692
700
 
701
+ * The `combine()` function will concatenate the two array arguments, combine them and and return the result
702
+
703
+ ```
704
+ combine([1, 2, 1], [2, 3], (element1, element2) => (element1 === element2)); // returns [1, 2, 3]
705
+ ```
706
+
693
707
  * 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:
694
708
 
695
709
  ```
@@ -30,6 +30,7 @@ exports.find = find;
30
30
  exports.prune = prune;
31
31
  exports.patch = patch;
32
32
  exports.compress = compress;
33
+ exports.combine = combine;
33
34
  exports.augment = augment;
34
35
  exports.separate = separate;
35
36
  exports.forwardsFind = forwardsFind;
@@ -226,6 +227,11 @@ function compress(array, callback) {
226
227
  length = array.length;
227
228
  }
228
229
  }
230
+ function combine(array1, array2, callback) {
231
+ var array = _toConsumableArray(array1).concat(_toConsumableArray(array2));
232
+ compress(array, callback);
233
+ return array;
234
+ }
229
235
  function augment(array1, array2, callback) {
230
236
  array2.forEach(function(element, index) {
231
237
  var passed = callback(element, index);
@@ -361,6 +367,7 @@ var _default = {
361
367
  prune: prune,
362
368
  patch: patch,
363
369
  compress: compress,
370
+ combine: combine,
364
371
  augment: augment,
365
372
  separate: separate,
366
373
  forwardsFind: forwardsFind,
@@ -376,4 +383,4 @@ var _default = {
376
383
  };
377
384
  exports.default = _default;
378
385
 
379
- //# sourceMappingURL=data:application/json;charset=utf-8;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 fifthLast(array) { return array[array.length - 5]; }\n\nexport function fourthLast(array) { return array[array.length - 4]; }\n\nexport function thirdLast(array) { return array[array.length - 3]; }\n\nexport function secondLast(array) { return array[array.length - 2]; }\n\nexport function firstLast(array) { return array[array.length - 1]; }\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(array1, array2) { Array.prototype.push.apply(array1, array2); }\n\nexport function unshift(array1, array2) { Array.prototype.unshift.apply(array1, array2); }\n\nexport function concat(array1, elementOrArray2) {\n  const array2 = (elementOrArray2 instanceof Array) ?\n                    elementOrArray2 :\n                     [elementOrArray2];\n  \n  push(array1, array2);\n}\n\nexport function clear(array) {\n  const start = 0;\n  \n  return array.splice(start);\n}\n\nexport function copy(array1, array2) {\n  const start = 0,\n        deleteCount = array2.length;  ///\n  \n  splice(array1, start, deleteCount, array2);\n}\n\nexport function merge(array1, array2) { Array.prototype.push.apply(array1, array2); }\n\nexport function splice(array1, start, deleteCount = Infinity, array2 = []) {\n  const args = [start, deleteCount, ...array2],\n        deletedItemsArray = Array.prototype.splice.apply(array1, args);\n\n  return deletedItemsArray;\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 filter(array, callback) {\n  const filteredElements = [];\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      filteredElements.unshift(firstDeletedElement);  ///\n    }\n  });\n  \n  return filteredElements;\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 prune(array, callback) {\n  let prunedElement = 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      prunedElement = firstDeletedElement;  ///\n\n      return true;\n    }\n  });\n  \n  return prunedElement;\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 element1 = array[index1];\n\n    for (let index2 = length - 1; index2 > index1; index2--) {\n      const element2 = array[index2],\n            passed = callback(element2, element1);\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 augment(array1, array2, callback) {\n  array2.forEach((element, index) => {\n    const passed = callback(element, index);\n\n    if (passed) {\n      array1.push(element);\n    }\n  });\n}\n\nexport function separate(array, array1, array2, callback) {\n  array.forEach((element, index) => {\n    const passed = callback(element, index);\n\n    passed ?\n      array1.push(element) :\n        array2.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  fifthLast,\n  fourthLast,\n  thirdLast,\n  secondLast,\n  firstLast,\n  last,\n  head,\n  tail,\n  back,\n  front,\n  push,\n  unshift,\n  concat,\n  clear,\n  copy,\n  merge,\n  splice,\n  replace,\n  filter,\n  find,\n  prune,\n  patch,\n  compress,\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":["first","second","third","fourth","fifth","fifthLast","fourthLast","thirdLast","secondLast","firstLast","last","head","tail","back","front","push","unshift","concat","clear","copy","merge","splice","replace","filter","find","prune","patch","compress","augment","separate","forwardsFind","backwardsFind","forwardsSome","backwardsSome","forwardsEvery","backwardsEvery","forwardsReduce","backwardsReduce","forwardsForEach","backwardsForEach","array","length","slice","Math","max","array1","array2","Array","prototype","apply","elementOrArray2","start","deleteCount","Infinity","args","deletedItemsArray","element","callback","found","some","index","passed","filteredElements","deletedElements","firstDeletedElement","elements","prunedElement","undefined","index1","element1","index2","element2","forEach","arrayLength","initialValue","value"],"mappings":"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"}
386
+ //# sourceMappingURL=data:application/json;charset=utf-8;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 fifthLast(array) { return array[array.length - 5]; }\n\nexport function fourthLast(array) { return array[array.length - 4]; }\n\nexport function thirdLast(array) { return array[array.length - 3]; }\n\nexport function secondLast(array) { return array[array.length - 2]; }\n\nexport function firstLast(array) { return array[array.length - 1]; }\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(array1, array2) { Array.prototype.push.apply(array1, array2); }\n\nexport function unshift(array1, array2) { Array.prototype.unshift.apply(array1, array2); }\n\nexport function concat(array1, elementOrArray2) {\n  const array2 = (elementOrArray2 instanceof Array) ?\n                    elementOrArray2 :\n                     [ elementOrArray2 ];\n  \n  push(array1, array2);\n}\n\nexport function clear(array) {\n  const start = 0;\n  \n  return array.splice(start);\n}\n\nexport function copy(array1, array2) {\n  const start = 0,\n        deleteCount = array2.length;  ///\n  \n  splice(array1, start, deleteCount, array2);\n}\n\nexport function merge(array1, array2) { Array.prototype.push.apply(array1, array2); }\n\nexport function splice(array1, start, deleteCount = Infinity, array2 = []) {\n  const args = [start, deleteCount, ...array2],\n        deletedItemsArray = Array.prototype.splice.apply(array1, args);\n\n  return deletedItemsArray;\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 filter(array, callback) {\n  const filteredElements = [];\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      filteredElements.unshift(firstDeletedElement);  ///\n    }\n  });\n  \n  return filteredElements;\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 prune(array, callback) {\n  let prunedElement = 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      prunedElement = firstDeletedElement;  ///\n\n      return true;\n    }\n  });\n  \n  return prunedElement;\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 element1 = array[index1];\n\n    for (let index2 = length - 1; index2 > index1; index2--) {\n      const element2 = array[index2],\n            passed = callback(element2, element1);\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(array1, array2, callback) {\n  const array = [\n    ...array1,\n    ...array2\n  ];\n\n  compress(array, callback);\n\n  return array;\n}\n\nexport function augment(array1, array2, callback) {\n  array2.forEach((element, index) => {\n    const passed = callback(element, index);\n\n    if (passed) {\n      array1.push(element);\n    }\n  });\n}\n\nexport function separate(array, array1, array2, callback) {\n  array.forEach((element, index) => {\n    const passed = callback(element, index);\n\n    passed ?\n      array1.push(element) :\n        array2.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  fifthLast,\n  fourthLast,\n  thirdLast,\n  secondLast,\n  firstLast,\n  last,\n  head,\n  tail,\n  back,\n  front,\n  push,\n  unshift,\n  concat,\n  clear,\n  copy,\n  merge,\n  splice,\n  replace,\n  filter,\n  find,\n  prune,\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":["first","second","third","fourth","fifth","fifthLast","fourthLast","thirdLast","secondLast","firstLast","last","head","tail","back","front","push","unshift","concat","clear","copy","merge","splice","replace","filter","find","prune","patch","compress","combine","augment","separate","forwardsFind","backwardsFind","forwardsSome","backwardsSome","forwardsEvery","backwardsEvery","forwardsReduce","backwardsReduce","forwardsForEach","backwardsForEach","array","length","slice","Math","max","array1","array2","Array","prototype","apply","elementOrArray2","start","deleteCount","Infinity","args","deletedItemsArray","element","callback","found","some","index","passed","filteredElements","deletedElements","firstDeletedElement","elements","prunedElement","undefined","index1","element1","index2","element2","forEach","arrayLength","initialValue","value"],"mappings":"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"}
@@ -11,6 +11,7 @@ exports.isDirectoryEmpty = isDirectoryEmpty;
11
11
  exports.readDirectory = readDirectory;
12
12
  exports.readFile = readFile;
13
13
  exports.writeFile = writeFile;
14
+ exports.createFile = createFile;
14
15
  exports.appendToFile = appendToFile;
15
16
  exports.createDirectory = createDirectory;
16
17
  exports.renameFile = renameFile;
@@ -18,6 +19,7 @@ exports.removeEntry = removeEntry;
18
19
  exports.getStats = getStats;
19
20
  exports.default = void 0;
20
21
  var _fs = _interopRequireDefault(require("fs"));
22
+ var _constants = require("../constants");
21
23
  var _defaults = require("../defaults");
22
24
  function _interopRequireDefault(obj) {
23
25
  return obj && obj.__esModule ? obj : {
@@ -76,6 +78,10 @@ function readFile(filePath) {
76
78
  function writeFile(filePath, content) {
77
79
  _fs.default.writeFileSync(filePath, content);
78
80
  }
81
+ function createFile(filePath) {
82
+ var content = _constants.EMPTY_STRING;
83
+ _fs.default.writeFileSync(filePath, content);
84
+ }
79
85
  function appendToFile(filePath, content) {
80
86
  _fs.default.appendFileSync(filePath, content);
81
87
  }
@@ -108,6 +114,7 @@ var _default = {
108
114
  readDirectory: readDirectory,
109
115
  readFile: readFile,
110
116
  writeFile: writeFile,
117
+ createFile: createFile,
111
118
  appendToFile: appendToFile,
112
119
  createDirectory: createDirectory,
113
120
  renameFile: renameFile,
@@ -116,4 +123,4 @@ var _default = {
116
123
  };
117
124
  exports.default = _default;
118
125
 
119
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/utilities/fileSystem.js"],"sourcesContent":["\"use strict\";\n\nimport fs from \"fs\";\n\nimport { DEFAULT_ENCODING } from \"../defaults\";\n\nexport function checkEntryExists(entryPath) {\n  const entryExists = fs.existsSync(entryPath);\n\n  return entryExists;\n}\n\nexport function checkFileExists(filePath) {\n  let fileExists = false;\n  \n  const entryPath = filePath, ///\n        entryExists = checkEntryExists(entryPath);\n  \n  if (entryExists) {\n    const entryFile = isEntryFile(entryPath);\n    \n    if (entryFile) {\n      fileExists = true;\n    }\n  }\n  \n  return fileExists;\n}\n\nexport function checkDirectoryExists(directoryPath) {\n  let directoryExists = false;\n\n  const entryPath = directoryPath, ///\n        entryExists = checkEntryExists(entryPath);\n\n  if (entryExists) {\n    const entryDirectory = isEntryDirectory(entryPath);\n\n    if (entryDirectory) {\n      directoryExists = true;\n    }\n  }\n\n  return directoryExists;\n}\n\nexport function isEntryFile(entryPath) {\n  const stat = fs.statSync(entryPath),\n        entryDirectory = stat.isDirectory(),\n        entryFile = !entryDirectory;\n\n  return entryFile;\n}\n\nexport function isEntryDirectory(entryPath) {\n  const stat = fs.statSync(entryPath),\n        entryDirectory = stat.isDirectory();\n\n  return entryDirectory;\n}\n\nexport function isDirectoryEmpty(directoryPath) {\n  const subEntryNames = readDirectory(directoryPath),\n        subEntryNamesLength = subEntryNames.length,\n        directoryEmpty = (subEntryNamesLength === 0);\n\n  return directoryEmpty;\n}\n\nexport function readDirectory(directoryPath) {\n  const subEntryNames = fs.readdirSync(directoryPath);\n\n  return subEntryNames;\n}\n\nexport function readFile(filePath, encoding = DEFAULT_ENCODING) {\n  const options = {\n          encoding\n        },\n        content = fs.readFileSync(filePath, options);\n\n  return content;\n}\n\nexport function writeFile(filePath, content) {\n  fs.writeFileSync(filePath, content);\n}\n\nexport function appendToFile(filePath, content) {\n  fs.appendFileSync(filePath, content);\n}\n\nexport function createDirectory(directoryPath) {\n  const recursive = true,\n        options = {\n          recursive\n        };\n\n  fs.mkdirSync(directoryPath, options);\n}\n\nexport function renameFile(oldFilePath, newFilePath) {\n  fs.renameSync(oldFilePath, newFilePath);\n}\n\nexport function removeEntry(entryPath) {\n  const force = true,\n        recursive = true,\n        options = {\n          force,\n          recursive\n        };\n\n  fs.rmSync(entryPath, options);\n}\n\nexport function getStats(filePath) {\n  return fs.statSync(filePath);\n}\n\nexport default {\n  checkEntryExists,\n  checkFileExists,\n  checkDirectoryExists,\n  isEntryFile,\n  isEntryDirectory,\n  isDirectoryEmpty,\n  readDirectory,\n  readFile,\n  writeFile,\n  appendToFile,\n  createDirectory,\n  renameFile,\n  removeEntry,\n  getStats\n};\n"],"names":["checkEntryExists","checkFileExists","checkDirectoryExists","isEntryFile","isEntryDirectory","isDirectoryEmpty","readDirectory","readFile","writeFile","appendToFile","createDirectory","renameFile","removeEntry","getStats","entryPath","entryExists","existsSync","filePath","fileExists","entryFile","directoryPath","directoryExists","entryDirectory","stat","statSync","isDirectory","subEntryNames","subEntryNamesLength","length","directoryEmpty","readdirSync","encoding","options","content","readFileSync","writeFileSync","appendFileSync","recursive","mkdirSync","oldFilePath","newFilePath","renameSync","force","rmSync"],"mappings":"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"}
126
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/utilities/fileSystem.js"],"sourcesContent":["\"use strict\";\n\nimport fs from \"fs\";\n\nimport { EMPTY_STRING } from \"../constants\";\nimport { DEFAULT_ENCODING } from \"../defaults\";\n\nexport function checkEntryExists(entryPath) {\n  const entryExists = fs.existsSync(entryPath);\n\n  return entryExists;\n}\n\nexport function checkFileExists(filePath) {\n  let fileExists = false;\n  \n  const entryPath = filePath, ///\n        entryExists = checkEntryExists(entryPath);\n  \n  if (entryExists) {\n    const entryFile = isEntryFile(entryPath);\n    \n    if (entryFile) {\n      fileExists = true;\n    }\n  }\n  \n  return fileExists;\n}\n\nexport function checkDirectoryExists(directoryPath) {\n  let directoryExists = false;\n\n  const entryPath = directoryPath, ///\n        entryExists = checkEntryExists(entryPath);\n\n  if (entryExists) {\n    const entryDirectory = isEntryDirectory(entryPath);\n\n    if (entryDirectory) {\n      directoryExists = true;\n    }\n  }\n\n  return directoryExists;\n}\n\nexport function isEntryFile(entryPath) {\n  const stat = fs.statSync(entryPath),\n        entryDirectory = stat.isDirectory(),\n        entryFile = !entryDirectory;\n\n  return entryFile;\n}\n\nexport function isEntryDirectory(entryPath) {\n  const stat = fs.statSync(entryPath),\n        entryDirectory = stat.isDirectory();\n\n  return entryDirectory;\n}\n\nexport function isDirectoryEmpty(directoryPath) {\n  const subEntryNames = readDirectory(directoryPath),\n        subEntryNamesLength = subEntryNames.length,\n        directoryEmpty = (subEntryNamesLength === 0);\n\n  return directoryEmpty;\n}\n\nexport function readDirectory(directoryPath) {\n  const subEntryNames = fs.readdirSync(directoryPath);\n\n  return subEntryNames;\n}\n\nexport function readFile(filePath, encoding = DEFAULT_ENCODING) {\n  const options = {\n          encoding\n        },\n        content = fs.readFileSync(filePath, options);\n\n  return content;\n}\n\nexport function writeFile(filePath, content) {\n  fs.writeFileSync(filePath, content);\n}\n\nexport function createFile(filePath) {\n  const content = EMPTY_STRING;\n\n  fs.writeFileSync(filePath, content);\n}\n\nexport function appendToFile(filePath, content) {\n  fs.appendFileSync(filePath, content);\n}\n\nexport function createDirectory(directoryPath) {\n  const recursive = true,\n        options = {\n          recursive\n        };\n\n  fs.mkdirSync(directoryPath, options);\n}\n\nexport function renameFile(oldFilePath, newFilePath) {\n  fs.renameSync(oldFilePath, newFilePath);\n}\n\nexport function removeEntry(entryPath) {\n  const force = true,\n        recursive = true,\n        options = {\n          force,\n          recursive\n        };\n\n  fs.rmSync(entryPath, options);\n}\n\nexport function getStats(filePath) {\n  return fs.statSync(filePath);\n}\n\nexport default {\n  checkEntryExists,\n  checkFileExists,\n  checkDirectoryExists,\n  isEntryFile,\n  isEntryDirectory,\n  isDirectoryEmpty,\n  readDirectory,\n  readFile,\n  writeFile,\n  createFile,\n  appendToFile,\n  createDirectory,\n  renameFile,\n  removeEntry,\n  getStats\n};\n"],"names":["checkEntryExists","checkFileExists","checkDirectoryExists","isEntryFile","isEntryDirectory","isDirectoryEmpty","readDirectory","readFile","writeFile","createFile","appendToFile","createDirectory","renameFile","removeEntry","getStats","entryPath","entryExists","existsSync","filePath","fileExists","entryFile","directoryPath","directoryExists","entryDirectory","stat","statSync","isDirectory","subEntryNames","subEntryNamesLength","length","directoryEmpty","readdirSync","encoding","options","content","readFileSync","writeFileSync","appendFileSync","recursive","mkdirSync","oldFilePath","newFilePath","renameSync","force","rmSync"],"mappings":"AAAA,CAAY;;;;QAOIA,gBAAgB,GAAhBA,gBAAgB;QAMhBC,eAAe,GAAfA,eAAe;QAiBfC,oBAAoB,GAApBA,oBAAoB;QAiBpBC,WAAW,GAAXA,WAAW;QAQXC,gBAAgB,GAAhBA,gBAAgB;QAOhBC,gBAAgB,GAAhBA,gBAAgB;QAQhBC,aAAa,GAAbA,aAAa;QAMbC,QAAQ,GAARA,QAAQ;QASRC,SAAS,GAATA,SAAS;QAITC,UAAU,GAAVA,UAAU;QAMVC,YAAY,GAAZA,YAAY;QAIZC,eAAe,GAAfA,eAAe;QASfC,UAAU,GAAVA,UAAU;QAIVC,WAAW,GAAXA,WAAW;QAWXC,QAAQ,GAARA,QAAQ;;AAzHT,GAAI,CAAJ,GAAI;AAEU,GAAc,CAAd,UAAc;AACV,GAAa,CAAb,SAAa;;;;;;SAE9Bd,gBAAgB,CAACe,SAAS,EAAE,CAAC;IAC3C,GAAK,CAACC,WAAW,GANJ,GAAI,SAMMC,UAAU,CAACF,SAAS;IAE3C,MAAM,CAACC,WAAW;AACpB,CAAC;SAEef,eAAe,CAACiB,QAAQ,EAAE,CAAC;IACzC,GAAG,CAACC,UAAU,GAAG,KAAK;IAEtB,GAAK,CAACJ,SAAS,GAAGG,QAAQ,EACpBF,WAAW,GAAGhB,gBAAgB,CAACe,SAAS;IAE9C,EAAE,EAAEC,WAAW,EAAE,CAAC;QAChB,GAAK,CAACI,SAAS,GAAGjB,WAAW,CAACY,SAAS;QAEvC,EAAE,EAAEK,SAAS,EAAE,CAAC;YACdD,UAAU,GAAG,IAAI;QACnB,CAAC;IACH,CAAC;IAED,MAAM,CAACA,UAAU;AACnB,CAAC;SAEejB,oBAAoB,CAACmB,aAAa,EAAE,CAAC;IACnD,GAAG,CAACC,eAAe,GAAG,KAAK;IAE3B,GAAK,CAACP,SAAS,GAAGM,aAAa,EACzBL,WAAW,GAAGhB,gBAAgB,CAACe,SAAS;IAE9C,EAAE,EAAEC,WAAW,EAAE,CAAC;QAChB,GAAK,CAACO,cAAc,GAAGnB,gBAAgB,CAACW,SAAS;QAEjD,EAAE,EAAEQ,cAAc,EAAE,CAAC;YACnBD,eAAe,GAAG,IAAI;QACxB,CAAC;IACH,CAAC;IAED,MAAM,CAACA,eAAe;AACxB,CAAC;SAEenB,WAAW,CAACY,SAAS,EAAE,CAAC;IACtC,GAAK,CAACS,IAAI,GA9CG,GAAI,SA8CDC,QAAQ,CAACV,SAAS,GAC5BQ,cAAc,GAAGC,IAAI,CAACE,WAAW,IACjCN,SAAS,IAAIG,cAAc;IAEjC,MAAM,CAACH,SAAS;AAClB,CAAC;SAEehB,gBAAgB,CAACW,SAAS,EAAE,CAAC;IAC3C,GAAK,CAACS,IAAI,GAtDG,GAAI,SAsDDC,QAAQ,CAACV,SAAS,GAC5BQ,cAAc,GAAGC,IAAI,CAACE,WAAW;IAEvC,MAAM,CAACH,cAAc;AACvB,CAAC;SAEelB,gBAAgB,CAACgB,aAAa,EAAE,CAAC;IAC/C,GAAK,CAACM,aAAa,GAAGrB,aAAa,CAACe,aAAa,GAC3CO,mBAAmB,GAAGD,aAAa,CAACE,MAAM,EAC1CC,cAAc,GAAIF,mBAAmB,KAAK,CAAC;IAEjD,MAAM,CAACE,cAAc;AACvB,CAAC;SAEexB,aAAa,CAACe,aAAa,EAAE,CAAC;IAC5C,GAAK,CAACM,aAAa,GArEN,GAAI,SAqEQI,WAAW,CAACV,aAAa;IAElD,MAAM,CAACM,aAAa;AACtB,CAAC;SAEepB,QAAQ,CAACW,QAAQ,EAA+B,CAAC;QAA9Bc,QAAQ,oEAvEV,SAAa;IAwE5C,GAAK,CAACC,OAAO,GAAG,CAAC;QACTD,QAAQ,EAARA,QAAQ;IACV,CAAC,EACDE,OAAO,GA9EA,GAAI,SA8EEC,YAAY,CAACjB,QAAQ,EAAEe,OAAO;IAEjD,MAAM,CAACC,OAAO;AAChB,CAAC;SAEe1B,SAAS,CAACU,QAAQ,EAAEgB,OAAO,EAAE,CAAC;IAnF/B,GAAI,SAoFdE,aAAa,CAAClB,QAAQ,EAAEgB,OAAO;AACpC,CAAC;SAEezB,UAAU,CAACS,QAAQ,EAAE,CAAC;IACpC,GAAK,CAACgB,OAAO,GAtFc,UAAc;IAF5B,GAAI,SA0FdE,aAAa,CAAClB,QAAQ,EAAEgB,OAAO;AACpC,CAAC;SAEexB,YAAY,CAACQ,QAAQ,EAAEgB,OAAO,EAAE,CAAC;IA7FlC,GAAI,SA8FdG,cAAc,CAACnB,QAAQ,EAAEgB,OAAO;AACrC,CAAC;SAEevB,eAAe,CAACU,aAAa,EAAE,CAAC;IAC9C,GAAK,CAACiB,SAAS,GAAG,IAAI,EAChBL,OAAO,GAAG,CAAC;QACTK,SAAS,EAATA,SAAS;IACX,CAAC;IArGM,GAAI,SAuGdC,SAAS,CAAClB,aAAa,EAAEY,OAAO;AACrC,CAAC;SAEerB,UAAU,CAAC4B,WAAW,EAAEC,WAAW,EAAE,CAAC;IA1GvC,GAAI,SA2GdC,UAAU,CAACF,WAAW,EAAEC,WAAW;AACxC,CAAC;SAEe5B,WAAW,CAACE,SAAS,EAAE,CAAC;IACtC,GAAK,CAAC4B,KAAK,GAAG,IAAI,EACZL,SAAS,GAAG,IAAI,EAChBL,OAAO,GAAG,CAAC;QACTU,KAAK,EAALA,KAAK;QACLL,SAAS,EAATA,SAAS;IACX,CAAC;IApHM,GAAI,SAsHdM,MAAM,CAAC7B,SAAS,EAAEkB,OAAO;AAC9B,CAAC;SAEenB,QAAQ,CAACI,QAAQ,EAAE,CAAC;IAClC,MAAM,CA1HO,GAAI,SA0HPO,QAAQ,CAACP,QAAQ;AAC7B,CAAC;eAEc,CAAC;IACdlB,gBAAgB,EAAhBA,gBAAgB;IAChBC,eAAe,EAAfA,eAAe;IACfC,oBAAoB,EAApBA,oBAAoB;IACpBC,WAAW,EAAXA,WAAW;IACXC,gBAAgB,EAAhBA,gBAAgB;IAChBC,gBAAgB,EAAhBA,gBAAgB;IAChBC,aAAa,EAAbA,aAAa;IACbC,QAAQ,EAARA,QAAQ;IACRC,SAAS,EAATA,SAAS;IACTC,UAAU,EAAVA,UAAU;IACVC,YAAY,EAAZA,YAAY;IACZC,eAAe,EAAfA,eAAe;IACfC,UAAU,EAAVA,UAAU;IACVC,WAAW,EAAXA,WAAW;IACXC,QAAQ,EAARA,QAAQ;AACV,CAAC"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "necessary",
3
3
  "author": "James Smith",
4
- "version": "11.3.2",
4
+ "version": "11.5.0",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/necessary",
7
7
  "description": "A collection of utility functions.",
@@ -37,7 +37,7 @@ export function unshift(array1, array2) { Array.prototype.unshift.apply(array1,
37
37
  export function concat(array1, elementOrArray2) {
38
38
  const array2 = (elementOrArray2 instanceof Array) ?
39
39
  elementOrArray2 :
40
- [elementOrArray2];
40
+ [ elementOrArray2 ];
41
41
 
42
42
  push(array1, array2);
43
43
  }
@@ -182,6 +182,17 @@ export function compress(array, callback) {
182
182
  }
183
183
  }
184
184
 
185
+ export function combine(array1, array2, callback) {
186
+ const array = [
187
+ ...array1,
188
+ ...array2
189
+ ];
190
+
191
+ compress(array, callback);
192
+
193
+ return array;
194
+ }
195
+
185
196
  export function augment(array1, array2, callback) {
186
197
  array2.forEach((element, index) => {
187
198
  const passed = callback(element, index);
@@ -369,6 +380,7 @@ export default {
369
380
  prune,
370
381
  patch,
371
382
  compress,
383
+ combine,
372
384
  augment,
373
385
  separate,
374
386
  forwardsFind,
@@ -2,6 +2,7 @@
2
2
 
3
3
  import fs from "fs";
4
4
 
5
+ import { EMPTY_STRING } from "../constants";
5
6
  import { DEFAULT_ENCODING } from "../defaults";
6
7
 
7
8
  export function checkEntryExists(entryPath) {
@@ -86,6 +87,12 @@ export function writeFile(filePath, content) {
86
87
  fs.writeFileSync(filePath, content);
87
88
  }
88
89
 
90
+ export function createFile(filePath) {
91
+ const content = EMPTY_STRING;
92
+
93
+ fs.writeFileSync(filePath, content);
94
+ }
95
+
89
96
  export function appendToFile(filePath, content) {
90
97
  fs.appendFileSync(filePath, content);
91
98
  }
@@ -128,6 +135,7 @@ export default {
128
135
  readDirectory,
129
136
  readFile,
130
137
  writeFile,
138
+ createFile,
131
139
  appendToFile,
132
140
  createDirectory,
133
141
  renameFile,