From c7e1508f2bb588c44624df6c378ef72160385f6f Mon Sep 17 00:00:00 2001 From: Marc Walter Date: Wed, 15 Jun 2022 07:46:20 +0200 Subject: [PATCH 01/17] Add `base64url` encoding for file-safe hashes The next major version will switch to use `base64url` as the default, see https://github.com/marc136/node-folder-hash/issues/152 base64 encoding contains `+` and `/`, which are replaced with `-` and `_` in base64url encoding. See the specification table on https://datatracker.ietf.org/doc/html/rfc4648#section-5 --- README.md | 4 ++-- index.js | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index 44032d4..8bf80b7 100644 --- a/README.md +++ b/README.md @@ -138,7 +138,7 @@ const options = { ```js { algo: 'sha1', // see crypto.getHashes() for options in your node.js REPL - encoding: 'base64', // 'base64', 'hex' or 'binary' + encoding: 'base64', // 'base64', 'base64url', 'hex' or 'binary' files: { exclude: [], include: [], @@ -199,7 +199,7 @@ const options = { 'base64' - encoding of the resulting hash. One of 'base64', 'hex' or 'binary' + encoding of the resulting hash. One of 'base64', 'base64url', 'hex' or 'binary' files diff --git a/index.js b/index.js index 96e55f7..6da0029 100644 --- a/index.js +++ b/index.js @@ -5,7 +5,7 @@ const defaultOptions = { algo: 'sha1', // see crypto.getHashes() for options - encoding: 'base64', // 'base64', 'hex' or 'binary' + encoding: 'base64', // 'base64', 'base64url', 'hex' or 'binary' files: { exclude: [], include: [], From 4518e6adb8029e64bd31b1e2305ad9b585da4f39 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 15 Jun 2022 10:28:50 +0200 Subject: [PATCH 02/17] Bump minimist from 1.2.5 to 1.2.6 (#144) Bumps [minimist](https://github.com/substack/minimist) from 1.2.5 to 1.2.6. - [Release notes](https://github.com/substack/minimist/releases) - [Commits](https://github.com/substack/minimist/compare/1.2.5...1.2.6) --- updated-dependencies: - dependency-name: minimist dependency-type: indirect ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> --- package-lock.json | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/package-lock.json b/package-lock.json index a17c10d..54ceee6 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1738,9 +1738,9 @@ } }, "node_modules/minimist": { - "version": "1.2.5", - "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", - "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", + "version": "1.2.6", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", + "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", "dev": true }, "node_modules/mkdirp": { @@ -4325,9 +4325,9 @@ } }, "minimist": { - "version": "1.2.5", - "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", - "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", + "version": "1.2.6", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", + "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", "dev": true }, "mkdirp": { From e4e3c0857b20329634187a8565514f1d985bdb59 Mon Sep 17 00:00:00 2001 From: Marc Walter Date: Fri, 20 May 2022 22:05:14 +0200 Subject: [PATCH 03/17] Add a test for issue #146 --- package.json | 1 - test/issue-146.js | 33 +++++++++++++++++++++++++++++++++ 2 files changed, 33 insertions(+), 1 deletion(-) create mode 100644 test/issue-146.js diff --git a/package.json b/package.json index af9c1c2..1439ef6 100644 --- a/package.json +++ b/package.json @@ -36,7 +36,6 @@ }, "dependencies": { "debug": "^4.3.3", - "graceful-fs": "~4.2.9", "minimatch": "~5.0.0" }, "devDependencies": { diff --git a/test/issue-146.js b/test/issue-146.js new file mode 100644 index 0000000..b42aad4 --- /dev/null +++ b/test/issue-146.js @@ -0,0 +1,33 @@ +const { folderHash, should, inspect } = require('./_common'); +const { Volume } = require('memfs'); + +it('Issue 146: Handle `EMFILE` and `ENFILE` errors gracefully', async function () { + const expected = 'BA8G/XdAkkeNRQd09bowxdp4rMg='; + const fs = Volume.fromJSON({ + 'folder/file.txt': 'content', + 'folder/file1.txt': 'content', + 'folder/file2.txt': 'content', + 'folder/b/file1.txt': 'content', + 'folder/b/file2.txt': 'content', + 'folder/b/file3.txt': 'content', + }); + let counter = 0; + const readdir = fs.promises.readdir; + fs.promises.readdir = (path, options) => { + counter++; + if (counter > 1 && counter < 5) { + throw { code: 'EMFILE', message: 'fake readdir error' }; + } else if (counter < 10) { + throw { code: 'ENFILE', message: 'fake readdir error' }; + } else { + return readdir(path, options); + } + }; + const hashElement = folderHash.prep(fs, Promise); + const folder = 'folder'; + const options = {}; + const result = await hashElement(folder, options); + // ensure that the errors were raised + counter.should.be.greaterThanOrEqual(7); + result.hash.should.equal('rGaf5+7Q5VwsunfiBL9XobKDio4='); +}); From bdb594f93a0cc70ce6b70685700b335ed1be9d19 Mon Sep 17 00:00:00 2001 From: Marc Walter Date: Fri, 20 May 2022 22:06:12 +0200 Subject: [PATCH 04/17] Retry hashing an element after `EMFILE` and `ENFILE` errors Fixes #146 and works around `graceful-fs` not implementing the fs/promises API. --- index.js | 43 ++++++++++++++++++++++++++++++++++++++----- 1 file changed, 38 insertions(+), 5 deletions(-) diff --git a/index.js b/index.js index 6da0029..97ec118 100644 --- a/index.js +++ b/index.js @@ -40,9 +40,13 @@ const log = { }, err: debug('fhash:err'), symlink: debug('fhash:symlink'), + queue: debug('fhash:queue'), }; function prep(fs) { + let queue = [] + let queueTimer = undefined + function hashElement(name, dir, options, callback) { callback = arguments[arguments.length - 1]; @@ -83,16 +87,45 @@ function prep(fs) { */ function hashElementPromise(stats, dirname, options, isRootElement = false) { const name = stats.name; + let promise = undefined if (stats.isDirectory()) { - return hashFolderPromise(name, dirname, options, isRootElement); + promise = hashFolderPromise(name, dirname, options, isRootElement); } else if (stats.isFile()) { - return hashFilePromise(name, dirname, options, isRootElement); + promise = hashFilePromise(name, dirname, options, isRootElement); } else if (stats.isSymbolicLink()) { - return hashSymLinkPromise(name, dirname, options, isRootElement); + promise = hashSymLinkPromise(name, dirname, options, isRootElement); } else { log.err('hashElementPromise cannot handle ', stats); - return { name, hash: 'Error: unknown element type' }; + return Promise.resolve({ name, hash: 'Error: unknown element type' }); } + + return promise.catch(err => { + if (err.code && (err.code === 'EMFILE' || err.code === 'ENFILE')) { + log.queue(`queued ${dirname}/${name} because of ${err.code}`) + + const promise = new Promise((resolve, reject) => { + queue.push(() => { + log.queue(`Will processs queued ${dirname}/${name}`) + return hashElementPromise(stats, dirname, options, isRootElement) + .then(ok => resolve(ok)).catch(err => reject(err)) + }) + }) + + if (queueTimer === undefined) { + queueTimer = setTimeout(processQueue, 0) + } + return promise + } + + throw err + }) + } + + function processQueue() { + queueTimer = undefined + const runnables = queue + queue = [] + runnables.forEach(run => run()) } function hashFolderPromise(name, dir, options, isRootElement = false) { @@ -131,7 +164,7 @@ function prep(fs) { log.match(`skipped '${filePath}'`); delete options.skipMatching; } else if (ignore(name, filePath, options.files)) { - return undefined; + return Promise.resolve(undefined); } return new Promise((resolve, reject) => { From 309a9b9f046034dc0d5f323837cc7e7466a32f2f Mon Sep 17 00:00:00 2001 From: Marc Walter Date: Sat, 28 May 2022 09:26:10 +0200 Subject: [PATCH 05/17] Mark `hashFolderPromise` as async --- index.js | 22 +++++++++------------- 1 file changed, 9 insertions(+), 13 deletions(-) diff --git a/index.js b/index.js index 97ec118..a831c52 100644 --- a/index.js +++ b/index.js @@ -128,7 +128,7 @@ function prep(fs) { runnables.forEach(run => run()) } - function hashFolderPromise(name, dir, options, isRootElement = false) { + async function hashFolderPromise(name, dir, options, isRootElement = false) { const folderPath = path.join(dir, name); let ignoreBasenameOnce = options.ignoreBasenameOnce; delete options.ignoreBasenameOnce; @@ -141,19 +141,15 @@ function prep(fs) { return undefined; } - return fs.promises.readdir(folderPath, { withFileTypes: true }).then(files => { - const children = files - .sort((a, b) => a.name.localeCompare(b.name)) - .map(child => { - return hashElementPromise(child, folderPath, options); - }); + const files = await fs.promises.readdir(folderPath, { withFileTypes: true }) + const children = await Promise.all(files + .sort((a, b) => a.name.localeCompare(b.name)) + .map(child => hashElementPromise(child, folderPath, options)) + ) - return Promise.all(children).then(children => { - if (ignoreBasenameOnce) options.ignoreBasenameOnce = true; - const hash = new HashedFolder(name, children.filter(notUndefined), options, isRootElement); - return hash; - }); - }); + if (ignoreBasenameOnce) options.ignoreBasenameOnce = true; + const hash = new HashedFolder(name, children.filter(notUndefined), options, isRootElement); + return hash; } function hashFilePromise(name, dir, options, isRootElement = false) { From 23372884449b2e783658d3f1a187e00a4fbc5f34 Mon Sep 17 00:00:00 2001 From: Marc Walter Date: Sat, 28 May 2022 10:05:05 +0200 Subject: [PATCH 06/17] Remove `graceful-fs` because the `EMFILE` and `ENFILE` errors are already handled Reason was that graceful-fs does not patch the fs/promise API and only a tiny change was needed to handle errors from `fs.createReadStream`. --- index.js | 3 ++- package-lock.json | 7 ++++--- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/index.js b/index.js index a831c52..fbae5c0 100644 --- a/index.js +++ b/index.js @@ -178,6 +178,7 @@ function prep(fs) { } const f = fs.createReadStream(filePath); + f.on('error', err => { reject(err) }) f.pipe(hash, { end: false }); f.on('end', () => { @@ -411,7 +412,7 @@ function reduceGlobPatterns(globs) { module.exports = { defaults: defaultOptions, - hashElement: prep(require('graceful-fs')), + hashElement: prep(require('fs')), // exposed for testing prep, parseParameters, diff --git a/package-lock.json b/package-lock.json index 54ceee6..7b16146 100644 --- a/package-lock.json +++ b/package-lock.json @@ -10,7 +10,6 @@ "license": "MIT", "dependencies": { "debug": "^4.3.3", - "graceful-fs": "~4.2.9", "minimatch": "~5.0.0" }, "bin": { @@ -1104,7 +1103,8 @@ "node_modules/graceful-fs": { "version": "4.2.9", "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.9.tgz", - "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==" + "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==", + "dev": true }, "node_modules/growl": { "version": "1.10.5", @@ -3838,7 +3838,8 @@ "graceful-fs": { "version": "4.2.9", "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.9.tgz", - "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==" + "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==", + "dev": true }, "growl": { "version": "1.10.5", From d8b5fa570a06f8abfe934d52807a7c8cc8815a21 Mon Sep 17 00:00:00 2001 From: Marc Walter Date: Tue, 10 Jan 2023 23:31:13 +0100 Subject: [PATCH 07/17] Bump prettier from 2.5.1 to 2.8.2 --- package-lock.json | 17 ++++++++++------- package.json | 2 +- 2 files changed, 11 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 7b16146..2c56dc5 100644 --- a/package-lock.json +++ b/package-lock.json @@ -24,7 +24,7 @@ "memfs": "^3.4.1", "mocha": "^9.2.0", "nyc": "^15.1.0", - "prettier": "~2.5.1" + "prettier": "~2.8.2" }, "engines": { "node": ">=10.10.0" @@ -2292,15 +2292,18 @@ } }, "node_modules/prettier": { - "version": "2.5.1", - "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.5.1.tgz", - "integrity": "sha512-vBZcPRUR5MZJwoyi3ZoyQlc1rXeEck8KgeC9AwwOn+exuxLxq5toTRDTSaVrXHxelDMHy9zlicw8u66yxoSUFg==", + "version": "2.8.2", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.8.2.tgz", + "integrity": "sha512-BtRV9BcncDyI2tsuS19zzhzoxD8Dh8LiCx7j7tHzrkz8GFXAexeWFdi22mjE1d16dftH2qNaytVxqiRTGlMfpw==", "dev": true, "bin": { "prettier": "bin-prettier.js" }, "engines": { "node": ">=10.13.0" + }, + "funding": { + "url": "https://github.com/prettier/prettier?sponsor=1" } }, "node_modules/process-on-spawn": { @@ -4760,9 +4763,9 @@ } }, "prettier": { - "version": "2.5.1", - "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.5.1.tgz", - "integrity": "sha512-vBZcPRUR5MZJwoyi3ZoyQlc1rXeEck8KgeC9AwwOn+exuxLxq5toTRDTSaVrXHxelDMHy9zlicw8u66yxoSUFg==", + "version": "2.8.2", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.8.2.tgz", + "integrity": "sha512-BtRV9BcncDyI2tsuS19zzhzoxD8Dh8LiCx7j7tHzrkz8GFXAexeWFdi22mjE1d16dftH2qNaytVxqiRTGlMfpw==", "dev": true }, "process-on-spawn": { diff --git a/package.json b/package.json index 1439ef6..ac2ac64 100644 --- a/package.json +++ b/package.json @@ -47,7 +47,7 @@ "memfs": "^3.4.1", "mocha": "^9.2.0", "nyc": "^15.1.0", - "prettier": "~2.5.1" + "prettier": "~2.8.2" }, "engines": { "node": ">=10.10.0" From f23a473043af3e08d379fe7c8451a95ef780fccf Mon Sep 17 00:00:00 2001 From: Marc Walter Date: Tue, 10 Jan 2023 23:31:34 +0100 Subject: [PATCH 08/17] Format code --- index.js | 48 ++++++++++++++++++++++++++---------------------- 1 file changed, 26 insertions(+), 22 deletions(-) diff --git a/index.js b/index.js index fbae5c0..59d9e0c 100644 --- a/index.js +++ b/index.js @@ -44,8 +44,8 @@ const log = { }; function prep(fs) { - let queue = [] - let queueTimer = undefined + let queue = []; + let queueTimer = undefined; function hashElement(name, dir, options, callback) { callback = arguments[arguments.length - 1]; @@ -87,7 +87,7 @@ function prep(fs) { */ function hashElementPromise(stats, dirname, options, isRootElement = false) { const name = stats.name; - let promise = undefined + let promise = undefined; if (stats.isDirectory()) { promise = hashFolderPromise(name, dirname, options, isRootElement); } else if (stats.isFile()) { @@ -101,31 +101,32 @@ function prep(fs) { return promise.catch(err => { if (err.code && (err.code === 'EMFILE' || err.code === 'ENFILE')) { - log.queue(`queued ${dirname}/${name} because of ${err.code}`) + log.queue(`queued ${dirname}/${name} because of ${err.code}`); const promise = new Promise((resolve, reject) => { queue.push(() => { - log.queue(`Will processs queued ${dirname}/${name}`) + log.queue(`Will processs queued ${dirname}/${name}`); return hashElementPromise(stats, dirname, options, isRootElement) - .then(ok => resolve(ok)).catch(err => reject(err)) - }) - }) + .then(ok => resolve(ok)) + .catch(err => reject(err)); + }); + }); if (queueTimer === undefined) { - queueTimer = setTimeout(processQueue, 0) + queueTimer = setTimeout(processQueue, 0); } - return promise + return promise; } - throw err - }) + throw err; + }); } function processQueue() { - queueTimer = undefined - const runnables = queue - queue = [] - runnables.forEach(run => run()) + queueTimer = undefined; + const runnables = queue; + queue = []; + runnables.forEach(run => run()); } async function hashFolderPromise(name, dir, options, isRootElement = false) { @@ -141,11 +142,12 @@ function prep(fs) { return undefined; } - const files = await fs.promises.readdir(folderPath, { withFileTypes: true }) - const children = await Promise.all(files - .sort((a, b) => a.name.localeCompare(b.name)) - .map(child => hashElementPromise(child, folderPath, options)) - ) + const files = await fs.promises.readdir(folderPath, { withFileTypes: true }); + const children = await Promise.all( + files + .sort((a, b) => a.name.localeCompare(b.name)) + .map(child => hashElementPromise(child, folderPath, options)), + ); if (ignoreBasenameOnce) options.ignoreBasenameOnce = true; const hash = new HashedFolder(name, children.filter(notUndefined), options, isRootElement); @@ -178,7 +180,9 @@ function prep(fs) { } const f = fs.createReadStream(filePath); - f.on('error', err => { reject(err) }) + f.on('error', err => { + reject(err); + }); f.pipe(hash, { end: false }); f.on('end', () => { From 574539abdf871e8d92b773f42e31be960102494b Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Tue, 10 Jan 2023 22:34:21 +0000 Subject: [PATCH 09/17] Bump memfs from 3.4.1 to 3.4.13 Bumps [memfs](https://github.com/streamich/memfs) from 3.4.1 to 3.4.13. - [Release notes](https://github.com/streamich/memfs/releases) - [Changelog](https://github.com/streamich/memfs/blob/master/CHANGELOG.md) - [Commits](https://github.com/streamich/memfs/compare/v3.4.1...v3.4.13) --- updated-dependencies: - dependency-name: memfs dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] --- package-lock.json | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index 2c56dc5..c5aa9f5 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1715,12 +1715,12 @@ "dev": true }, "node_modules/memfs": { - "version": "3.4.1", - "resolved": "https://registry.npmjs.org/memfs/-/memfs-3.4.1.tgz", - "integrity": "sha512-1c9VPVvW5P7I85c35zAdEr1TD5+F11IToIHIlrVIcflfnzPkJa0ZoYEoEdYDP8KgPFoSZ/opDrUsAoZWym3mtw==", + "version": "3.4.13", + "resolved": "https://registry.npmjs.org/memfs/-/memfs-3.4.13.tgz", + "integrity": "sha512-omTM41g3Skpvx5dSYeZIbXKcXoAVc/AoMNwn9TKx++L/gaen/+4TTttmu8ZSch5vfVJ8uJvGbroTsIlslRg6lg==", "dev": true, "dependencies": { - "fs-monkey": "1.0.3" + "fs-monkey": "^1.0.3" }, "engines": { "node": ">= 4.0.0" @@ -4312,12 +4312,12 @@ "dev": true }, "memfs": { - "version": "3.4.1", - "resolved": "https://registry.npmjs.org/memfs/-/memfs-3.4.1.tgz", - "integrity": "sha512-1c9VPVvW5P7I85c35zAdEr1TD5+F11IToIHIlrVIcflfnzPkJa0ZoYEoEdYDP8KgPFoSZ/opDrUsAoZWym3mtw==", + "version": "3.4.13", + "resolved": "https://registry.npmjs.org/memfs/-/memfs-3.4.13.tgz", + "integrity": "sha512-omTM41g3Skpvx5dSYeZIbXKcXoAVc/AoMNwn9TKx++L/gaen/+4TTttmu8ZSch5vfVJ8uJvGbroTsIlslRg6lg==", "dev": true, "requires": { - "fs-monkey": "1.0.3" + "fs-monkey": "^1.0.3" } }, "minimatch": { From c2e524e867953998d45878711609019ea12fd001 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Tue, 10 Jan 2023 22:34:21 +0000 Subject: [PATCH 10/17] Bump minimatch from 5.0.0 to 5.1.2 Bumps [minimatch](https://github.com/isaacs/minimatch) from 5.0.0 to 5.1.2. - [Release notes](https://github.com/isaacs/minimatch/releases) - [Changelog](https://github.com/isaacs/minimatch/blob/main/changelog.md) - [Commits](https://github.com/isaacs/minimatch/compare/v5.0.0...v5.1.2) --- updated-dependencies: - dependency-name: minimatch dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] --- package-lock.json | 14 +++++++------- package.json | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/package-lock.json b/package-lock.json index c5aa9f5..c0c079f 100644 --- a/package-lock.json +++ b/package-lock.json @@ -10,7 +10,7 @@ "license": "MIT", "dependencies": { "debug": "^4.3.3", - "minimatch": "~5.0.0" + "minimatch": "~5.1.2" }, "bin": { "folder-hash": "bin/folder-hash" @@ -1727,9 +1727,9 @@ } }, "node_modules/minimatch": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.0.0.tgz", - "integrity": "sha512-EU+GCVjXD00yOUf1TwAHVP7v3fBD3A8RkkPYsWWKGWesxM/572sL53wJQnHxquHlRhYUV36wHkqrN8cdikKc2g==", + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.2.tgz", + "integrity": "sha512-bNH9mmM9qsJ2X4r2Nat1B//1dJVcn3+iBLa3IgqJ7EbGaDNepL9QSHOxN4ng33s52VMMhhIfgCYDk3C4ZmlDAg==", "dependencies": { "brace-expansion": "^2.0.1" }, @@ -4321,9 +4321,9 @@ } }, "minimatch": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.0.0.tgz", - "integrity": "sha512-EU+GCVjXD00yOUf1TwAHVP7v3fBD3A8RkkPYsWWKGWesxM/572sL53wJQnHxquHlRhYUV36wHkqrN8cdikKc2g==", + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.2.tgz", + "integrity": "sha512-bNH9mmM9qsJ2X4r2Nat1B//1dJVcn3+iBLa3IgqJ7EbGaDNepL9QSHOxN4ng33s52VMMhhIfgCYDk3C4ZmlDAg==", "requires": { "brace-expansion": "^2.0.1" } diff --git a/package.json b/package.json index ac2ac64..7787336 100644 --- a/package.json +++ b/package.json @@ -36,7 +36,7 @@ }, "dependencies": { "debug": "^4.3.3", - "minimatch": "~5.0.0" + "minimatch": "~5.1.2" }, "devDependencies": { "chai": "^4.3.6", From 81af05f2868f5582e7258bc7387710fa185aaaad Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 6 Jan 2023 02:42:56 +0000 Subject: [PATCH 11/17] Bump json5 from 2.1.3 to 2.2.3 Bumps [json5](https://github.com/json5/json5) from 2.1.3 to 2.2.3. - [Release notes](https://github.com/json5/json5/releases) - [Changelog](https://github.com/json5/json5/blob/main/CHANGELOG.md) - [Commits](https://github.com/json5/json5/compare/v2.1.3...v2.2.3) --- updated-dependencies: - dependency-name: json5 dependency-type: indirect ... Signed-off-by: dependabot[bot] --- package-lock.json | 32 +++++++------------------------- 1 file changed, 7 insertions(+), 25 deletions(-) diff --git a/package-lock.json b/package-lock.json index c0c079f..84d8173 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1492,13 +1492,10 @@ } }, "node_modules/json5": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/json5/-/json5-2.1.3.tgz", - "integrity": "sha512-KXPvOm8K9IJKFM0bmdn8QXh7udDh1g/giieX0NLCaMnb4hEiVFqnop2ImTXCc5e0/oHz3LTqmHGtExn5hfMkOA==", + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", + "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", "dev": true, - "dependencies": { - "minimist": "^1.2.5" - }, "bin": { "json5": "lib/cli.js" }, @@ -1737,12 +1734,6 @@ "node": ">=10" } }, - "node_modules/minimist": { - "version": "1.2.6", - "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", - "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", - "dev": true - }, "node_modules/mkdirp": { "version": "1.0.4", "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", @@ -4140,13 +4131,10 @@ "dev": true }, "json5": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/json5/-/json5-2.1.3.tgz", - "integrity": "sha512-KXPvOm8K9IJKFM0bmdn8QXh7udDh1g/giieX0NLCaMnb4hEiVFqnop2ImTXCc5e0/oHz3LTqmHGtExn5hfMkOA==", - "dev": true, - "requires": { - "minimist": "^1.2.5" - } + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", + "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", + "dev": true }, "klaw": { "version": "4.0.1", @@ -4328,12 +4316,6 @@ "brace-expansion": "^2.0.1" } }, - "minimist": { - "version": "1.2.6", - "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", - "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", - "dev": true - }, "mkdirp": { "version": "1.0.4", "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", From f8bfdf0132ec0495bc405bb12c14542886f398c1 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Tue, 20 Dec 2022 06:00:23 +0000 Subject: [PATCH 12/17] Bump ignore from 5.2.0 to 5.2.4 Bumps [ignore](https://github.com/kaelzhang/node-ignore) from 5.2.0 to 5.2.4. - [Release notes](https://github.com/kaelzhang/node-ignore/releases) - [Changelog](https://github.com/kaelzhang/node-ignore/blob/master/CHANGELOG.md) - [Commits](https://github.com/kaelzhang/node-ignore/compare/5.2.0...5.2.4) --- updated-dependencies: - dependency-name: ignore dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] --- package-lock.json | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/package-lock.json b/package-lock.json index 84d8173..59318fc 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1153,9 +1153,9 @@ "dev": true }, "node_modules/ignore": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.0.tgz", - "integrity": "sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ==", + "version": "5.2.4", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", + "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", "dev": true, "engines": { "node": ">= 4" @@ -3870,9 +3870,9 @@ "dev": true }, "ignore": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.0.tgz", - "integrity": "sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ==", + "version": "5.2.4", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", + "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", "dev": true }, "imurmurhash": { From e8d56320814134c0b8bda6f2ae122d81a6e312dc Mon Sep 17 00:00:00 2001 From: Marc Walter Date: Tue, 10 Jan 2023 23:41:11 +0100 Subject: [PATCH 13/17] Add forgotten fix for #416 --- CHANGELOG.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 682c9f3..31d6720 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,9 @@ # Changelog +## 4.0.3 (2023-01-10) +- Fix #146 and remove `graceful-fs` +- Update dependencies + ## 4.0.2 (2022-02-15) - Update dependencies - Minor changes to README From dc1765beee0dfd22448e1a8dae2b5bbec542dc66 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Tue, 10 Jan 2023 22:37:04 +0000 Subject: [PATCH 14/17] Bump chai from 4.3.6 to 4.3.7 Bumps [chai](https://github.com/chaijs/chai) from 4.3.6 to 4.3.7. - [Release notes](https://github.com/chaijs/chai/releases) - [Changelog](https://github.com/chaijs/chai/blob/4.x.x/History.md) - [Commits](https://github.com/chaijs/chai/compare/v4.3.6...v4.3.7) --- updated-dependencies: - dependency-name: chai dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] --- package-lock.json | 30 +++++++++++++++--------------- 1 file changed, 15 insertions(+), 15 deletions(-) diff --git a/package-lock.json b/package-lock.json index 59318fc..c6cc05f 100644 --- a/package-lock.json +++ b/package-lock.json @@ -566,14 +566,14 @@ } }, "node_modules/chai": { - "version": "4.3.6", - "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.6.tgz", - "integrity": "sha512-bbcp3YfHCUzMOvKqsztczerVgBKSsEijCySNlHHbX3VG1nskvqjz5Rfso1gGwD6w6oOV3eI60pKuMOV5MV7p3Q==", + "version": "4.3.7", + "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.7.tgz", + "integrity": "sha512-HLnAzZ2iupm25PlN0xFreAlBA5zaBSv3og0DdeGA4Ar6h6rJ3A0rolRUKJhSF2V10GZKDgWF/VmAEsNWjCRB+A==", "dev": true, "dependencies": { "assertion-error": "^1.1.0", "check-error": "^1.0.2", - "deep-eql": "^3.0.1", + "deep-eql": "^4.1.2", "get-func-name": "^2.0.0", "loupe": "^2.3.1", "pathval": "^1.1.1", @@ -824,15 +824,15 @@ } }, "node_modules/deep-eql": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", - "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-4.1.3.tgz", + "integrity": "sha512-WaEtAOpRA1MQ0eohqZjpGD8zdI0Ovsm8mmFhaDN8dvDZzyoUMcYDnf5Y6iu7HTXxf8JDS23qWa4a+hKCDyOPzw==", "dev": true, "dependencies": { "type-detect": "^4.0.0" }, "engines": { - "node": ">=0.12" + "node": ">=6" } }, "node_modules/default-require-extensions": { @@ -3422,14 +3422,14 @@ } }, "chai": { - "version": "4.3.6", - "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.6.tgz", - "integrity": "sha512-bbcp3YfHCUzMOvKqsztczerVgBKSsEijCySNlHHbX3VG1nskvqjz5Rfso1gGwD6w6oOV3eI60pKuMOV5MV7p3Q==", + "version": "4.3.7", + "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.7.tgz", + "integrity": "sha512-HLnAzZ2iupm25PlN0xFreAlBA5zaBSv3og0DdeGA4Ar6h6rJ3A0rolRUKJhSF2V10GZKDgWF/VmAEsNWjCRB+A==", "dev": true, "requires": { "assertion-error": "^1.1.0", "check-error": "^1.0.2", - "deep-eql": "^3.0.1", + "deep-eql": "^4.1.2", "get-func-name": "^2.0.0", "loupe": "^2.3.1", "pathval": "^1.1.1", @@ -3625,9 +3625,9 @@ "dev": true }, "deep-eql": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", - "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-4.1.3.tgz", + "integrity": "sha512-WaEtAOpRA1MQ0eohqZjpGD8zdI0Ovsm8mmFhaDN8dvDZzyoUMcYDnf5Y6iu7HTXxf8JDS23qWa4a+hKCDyOPzw==", "dev": true, "requires": { "type-detect": "^4.0.0" From 96ee64cb13aa3fb0fda66292393357301fe584ad Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Tue, 10 Jan 2023 22:37:10 +0000 Subject: [PATCH 15/17] Bump debug from 4.3.3 to 4.3.4 Bumps [debug](https://github.com/debug-js/debug) from 4.3.3 to 4.3.4. - [Release notes](https://github.com/debug-js/debug/releases) - [Commits](https://github.com/debug-js/debug/compare/4.3.3...4.3.4) --- updated-dependencies: - dependency-name: debug dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] --- package-lock.json | 52 +++++++++++++++++++++++++++++++++++++++++------ 1 file changed, 46 insertions(+), 6 deletions(-) diff --git a/package-lock.json b/package-lock.json index c6cc05f..7228aac 100644 --- a/package-lock.json +++ b/package-lock.json @@ -799,9 +799,9 @@ } }, "node_modules/debug": { - "version": "4.3.3", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", - "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", "dependencies": { "ms": "2.1.2" }, @@ -1846,6 +1846,29 @@ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", "dev": true }, + "node_modules/mocha/node_modules/debug": { + "version": "4.3.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", + "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", + "dev": true, + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/mocha/node_modules/debug/node_modules/ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, "node_modules/mocha/node_modules/escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", @@ -3611,9 +3634,9 @@ } }, "debug": { - "version": "4.3.3", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", - "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", "requires": { "ms": "2.1.2" } @@ -4405,6 +4428,23 @@ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", "dev": true }, + "debug": { + "version": "4.3.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", + "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", + "dev": true, + "requires": { + "ms": "2.1.2" + }, + "dependencies": { + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + } + } + }, "escape-string-regexp": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", From 0b815ce8afbcd7bb7beb4cdb488eaa7cf7811b14 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 4 Nov 2022 06:00:28 +0000 Subject: [PATCH 16/17] Bump jsdoc from 3.6.10 to 4.0.0 Bumps [jsdoc](https://github.com/jsdoc/jsdoc) from 3.6.10 to 4.0.0. - [Release notes](https://github.com/jsdoc/jsdoc/releases) - [Changelog](https://github.com/jsdoc/jsdoc/blob/main/CHANGES.md) - [Commits](https://github.com/jsdoc/jsdoc/compare/3.6.10...4.0.0) --- updated-dependencies: - dependency-name: jsdoc dependency-type: direct:development update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] --- package-lock.json | 78 +++++++++++++++++++++++++++-------------------- package.json | 2 +- 2 files changed, 46 insertions(+), 34 deletions(-) diff --git a/package-lock.json b/package-lock.json index 7228aac..6547510 100644 --- a/package-lock.json +++ b/package-lock.json @@ -20,7 +20,7 @@ "chai-as-promised": "^7.1.1", "clone": "^2.1.2", "ignore": "^5.2.0", - "jsdoc": "3.6.10", + "jsdoc": "4.0.0", "memfs": "^3.4.1", "mocha": "^9.2.0", "nyc": "^15.1.0", @@ -357,6 +357,18 @@ "node": ">=8" } }, + "node_modules/@jsdoc/salty": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/@jsdoc/salty/-/salty-0.2.1.tgz", + "integrity": "sha512-JXwylDNSHa549N9uceDYu8D4GMXwSo3H8CCPYEQqxhhHpxD28+lRl2b3bS/caaPj5w1YD3SWtrficJNTnUjGpg==", + "dev": true, + "dependencies": { + "lodash": "^4.17.21" + }, + "engines": { + "node": ">=v12.0.0" + } + }, "node_modules/@types/color-name": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", @@ -1451,32 +1463,32 @@ } }, "node_modules/jsdoc": { - "version": "3.6.10", - "resolved": "https://registry.npmjs.org/jsdoc/-/jsdoc-3.6.10.tgz", - "integrity": "sha512-IdQ8ppSo5LKZ9o3M+LKIIK8i00DIe5msDvG3G81Km+1dhy0XrOWD0Ji8H61ElgyEj/O9KRLokgKbAM9XX9CJAg==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/jsdoc/-/jsdoc-4.0.0.tgz", + "integrity": "sha512-tzTgkklbWKrlaQL2+e3NNgLcZu3NaK2vsHRx7tyHQ+H5jcB9Gx0txSd2eJWlMC/xU1+7LQu4s58Ry0RkuaEQVg==", "dev": true, "dependencies": { "@babel/parser": "^7.9.4", + "@jsdoc/salty": "^0.2.1", "@types/markdown-it": "^12.2.3", "bluebird": "^3.7.2", "catharsis": "^0.9.0", "escape-string-regexp": "^2.0.0", "js2xmlparser": "^4.0.2", - "klaw": "^4.0.1", + "klaw": "^3.0.0", "markdown-it": "^12.3.2", "markdown-it-anchor": "^8.4.1", "marked": "^4.0.10", "mkdirp": "^1.0.4", "requizzle": "^0.2.3", "strip-json-comments": "^3.1.0", - "taffydb": "2.6.2", "underscore": "~1.13.2" }, "bin": { "jsdoc": "jsdoc.js" }, "engines": { - "node": ">=8.15.0" + "node": ">=12.0.0" } }, "node_modules/jsesc": { @@ -1504,12 +1516,12 @@ } }, "node_modules/klaw": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/klaw/-/klaw-4.0.1.tgz", - "integrity": "sha512-pgsE40/SvC7st04AHiISNewaIMUbY5V/K8b21ekiPiFoYs/EYSdsGa+FJArB1d441uq4Q8zZyIxvAzkGNlBdRw==", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/klaw/-/klaw-3.0.0.tgz", + "integrity": "sha512-0Fo5oir+O9jnXu5EefYbVK+mHMBeEVEy2cmctR1O1NECcCkPRreJKrS6Qt/j3KC2C148Dfo9i3pCmCMsdqGr0g==", "dev": true, - "engines": { - "node": ">=14.14.0" + "dependencies": { + "graceful-fs": "^4.1.9" } }, "node_modules/linkify-it": { @@ -2562,12 +2574,6 @@ "node": ">=8" } }, - "node_modules/taffydb": { - "version": "2.6.2", - "resolved": "https://registry.npmjs.org/taffydb/-/taffydb-2.6.2.tgz", - "integrity": "sha1-fLy2S1oUG2ou/CxdLGe04VCyomg=", - "dev": true - }, "node_modules/test-exclude": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", @@ -3272,6 +3278,15 @@ "integrity": "sha512-tsAQNx32a8CoFhjhijUIhI4kccIAgmGhy8LZMZgGfmXcpMbPRUqn5LWmgRttILi6yeGmBJd2xsPkFMs0PzgPCw==", "dev": true }, + "@jsdoc/salty": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/@jsdoc/salty/-/salty-0.2.1.tgz", + "integrity": "sha512-JXwylDNSHa549N9uceDYu8D4GMXwSo3H8CCPYEQqxhhHpxD28+lRl2b3bS/caaPj5w1YD3SWtrficJNTnUjGpg==", + "dev": true, + "requires": { + "lodash": "^4.17.21" + } + }, "@types/color-name": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", @@ -4125,25 +4140,25 @@ } }, "jsdoc": { - "version": "3.6.10", - "resolved": "https://registry.npmjs.org/jsdoc/-/jsdoc-3.6.10.tgz", - "integrity": "sha512-IdQ8ppSo5LKZ9o3M+LKIIK8i00DIe5msDvG3G81Km+1dhy0XrOWD0Ji8H61ElgyEj/O9KRLokgKbAM9XX9CJAg==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/jsdoc/-/jsdoc-4.0.0.tgz", + "integrity": "sha512-tzTgkklbWKrlaQL2+e3NNgLcZu3NaK2vsHRx7tyHQ+H5jcB9Gx0txSd2eJWlMC/xU1+7LQu4s58Ry0RkuaEQVg==", "dev": true, "requires": { "@babel/parser": "^7.9.4", + "@jsdoc/salty": "^0.2.1", "@types/markdown-it": "^12.2.3", "bluebird": "^3.7.2", "catharsis": "^0.9.0", "escape-string-regexp": "^2.0.0", "js2xmlparser": "^4.0.2", - "klaw": "^4.0.1", + "klaw": "^3.0.0", "markdown-it": "^12.3.2", "markdown-it-anchor": "^8.4.1", "marked": "^4.0.10", "mkdirp": "^1.0.4", "requizzle": "^0.2.3", "strip-json-comments": "^3.1.0", - "taffydb": "2.6.2", "underscore": "~1.13.2" } }, @@ -4160,10 +4175,13 @@ "dev": true }, "klaw": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/klaw/-/klaw-4.0.1.tgz", - "integrity": "sha512-pgsE40/SvC7st04AHiISNewaIMUbY5V/K8b21ekiPiFoYs/EYSdsGa+FJArB1d441uq4Q8zZyIxvAzkGNlBdRw==", - "dev": true + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/klaw/-/klaw-3.0.0.tgz", + "integrity": "sha512-0Fo5oir+O9jnXu5EefYbVK+mHMBeEVEy2cmctR1O1NECcCkPRreJKrS6Qt/j3KC2C148Dfo9i3pCmCMsdqGr0g==", + "dev": true, + "requires": { + "graceful-fs": "^4.1.9" + } }, "linkify-it": { "version": "3.0.3", @@ -4985,12 +5003,6 @@ } } }, - "taffydb": { - "version": "2.6.2", - "resolved": "https://registry.npmjs.org/taffydb/-/taffydb-2.6.2.tgz", - "integrity": "sha1-fLy2S1oUG2ou/CxdLGe04VCyomg=", - "dev": true - }, "test-exclude": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", diff --git a/package.json b/package.json index 7787336..26113c9 100644 --- a/package.json +++ b/package.json @@ -43,7 +43,7 @@ "chai-as-promised": "^7.1.1", "clone": "^2.1.2", "ignore": "^5.2.0", - "jsdoc": "3.6.10", + "jsdoc": "4.0.0", "memfs": "^3.4.1", "mocha": "^9.2.0", "nyc": "^15.1.0", From 3e05a29e96ed7e46eedcfb9458789152c058312f Mon Sep 17 00:00:00 2001 From: Marc Walter Date: Tue, 10 Jan 2023 23:50:32 +0100 Subject: [PATCH 17/17] 4.0.3 --- package-lock.json | 4 ++-- package.json | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/package-lock.json b/package-lock.json index 6547510..5eab945 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "folder-hash", - "version": "4.0.2", + "version": "4.0.3", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "folder-hash", - "version": "4.0.2", + "version": "4.0.3", "license": "MIT", "dependencies": { "debug": "^4.3.3", diff --git a/package.json b/package.json index 26113c9..d1c95e0 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "folder-hash", - "version": "4.0.2", + "version": "4.0.3", "description": "Create a hash checksum over a folder and its content - its children and their content", "main": "index.js", "bin": {