necessary 11.9.4 → 11.10.2

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
@@ -151,7 +151,7 @@ Note that the `headers` argument is not optional this time.
151
151
 
152
152
  Functions that can be used for Node applications running in a shell window.
153
153
 
154
- * The `onETX()` function takes a handler which is invoked whenever the `ETX` character code is encountered in the `stdin` stream, which typically happens when the user presses `Ctrl-C`. This method is therefore useful for exiting a console application immediately upon the user's behest, if it is passed `process.exit`. It also returns a function that can be called to remove the listener at some later point in time:
154
+ * The `onETX()` function takes a handler which is invoked whenever the `ETX` character code is encountered in the `stdin` stream, which typically happens when the user presses `Ctrl-C`. This function is therefore useful for exiting a console application immediately upon the user's behest, if it is passed `process.exit`. It also returns a function that can be called to remove the listener at some later point in time:
155
155
 
156
156
  ```
157
157
  const offEXT = onEXT(process.exit);
@@ -358,11 +358,13 @@ const packageJSON = getPackageJSON(); // Returns the contents of the package.jso
358
358
  - `readDirectory()`
359
359
  - `readFile()`
360
360
  - `writeFile()`
361
- - `createFile()`
362
361
  - `appendToFile()`
363
362
  - `createDirectory()`
364
363
  - `renameDirectory()`
364
+ - `moveDirectory()`
365
+ - `createFile()`
365
366
  - `renameFile()`
367
+ - `moveFile()`
366
368
  - `removeEntry()`
367
369
  - `getStats()`
368
370
 
@@ -402,12 +404,6 @@ readFile("root/etc/init.conf"); // returns the content of the 'root/etc/init.con
402
404
  writeFile("root/etc/init.conf", ""); // writes '' to the 'root/etc/init.conf' file
403
405
  ```
404
406
 
405
- * The `createFile()` creates an empty file. It does not return anything upon success:
406
-
407
- ```
408
- createFile("root/etc/init.conf"); // writes '' to the 'root/etc/init.conf' file
409
- ```
410
-
411
407
  * 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:
412
408
 
413
409
  ```
@@ -426,12 +422,34 @@ createDirectory("root/etc/init"); // Creates the 'root/etc/init' directory
426
422
  renameDirectory("/root/usr", "/root/lib"); // Renames the '/root/usr' directory to '/root/lib'
427
423
  ```
428
424
 
425
+ Note that if the parent directory of the newly named directory does not exist then this function will fail. Instead use the `moveDirectory()` function.
426
+
427
+ * The `moveDirectory()` function moves a directory:
428
+
429
+ ```
430
+ moveDirectory("/root/usr", "/etc/lib"); // Moves the '/root/usr' directory to '/etc/lib'
431
+ ```
432
+
433
+ * The `createFile()` creates an empty file. It does not return anything upon success:
434
+
435
+ ```
436
+ createFile("root/etc/init.conf"); // writes '' to the 'root/etc/init.conf' file
437
+ ```
438
+
429
439
  * The `renameFile()` function renames a file:
430
440
 
431
441
  ```
432
442
  renameFile("hosts", "host"); // Renames the 'hosts' file to 'host'
433
443
  ```
434
444
 
445
+ Note that if the parent directory of the newly named file does not exist then this function will fail. Instead use the `moveFile()` function.
446
+
447
+ * The `moveFile()` function moves a file:
448
+
449
+ ```
450
+ moveFile("/root/usr/init.conf", "/etc/lib/init.conf"); // Moves the '/root/usr/init.conf' file to '/etc/lib/init.conf'
451
+ ```
452
+
435
453
  * The `removeEntry()` function removes a file or directory:
436
454
 
