@appium/support 2.61.1 → 3.0.1

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.
Files changed (61) hide show
  1. package/build/lib/console.d.ts +1 -1
  2. package/build/lib/console.js +169 -105
  3. package/build/lib/console.js.map +1 -1
  4. package/build/lib/env.d.ts.map +1 -1
  5. package/build/lib/env.js +144 -117
  6. package/build/lib/env.js.map +1 -1
  7. package/build/lib/fs.d.ts +9 -2
  8. package/build/lib/fs.d.ts.map +1 -1
  9. package/build/lib/fs.js +358 -246
  10. package/build/lib/fs.js.map +1 -1
  11. package/build/lib/image-util.js +139 -124
  12. package/build/lib/image-util.js.map +1 -1
  13. package/build/lib/index.js +64 -103
  14. package/build/lib/index.js.map +1 -1
  15. package/build/lib/log-internal.d.ts +4 -27
  16. package/build/lib/log-internal.d.ts.map +1 -1
  17. package/build/lib/log-internal.js +141 -123
  18. package/build/lib/log-internal.js.map +1 -1
  19. package/build/lib/logger.d.ts +1 -1
  20. package/build/lib/logger.d.ts.map +1 -1
  21. package/build/lib/logger.js +5 -14
  22. package/build/lib/logger.js.map +1 -1
  23. package/build/lib/logging.d.ts +3 -4
  24. package/build/lib/logging.d.ts.map +1 -1
  25. package/build/lib/logging.js +139 -110
  26. package/build/lib/logging.js.map +1 -1
  27. package/build/lib/mjpeg.js +169 -141
  28. package/build/lib/mjpeg.js.map +1 -1
  29. package/build/lib/mkdirp.js +7 -13
  30. package/build/lib/mkdirp.js.map +1 -1
  31. package/build/lib/net.d.ts.map +1 -1
  32. package/build/lib/net.js +278 -254
  33. package/build/lib/net.js.map +1 -1
  34. package/build/lib/node.js +203 -192
  35. package/build/lib/node.js.map +1 -1
  36. package/build/lib/npm.d.ts +19 -4
  37. package/build/lib/npm.d.ts.map +1 -1
  38. package/build/lib/npm.js +277 -228
  39. package/build/lib/npm.js.map +1 -1
  40. package/build/lib/plist.js +145 -136
  41. package/build/lib/plist.js.map +1 -1
  42. package/build/lib/process.js +41 -42
  43. package/build/lib/process.js.map +1 -1
  44. package/build/lib/system.js +39 -56
  45. package/build/lib/system.js.map +1 -1
  46. package/build/lib/tempdir.js +112 -73
  47. package/build/lib/tempdir.js.map +1 -1
  48. package/build/lib/timing.js +99 -84
  49. package/build/lib/timing.js.map +1 -1
  50. package/build/lib/util.js +454 -356
  51. package/build/lib/util.js.map +1 -1
  52. package/build/lib/zip.js +469 -423
  53. package/build/lib/zip.js.map +1 -1
  54. package/build/tsconfig.tsbuildinfo +1 -1
  55. package/lib/env.js +6 -4
  56. package/lib/fs.js +15 -1
  57. package/lib/log-internal.js +12 -16
  58. package/lib/logging.js +2 -3
  59. package/lib/net.js +15 -6
  60. package/lib/npm.js +28 -18
  61. package/package.json +20 -19
package/build/lib/fs.js CHANGED
@@ -1,254 +1,366 @@
1
1
  "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.fs = exports.default = void 0;
