binary-collections 2.0.9 → 2.0.11
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/.puppeterrc.cjs +25 -0
- package/binaries/binary-executor.cjs +178 -0
- package/{bin → binaries}/clean-nodemodule +0 -0
- package/binaries/clean-nodemodule.cjs +178 -0
- package/binaries/clean-nodemodule.cmd +4 -0
- package/{bin → binaries}/clean-nodemodules +0 -0
- package/binaries/clean-nodemodules.cjs +178 -0
- package/binaries/clean-nodemodules.cmd +5 -0
- package/{bin → binaries}/dev +0 -0
- package/binaries/dev.cjs +178 -0
- package/{bin → binaries}/empty +0 -0
- package/binaries/empty.cjs +178 -0
- package/{bin → binaries}/git-reduce-size +0 -0
- package/binaries/git-reduce-size.cjs +178 -0
- package/binaries/javakill.cjs +178 -0
- package/{bin → binaries}/javakill.cmd +0 -0
- package/binaries/kill-night-crows.bat +7 -0
- package/binaries/kill-night-crows.ps1 +172 -0
- package/{bin → binaries}/kill-process +0 -0
- package/binaries/kill-process.cjs +178 -0
- package/binaries/nodekill.cjs +178 -0
- package/{bin → binaries}/nodekill.ps1 +0 -0
- package/{bin → binaries}/prod +0 -0
- package/binaries/prod.cjs +178 -0
- package/binaries/py +111 -0
- package/binaries/py.cjs +178 -0
- package/binaries/py.cmd +49 -0
- package/{bin → binaries}/rmfind +0 -0
- package/binaries/rmfind.cjs +178 -0
- package/{bin → binaries}/rmx +0 -0
- package/binaries/rmx.cjs +178 -0
- package/{bin → binaries}/submodule-token +0 -0
- package/binaries/submodule-token.cjs +178 -0
- package/binaries/test-cjs +10 -0
- package/binaries/test-cjs.cjs +178 -0
- package/binaries/test-cjs.cmd +11 -0
- package/binaries/yarn-clean +32 -0
- package/binaries/yarn-clean.cjs +178 -0
- package/binaries/yarn-clean.cmd +30 -0
- package/binaries/yarn-clean.py +148 -0
- package/docs-src/clean-github-actions-caches.md +26 -0
- package/docs-src/free-chatgpt.md +26 -0
- package/lib/binary-collections-config.cjs +3 -2
- package/lib/binary-collections-config.mjs +2 -2
- package/lib/binary-collections.cjs +513 -105
- package/lib/binary-collections.mjs +178 -117
- package/lib/changelog.cjs +64 -16
- package/lib/changelog.mjs +177 -171
- package/lib/{chunk-VVEZVNIV.mjs → chunk-2CBJCW7E.mjs} +3 -3
- package/lib/chunk-34IQDTLZ.mjs +27 -0
- package/lib/chunk-3HFFECCI.mjs +27 -0
- package/lib/chunk-4UHL4WVN.mjs +136 -0
- package/lib/{chunk-4BYBVEYC.mjs → chunk-66PAU5PS.mjs} +5 -4
- package/lib/chunk-6HHJRKFB.mjs +59 -0
- package/lib/chunk-6S4NXESK.mjs +26 -0
- package/lib/chunk-7XTEJHOE.mjs +193 -0
- package/lib/{chunk-ZYAQRPUL.mjs → chunk-7YD7IPFF.mjs} +2 -2
- package/lib/{chunk-SH3L6HHV.mjs → chunk-A2JQXI5Z.mjs} +2 -2
- package/lib/{chunk-EGSSKVDH.mjs → chunk-A3VUZEJK.mjs} +1 -1
- package/lib/chunk-AJDD5DZM.mjs +109 -0
- package/lib/chunk-BZWVHODJ.mjs +62 -0
- package/lib/chunk-FCDQGYBF.mjs +136 -0
- package/lib/chunk-FKI7IEB5.mjs +172 -0
- package/lib/chunk-GEYA2USY.mjs +207 -0
- package/lib/chunk-GJTGHXRA.mjs +356 -0
- package/lib/{chunk-YV7DO3YV.mjs → chunk-HLGOWBEO.mjs} +1 -1
- package/lib/chunk-ID2WBTE2.mjs +80 -0
- package/lib/chunk-JXFOHKDM.mjs +239 -0
- package/lib/{chunk-YX5U7XDR.mjs → chunk-M3YIYRHT.mjs} +6 -5
- package/lib/chunk-N436BNBK.mjs +514 -0
- package/lib/chunk-NCXAP7AA.mjs +31 -0
- package/lib/chunk-PDN26I7O.mjs +188 -0
- package/lib/{chunk-JGR2NW6D.mjs → chunk-PDSXF5HY.mjs} +3 -3
- package/lib/{chunk-AASHBCRW.mjs → chunk-QQ4A6DLD.mjs} +8 -0
- package/lib/{chunk-ONIBBBQ3.mjs → chunk-RWLXRTYP.mjs} +4 -3
- package/lib/chunk-TOIVAQF7.mjs +136 -0
- package/lib/chunk-V5SKYJUB.mjs +136 -0
- package/lib/chunk-WSRETQCA.mjs +59 -0
- package/lib/chunk-XA3SNBPA.mjs +184 -0
- package/lib/chunk-XVBFFVCJ.mjs +209 -0
- package/lib/chunk-YYLIQQKF.mjs +31 -0
- package/lib/{chunk-APBWENF6.mjs → chunk-Z6JLYU2J.mjs} +63 -16
- package/lib/chunk-ZDMWBSYF.mjs +81 -0
- package/lib/clean-github-actions-caches.cjs +291 -148
- package/lib/clean-github-actions-caches.mjs +4 -3
- package/lib/del-gradle.cjs +63 -15
- package/lib/del-gradle.js +2 -1
- package/lib/del-gradle.mjs +2 -2
- package/lib/del-node-modules.cjs +143 -148
- package/lib/del-node-modules.js +210 -14
- package/lib/del-node-modules.mjs +149 -18
- package/lib/del-ps.cjs +90 -21
- package/lib/del-ps.js +3 -2
- package/lib/del-ps.mjs +7 -5
- package/lib/del-yarn-caches.cjs +87 -18
- package/lib/del-yarn-caches.js +38 -3
- package/lib/del-yarn-caches.mjs +6 -6
- package/lib/find-node-modules-cli.cjs +5 -4
- package/lib/find-node-modules-cli.js +2 -1
- package/lib/find-node-modules-cli.mjs +2 -2
- package/lib/find-node-modules.cjs +4 -3
- package/lib/{find-node-modules.d.ts → find-node-modules.d.cts} +1 -1
- package/lib/find-node-modules.mjs +2 -2
- package/lib/free-chatgpt.cjs +754 -0
- package/lib/free-chatgpt.js +51 -0
- package/lib/free-chatgpt.mjs +50 -0
- package/lib/git/gitattributes.cjs +2 -1
- package/lib/git/{gitattributes.d.ts → gitattributes.d.cts} +7 -2
- package/lib/git/gitattributes.mjs +2 -2
- package/lib/git/line-endings.cjs +298 -64
- package/lib/git/line-endings.mjs +4 -4
- package/lib/git/normalize.cjs +26 -36
- package/lib/git/normalize.mjs +2 -2
- package/lib/git/permissions.cjs +77 -11
- package/lib/git/permissions.mjs +3 -3
- package/lib/git/pull-strategy.cjs +76 -9
- package/lib/git/pull-strategy.mjs +3 -3
- package/lib/git/undo-commit-cli.cjs +110 -0
- package/lib/git/undo-commit-cli.d.ts +1 -0
- package/lib/git/undo-commit-cli.js +4 -0
- package/lib/git/undo-commit-cli.mjs +14 -0
- package/lib/git/undo-commit.cjs +81 -0
- package/lib/git/undo-commit.d.cts +1 -0
- package/lib/git/undo-commit.mjs +7 -0
- package/lib/git/undo-staged-cli.cjs +110 -0
- package/lib/git/undo-staged-cli.d.ts +1 -0
- package/lib/git/undo-staged-cli.js +4 -0
- package/lib/git/undo-staged-cli.mjs +14 -0
- package/lib/git/undo-staged.cjs +81 -0
- package/lib/git/undo-staged.d.cts +1 -0
- package/lib/git/undo-staged.mjs +7 -0
- package/lib/git/user-config.cjs +313 -83
- package/lib/git/user-config.mjs +4 -4
- package/lib/git/utils.cjs +40 -60
- package/lib/git/utils.mjs +2 -2
- package/lib/git-diff-cli.cjs +857 -0
- package/lib/git-diff-cli.js +16 -0
- package/lib/git-diff-cli.mjs +17 -0
- package/lib/git-diff.cjs +862 -58
- package/lib/git-diff.d.ts +38 -83
- package/lib/git-diff.js +152 -0
- package/lib/git-diff.mjs +23 -85
- package/lib/git-fix.cjs +733 -97
- package/lib/git-fix.mjs +10 -9
- package/lib/git-purge.cjs +64 -16
- package/lib/git-purge.d.cts +1 -0
- package/lib/git-purge.mjs +43 -37
- package/lib/index.cjs +7 -6
- package/lib/index.d.ts +1 -1
- package/lib/index.js +2 -5
- package/lib/index.mjs +4 -4
- package/lib/kill-night-crows.cjs +87 -0
- package/lib/kill-night-crows.d.mts +1 -0
- package/lib/kill-night-crows.mjs +65 -0
- package/lib/npm-run-series.cjs +63 -16
- package/lib/npm-run-series.mjs +42 -36
- package/lib/package-resolutions-updater-cli.cjs +560 -0
- package/lib/package-resolutions-updater-cli.d.mts +1 -0
- package/lib/package-resolutions-updater-cli.mjs +124 -0
- package/lib/package-resolutions-updater.cjs +178 -158
- package/lib/package-resolutions-updater.d.mts +32 -1
- package/lib/package-resolutions-updater.mjs +17 -338
- package/lib/php-cs-fixer-staged.cjs +105 -0
- package/lib/php-cs-fixer-staged.d.cts +2 -0
- package/lib/php-cs-fixer-staged.mjs +117 -0
- package/lib/print-directory-tree.cjs +320 -207
- package/lib/print-directory-tree.mjs +3 -3
- package/lib/ps/connected-domain.cjs +25 -2
- package/lib/ps/connected-domain.d.ts +10 -2
- package/lib/ps/connected-domain.js +5 -2
- package/lib/ps/connected-domain.mjs +8 -4
- package/lib/ps/index.cjs +345 -322
- package/lib/ps/index.d.mjs +1 -1
- package/lib/ps/index.js +2 -1
- package/lib/ps/index.mjs +179 -182
- package/lib/ps/isWin.cjs +24 -1
- package/lib/ps/isWin.d.ts +1 -1
- package/lib/ps/isWin.js +3 -1
- package/lib/ps/isWin.mjs +8 -4
- package/lib/ps/table-parser.cjs +167 -159
- package/lib/ps/table-parser.d.ts +5 -0
- package/lib/ps/table-parser.js +10 -4
- package/lib/ps/table-parser.mjs +9 -5
- package/lib/remove-module.cjs +310 -0
- package/lib/remove-module.d.mts +1 -0
- package/lib/remove-module.mjs +111 -0
- package/lib/rmpath.cjs +322 -0
- package/lib/rmpath.d.mts +3 -0
- package/lib/rmpath.mjs +108 -0
- package/lib/submodule-install.cjs +311 -86
- package/lib/submodule-install.mjs +53 -5
- package/lib/submodule-remove-cli.cjs +107 -0
- package/lib/submodule-remove-cli.d.ts +1 -0
- package/lib/submodule-remove-cli.js +31 -0
- package/lib/submodule-remove-cli.mjs +28 -0
- package/lib/submodule-remove.cjs +46 -0
- package/lib/submodule-remove.d.cts +2 -0
- package/lib/submodule-remove.mjs +6 -0
- package/lib/utils/chatgpt.cjs +541 -0
- package/lib/utils/chatgpt.d.ts +31 -0
- package/lib/utils/chatgpt.js +708 -0
- package/lib/utils/chatgpt.mjs +8 -0
- package/lib/utils/findEnvFiles.cjs +107 -0
- package/lib/utils/findEnvFiles.d.ts +8 -0
- package/lib/utils/findEnvFiles.js +121 -0
- package/lib/utils/findEnvFiles.mjs +8 -0
- package/lib/utils/findWorkspaceRoot.cjs +70 -0
- package/lib/utils/findWorkspaceRoot.d.ts +9 -0
- package/lib/utils/findWorkspaceRoot.js +57 -0
- package/lib/utils/findWorkspaceRoot.mjs +40 -0
- package/lib/{utils.cjs → utils/index.cjs} +61 -14
- package/lib/{utils.mjs → utils/index.mjs} +2 -2
- package/lib/utils/isGithubTokenValid.cjs +64 -0
- package/lib/utils/isGithubTokenValid.d.ts +7 -0
- package/lib/utils/isGithubTokenValid.js +48 -0
- package/lib/utils/isGithubTokenValid.mjs +36 -0
- package/lib/yarn-reinstall.cjs +220 -38
- package/lib/yarn-reinstall.mjs +2 -2
- package/package.json +138 -104
- package/readme.md +48 -75
- package/releases/readme.md +36 -0
- package/requirements.txt +1 -0
- package/test/README.md +101 -0
- package/test/package.json +2 -1
- package/test-project/readme.md +26 -0
- package/tmp/test-repo/README.md +35 -0
- package/tmp/test-repo/package.json +1 -1
- package/tmp/typedoc/readme.md +320 -0
- package/bin/bash-dummy +0 -56
- package/bin/bash-dummy.cmd +0 -25
- package/bin/dir-tree.cmd +0 -7
- package/bin/git-diff +0 -4
- package/bin/git-diff.cmd +0 -7
- package/bin/git-fix +0 -36
- package/bin/git-fix.cmd +0 -7
- package/bin/rmpath +0 -70
- package/bin/submodule-install.txt +0 -118
- package/bin/submodule-remove +0 -46
- package/bin/submodule.txt +0 -172
- package/lib/binary-collections-config.d.mts +0 -18
- package/lib/binary-collections-config.js +0 -39
- package/lib/binary-collections.d.mts +0 -137
- package/lib/binary-collections.d.ts +0 -137
- package/lib/changelog.d.mts +0 -2
- package/lib/changelog.js +0 -226
- package/lib/chunk-DPKAJKFO.mjs +0 -171
- package/lib/chunk-G3THLIDT.mjs +0 -200
- package/lib/chunk-W3ENOM53.mjs +0 -18
- package/lib/clean-github-actions-caches.d.mts +0 -169
- package/lib/clean-github-actions-caches.d.ts +0 -169
- package/lib/del-gradle.d.mts +0 -2
- package/lib/del-node-modules.d.mts +0 -2
- package/lib/del-ps.d.mts +0 -2
- package/lib/del-yarn-caches.d.mts +0 -2
- package/lib/find-node-modules-cli.d.mts +0 -1
- package/lib/find-node-modules.d.mts +0 -13
- package/lib/find-node-modules.js +0 -53
- package/lib/git/gitattributes.d.mts +0 -35
- package/lib/git/gitattributes.js +0 -223
- package/lib/git/line-endings.d.mts +0 -83
- package/lib/git/line-endings.d.ts +0 -83
- package/lib/git/normalize.d.mts +0 -43
- package/lib/git/normalize.d.ts +0 -43
- package/lib/git/permissions.d.mts +0 -17
- package/lib/git/permissions.d.ts +0 -17
- package/lib/git/pull-strategy.d.mts +0 -15
- package/lib/git/pull-strategy.d.ts +0 -15
- package/lib/git/user-config.d.mts +0 -105
- package/lib/git/user-config.d.ts +0 -105
- package/lib/git/utils.d.mts +0 -69
- package/lib/git/utils.d.ts +0 -69
- package/lib/git-diff.d.mts +0 -84
- package/lib/git-fix.d.mts +0 -141
- package/lib/git-fix.d.ts +0 -141
- package/lib/git-purge.d.mts +0 -2
- package/lib/git-purge.js +0 -59
- package/lib/index.d.mts +0 -1
- package/lib/npm-run-series.d.mts +0 -1
- package/lib/npm-run-series.js +0 -86
- package/lib/package-resolutions-updater.d.ts +0 -352
- package/lib/print-directory-tree.d.mts +0 -234
- package/lib/print-directory-tree.d.ts +0 -234
- package/lib/ps/connected-domain.d.mts +0 -3
- package/lib/ps/index.d.d.mts +0 -26
- package/lib/ps/index.d.d.ts +0 -26
- package/lib/ps/index.d.mts +0 -26
- package/lib/ps/isWin.d.mts +0 -3
- package/lib/ps/table-parser.d.mts +0 -3
- package/lib/submodule-install.d.mts +0 -121
- package/lib/submodule-install.d.ts +0 -121
- package/lib/utils.d.mts +0 -40
- package/lib/utils.js +0 -181
- package/lib/yarn-reinstall.d.mts +0 -49
- package/lib/yarn-reinstall.d.ts +0 -49
- package/src/package-resolutions-updater.mjs +0 -350
- package/src/print-directory-tree.cjs +0 -234
- package/src/ps/index.js +0 -286
- package/src/yarn-reinstall.cjs +0 -49
- /package/{bin → binaries}/nodekill +0 -0
- /package/{bin → binaries}/nodekill.cmd +0 -0
- /package/lib/{binary-collections-config.d.ts → binary-collections-config.d.cts} +0 -0
- /package/lib/{changelog.d.ts → changelog.d.cts} +0 -0
- /package/lib/{git-purge.d.ts → free-chatgpt.d.ts} +0 -0
- /package/lib/{git-diff.d.cts → git-diff-cli.d.ts} +0 -0
- /package/lib/{npm-run-series.d.ts → npm-run-series.d.cts} +0 -0
- /package/lib/{utils.d.ts → utils/index.d.cts} +0 -0
package/lib/del-node-modules.cjs
CHANGED
|
@@ -1,156 +1,151 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
var
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
}
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
// src/del-node-modules.js
|
|
3
|
+
var fs = require("fs");
|
|
4
|
+
var fsp = fs.promises;
|
|
5
|
+
var path = require("path");
|
|
6
|
+
var os = require("os");
|
|
7
|
+
var minimist = require("minimist");
|
|
8
|
+
var argv = minimist(process.argv.slice(2), {
|
|
9
|
+
boolean: ["force", "help"],
|
|
10
|
+
alias: { h: "help", f: "force", c: "concurrent" },
|
|
11
|
+
default: { force: false, concurrent: 2 }
|
|
13
12
|
});
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
if (
|
|
60
|
-
|
|
13
|
+
if (argv.help) {
|
|
14
|
+
console.log(`Usage: clean-node [--force] [-c|--concurrent N]
|
|
15
|
+
By default runs in dry-run mode. Use --force to actually delete.
|
|
16
|
+
Use -c/--concurrent to set concurrent removals (default 2).`);
|
|
17
|
+
process.exit(0);
|
|
18
|
+
}
|
|
19
|
+
var DRY_RUN = !argv.force;
|
|
20
|
+
var defaultConcurrency = Math.max(2, os.cpus().length || 2);
|
|
21
|
+
var CONCURRENCY = Math.max(1, Number(argv.concurrent || argv.c || defaultConcurrency));
|
|
22
|
+
var customChars = "@.";
|
|
23
|
+
var vowels = "aeiouAEIOU";
|
|
24
|
+
var alnum = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
|
|
25
|
+
var combined = alnum + vowels + customChars;
|
|
26
|
+
var ROOT = process.cwd();
|
|
27
|
+
async function isSymlinkAsync(p) {
|
|
28
|
+
try {
|
|
29
|
+
return (await fsp.lstat(p)).isSymbolicLink();
|
|
30
|
+
} catch {
|
|
31
|
+
return false;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
async function removeAsync(target) {
|
|
35
|
+
if (await isSymlinkAsync(target)) {
|
|
36
|
+
console.log("Skipping symlink", target);
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
if (DRY_RUN) {
|
|
40
|
+
console.log("Would remove", target);
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
try {
|
|
44
|
+
await fsp.rm(target, { recursive: true, force: true });
|
|
45
|
+
console.log("Deleting", target);
|
|
46
|
+
} catch (e) {
|
|
47
|
+
console.error("Failed:", target, e.message);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
function runWithConcurrency(tasks, concurrency) {
|
|
51
|
+
return new Promise((resolve, reject) => {
|
|
52
|
+
let i = 0;
|
|
53
|
+
let active = 0;
|
|
54
|
+
let done = 0;
|
|
55
|
+
const total = tasks.length;
|
|
56
|
+
if (total === 0) return resolve();
|
|
57
|
+
function next() {
|
|
58
|
+
if (done === total) return resolve();
|
|
59
|
+
while (active < concurrency && i < total) {
|
|
60
|
+
const idx = i++;
|
|
61
|
+
active++;
|
|
62
|
+
Promise.resolve().then(() => tasks[idx]()).then(() => {
|
|
63
|
+
active--;
|
|
64
|
+
done++;
|
|
65
|
+
next();
|
|
66
|
+
}).catch((err) => reject(err));
|
|
61
67
|
}
|
|
62
|
-
return fullPath;
|
|
63
|
-
}
|
|
64
|
-
module2.exports.joinPathPreserveDriveLetter = joinPathPreserveDriveLetter;
|
|
65
|
-
function getArgs() {
|
|
66
|
-
return argv;
|
|
67
68
|
}
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
69
|
+
next();
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
function walk(dir, callback, { skipNodeModulesChildren = false } = {}) {
|
|
73
|
+
let entries;
|
|
74
|
+
try {
|
|
75
|
+
entries = fs.readdirSync(dir, { withFileTypes: true });
|
|
76
|
+
} catch {
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
for (const entry of entries) {
|
|
80
|
+
const fullPath = path.join(dir, entry.name);
|
|
81
|
+
if (entry.isSymbolicLink()) continue;
|
|
82
|
+
if (skipNodeModulesChildren && dir.includes("node_modules")) continue;
|
|
83
|
+
callback(fullPath, entry);
|
|
84
|
+
if (entry.isDirectory()) {
|
|
85
|
+
if (skipNodeModulesChildren && entry.name === "node_modules") {
|
|
86
|
+
continue;
|
|
82
87
|
}
|
|
88
|
+
walk(fullPath, callback, { skipNodeModulesChildren });
|
|
83
89
|
}
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
async function processNodeModules(dir) {
|
|
93
|
+
console.log("Found:", dir);
|
|
94
|
+
let items;
|
|
95
|
+
try {
|
|
96
|
+
items = fs.readdirSync(dir, { withFileTypes: true });
|
|
97
|
+
} catch {
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
const targets = items.filter((entry) => entry.name.length && combined.includes(entry.name[0]));
|
|
101
|
+
const tasks = targets.map((entry) => async () => {
|
|
102
|
+
const name = entry.name;
|
|
103
|
+
const target = path.join(dir, name);
|
|
104
|
+
if (entry.isSymbolicLink && entry.isSymbolicLink()) {
|
|
105
|
+
console.log("Skipping symlink", target);
|
|
106
|
+
return;
|
|
96
107
|
}
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
const part = parts[i];
|
|
108
|
-
if (i === parts.length - 1) {
|
|
109
|
-
current[part] = null;
|
|
110
|
-
} else {
|
|
111
|
-
current[part] = current[part] || {};
|
|
112
|
-
current = current[part];
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
function printNode(node, prefix = "", parentPath = "") {
|
|
117
|
-
const keys = Object.keys(node).sort();
|
|
118
|
-
let lines = [];
|
|
119
|
-
keys.forEach((key, idx) => {
|
|
120
|
-
const isLast = idx === keys.length - 1;
|
|
121
|
-
const branch = isLast ? "\u2514\u2500\u2500 " : "\u251C\u2500\u2500 ";
|
|
122
|
-
const currentPath = parentPath ? parentPath + "/" + key : key;
|
|
123
|
-
if (node[key] === null) {
|
|
124
|
-
lines.push(prefix + branch + key + " [" + (hashMap[currentPath] || "") + "]");
|
|
125
|
-
} else {
|
|
126
|
-
lines.push(prefix + branch + key + "/");
|
|
127
|
-
lines = lines.concat(printNode(node[key], prefix + (isLast ? " " : "\u2502 "), currentPath));
|
|
128
|
-
}
|
|
129
|
-
});
|
|
130
|
-
return lines;
|
|
131
|
-
}
|
|
132
|
-
return printNode(tree, "", "").join("\n");
|
|
108
|
+
await removeAsync(target);
|
|
109
|
+
});
|
|
110
|
+
await runWithConcurrency(tasks, CONCURRENCY);
|
|
111
|
+
await removeAsync(dir);
|
|
112
|
+
}
|
|
113
|
+
async function main() {
|
|
114
|
+
const nodeModulesDirs = [];
|
|
115
|
+
walk(ROOT, (fullPath, entry) => {
|
|
116
|
+
if (entry.isDirectory() && entry.name === "node_modules") {
|
|
117
|
+
nodeModulesDirs.push(fullPath);
|
|
133
118
|
}
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
119
|
+
});
|
|
120
|
+
for (const dir of nodeModulesDirs) {
|
|
121
|
+
await processNodeModules(dir);
|
|
137
122
|
}
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
123
|
+
const packageLocks = [];
|
|
124
|
+
const yarnLocks = [];
|
|
125
|
+
const yarnCaches = [];
|
|
126
|
+
walk(
|
|
127
|
+
ROOT,
|
|
128
|
+
(fullPath, entry) => {
|
|
129
|
+
const base = path.basename(fullPath);
|
|
130
|
+
if (base === "package-lock.json") packageLocks.push(fullPath);
|
|
131
|
+
if (base === "yarn.lock") yarnLocks.push(fullPath);
|
|
132
|
+
if (entry.isDirectory() && fullPath.endsWith(path.join(".yarn", "cache"))) yarnCaches.push(fullPath);
|
|
133
|
+
},
|
|
134
|
+
{ skipNodeModulesChildren: true }
|
|
135
|
+
);
|
|
136
|
+
if (DRY_RUN) {
|
|
137
|
+
console.log("Would remove package-lock.json files:");
|
|
138
|
+
for (const p of packageLocks) console.log(p);
|
|
139
|
+
console.log("Would remove yarn.lock files:");
|
|
140
|
+
for (const p of yarnLocks) console.log(p);
|
|
141
|
+
console.log("Would remove .yarn/cache directories:");
|
|
142
|
+
for (const p of yarnCaches) console.log(p);
|
|
143
|
+
} else {
|
|
144
|
+
const allTasks = [];
|
|
145
|
+
allTasks.push(...packageLocks.map((p) => async () => removeAsync(p)));
|
|
146
|
+
allTasks.push(...yarnLocks.map((p) => async () => removeAsync(p)));
|
|
147
|
+
allTasks.push(...yarnCaches.map((p) => async () => removeAsync(p)));
|
|
148
|
+
await runWithConcurrency(allTasks, CONCURRENCY);
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
main();
|
package/lib/del-node-modules.js
CHANGED
|
@@ -1,15 +1,211 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
];
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
const fs = require("fs");
|
|
12
|
+
const fsp = fs.promises;
|
|
13
|
+
const path = require("path");
|
|
14
|
+
const os = require("os");
|
|
15
|
+
const minimist = require("minimist");
|
|
16
|
+
// ----------------------
|
|
17
|
+
// CLI
|
|
18
|
+
// ----------------------
|
|
19
|
+
const argv = minimist(process.argv.slice(2), {
|
|
20
|
+
boolean: ["force", "help"],
|
|
21
|
+
alias: { h: "help", f: "force", c: "concurrent" },
|
|
22
|
+
default: { force: false, concurrent: 2 }
|
|
14
23
|
});
|
|
15
|
-
|
|
24
|
+
if (argv.help) {
|
|
25
|
+
console.log(`Usage: clean-node [--force] [-c|--concurrent N]
|
|
26
|
+
By default runs in dry-run mode. Use --force to actually delete.
|
|
27
|
+
Use -c/--concurrent to set concurrent removals (default 2).`);
|
|
28
|
+
process.exit(0);
|
|
29
|
+
}
|
|
30
|
+
const DRY_RUN = !argv.force;
|
|
31
|
+
const defaultConcurrency = Math.max(2, os.cpus().length || 2);
|
|
32
|
+
const CONCURRENCY = Math.max(1, Number(argv.concurrent || argv.c || defaultConcurrency));
|
|
33
|
+
// ----------------------
|
|
34
|
+
// CONSTANTS
|
|
35
|
+
// ----------------------
|
|
36
|
+
const customChars = "@.";
|
|
37
|
+
const vowels = "aeiouAEIOU";
|
|
38
|
+
const alnum = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
|
|
39
|
+
const combined = alnum + vowels + customChars;
|
|
40
|
+
const ROOT = process.cwd();
|
|
41
|
+
// ----------------------
|
|
42
|
+
// HELPERS
|
|
43
|
+
// ----------------------
|
|
44
|
+
function isSymlinkAsync(p) {
|
|
45
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
46
|
+
try {
|
|
47
|
+
return (yield fsp.lstat(p)).isSymbolicLink();
|
|
48
|
+
}
|
|
49
|
+
catch (_a) {
|
|
50
|
+
return false;
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
function removeAsync(target) {
|
|
55
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
56
|
+
if (yield isSymlinkAsync(target)) {
|
|
57
|
+
console.log("Skipping symlink", target);
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
if (DRY_RUN) {
|
|
61
|
+
console.log("Would remove", target);
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
try {
|
|
65
|
+
yield fsp.rm(target, { recursive: true, force: true });
|
|
66
|
+
console.log("Deleting", target);
|
|
67
|
+
}
|
|
68
|
+
catch (e) {
|
|
69
|
+
console.error("Failed:", target, e.message);
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
function runWithConcurrency(tasks, concurrency) {
|
|
74
|
+
return new Promise((resolve, reject) => {
|
|
75
|
+
let i = 0;
|
|
76
|
+
let active = 0;
|
|
77
|
+
let done = 0;
|
|
78
|
+
const total = tasks.length;
|
|
79
|
+
if (total === 0)
|
|
80
|
+
return resolve();
|
|
81
|
+
function next() {
|
|
82
|
+
if (done === total)
|
|
83
|
+
return resolve();
|
|
84
|
+
while (active < concurrency && i < total) {
|
|
85
|
+
const idx = i++;
|
|
86
|
+
active++;
|
|
87
|
+
Promise.resolve()
|
|
88
|
+
.then(() => tasks[idx]())
|
|
89
|
+
.then(() => {
|
|
90
|
+
active--;
|
|
91
|
+
done++;
|
|
92
|
+
next();
|
|
93
|
+
})
|
|
94
|
+
.catch((err) => reject(err));
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
next();
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
// `removeAsync` is the single deletion path; synchronous removals were
|
|
101
|
+
// removed in favor of collecting targets and executing them with
|
|
102
|
+
// `runWithConcurrency` so all deletions respect `DRY_RUN` and concurrency.
|
|
103
|
+
/**
|
|
104
|
+
* Walk (no symlink traversal)
|
|
105
|
+
*/
|
|
106
|
+
function walk(dir, callback, { skipNodeModulesChildren = false } = {}) {
|
|
107
|
+
let entries;
|
|
108
|
+
try {
|
|
109
|
+
entries = fs.readdirSync(dir, { withFileTypes: true });
|
|
110
|
+
}
|
|
111
|
+
catch (_a) {
|
|
112
|
+
return;
|
|
113
|
+
}
|
|
114
|
+
for (const entry of entries) {
|
|
115
|
+
const fullPath = path.join(dir, entry.name);
|
|
116
|
+
// 🚫 never follow symlinks
|
|
117
|
+
if (entry.isSymbolicLink())
|
|
118
|
+
continue;
|
|
119
|
+
// skip inside node_modules/*
|
|
120
|
+
if (skipNodeModulesChildren && dir.includes("node_modules"))
|
|
121
|
+
continue;
|
|
122
|
+
callback(fullPath, entry);
|
|
123
|
+
if (entry.isDirectory()) {
|
|
124
|
+
if (skipNodeModulesChildren && entry.name === "node_modules") {
|
|
125
|
+
continue;
|
|
126
|
+
}
|
|
127
|
+
walk(fullPath, callback, { skipNodeModulesChildren });
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
// ----------------------
|
|
132
|
+
// NODE_MODULES HANDLER
|
|
133
|
+
// ----------------------
|
|
134
|
+
function processNodeModules(dir) {
|
|
135
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
136
|
+
console.log("Found:", dir);
|
|
137
|
+
let items;
|
|
138
|
+
try {
|
|
139
|
+
items = fs.readdirSync(dir, { withFileTypes: true });
|
|
140
|
+
}
|
|
141
|
+
catch (_a) {
|
|
142
|
+
return;
|
|
143
|
+
}
|
|
144
|
+
// determine targets whose first char is in the allowed combined set
|
|
145
|
+
const targets = items.filter((entry) => entry.name.length && combined.includes(entry.name[0]));
|
|
146
|
+
const tasks = targets.map((entry) => () => __awaiter(this, void 0, void 0, function* () {
|
|
147
|
+
const name = entry.name;
|
|
148
|
+
const target = path.join(dir, name);
|
|
149
|
+
// 🚫 skip symlinks entirely (Dirent gives this cheaply)
|
|
150
|
+
if (entry.isSymbolicLink && entry.isSymbolicLink()) {
|
|
151
|
+
console.log("Skipping symlink", target);
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
154
|
+
yield removeAsync(target);
|
|
155
|
+
}));
|
|
156
|
+
// run with limited concurrency
|
|
157
|
+
yield runWithConcurrency(tasks, CONCURRENCY);
|
|
158
|
+
yield removeAsync(dir);
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
// ----------------------
|
|
162
|
+
// MAIN
|
|
163
|
+
// ----------------------
|
|
164
|
+
function main() {
|
|
165
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
166
|
+
const nodeModulesDirs = [];
|
|
167
|
+
// find node_modules
|
|
168
|
+
walk(ROOT, (fullPath, entry) => {
|
|
169
|
+
if (entry.isDirectory() && entry.name === "node_modules") {
|
|
170
|
+
nodeModulesDirs.push(fullPath);
|
|
171
|
+
}
|
|
172
|
+
});
|
|
173
|
+
for (const dir of nodeModulesDirs) {
|
|
174
|
+
// process each node_modules directory, await to avoid too many parallel top-level ops
|
|
175
|
+
// (internals already limit concurrency)
|
|
176
|
+
yield processNodeModules(dir);
|
|
177
|
+
}
|
|
178
|
+
// collect package/yarn targets then remove them with concurrency
|
|
179
|
+
const packageLocks = [];
|
|
180
|
+
const yarnLocks = [];
|
|
181
|
+
const yarnCaches = [];
|
|
182
|
+
walk(ROOT, (fullPath, entry) => {
|
|
183
|
+
const base = path.basename(fullPath);
|
|
184
|
+
if (base === "package-lock.json")
|
|
185
|
+
packageLocks.push(fullPath);
|
|
186
|
+
if (base === "yarn.lock")
|
|
187
|
+
yarnLocks.push(fullPath);
|
|
188
|
+
if (entry.isDirectory() && fullPath.endsWith(path.join(".yarn", "cache")))
|
|
189
|
+
yarnCaches.push(fullPath);
|
|
190
|
+
}, { skipNodeModulesChildren: true });
|
|
191
|
+
if (DRY_RUN) {
|
|
192
|
+
console.log("Would remove package-lock.json files:");
|
|
193
|
+
for (const p of packageLocks)
|
|
194
|
+
console.log(p);
|
|
195
|
+
console.log("Would remove yarn.lock files:");
|
|
196
|
+
for (const p of yarnLocks)
|
|
197
|
+
console.log(p);
|
|
198
|
+
console.log("Would remove .yarn/cache directories:");
|
|
199
|
+
for (const p of yarnCaches)
|
|
200
|
+
console.log(p);
|
|
201
|
+
}
|
|
202
|
+
else {
|
|
203
|
+
const allTasks = [];
|
|
204
|
+
allTasks.push(...packageLocks.map((p) => () => __awaiter(this, void 0, void 0, function* () { return removeAsync(p); })));
|
|
205
|
+
allTasks.push(...yarnLocks.map((p) => () => __awaiter(this, void 0, void 0, function* () { return removeAsync(p); })));
|
|
206
|
+
allTasks.push(...yarnCaches.map((p) => () => __awaiter(this, void 0, void 0, function* () { return removeAsync(p); })));
|
|
207
|
+
yield runWithConcurrency(allTasks, CONCURRENCY);
|
|
208
|
+
}
|
|
209
|
+
});
|
|
210
|
+
}
|
|
211
|
+
main();
|