437
455
  ```
@@ -36,9 +36,6 @@ _export(exports, {
36
36
  writeFile: function() {
37
37
  return writeFile;
38
38
  },
39
- createFile: function() {
40
- return createFile;
41
- },
42
39
  appendToFile: function() {
43
40
  return appendToFile;
44
41
  },
@@ -48,9 +45,18 @@ _export(exports, {
48
45
  renameDirectory: function() {
49
46
  return renameDirectory;
50
47
  },
48
+ moveDirectory: function() {
49
+ return moveDirectory;
50
+ },
51
+ createFile: function() {
52
+ return createFile;
53
+ },
51
54
  renameFile: function() {
52
55
  return renameFile;
53
56
  },
57
+ moveFile: function() {
58
+ return moveFile;
59
+ },
54
60
  removeEntry: function() {
55
61
  return removeEntry;
56
62
  },
@@ -62,6 +68,7 @@ _export(exports, {
62
68
  }
63
69
  });
64
70
  var _fs = /*#__PURE__*/ _interop_require_default(require("fs"));
71
+ var _path = /*#__PURE__*/ _interop_require_default(require("path"));
65
72
  var _constants = require("../constants");
66
73
  var _defaults = require("../defaults");
67
74
  function _interop_require_default(obj) {
@@ -121,15 +128,12 @@ function readFile(filePath) {
121
128
  function writeFile(filePath, content) {
122
129
  _fs.default.writeFileSync(filePath, content);
123
130
  }
124
- function createFile(filePath) {
125
- var content = _constants.EMPTY_STRING;
126
- _fs.default.writeFileSync(filePath, content);
127
- }
128
131
  function appendToFile(filePath, content) {
129
132
  _fs.default.appendFileSync(filePath, content);
130
133
  }
131
134
  function createDirectory(directoryPath) {
132
- var recursive = true, options = {
135
+ var recursive = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : true;
136
+ var options = {
133
137
  recursive: recursive
134
138
  };
135
139
  _fs.default.mkdirSync(directoryPath, options);
@@ -137,9 +141,21 @@ function createDirectory(directoryPath) {
137
141
  function renameDirectory(oldDirectoryPath, newDirectoryPath) {
138
142
  _fs.default.renameSync(oldDirectoryPath, newDirectoryPath);
139
143
  }
144
+ function moveDirectory(oldDirectoryPath, newDirectoryPath) {
145
+ ensureParentDirectoryExists(newDirectoryPath);
146
+ renameDirectory(oldDirectoryPath, newDirectoryPath);
147
+ }
148
+ function createFile(filePath) {
149
+ var content = _constants.EMPTY_STRING;
150
+ _fs.default.writeFileSync(filePath, content);
151
+ }
140
152
  function renameFile(oldFilePath, newFilePath) {
141
153
  _fs.default.renameSync(oldFilePath, newFilePath);
142
154
  }
155
+ function moveFile(oldFilePath, newFilePath) {
156
+ ensureParentFileExists(newFilePath);
157
+ renameFile(oldFilePath, newFilePath);
158
+ }
143
159
  function removeEntry(entryPath) {
144
160
  var force = true, recursive = true, options = {
145
161
  force: force,
@@ -160,13 +176,21 @@ var _default = {
160
176
  readDirectory: readDirectory,
161
177
  readFile: readFile,
162
178
  writeFile: writeFile,
163
- createFile: createFile,
164
179
  appendToFile: appendToFile,
165
180
  createDirectory: createDirectory,
166
181
  renameDirectory: renameDirectory,
182
+ moveDirectory: moveDirectory,
183
+ createFile: createFile,
167
184
  renameFile: renameFile,
185
+ moveFile: moveFile,
168
186
  removeEntry: removeEntry,
169
187
  getStats: getStats
170
188
  };
189
+ function ensureParentDirectoryExists(filePath) {
190
+ var parentDirectoryPath = _path.default.dirname(filePath), parentDirectoryExists = checkDirectoryExists(parentDirectoryPath);
191
+ if (!parentDirectoryExists) {
192
+ createDirectory(parentDirectoryPath);
193
+ }
194
+ }
171
195
 
172
- //# sourceMappingURL=data:application/json;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 renameDirectory(oldDirectoryPath, newDirectoryPath) {\n  fs.renameSync(oldDirectoryPath, newDirectoryPath);\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  renameDirectory,\n  renameFile,\n  removeEntry,\n  getStats\n};\n"],"names":["checkEntryExists","checkFileExists","checkDirectoryExists","isEntryFile","isEntryDirectory","isDirectoryEmpty","readDirectory","readFile","writeFile","createFile","appendToFile","createDirectory","renameDirectory","renameFile","removeEntry","getStats","entryPath","entryExists","fs","existsSync","filePath","fileExists","entryFile","directoryPath","directoryExists","entryDirectory","stat","statSync","isDirectory","subEntryNames","subEntryNamesLength","length","directoryEmpty","readdirSync","encoding","DEFAULT_ENCODING","options","content","readFileSync","writeFileSync","EMPTY_STRING","appendFileSync","recursive","mkdirSync","oldDirectoryPath","newDirectoryPath","renameSync","oldFilePath","newFilePath","force","rmSync"],"mappings":"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"}
196
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/fileSystem.js"],"sourcesContent":["\"use strict\";\n\nimport fs from \"fs\";\nimport path from \"path\";\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 appendToFile(filePath, content) {\n  fs.appendFileSync(filePath, content);\n}\n\nexport function createDirectory(directoryPath, recursive = true) {\n  const options = {\n    recursive\n  };\n\n  fs.mkdirSync(directoryPath, options);\n}\n\nexport function renameDirectory(oldDirectoryPath, newDirectoryPath) {\n  fs.renameSync(oldDirectoryPath, newDirectoryPath);\n}\n\nexport function moveDirectory(oldDirectoryPath, newDirectoryPath) {\n  ensureParentDirectoryExists(newDirectoryPath);\n\n  renameDirectory(oldDirectoryPath, newDirectoryPath);\n}\n\nexport function createFile(filePath) {\n  const content = EMPTY_STRING;\n\n  fs.writeFileSync(filePath, content);\n}\n\nexport function renameFile(oldFilePath, newFilePath) {\n  fs.renameSync(oldFilePath, newFilePath);\n}\n\nexport function moveFile(oldFilePath, newFilePath) {\n  ensureParentFileExists(newFilePath);\n\n  renameFile(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  renameDirectory,\n  moveDirectory,\n  createFile,\n  renameFile,\n  moveFile,\n  removeEntry,\n  getStats\n};\n\nfunction ensureParentDirectoryExists(filePath) {\n  const parentDirectoryPath = path.dirname(filePath), ///\n        parentDirectoryExists = checkDirectoryExists(parentDirectoryPath);\n\n  if (!parentDirectoryExists) {\n    createDirectory(parentDirectoryPath);\n  }\n}\n"],"names":["checkEntryExists","checkFileExists","checkDirectoryExists","isEntryFile","isEntryDirectory","isDirectoryEmpty","readDirectory","readFile","writeFile","appendToFile","createDirectory","renameDirectory","moveDirectory","createFile","renameFile","moveFile","removeEntry","getStats","entryPath","entryExists","fs","existsSync","filePath","fileExists","entryFile","directoryPath","directoryExists","entryDirectory","stat","statSync","isDirectory","subEntryNames","subEntryNamesLength","length","directoryEmpty","readdirSync","encoding","DEFAULT_ENCODING","options","content","readFileSync","writeFileSync","appendFileSync","recursive","mkdirSync","oldDirectoryPath","newDirectoryPath","renameSync","ensureParentDirectoryExists","EMPTY_STRING","oldFilePath","newFilePath","ensureParentFileExists","force","rmSync","parentDirectoryPath","path","dirname","parentDirectoryExists"],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "necessary",
3
3
  "author": "James Smith",
4
- "version": "11.9.4",
4
+ "version": "11.10.2",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/necessary",
7
7
  "description": "A collection of utility functions.",
@@ -1,6 +1,7 @@
1
1
  "use strict";
2
2
 
3
3
  import fs from "fs";
4
+ import path from "path";
4
5
 
5
6
  import { EMPTY_STRING } from "../constants";
6
7
  import { DEFAULT_ENCODING } from "../defaults";
@@ -87,21 +88,14 @@ export function writeFile(filePath, content) {
87
88
  fs.writeFileSync(filePath, content);
88
89
  }
89
90
 
90
- export function createFile(filePath) {
91
- const content = EMPTY_STRING;
92
-
93
- fs.writeFileSync(filePath, content);
94
- }
95
-
96
91
  export function appendToFile(filePath, content) {
97
92
  fs.appendFileSync(filePath, content);
98
93
  }
99
94
 
100
- export function createDirectory(directoryPath) {
101
- const recursive = true,
102
- options = {
103
- recursive
104
- };
95
+ export function createDirectory(directoryPath, recursive = true) {
96
+ const options = {
97
+ recursive
98
+ };
105
99
 
106
100
  fs.mkdirSync(directoryPath, options);
107
101
  }
@@ -110,10 +104,28 @@ export function renameDirectory(oldDirectoryPath, newDirectoryPath) {
110
104
  fs.renameSync(oldDirectoryPath, newDirectoryPath);
111
105
  }
112
106
 
107
+ export function moveDirectory(oldDirectoryPath, newDirectoryPath) {
108
+ ensureParentDirectoryExists(newDirectoryPath);
109
+
110
+ renameDirectory(oldDirectoryPath, newDirectoryPath);
111
+ }
112
+
113
+ export function createFile(filePath) {
114
+ const content = EMPTY_STRING;
115
+
116
+ fs.writeFileSync(filePath, content);
117
+ }
118
+
113
119
  export function renameFile(oldFilePath, newFilePath) {
114
120
  fs.renameSync(oldFilePath, newFilePath);
115
121
  }
116
122
 
123
+ export function moveFile(oldFilePath, newFilePath) {
124
+ ensureParentFileExists(newFilePath);
125
+
126
+ renameFile(oldFilePath, newFilePath);
127
+ }
128
+
117
129
  export function removeEntry(entryPath) {
118
130
  const force = true,
119
131
  recursive = true,
@@ -139,11 +151,22 @@ export default {
139
151
  readDirectory,
140
152
  readFile,
141
153
  writeFile,
142
- createFile,
143
154
  appendToFile,
144
155
  createDirectory,
145
156
  renameDirectory,
157
+ moveDirectory,
158
+ createFile,
146
159
  renameFile,
160
+ moveFile,
147
161
  removeEntry,
148
162
  getStats
149
163
  };
164
+
165
+ function ensureParentDirectoryExists(filePath) {
166
+ const parentDirectoryPath = path.dirname(filePath), ///
167
+ parentDirectoryExists = checkDirectoryExists(parentDirectoryPath);
168
+
169
+ if (!parentDirectoryExists) {
170
+ createDirectory(parentDirectoryPath);
171
+ }
172
+ }