7
-
8
- require("source-map-support/register");
9
-
10
- var _bluebird = _interopRequireDefault(require("bluebird"));
11
-
12
- var _crypto = _interopRequireDefault(require("crypto"));
13
-
14
- var _fs = require("fs");
15
-
16
- var _glob = _interopRequireDefault(require("glob"));
17
-
18
- var _klaw = _interopRequireDefault(require("klaw"));
19
-
20
- var _lodash = _interopRequireDefault(require("lodash"));
21
-
22
- var _mv = _interopRequireDefault(require("mv"));
23
-
24
- var _ncp = _interopRequireDefault(require("ncp"));
25
-
26
- var _path = _interopRequireDefault(require("path"));
27
-
28
- var _pkgDir = _interopRequireDefault(require("pkg-dir"));
29
-
30
- var _readPkg = _interopRequireDefault(require("read-pkg"));
31
-
32
- var _rimraf = _interopRequireDefault(require("rimraf"));
33
-
34
- var _sanitizeFilename = _interopRequireDefault(require("sanitize-filename"));
35
-
36
- var _which = _interopRequireDefault(require("which"));
37
-
38
- var _logger = _interopRequireDefault(require("./logger"));
39
-
40
- var _timing = _interopRequireDefault(require("./timing"));
41
-
42
- var _system = require("./system");
43
-
44
- var _util = require("./util");
45
-
46
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
47
-
48
- const ncpAsync = _bluebird.default.promisify(_ncp.default);
49
-
50
- const findRootCached = _lodash.default.memoize(_pkgDir.default.sync);
51
-
2
+ // @ts-check
3
+ var __importDefault = (this && this.__importDefault) || function (mod) {
4
+ return (mod && mod.__esModule) ? mod : { "default": mod };
5
+ };
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.fs = void 0;
8
+ const bluebird_1 = __importDefault(require("bluebird"));
9
+ const crypto_1 = __importDefault(require("crypto"));
10
+ const fs_1 = require("fs");
11
+ const glob_1 = __importDefault(require("glob"));
12
+ const klaw_1 = __importDefault(require("klaw"));
13
+ const lodash_1 = __importDefault(require("lodash"));
14
+ const mv_1 = __importDefault(require("mv"));
15
+ const ncp_1 = __importDefault(require("ncp"));
16
+ const path_1 = __importDefault(require("path"));
17
+ const pkg_dir_1 = __importDefault(require("pkg-dir"));
18
+ const read_pkg_1 = __importDefault(require("read-pkg"));
19
+ const rimraf_1 = __importDefault(require("rimraf"));
20
+ const sanitize_filename_1 = __importDefault(require("sanitize-filename"));
21
+ const which_1 = __importDefault(require("which"));
22
+ const logger_1 = __importDefault(require("./logger"));
23
+ const timing_1 = __importDefault(require("./timing"));
24
+ const system_1 = require("./system");
25
+ const util_1 = require("./util");
26
+ const ncpAsync =
27
+ /** @type {(source: string, dest: string, opts: ncp.Options|undefined) => B<void>} */ (bluebird_1.default.promisify(ncp_1.default));
28
+ const findRootCached = lodash_1.default.memoize(pkg_dir_1.default.sync);
52
29
  const fs = {
53
- async hasAccess(path) {
54
- try {
55
- await _fs.promises.access(path, _fs.constants.R_OK);
56
- } catch {
57
- return false;
58
- }
59
-
60
- return true;
61
- },
62
-
63
- async isExecutable(path) {
64
- try {
65
- if ((0, _system.isWindows)()) {
30
+ /**
31
+ * Resolves `true` if `path` is _readable_, which differs from Node.js' default behavior of "can we see it?"
32
+ *
33
+ * On Windows, ACLs are not supported, so this becomes a simple check for existence.
34
+ *
35
+ * This function will never reject.
36
+ * @param {PathLike} path
37
+ * @returns {Promise<boolean>}
38
+ */
39
+ async hasAccess(path) {
40
+ try {
41
+ await fs_1.promises.access(path, fs_1.constants.R_OK);
42
+ }
43
+ catch {
44
+ return false;
45
+ }
46
+ return true;
47
+ },
48
+ /**
49
+ * Resolves `true` if `path` is executable; `false` otherwise.
50
+ *
51
+ * On Windows, this function delegates to {@linkcode fs.hasAccess}.
52
+ *
53
+ * This function will never reject.
54
+ * @param {PathLike} path
55
+ * @returns {Promise<boolean>}
56
+ */
57
+ async isExecutable(path) {
58
+ try {
59
+ if ((0, system_1.isWindows)()) {
60
+ return await fs.hasAccess(path);
61
+ }
62
+ await fs_1.promises.access(path, fs_1.constants.R_OK | fs_1.constants.X_OK);
63
+ }
64
+ catch {
65
+ return false;
66
+ }
67
+ return true;
68
+ },
69
+ /**
70
+ * Alias for {@linkcode fs.hasAccess}
71
+ * @param {PathLike} path
72
+ */
73
+ async exists(path) {
66
74
  return await fs.hasAccess(path);
67
- }
68
-
69
- await _fs.promises.access(path, _fs.constants.R_OK | _fs.constants.X_OK);
70
- } catch {
71
- return false;
72
- }
73
-
74
- return true;
75
- },
76
-
77
- async exists(path) {
78
- return await fs.hasAccess(path);
79
- },
80
-
81
- rimraf: _bluebird.default.promisify(_rimraf.default),
82
- rimrafSync: _rimraf.default.sync,
83
-
84
- async mkdir(filepath, opts = {}) {
85
- try {
86
- return await _fs.promises.mkdir(filepath, opts);
87
- } catch (err) {
88
- if ((err === null || err === void 0 ? void 0 : err.code) !== 'EEXIST') {
89
- throw err;
90
- }
91
- }
92
- },
93
-
94
- async copyFile(source, destination, opts = {}) {
95
- if (!(await fs.hasAccess(source))) {
96
- throw new Error(`The file at '${source}' does not exist or is not accessible`);
97
- }
98
-
99
- return await ncpAsync(source, destination, opts);
100
- },
101
-
102
- async md5(filePath) {
103
- return await fs.hash(filePath, 'md5');
104
- },
105
-
106
- mv: _bluebird.default.promisify(_mv.default),
107
- which: _which.default,
108
- glob: _bluebird.default.promisify(_glob.default),
109
- sanitizeName: _sanitizeFilename.default,
110
-
111
- async hash(filePath, algorithm = 'sha1') {
112
- return await new _bluebird.default((resolve, reject) => {
113
- const fileHash = _crypto.default.createHash(algorithm);
114
-
115
- const readStream = (0, _fs.createReadStream)(filePath);
116
- readStream.on('error', e => reject(new Error(`Cannot calculate ${algorithm} hash for '${filePath}'. Original error: ${e.message}`)));
117
- readStream.on('data', chunk => fileHash.update(chunk));
118
- readStream.on('end', () => resolve(fileHash.digest('hex')));
119
- });
120
- },
121
-
122
- walk(dir, opts) {
123
- return (0, _klaw.default)(dir, opts);
124
- },
125
-
126
- async mkdirp(dir) {
127
- return await fs.mkdir(dir, {
128
- recursive: true
129
- });
130
- },
131
-
132
- async walkDir(dir, recursive, callback) {
133
- let isValidRoot = false;
134
- let errMsg = null;
135
-
136
- try {
137
- isValidRoot = (await fs.stat(dir)).isDirectory();
138
- } catch (e) {
139
- errMsg = e.message;
140
- }
141
-
142
- if (!isValidRoot) {
143
- throw Error(`'${dir}' is not a valid root directory` + (errMsg ? `. Original error: ${errMsg}` : ''));
144
- }
145
-
146
- let walker;
147
- let fileCount = 0;
148
- let directoryCount = 0;
149
- const timer = new _timing.default().start();
150
- return await new _bluebird.default(function (resolve, reject) {
151
- let lastFileProcessed = _bluebird.default.resolve();
152
-
153
- walker = (0, _klaw.default)(dir, {
154
- depthLimit: recursive ? -1 : 0
155
- });
156
- walker.on('data', function (item) {
157
- walker.pause();
158
-
159
- if (!item.stats.isDirectory()) {
160
- fileCount++;
161
- } else {
162
- directoryCount++;
75
+ },
76
+ /**
77
+ * Remove a directory and all its contents, recursively
78
+ * @todo Replace with `rm()` from `fs.promises` when Node.js v12 support is dropped.
79
+ */
80
+ rimraf: /** @type {(dirpath: string, opts?: import('rimraf').Options) => Promise<void>} */ (bluebird_1.default.promisify(rimraf_1.default)),
81
+ /**
82
+ * Alias of {@linkcode rimrafIdx.sync}
83
+ * @todo Replace with `rmSync()` from `fs` when Node.js v12 support is dropped.
84
+ */
85
+ rimrafSync: rimraf_1.default.sync,
86
+ /**
87
+ * Like Node.js' `fsPromises.mkdir()`, but will _not_ reject if the directory already exists.
88
+ *
89
+ * @param {string|Buffer|URL} filepath
90
+ * @param {import('fs').MakeDirectoryOptions} [opts]
91
+ * @returns {Promise<string|undefined>}
92
+ * @see https://nodejs.org/api/fs.html#fspromisesmkdirpath-options
93
+ */
94
+ async mkdir(filepath, opts = {}) {
95
+ try {
96
+ return await fs_1.promises.mkdir(filepath, opts);
97
+ }
98
+ catch (err) {
99
+ if (err?.code !== 'EEXIST') {
100
+ throw err;
101
+ }
102
+ }
103
+ },
104
+ /**
105
+ * Copies files _and entire directories_
106
+ * @param {string} source - Source to copy
107
+ * @param {string} destination - Destination to copy to
108
+ * @param {ncp.Options} [opts] - Additional arguments to pass to `ncp`
109
+ * @see https://npm.im/ncp
110
+ * @returns {Promise<void>}
111
+ */
112
+ async copyFile(source, destination, opts = {}) {
113
+ if (!(await fs.hasAccess(source))) {
114
+ throw new Error(`The file at '${source}' does not exist or is not accessible`);
163
115
  }
164
-
165
- lastFileProcessed = _bluebird.default.try(async () => await callback(item.path, item.stats.isDirectory())).then(function (done = false) {
166
- if (done) {
167
- resolve(item.path);
168
- } else {
169
- walker.resume();
170
- }
171
- }).catch(reject);
172
- }).on('error', function (err, item) {
173
- _logger.default.warn(`Got an error while walking '${item.path}': ${err.message}`);
174
-
175
- if (err.code === 'ENOENT') {
176
- _logger.default.warn('All files may not have been accessed');
177
-
178
- reject(err);
116
+ return await ncpAsync(source, destination, opts);
117
+ },
118
+ /**
119
+ * Create an MD5 hash of a file.
120
+ * @param {PathLike} filePath
121
+ * @returns {Promise<string>}
122
+ */
123
+ async md5(filePath) {
124
+ return await fs.hash(filePath, 'md5');
125
+ },
126
+ /**
127
+ * Move a file
128
+ */
129
+ mv: /** @type {(from: string, to: string, opts?: mv.Options) => B<void>} */ (bluebird_1.default.promisify(mv_1.default)),
130
+ /**
131
+ * Find path to an executable in system `PATH`
132
+ * @see https://github.com/npm/node-which
133
+ */
134
+ which: which_1.default,
135
+ /**
136
+ * Given a glob pattern, resolve with list of files matching that pattern
137
+ * @see https://github.com/isaacs/node-glob
138
+ */
139
+ glob: /** @type {(pattern: string, opts?: glob.IOptions) => B<string[]>} */ (bluebird_1.default.promisify(glob_1.default)),
140
+ /**
141
+ * Sanitize a filename
142
+ * @see https://github.com/parshap/node-sanitize-filename
143
+ */
144
+ sanitizeName: sanitize_filename_1.default,
145
+ /**
146
+ * Create a hex digest of some file at `filePath`
147
+ * @param {PathLike} filePath
148
+ * @param {string} [algorithm]
149
+ * @returns {Promise<string>}
150
+ */
151
+ async hash(filePath, algorithm = 'sha1') {
152
+ return await new bluebird_1.default((resolve, reject) => {
153
+ const fileHash = crypto_1.default.createHash(algorithm);
154
+ const readStream = (0, fs_1.createReadStream)(filePath);
155
+ readStream.on('error', (e) => reject(new Error(`Cannot calculate ${algorithm} hash for '${filePath}'. Original error: ${e.message}`)));
156
+ readStream.on('data', (chunk) => fileHash.update(chunk));
157
+ readStream.on('end', () => resolve(fileHash.digest('hex')));
158
+ });
159
+ },
160
+ /**
161
+ * Returns an `Walker` instance, which is a readable stream (and thusly an async iterator).
162
+ *
163
+ * @param {string} dir - Dir to start walking at
164
+ * @param {import('klaw').Options} [opts]
165
+ * @returns {import('klaw').Walker}
166
+ * @see https://www.npmjs.com/package/klaw
167
+ */
168
+ walk(dir, opts) {
169
+ return (0, klaw_1.default)(dir, opts);
170
+ },
171
+ /**
172
+ * Recursively create a directory.
173
+ * @param {PathLike} dir
174
+ * @returns {Promise<string|undefined>}
175
+ */
176
+ async mkdirp(dir) {
177
+ return await fs.mkdir(dir, { recursive: true });
178
+ },
179
+ /**
180
+ * Walks a directory given according to the parameters given. The callback will be invoked with a path joined with the dir parameter
181
+ * @param {string} dir Directory path where we will start walking
182
+ * @param {boolean} recursive Set it to true if you want to continue walking sub directories
183
+ * @param {WalkDirCallback} callback The callback to be called when a new path is found
184
+ * @throws {Error} If the `dir` parameter contains a path to an invalid folder
185
+ * @returns {Promise<string?>} returns the found path or null if the item was not found
186
+ */
187
+ async walkDir(dir, recursive, callback) {
188
+ //eslint-disable-line promise/prefer-await-to-callbacks
189
+ let isValidRoot = false;
190
+ let errMsg = null;
191
+ try {
192
+ isValidRoot = (await fs.stat(dir)).isDirectory();
193
+ }
194
+ catch (e) {
195
+ errMsg = e.message;
179
196
  }
180
- }).on('end', function () {
181
- lastFileProcessed.then(file => {
182
- resolve(file ?? null);
183
- }).catch(function (err) {
184
- _logger.default.warn(`Unexpected error: ${err.message}`);
185
-
186
- reject(err);
197
+ if (!isValidRoot) {
198
+ throw Error(`'${dir}' is not a valid root directory` + (errMsg ? `. Original error: ${errMsg}` : ''));
199
+ }
200
+ let walker;
201
+ let fileCount = 0;
202
+ let directoryCount = 0;
203
+ const timer = new timing_1.default().start();
204
+ return await new bluebird_1.default(function (resolve, reject) {
205
+ let lastFileProcessed = bluebird_1.default.resolve();
206
+ walker = (0, klaw_1.default)(dir, {
207
+ depthLimit: recursive ? -1 : 0,
208
+ });
209
+ walker
210
+ .on('data', function (item) {
211
+ walker.pause();
212
+ if (!item.stats.isDirectory()) {
213
+ fileCount++;
214
+ }
215
+ else {
216
+ directoryCount++;
217
+ }
218
+ // eslint-disable-next-line promise/prefer-await-to-callbacks
219
+ lastFileProcessed = bluebird_1.default.try(async () => await callback(item.path, item.stats.isDirectory()))
220
+ .then(function (done = false) {
221
+ if (done) {
222
+ resolve(item.path);
223
+ }
224
+ else {
225
+ walker.resume();
226
+ }
227
+ })
228
+ .catch(reject);
229
+ })
230
+ .on('error', function (err, item) {
231
+ logger_1.default.warn(`Got an error while walking '${item.path}': ${err.message}`);
232
+ // klaw cannot get back from an ENOENT error
233
+ if (err.code === 'ENOENT') {
234
+ logger_1.default.warn('All files may not have been accessed');
235
+ reject(err);
236
+ }
237
+ })
238
+ .on('end', function () {
239
+ lastFileProcessed
240
+ .then((file) => {
241
+ resolve(/** @type {string|undefined} */ (file) ?? null);
242
+ })
243
+ .catch(function (err) {
244
+ logger_1.default.warn(`Unexpected error: ${err.message}`);
245
+ reject(err);
246
+ });
247
+ });
248
+ }).finally(function () {
249
+ logger_1.default.debug(`Traversed ${(0, util_1.pluralize)('directory', directoryCount, true)} ` +
250
+ `and ${(0, util_1.pluralize)('file', fileCount, true)} ` +
251
+ `in ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);
252
+ if (walker) {
253
+ walker.destroy();
254
+ }
187
255
  });
188
- });
189
- }).finally(function () {
190
- _logger.default.debug(`Traversed ${(0, _util.pluralize)('directory', directoryCount, true)} ` + `and ${(0, _util.pluralize)('file', fileCount, true)} ` + `in ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`);
191
-
192
- if (walker) {
193
- walker.destroy();
194
- }
195
- });
196
- },
197
-
198
- readPackageJsonFrom(dir, opts = {}) {
199
- const cwd = fs.findRoot(dir);
200
-
201
- try {
202
- return _readPkg.default.sync({ ...opts,
203
- cwd
204
- });
205
- } catch (err) {
206
- err.message = `Failed to read a \`package.json\` from dir \`${dir}\`:\n\n${err.message}`;
207
- throw err;
208
- }
209
- },
210
-
211
- findRoot(dir) {
212
- if (!dir || !_path.default.isAbsolute(dir)) {
213
- throw new TypeError('`findRoot()` must be provided a non-empty, absolute path');
214
- }
215
-
216
- const result = findRootCached(dir);
217
-
218
- if (!result) {
219
- throw new Error(`\`findRoot()\` could not find \`package.json\` from ${dir}`);
220
- }
221
-
222
- return result;
223
- },
224
-
225
- access: _fs.promises.access,
226
- appendFile: _fs.promises.appendFile,
227
- chmod: _fs.promises.chmod,
228
- close: _bluebird.default.promisify(_fs.close),
229
- constants: _fs.constants,
230
- createWriteStream: _fs.createWriteStream,
231
- createReadStream: _fs.createReadStream,
232
- lstat: _fs.promises.lstat,
233
- open: _bluebird.default.promisify(_fs.open),
234
- openFile: _fs.promises.open,
235
- readdir: _fs.promises.readdir,
236
- read: _bluebird.default.promisify(_fs.read),
237
- readFile: _fs.promises.readFile,
238
- readlink: _fs.promises.readlink,
239
- realpath: _fs.promises.realpath,
240
- rename: _fs.promises.rename,
241
- stat: _fs.promises.stat,
242
- symlink: _fs.promises.symlink,
243
- unlink: _fs.promises.unlink,
244
- write: _bluebird.default.promisify(_fs.write),
245
- writeFile: _fs.promises.writeFile,
246
- F_OK: _fs.constants.F_OK,
247
- R_OK: _fs.constants.R_OK,
248
- W_OK: _fs.constants.W_OK,
249
- X_OK: _fs.constants.X_OK
256
+ },
257
+ /**
258
+ * Reads the closest `package.json` file from absolute path `dir`.
259
+ * @param {string} dir - Directory to search from
260
+ * @param {import('read-pkg').Options} [opts] - Additional options for `read-pkg`
261
+ * @throws {Error} If there were problems finding or reading a `package.json` file
262
+ * @returns {object} A parsed `package.json`
263
+ */
264
+ readPackageJsonFrom(dir, opts = {}) {
265
+ const cwd = fs.findRoot(dir);
266
+ try {
267
+ return read_pkg_1.default.sync({ ...opts, cwd });
268
+ }
269
+ catch (err) {
270
+ err.message = `Failed to read a \`package.json\` from dir \`${dir}\`:\n\n${err.message}`;
271
+ throw err;
272
+ }
273
+ },
274
+ /**
275
+ * Finds the project root directory from `dir`.
276
+ * @param {string} dir - Directory to search from
277
+ * @throws {TypeError} If `dir` is not a nonempty string or relative path
278
+ * @throws {Error} If there were problems finding the project root
279
+ * @returns {string} The closeset parent dir containing `package.json`
280
+ */
281
+ findRoot(dir) {
282
+ if (!dir || !path_1.default.isAbsolute(dir)) {
283
+ throw new TypeError('`findRoot()` must be provided a non-empty, absolute path');
284
+ }
285
+ const result = findRootCached(dir);
286
+ if (!result) {
287
+ throw new Error(`\`findRoot()\` could not find \`package.json\` from ${dir}`);
288
+ }
289
+ return result;
290
+ },
291
+ // add the supported `fs` functions
292
+ access: fs_1.promises.access,
293
+ appendFile: fs_1.promises.appendFile,
294
+ chmod: fs_1.promises.chmod,
295
+ close: bluebird_1.default.promisify(fs_1.close),
296
+ constants: fs_1.constants,
297
+ createWriteStream: fs_1.createWriteStream,
298
+ createReadStream: fs_1.createReadStream,
299
+ lstat: fs_1.promises.lstat,
300
+ /**
301
+ * Warning: this is a promisified {@linkcode open fs.open}.
302
+ * It resolves w/a file descriptor instead of a {@linkcode fsPromises.FileHandle FileHandle} object, as {@linkcode fsPromises.open} does. Use {@linkcode fs.openFile} if you want a `FileHandle`.
303
+ * @type {(path: PathLike, flags: import('fs').OpenMode, mode?: import('fs').Mode) => Promise<number>}
304
+ */
305
+ open: bluebird_1.default.promisify(fs_1.open),
306
+ openFile: fs_1.promises.open,
307
+ readdir: fs_1.promises.readdir,
308
+ read: /**
309
+ * @type {ReadFn<NodeJS.ArrayBufferView>}
310
+ */ ( /** @type {unknown} */(bluebird_1.default.promisify(fs_1.read))),
311
+ readFile: fs_1.promises.readFile,
312
+ readlink: fs_1.promises.readlink,
313
+ realpath: fs_1.promises.realpath,
314
+ rename: fs_1.promises.rename,
315
+ stat: fs_1.promises.stat,
316
+ symlink: fs_1.promises.symlink,
317
+ unlink: fs_1.promises.unlink,
318
+ write: bluebird_1.default.promisify(fs_1.write),
319
+ writeFile: fs_1.promises.writeFile,
320
+ // deprecated props
321
+ /**
322
+ * Use `constants.F_OK` instead.
323
+ * @deprecated
324
+ */
325
+ F_OK: fs_1.constants.F_OK,
326
+ /**
327
+ * Use `constants.R_OK` instead.
328
+ * @deprecated
329
+ */
330
+ R_OK: fs_1.constants.R_OK,
331
+ /**
332
+ * Use `constants.W_OK` instead.
333
+ * @deprecated
334
+ */
335
+ W_OK: fs_1.constants.W_OK,
336
+ /**
337
+ * Use `constants.X_OK` instead.
338
+ * @deprecated
339
+ */
340
+ X_OK: fs_1.constants.X_OK,
250
341
  };
251
342
  exports.fs = fs;
252
- var _default = fs;
253
- exports.default = _default;
254
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ncpAsync","B","promisify","ncp","findRootCached","_","memoize","pkgDir","sync","fs","hasAccess","path","fsPromises","access","constants","R_OK","isExecutable","isWindows","X_OK","exists","rimraf","rimrafIdx","rimrafSync","mkdir","filepath","opts","err","code","copyFile","source","destination","Error","md5","filePath","hash","mv","which","glob","sanitizeName","sanitize","algorithm","resolve","reject","fileHash","crypto","createHash","readStream","createReadStream","on","e","message","chunk","update","digest","walk","dir","klaw","mkdirp","recursive","walkDir","callback","isValidRoot","errMsg","stat","isDirectory","walker","fileCount","directoryCount","timer","Timer","start","lastFileProcessed","depthLimit","item","pause","stats","try","then","done","resume","catch","log","warn","file","finally","debug","pluralize","getDuration","asMilliSeconds","toFixed","destroy","readPackageJsonFrom","cwd","findRoot","readPkg","isAbsolute","TypeError","result","appendFile","chmod","close","createWriteStream","lstat","open","openFile","readdir","read","readFile","readlink","realpath","rename","symlink","unlink","write","writeFile","F_OK","W_OK"],"sources":["../../lib/fs.js"],"sourcesContent":["// @ts-check\n\nimport B from 'bluebird';\nimport crypto from 'crypto';\nimport {\n  close,\n  constants,\n  createReadStream,\n  createWriteStream,\n  promises as fsPromises,\n  read,\n  write,\n  open,\n} from 'fs';\nimport glob from 'glob';\nimport klaw from 'klaw';\nimport _ from 'lodash';\nimport mv from 'mv';\nimport ncp from 'ncp';\nimport path from 'path';\nimport pkgDir from 'pkg-dir';\nimport readPkg from 'read-pkg';\nimport rimrafIdx from 'rimraf';\nimport sanitize from 'sanitize-filename';\nimport which from 'which';\nimport log from './logger';\nimport Timer from './timing';\nimport {isWindows} from './system';\nimport {pluralize} from './util';\n\nconst ncpAsync =\n  /** @type {(source: string, dest: string, opts: ncp.Options|undefined) => B<void>} */ (\n    B.promisify(ncp)\n  );\nconst findRootCached = _.memoize(pkgDir.sync);\n\nconst fs = {\n  /**\n   * Resolves `true` if `path` is _readable_, which differs from Node.js' default behavior of \"can we see it?\"\n   *\n   * On Windows, ACLs are not supported, so this becomes a simple check for existence.\n   *\n   * This function will never reject.\n   * @param {PathLike} path\n   * @returns {Promise<boolean>}\n   */\n  async hasAccess(path) {\n    try {\n      await fsPromises.access(path, constants.R_OK);\n    } catch {\n      return false;\n    }\n    return true;\n  },\n\n  /**\n   * Resolves `true` if `path` is executable; `false` otherwise.\n   *\n   * On Windows, this function delegates to {@linkcode fs.hasAccess}.\n   *\n   * This function will never reject.\n   * @param {PathLike} path\n   * @returns {Promise<boolean>}\n   */\n  async isExecutable(path) {\n    try {\n      if (isWindows()) {\n        return await fs.hasAccess(path);\n      }\n      await fsPromises.access(path, constants.R_OK | constants.X_OK);\n    } catch {\n      return false;\n    }\n    return true;\n  },\n\n  /**\n   * Alias for {@linkcode fs.hasAccess}\n   * @param {PathLike} path\n   */\n  async exists(path) {\n    return await fs.hasAccess(path);\n  },\n\n  /**\n   * Remove a directory and all its contents, recursively\n   * @todo Replace with `rm()` from `fs.promises` when Node.js v12 support is dropped.\n   */\n  rimraf: /** @type {(dirpath: string, opts?: import('rimraf').Options) => Promise<void>} */ (\n    B.promisify(rimrafIdx)\n  ),\n\n  /**\n   * Alias of {@linkcode rimrafIdx.sync}\n   * @todo Replace with `rmSync()` from `fs` when Node.js v12 support is dropped.\n   */\n  rimrafSync: rimrafIdx.sync,\n\n  /**\n   * Like Node.js' `fsPromises.mkdir()`, but will _not_ reject if the directory already exists.\n   *\n   * @param {string|Buffer|URL} filepath\n   * @param {import('fs').MakeDirectoryOptions} [opts]\n   * @returns {Promise<string|undefined>}\n   * @see https://nodejs.org/api/fs.html#fspromisesmkdirpath-options\n   */\n  async mkdir(filepath, opts = {}) {\n    try {\n      return await fsPromises.mkdir(filepath, opts);\n    } catch (err) {\n      if (err?.code !== 'EEXIST') {\n        throw err;\n      }\n    }\n  },\n  /**\n   * Copies files _and entire directories_\n   * @param {string} source - Source to copy\n   * @param {string} destination - Destination to copy to\n   * @param {ncp.Options} [opts] - Additional arguments to pass to `ncp`\n   * @see https://npm.im/ncp\n   * @returns {Promise<void>}\n   */\n  async copyFile(source, destination, opts = {}) {\n    if (!(await fs.hasAccess(source))) {\n      throw new Error(`The file at '${source}' does not exist or is not accessible`);\n    }\n    return await ncpAsync(source, destination, opts);\n  },\n\n  /**\n   * Create an MD5 hash of a file.\n   * @param {PathLike} filePath\n   * @returns {Promise<string>}\n   */\n  async md5(filePath) {\n    return await fs.hash(filePath, 'md5');\n  },\n\n  /**\n   * Move a file\n   */\n  mv: /** @type {(from: string, to: string, opts?: mv.Options) => B<void>} */ (B.promisify(mv)),\n\n  /**\n   * Find path to an executable in system `PATH`\n   * @see https://github.com/npm/node-which\n   */\n  which,\n\n  /**\n   * Given a glob pattern, resolve with list of files matching that pattern\n   * @see https://github.com/isaacs/node-glob\n   */\n  glob: /** @type {(pattern: string, opts?: glob.IOptions) => B<string[]>} */ (B.promisify(glob)),\n\n  /**\n   * Sanitize a filename\n   * @see https://github.com/parshap/node-sanitize-filename\n   */\n  sanitizeName: sanitize,\n\n  /**\n   * Create a hex digest of some file at `filePath`\n   * @param {PathLike} filePath\n   * @param {string} [algorithm]\n   * @returns {Promise<string>}\n   */\n  async hash(filePath, algorithm = 'sha1') {\n    return await new B((resolve, reject) => {\n      const fileHash = crypto.createHash(algorithm);\n      const readStream = createReadStream(filePath);\n      readStream.on('error', (e) =>\n        reject(\n          new Error(\n            `Cannot calculate ${algorithm} hash for '${filePath}'. Original error: ${e.message}`\n          )\n        )\n      );\n      readStream.on('data', (chunk) => fileHash.update(chunk));\n      readStream.on('end', () => resolve(fileHash.digest('hex')));\n    });\n  },\n\n  /**\n   * Returns an `Walker` instance, which is a readable stream (and thusly an async iterator).\n   *\n   * @param {string} dir - Dir to start walking at\n   * @param {import('klaw').Options} [opts]\n   * @returns {import('klaw').Walker}\n   * @see https://www.npmjs.com/package/klaw\n   */\n  walk(dir, opts) {\n    return klaw(dir, opts);\n  },\n\n  /**\n   * Recursively create a directory.\n   * @param {PathLike} dir\n   * @returns {Promise<string|undefined>}\n   */\n  async mkdirp(dir) {\n    return await fs.mkdir(dir, {recursive: true});\n  },\n\n  /**\n   * Walks a directory given according to the parameters given. The callback will be invoked with a path joined with the dir parameter\n   * @param {string} dir Directory path where we will start walking\n   * @param {boolean} recursive Set it to true if you want to continue walking sub directories\n   * @param {WalkDirCallback} callback The callback to be called when a new path is found\n   * @throws {Error} If the `dir` parameter contains a path to an invalid folder\n   * @returns {Promise<string?>} returns the found path or null if the item was not found\n   */\n  async walkDir(dir, recursive, callback) {\n    //eslint-disable-line promise/prefer-await-to-callbacks\n    let isValidRoot = false;\n    let errMsg = null;\n    try {\n      isValidRoot = (await fs.stat(dir)).isDirectory();\n    } catch (e) {\n      errMsg = e.message;\n    }\n    if (!isValidRoot) {\n      throw Error(\n        `'${dir}' is not a valid root directory` + (errMsg ? `. Original error: ${errMsg}` : '')\n      );\n    }\n\n    let walker;\n    let fileCount = 0;\n    let directoryCount = 0;\n    const timer = new Timer().start();\n    return await new B(function (resolve, reject) {\n      let lastFileProcessed = B.resolve();\n      walker = klaw(dir, {\n        depthLimit: recursive ? -1 : 0,\n      });\n      walker\n        .on('data', function (item) {\n          walker.pause();\n\n          if (!item.stats.isDirectory()) {\n            fileCount++;\n          } else {\n            directoryCount++;\n          }\n\n          // eslint-disable-next-line promise/prefer-await-to-callbacks\n          lastFileProcessed = B.try(async () => await callback(item.path, item.stats.isDirectory()))\n            .then(function (done = false) {\n              if (done) {\n                resolve(item.path);\n              } else {\n                walker.resume();\n              }\n            })\n            .catch(reject);\n        })\n        .on('error', function (err, item) {\n          log.warn(`Got an error while walking '${item.path}': ${err.message}`);\n          // klaw cannot get back from an ENOENT error\n          if (err.code === 'ENOENT') {\n            log.warn('All files may not have been accessed');\n            reject(err);\n          }\n        })\n        .on('end', function () {\n          lastFileProcessed\n            .then((file) => {\n              resolve(/** @type {string|undefined} */ (file) ?? null);\n            })\n            .catch(function (err) {\n              log.warn(`Unexpected error: ${err.message}`);\n              reject(err);\n            });\n        });\n    }).finally(function () {\n      log.debug(\n        `Traversed ${pluralize('directory', directoryCount, true)} ` +\n          `and ${pluralize('file', fileCount, true)} ` +\n          `in ${timer.getDuration().asMilliSeconds.toFixed(0)}ms`\n      );\n      if (walker) {\n        walker.destroy();\n      }\n    });\n  },\n  /**\n   * Reads the closest `package.json` file from absolute path `dir`.\n   * @param {string} dir - Directory to search from\n   * @param {import('read-pkg').Options} [opts] - Additional options for `read-pkg`\n   * @throws {Error} If there were problems finding or reading a `package.json` file\n   * @returns {object} A parsed `package.json`\n   */\n  readPackageJsonFrom(dir, opts = {}) {\n    const cwd = fs.findRoot(dir);\n    try {\n      return readPkg.sync({...opts, cwd});\n    } catch (err) {\n      err.message = `Failed to read a \\`package.json\\` from dir \\`${dir}\\`:\\n\\n${err.message}`;\n      throw err;\n    }\n  },\n  /**\n   * Finds the project root directory from `dir`.\n   * @param {string} dir - Directory to search from\n   * @throws {TypeError} If `dir` is not a nonempty string or relative path\n   * @throws {Error} If there were problems finding the project root\n   * @returns {string} The closeset parent dir containing `package.json`\n   */\n  findRoot(dir) {\n    if (!dir || !path.isAbsolute(dir)) {\n      throw new TypeError('`findRoot()` must be provided a non-empty, absolute path');\n    }\n    const result = findRootCached(dir);\n    if (!result) {\n      throw new Error(`\\`findRoot()\\` could not find \\`package.json\\` from ${dir}`);\n    }\n    return result;\n  },\n\n  // add the supported `fs` functions\n  access: fsPromises.access,\n  appendFile: fsPromises.appendFile,\n  chmod: fsPromises.chmod,\n  close: B.promisify(close),\n  constants,\n  createWriteStream,\n  createReadStream,\n  lstat: fsPromises.lstat,\n  /**\n   * Warning: this is a promisified {@linkcode open fs.open}.\n   * It resolves w/a file descriptor instead of a {@linkcode fsPromises.FileHandle FileHandle} object, as {@linkcode fsPromises.open} does. Use {@linkcode fs.openFile} if you want a `FileHandle`.\n   * @type {(path: PathLike, flags: import('fs').OpenMode, mode?: import('fs').Mode) => Promise<number>}\n   */\n  open: B.promisify(open),\n  openFile: fsPromises.open,\n  readdir: fsPromises.readdir,\n  read: B.promisify(read),\n  readFile: fsPromises.readFile,\n  readlink: fsPromises.readlink,\n  realpath: fsPromises.realpath,\n  rename: fsPromises.rename,\n  stat: fsPromises.stat,\n  symlink: fsPromises.symlink,\n  unlink: fsPromises.unlink,\n  write: B.promisify(write),\n  writeFile: fsPromises.writeFile,\n\n  // deprecated props\n\n  /**\n   * Use `constants.F_OK` instead.\n   * @deprecated\n   */\n  F_OK: constants.F_OK,\n\n  /**\n   * Use `constants.R_OK` instead.\n   * @deprecated\n   */\n  R_OK: constants.R_OK,\n\n  /**\n   * Use `constants.W_OK` instead.\n   * @deprecated\n   */\n  W_OK: constants.W_OK,\n\n  /**\n   * Use `constants.X_OK` instead.\n   * @deprecated\n   */\n  X_OK: constants.X_OK,\n};\n\nexport {fs};\nexport default fs;\n\n/**\n * The callback function which will be called during the directory walking\n * @callback WalkDirCallback\n * @param {string} itemPath The path of the file or folder\n * @param {boolean} isDirectory Shows if it is a directory or a file\n * @return {boolean} return true if you want to stop walking\n */\n\n/**\n * @typedef {import('glob')} glob\n * @typedef {import('mv')} mv\n * @typedef {import('fs').PathLike} PathLike\n */\n"],"mappings":"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"}
343
+ exports.default = fs;
344
+ /**
345
+ * The callback function which will be called during the directory walking
346
+ * @callback WalkDirCallback
347
+ * @param {string} itemPath The path of the file or folder
348
+ * @param {boolean} isDirectory Shows if it is a directory or a file
349
+ * @return {boolean} return true if you want to stop walking
350
+ */
351
+ /**
352
+ * @typedef {import('glob')} glob
353
+ * @typedef {import('mv')} mv
354
+ * @typedef {import('fs').PathLike} PathLike
355
+ */
356
+ /**
357
+ * @template {NodeJS.ArrayBufferView} TBuffer
358
+ * @callback ReadFn
359
+ * @param {number} fd
360
+ * @param {TBuffer|import('node:fs').ReadAsyncOptions<TBuffer>} buffer
361
+ * @param {number} [offset]
362
+ * @param {number} [length]
363
+ * @param {number?} [position]
364
+ * @returns {B<{bytesRead: number, buffer: TBuffer}>}
365
+ */
366
+ //# sourceMappingURL=fs.js.map