necessary 11.9.3 → 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 +41 -11
- package/lib/utilities/fileSystem.js +34 -10
- package/package.json +1 -1
- package/src/utilities/fileSystem.js +35 -12
package/README.md
CHANGED
|
@@ -52,12 +52,24 @@ const { first, last } = arrayUtilities,
|
|
|
52
52
|
|
|
53
53
|
...
|
|
54
54
|
```
|
|
55
|
+
|
|
56
|
+
Or the `require()` function can be used where appropriate:
|
|
57
|
+
|
|
58
|
+
```
|
|
59
|
+
const { arrayUtilities, asynchronousUtilities, fileSystemUtilities } = require("necessary");
|
|
60
|
+
|
|
61
|
+
const { first, last } = arrayUtilities,
|
|
62
|
+
{ isDirectory } = fileSystemUtilities;
|
|
63
|
+
|
|
64
|
+
...
|
|
65
|
+
```
|
|
66
|
+
|
|
55
67
|
The miscellaneous functions are a special case. They can be treated as above but may well have other functions assigned to them. See below.
|
|
56
68
|
|
|
57
69
|
## Ajax utilities
|
|
58
70
|
|
|
59
71
|
- `get()`
|
|
60
|
-
- `post()`
|
|
72
|
+
- `post()`cp
|
|
61
73
|
- `request()`
|
|
62
74
|
|
|
63
75
|
The first two `get()` and `post()` functions make use of the third `request()` function, which is more generic and can be used for arbitrary HTTP requests.
|
|
@@ -139,7 +151,7 @@ Note that the `headers` argument is not optional this time.
|
|
|
139
151
|
|
|
140
152
|
Functions that can be used for Node applications running in a shell window.
|
|
141
153
|
|
|
142
|
-
* 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
|
|
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:
|
|
143
155
|
|
|
144
156
|
```
|
|
145
157
|
const offEXT = onEXT(process.exit);
|
|
@@ -346,11 +358,13 @@ const packageJSON = getPackageJSON(); // Returns the contents of the package.jso
|
|
|
346
358
|
- `readDirectory()`
|
|
347
359
|
- `readFile()`
|
|
348
360
|
- `writeFile()`
|
|
349
|
-
- `createFile()`
|
|
350
361
|
- `appendToFile()`
|
|
351
362
|
- `createDirectory()`
|
|
352
363
|
- `renameDirectory()`
|
|
364
|
+
- `moveDirectory()`
|
|
365
|
+
- `createFile()`
|
|
353
366
|
- `renameFile()`
|
|
367
|
+
- `moveFile()`
|
|
354
368
|
- `removeEntry()`
|
|
355
369
|
- `getStats()`
|
|
356
370
|
|
|
@@ -390,12 +404,6 @@ readFile("root/etc/init.conf"); // returns the content of the 'root/etc/init.con
|
|
|
390
404
|
writeFile("root/etc/init.conf", ""); // writes '' to the 'root/etc/init.conf' file
|
|
391
405
|
```
|
|
392
406
|
|
|
393
|
-
* The `createFile()` creates an empty file. It does not return anything upon success:
|
|
394
|
-
|
|
395
|
-
```
|
|
396
|
-
createFile("root/etc/init.conf"); // writes '' to the 'root/etc/init.conf' file
|
|
397
|
-
```
|
|
398
|
-
|
|
399
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:
|
|
400
408
|
|
|
401
409
|
```
|
|
@@ -414,12 +422,34 @@ createDirectory("root/etc/init"); // Creates the 'root/etc/init' directory
|
|
|
414
422
|
renameDirectory("/root/usr", "/root/lib"); // Renames the '/root/usr' directory to '/root/lib'
|
|
415
423
|
```
|
|
416
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
|
+
|
|
417
439
|
* The `renameFile()` function renames a file:
|
|
418
440
|
|
|
419
441
|
```
|
|
420
442
|
renameFile("hosts", "host"); // Renames the 'hosts' file to 'host'
|
|
421
443
|
```
|
|
422
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
|
+
|
|
423
453
|
* The `removeEntry()` function removes a file or directory:
|
|
424
454
|
|
|
425
455
|
```
|
|
@@ -490,7 +520,7 @@ rc(); // Provides the first environment in the '.defaultrc' file
|
|
|
490
520
|
|
|
491
521
|
Note that the `rc()` function can be included in any file but only needs to be called once. But be careful that it is called before it is ever destructured.
|
|
492
522
|
|
|
493
|
-
Aside from the aforementioned `setRCBaseExtension()` functions, the `checkRCFileExists()`, `createVacuousRCFile()`, `readRCFile()` and `writeRCFile()` functions do as their names suggest. The `updateRCFile()` function, if passed a plain old JavaScript object as the first
|
|
523
|
+
Aside from the aforementioned `setRCBaseExtension()` functions, the `checkRCFileExists()`, `createVacuousRCFile()`, `readRCFile()` and `writeRCFile()` functions do as their names suggest. The `updateRCFile()` function, if passed a plain old JavaScript object as the first argument, will add the properties therein, overwriting any existing properties. Properties to be removed can be given as further arguments. If you do not want to add as well as remove properties, set the first argument to a falsey value.
|
|
494
524
|
|
|
495
525
|
```
|
|
496
526
|
const { readRCFile, writeRCFile, updateRCFile, checkRCFileExists, createVacuousRCFile } = rc;
|
|
@@ -1054,7 +1084,7 @@ eventually(operations, () => {
|
|
|
1054
1084
|
/// done
|
|
1055
1085
|
}, context);
|
|
1056
1086
|
```
|
|
1057
|
-
* The `repeatedly()` function takes a single operation and a `length`
|
|
1087
|
+
* The `repeatedly()` function takes a single operation and a `length` argument, immediately calling the operation a `length` number of times without waiting for it to invoke the given `next()` function each time. When the operation has invoked the given `next()` function a `length` number of times, it will call the `done()` function. Note that in this case invoking the `done()` function from within the operation will not halt its execution the requisite number of times, it is passed as an argument only for the sake of convention. In the example below the operation is executed ten times:
|
|
1058
1088
|
|
|
1059
1089
|
```
|
|
1060
1090
|
const context = {};
|
|
@@ -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 =
|
|
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,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
|
|
102
|
-
|
|
103
|
-
|
|
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
|
+
}
|