binary-collections 2.0.12 → 2.0.14
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/binaries/binary-executor.cjs +307 -162
- package/binaries/clean-nodemodule.cjs +307 -162
- package/binaries/clean-nodemodules.cjs +307 -162
- package/binaries/composer.cjs +323 -0
- package/binaries/composer.cmd +2 -0
- package/binaries/composer.phar +0 -0
- package/binaries/dev.cjs +307 -162
- package/binaries/empty.cjs +307 -162
- package/binaries/git-reduce-size.cjs +307 -162
- package/binaries/javakill.cjs +307 -162
- package/binaries/kill-process.cjs +307 -162
- package/binaries/nodekill.cjs +307 -162
- package/binaries/prod.cjs +307 -162
- package/binaries/py.cjs +307 -162
- package/binaries/rmfind.cjs +307 -162
- package/binaries/rmx.cjs +307 -162
- package/binaries/submodule-token.cjs +307 -162
- package/binaries/test-cjs.cjs +307 -162
- package/binaries/test-esm.cjs +307 -162
- package/binaries/yarn-clean.cjs +307 -162
- package/binaries/yc +22 -1
- package/binaries/yc.cjs +307 -162
- package/binaries/ycw +256 -0
- package/binaries/ycw.cjs +323 -0
- package/docs-src/binary-collections.md +34 -0
- package/docs-src/changelog.md +26 -0
- package/docs-src/clean-github-actions-caches.md +115 -0
- package/docs-src/copy-move-file.md +56 -0
- package/docs-src/del-gradle.md +17 -0
- package/docs-src/del-ps.md +28 -0
- package/docs-src/downloader.md +62 -0
- package/docs-src/env-helpers.md +29 -0
- package/docs-src/find-node-modules.md +17 -0
- package/docs-src/free-chatgpt.md +26 -0
- package/docs-src/generate-test-ci.md +56 -0
- package/docs-src/get-latest-workflow-status.md +100 -0
- package/docs-src/git-diff.md +33 -0
- package/docs-src/git-fix.md +34 -0
- package/docs-src/git-purge.md +17 -0
- package/docs-src/git-reduce-size.md +17 -0
- package/docs-src/git-undo.md +21 -0
- package/docs-src/kill-night-crows.md +26 -0
- package/docs-src/node-cache-cleaner.md +182 -0
- package/docs-src/node-executor.md +50 -0
- package/docs-src/node-package-packer.md +48 -0
- package/docs-src/npm-run-series.md +43 -0
- package/docs-src/opencode-cli.md +127 -0
- package/docs-src/package-resolutions-updater.md +22 -0
- package/docs-src/php-cs-fixer-staged.md +19 -0
- package/docs-src/print-directory-tree.md +35 -0
- package/docs-src/print-tarball-tree.md +55 -0
- package/docs-src/py.md +19 -0
- package/docs-src/remove-module.md +32 -0
- package/docs-src/rmfind-rmx.md +21 -0
- package/docs-src/rmpath.md +38 -0
- package/docs-src/run-by-checksum.md +87 -0
- package/docs-src/submodule-install.md +31 -0
- package/docs-src/submodule-remove.md +22 -0
- package/docs-src/submodule-token.md +17 -0
- package/docs-src/test-runners.md +21 -0
- package/docs-src/upload-backend.md +29 -0
- package/docs-src/vscode-cli.md +84 -0
- package/docs-src/workflow-badge.md +120 -0
- package/docs-src/yarn-install.md +31 -0
- package/docs-src/yarn-reinstall.md +27 -0
- package/lib/binary-collections/config.cjs +15 -3
- package/lib/binary-collections/config.d.cts +10 -0
- package/lib/binary-collections/config.mjs +2 -2
- package/lib/binary-collections/findScript.cjs +75 -28
- package/lib/binary-collections/findScript.mjs +2 -2
- package/lib/binary-collections/listScript.cjs +75 -28
- package/lib/binary-collections/listScript.mjs +2 -2
- package/lib/binary-collections.cjs +85 -43
- package/lib/binary-collections.mjs +8 -8
- package/lib/changelog.cjs +7 -12
- package/lib/changelog.mjs +2 -2
- package/lib/chunk-2SJKVOTN.mjs +146 -0
- package/lib/{chunk-SPTECFE5.mjs → chunk-3F6EIHYG.mjs} +87 -21
- package/lib/chunk-546KAIYT.mjs +113 -0
- package/lib/chunk-56BVU63B.mjs +86 -0
- package/lib/chunk-5WAOOOGZ.mjs +77 -0
- package/lib/{chunk-V2IBPCEV.mjs → chunk-6C7KTYGZ.mjs} +3 -1
- package/lib/{chunk-5RTXZVCW.mjs → chunk-6RK5UCTP.mjs} +5 -10
- package/lib/chunk-72XTQ3CK.mjs +45 -0
- package/lib/chunk-7N52Z4IJ.mjs +39 -0
- package/lib/chunk-7Q6YEUQF.mjs +246 -0
- package/lib/{chunk-ZOWVMII3.mjs → chunk-AJ3OIYYP.mjs} +75 -28
- package/lib/chunk-AQZ7LMFS.mjs +100 -0
- package/lib/chunk-BDCMTOZI.mjs +246 -0
- package/lib/chunk-BEUM4LH4.mjs +184 -0
- package/lib/{chunk-66KDU4TX.mjs → chunk-BO4TZS4Q.mjs} +39 -61
- package/lib/chunk-CM3IC5YC.mjs +226 -0
- package/lib/{chunk-6PU7BAHB.mjs → chunk-D42YBRZW.mjs} +1 -1
- package/lib/chunk-FR3DMHJC.mjs +146 -0
- package/lib/chunk-I3O5ZRYU.mjs +77 -0
- package/lib/chunk-J4M5EL5P.mjs +108 -0
- package/lib/chunk-JK3MG2KF.mjs +236 -0
- package/lib/chunk-JMUFQSPE.mjs +184 -0
- package/lib/chunk-JVMLKHD2.mjs +62 -0
- package/lib/chunk-KAT2JNLZ.mjs +146 -0
- package/lib/chunk-KLKAIFKI.mjs +40 -0
- package/lib/{chunk-FB2WKVJD.mjs → chunk-KRCPFWIF.mjs} +72 -37
- package/lib/chunk-LACQTD5V.mjs +225 -0
- package/lib/chunk-LVSPEFU2.mjs +86 -0
- package/lib/chunk-MCCMMZSM.mjs +60 -0
- package/lib/{chunk-2LSRSEXF.mjs → chunk-MGPYPKIE.mjs} +2 -2
- package/lib/chunk-OA2RKEY3.mjs +162 -0
- package/lib/{chunk-C6D2TTYU.mjs → chunk-OBXLTXFJ.mjs} +4 -2
- package/lib/{chunk-G5UUEWUO.mjs → chunk-PAZH45HS.mjs} +8 -2
- package/lib/chunk-QD4T255Z.mjs +40 -0
- package/lib/{chunk-XPJGCDOD.mjs → chunk-QII2EKCS.mjs} +14 -2
- package/lib/chunk-QZMGBDSA.mjs +32 -0
- package/lib/chunk-RDGDLSPD.mjs +76 -0
- package/lib/chunk-RJKTSUAX.mjs +123 -0
- package/lib/chunk-RKPIBGKE.mjs +61 -0
- package/lib/chunk-SARIXFHP.mjs +44 -0
- package/lib/chunk-SJYP66BO.mjs +62 -0
- package/lib/chunk-SWUAEY4H.mjs +44 -0
- package/lib/chunk-TP3O2JGW.mjs +88 -0
- package/lib/chunk-UAIF5VIA.mjs +89 -0
- package/lib/chunk-UDZBVKXH.mjs +94 -0
- package/lib/chunk-UEOWRYAN.mjs +32 -0
- package/lib/chunk-UHPFLJXH.mjs +227 -0
- package/lib/{chunk-M3YIYRHT.mjs → chunk-UY5VUEA3.mjs} +1 -1
- package/lib/chunk-UYNBNLV5.mjs +113 -0
- package/lib/chunk-WOC4FZ6F.mjs +164 -0
- package/lib/chunk-WSHVPGNM.mjs +44 -0
- package/lib/chunk-X7UVQ6ZC.mjs +183 -0
- package/lib/{chunk-NCZPTKDV.mjs → chunk-XI67TI46.mjs} +1 -1
- package/lib/chunk-XW5NZAKI.mjs +82 -0
- package/lib/chunk-YLV4QATP.mjs +86 -0
- package/lib/chunk-YWSLMAQ7.mjs +65 -0
- package/lib/chunk-ZB4IQ6VJ.mjs +46 -0
- package/lib/cross-env/command.cjs +2 -2
- package/lib/cross-env/command.js +2 -2
- package/lib/cross-env/command.mjs +2 -2
- package/lib/cross-env/index.cjs +2 -2
- package/lib/cross-env/index.mjs +5 -5
- package/lib/cross-env/variable.mjs +2 -2
- package/lib/del-gradle.cjs +7 -12
- package/lib/del-gradle.mjs +23 -17
- package/lib/del-node-modules.cjs +186 -4
- package/lib/del-node-modules.mjs +151 -142
- package/lib/{del-ps.cjs → del-ps-cli.cjs} +36 -41
- package/lib/del-ps-cli.mjs +44 -0
- package/lib/del-yarn-caches.cjs +6 -11
- package/lib/del-yarn-caches.mjs +1 -1
- package/lib/downloader-cli.cjs +256 -0
- package/lib/downloader-cli.mjs +90 -0
- package/lib/file/copy-cli.cjs +183 -2
- package/lib/file/copy-cli.mjs +6 -2
- package/lib/file/move-cli.cjs +183 -2
- package/lib/file/move-cli.mjs +6 -2
- package/lib/find-node-modules-cli.cjs +2 -2
- package/lib/find-node-modules-cli.mjs +11 -5
- package/lib/find-node-modules.cjs +1 -1
- package/lib/find-node-modules.mjs +1 -1
- package/lib/free-chatgpt.cjs +6 -11
- package/lib/free-chatgpt.mjs +1 -1
- package/lib/{git-diff-cli.cjs → git/git-diff-cli.cjs} +109 -36
- package/lib/{git-diff-cli.mjs → git/git-diff-cli.mjs} +7 -7
- package/lib/{git-diff.cjs → git/git-diff.cjs} +107 -34
- package/lib/{git-diff.js → git/git-diff.js} +88 -31
- package/lib/{git-diff.mjs → git/git-diff.mjs} +6 -6
- package/lib/{git-fix.cjs → git/git-fix.cjs} +140 -14
- package/lib/git/git-fix.d.cts +2 -0
- package/lib/{git-fix.mjs → git/git-fix.mjs} +19 -14
- package/lib/{git-purge.cjs → git/git-purge.cjs} +8 -13
- package/lib/{git-purge.mjs → git/git-purge.mjs} +5 -5
- package/lib/git/user-config.cjs +137 -12
- package/lib/git/user-config.mjs +4 -2
- package/lib/{clean-github-actions-caches-cli.cjs → github-workflows/clean-github-actions-caches-cli.cjs} +292 -222
- package/lib/{clean-github-actions-caches-cli.mjs → github-workflows/clean-github-actions-caches-cli.mjs} +30 -11
- package/lib/github-workflows/clean-github-actions-caches.cjs +473 -0
- package/lib/github-workflows/clean-github-actions-caches.d.cts +53 -0
- package/lib/{clean-github-actions-caches.mjs → github-workflows/clean-github-actions-caches.mjs} +5 -3
- package/lib/github-workflows/generate-test-ci-step-cli.cjs +240 -0
- package/lib/github-workflows/generate-test-ci-step-cli.d.mts +2 -0
- package/lib/github-workflows/generate-test-ci-step-cli.mjs +132 -0
- package/lib/github-workflows/get-latest-workflow-status-cli.cjs +541 -0
- package/lib/github-workflows/get-latest-workflow-status-cli.d.mts +2 -0
- package/lib/github-workflows/get-latest-workflow-status-cli.mjs +61 -0
- package/lib/github-workflows/get-latest-workflow-status.cjs +56 -0
- package/lib/github-workflows/get-latest-workflow-status.d.mts +1 -0
- package/lib/{ps/isWin.mjs → github-workflows/get-latest-workflow-status.mjs} +3 -5
- package/lib/github-workflows/utils.cjs +271 -0
- package/lib/github-workflows/utils.d.cts +76 -0
- package/lib/github-workflows/utils.mjs +8 -0
- package/lib/github-workflows/workflow-badge-cli.cjs +722 -0
- package/lib/github-workflows/workflow-badge-cli.d.mts +2 -0
- package/lib/github-workflows/workflow-badge-cli.mjs +98 -0
- package/lib/github-workflows/workflow-badge-generator.cjs +200 -0
- package/lib/github-workflows/workflow-badge-generator.d.mts +14 -0
- package/lib/github-workflows/workflow-badge-generator.mjs +8 -0
- package/lib/github-workflows/workflow-test-data.cjs +73 -0
- package/lib/github-workflows/workflow-test-data.d.cts +63 -0
- package/lib/github-workflows/workflow-test-data.mjs +6 -0
- package/lib/index.cjs +1 -1
- package/lib/index.mjs +1 -1
- package/lib/node-cache-cleaner-cli.cjs +185 -2
- package/lib/node-cache-cleaner-cli.js +2 -5
- package/lib/node-cache-cleaner-cli.mjs +8 -4
- package/lib/node-executor.cjs +183 -2
- package/lib/node-executor.mjs +5 -2
- package/lib/node-package-packer/build-readme.cjs +150 -0
- package/lib/node-package-packer/build-readme.d.mts +10 -0
- package/lib/node-package-packer/build-readme.mjs +10 -0
- package/lib/node-package-packer/build-tarball.cjs +495 -0
- package/lib/node-package-packer/build-tarball.d.mts +33 -0
- package/lib/node-package-packer/build-tarball.mjs +175 -0
- package/lib/node-package-packer-cli.cjs +525 -0
- package/lib/node-package-packer-cli.d.mts +1 -0
- package/lib/node-package-packer-cli.mjs +34 -0
- package/lib/npm-run-series.cjs +7 -12
- package/lib/npm-run-series.mjs +2 -2
- package/lib/opencode/cli/auth-rotate.cjs +143 -0
- package/lib/opencode/cli/auth-rotate.d.ts +1 -0
- package/lib/opencode/cli/auth-rotate.js +70 -0
- package/lib/opencode/cli/auth-rotate.mjs +10 -0
- package/lib/opencode/cli/list-projects.cjs +184 -0
- package/lib/opencode/cli/list-projects.d.ts +1 -0
- package/lib/opencode/cli/list-projects.js +32 -0
- package/lib/opencode/cli/list-projects.mjs +11 -0
- package/lib/opencode/cli/list-sessions.cjs +215 -0
- package/lib/opencode/cli/list-sessions.d.ts +1 -0
- package/lib/opencode/cli/list-sessions.js +45 -0
- package/lib/opencode/cli/list-sessions.mjs +11 -0
- package/lib/opencode/database.cjs +349 -0
- package/lib/opencode/database.d.ts +91 -0
- package/lib/opencode/database.js +252 -0
- package/lib/opencode/database.mjs +28 -0
- package/lib/opencode/database.runner.cjs +145 -0
- package/lib/opencode/database.runner.d.ts +1 -0
- package/lib/opencode/database.runner.js +56 -0
- package/lib/opencode/database.runner.mjs +37 -0
- package/lib/opencode/opencode-zen.runner.cjs +48 -0
- package/lib/opencode/opencode-zen.runner.d.mts +1 -0
- package/lib/opencode/opencode-zen.runner.mjs +31 -0
- package/lib/opencode/sqlite.cjs +114 -0
- package/lib/opencode/sqlite.d.ts +18 -0
- package/lib/opencode/sqlite.js +82 -0
- package/lib/opencode/sqlite.mjs +10 -0
- package/lib/opencode/storage.cjs +124 -0
- package/lib/opencode/storage.d.ts +27 -0
- package/lib/opencode/storage.js +101 -0
- package/lib/opencode/storage.mjs +38 -0
- package/lib/opencode/storage.runner.cjs +50 -0
- package/lib/opencode/storage.runner.d.ts +1 -0
- package/lib/opencode/storage.runner.js +13 -0
- package/lib/opencode/storage.runner.mjs +29 -0
- package/lib/{ps/isWin.cjs → opencode/types.cjs} +3 -12
- package/lib/opencode/types.d.ts +31 -0
- package/lib/{ps/isWin.js → opencode/types.js} +0 -2
- package/lib/opencode/types.mjs +7 -0
- package/lib/opencode/utils/check-api.cjs +59 -0
- package/lib/opencode/utils/check-api.d.ts +12 -0
- package/lib/opencode/utils/check-api.js +46 -0
- package/lib/opencode/utils/check-api.mjs +8 -0
- package/lib/opencode-cli.cjs +473 -0
- package/lib/opencode-cli.d.ts +2 -0
- package/lib/opencode-cli.js +115 -0
- package/lib/opencode-cli.mjs +111 -0
- package/lib/package-resolutions-updater-cli.cjs +218 -194
- package/lib/package-resolutions-updater-cli.mjs +6 -4
- package/lib/package-resolutions-updater.cjs +216 -192
- package/lib/package-resolutions-updater.d.mts +44 -1
- package/lib/package-resolutions-updater.mjs +5 -3
- package/lib/php-cs-fixer-staged.cjs +1 -1
- package/lib/php-cs-fixer-staged.mjs +1 -1
- package/lib/print-directory-tree.cjs +147 -21
- package/lib/print-directory-tree.mjs +17 -11
- package/lib/print-tarball-tree.cjs +262 -0
- package/lib/print-tarball-tree.d.mts +1 -0
- package/lib/print-tarball-tree.mjs +68 -0
- package/lib/ps/index.cjs +10 -10
- package/lib/ps/index.mjs +4 -4
- package/lib/ps/table-parser.d.ts +3 -4
- package/lib/ps/table-parser.js +9 -16
- package/lib/remove-module.cjs +17 -22
- package/lib/remove-module.mjs +2 -2
- package/lib/rm-node-module-cli.cjs +171 -4
- package/lib/rm-node-module-cli.mjs +7 -4
- package/lib/rmpath-cli.cjs +411 -0
- package/lib/rmpath-cli.d.mts +1 -0
- package/lib/rmpath-cli.mjs +25 -0
- package/lib/rmpath.cjs +113 -188
- package/lib/rmpath.mjs +7 -101
- package/lib/run-by-checksum/cache.cjs +69 -0
- package/lib/run-by-checksum/cache.d.ts +19 -0
- package/lib/run-by-checksum/cache.js +50 -0
- package/lib/run-by-checksum/cache.mjs +12 -0
- package/lib/run-by-checksum/hash.cjs +88 -0
- package/lib/run-by-checksum/hash.d.ts +17 -0
- package/lib/run-by-checksum/hash.js +119 -0
- package/lib/run-by-checksum/hash.mjs +10 -0
- package/lib/run-by-checksum/run.cjs +185 -0
- package/lib/run-by-checksum/run.d.ts +22 -0
- package/lib/run-by-checksum/run.js +93 -0
- package/lib/run-by-checksum/run.mjs +10 -0
- package/lib/run-by-checksum-cli.cjs +398 -0
- package/lib/run-by-checksum-cli.d.ts +2 -0
- package/lib/run-by-checksum-cli.js +43 -0
- package/lib/run-by-checksum-cli.mjs +56 -0
- package/lib/submodule-install.cjs +137 -16
- package/lib/submodule-install.mjs +7 -6
- package/lib/submodule-remove-cli.cjs +300 -7
- package/lib/submodule-remove-cli.js +2 -2
- package/lib/submodule-remove-cli.mjs +8 -3
- package/lib/submodule-remove.cjs +146 -5
- package/lib/submodule-remove.mjs +3 -1
- package/lib/utils/fetchResponse.cjs +24 -0
- package/lib/utils/fetchResponse.d.cts +25 -0
- package/lib/utils/fetchResponse.mjs +6 -0
- package/lib/utils/findEnvFiles.cjs +3 -0
- package/lib/utils/findEnvFiles.d.cts +2 -2
- package/lib/utils/findEnvFiles.mjs +1 -1
- package/lib/utils/index.cjs +5 -10
- package/lib/utils/index.d.cts +2 -9
- package/lib/utils/index.mjs +1 -1
- package/lib/utils/isWindows.mjs +3 -1
- package/lib/utils/runBash.cjs +1 -1
- package/lib/utils/runBash.mjs +1 -1
- package/lib/vscode/project.cjs +0 -0
- package/lib/vscode/project.d.ts +0 -0
- package/lib/vscode/project.js +1 -0
- package/lib/vscode/project.mjs +7 -0
- package/lib/vscode/storage.cjs +138 -0
- package/lib/vscode/storage.d.ts +51 -0
- package/lib/vscode/storage.js +169 -0
- package/lib/vscode/storage.mjs +42 -0
- package/lib/vscode/storage.runner.cjs +125 -0
- package/lib/vscode/storage.runner.d.ts +1 -0
- package/lib/vscode/storage.runner.js +47 -0
- package/lib/vscode/storage.runner.mjs +60 -0
- package/lib/vscode-cli.cjs +155 -0
- package/lib/vscode-cli.d.ts +2 -0
- package/lib/vscode-cli.js +80 -0
- package/lib/vscode-cli.mjs +71 -0
- package/lib/yarn-per-branch-lock-installer.cjs +202 -11
- package/lib/yarn-per-branch-lock-installer.mjs +24 -11
- package/lib/yarn-reinstall.cjs +6 -11
- package/lib/yarn-reinstall.mjs +1 -1
- package/package.json +75 -28
- package/readme.html +2 -2
- package/readme.md +44 -11
- package/releases/readme.md +6 -3
- package/src/github-workflows/generate-test-ci-step-cli.mjs +126 -0
- package/tmp/test-repo-runChecksum/test-complex-glob/README.md +1 -0
- package/tmp/test-repo-runChecksum/test-mixed-args/README.md +1 -0
- package/vendor/clue/ndjson-react/README.md +365 -0
- package/vendor/composer/pcre/README.md +189 -0
- package/vendor/composer/semver/README.md +99 -0
- package/vendor/composer/xdebug-handler/README.md +305 -0
- package/vendor/ergebnis/agent-detector/README.md +107 -0
- package/vendor/evenement/evenement/README.md +64 -0
- package/vendor/fidry/cpu-core-counter/README.md +138 -0
- package/vendor/friendsofphp/php-cs-fixer/README.md +97 -0
- package/vendor/psr/container/README.md +13 -0
- package/vendor/psr/event-dispatcher/README.md +6 -0
- package/vendor/psr/log/README.md +58 -0
- package/vendor/react/cache/README.md +367 -0
- package/vendor/react/child-process/README.md +619 -0
- package/vendor/react/dns/README.md +453 -0
- package/vendor/react/event-loop/README.md +930 -0
- package/vendor/react/promise/README.md +722 -0
- package/vendor/react/socket/README.md +1564 -0
- package/vendor/react/stream/README.md +1249 -0
- package/vendor/sebastian/diff/README.md +151 -0
- package/vendor/symfony/console/README.md +30 -0
- package/vendor/symfony/deprecation-contracts/README.md +26 -0
- package/vendor/symfony/event-dispatcher/README.md +25 -0
- package/vendor/symfony/event-dispatcher-contracts/README.md +9 -0
- package/vendor/symfony/filesystem/README.md +23 -0
- package/vendor/symfony/finder/README.md +24 -0
- package/vendor/symfony/options-resolver/README.md +25 -0
- package/vendor/symfony/polyfill-ctype/README.md +12 -0
- package/vendor/symfony/polyfill-intl-grapheme/README.md +32 -0
- package/vendor/symfony/polyfill-intl-normalizer/README.md +14 -0
- package/vendor/symfony/polyfill-mbstring/README.md +13 -0
- package/vendor/symfony/polyfill-php80/README.md +25 -0
- package/vendor/symfony/polyfill-php81/README.md +18 -0
- package/vendor/symfony/polyfill-php84/README.md +23 -0
- package/vendor/symfony/polyfill-php85/README.md +20 -0
- package/vendor/symfony/process/README.md +23 -0
- package/vendor/symfony/service-contracts/README.md +9 -0
- package/vendor/symfony/stopwatch/README.md +52 -0
- package/vendor/symfony/string/README.md +24 -0
- package/.opencode/package.json +0 -5
- package/lib/chunk-6S4NXESK.mjs +0 -26
- package/lib/clean-github-actions-caches.cjs +0 -249
- package/lib/clean-github-actions-caches.d.cts +0 -15
- package/lib/del-gradle.js +0 -16
- package/lib/del-node-modules.js +0 -211
- package/lib/del-ps.js +0 -32
- package/lib/del-ps.mjs +0 -43
- package/lib/find-node-modules-cli.js +0 -4
- package/lib/ps/isWin.d.ts +0 -2
- package/test/package.json +0 -20
- package/test-project/package.json +0 -22
- package/test-project/workspaces/workspace-a/package.json +0 -135
- package/test-project/workspaces/workspace-a/test/demo/package.json +0 -25
- package/test-project/workspaces/workspace-b/package.json +0 -139
- package/test-project/workspaces/workspace-b/test/sample-project/package.json +0 -7
- package/test-project/workspaces/workspace-b/themes/hexo-theme-flowbite/package.json +0 -96
- package/tmp/rm-node-modules-test-project/package.json +0 -17
- package/tmp/rm-node-modules-test-project/packages/workspace-a/package.json +0 -16
- package/tmp/rm-node-modules-test-project/packages/workspace-b/package.json +0 -16
- package/tmp/test-repo/package.json +0 -17
- /package/lib/{clean-github-actions-caches-cli.d.cts → del-gradle.d.cts} +0 -0
- /package/lib/{del-gradle.d.ts → del-node-modules.d.cts} +0 -0
- /package/lib/{del-node-modules.d.ts → del-ps-cli.d.mts} +0 -0
- /package/lib/{find-node-modules-cli.d.ts → downloader-cli.d.cts} +0 -0
- /package/lib/{git-diff-cli.d.ts → find-node-modules-cli.d.cts} +0 -0
- /package/lib/{git-fix.d.cts → git/git-diff-cli.d.ts} +0 -0
- /package/lib/{git-diff-cli.js → git/git-diff-cli.js} +0 -0
- /package/lib/{git-diff.d.ts → git/git-diff.d.ts} +0 -0
- /package/lib/{git-purge.d.cts → git/git-purge.d.cts} +0 -0
- /package/lib/{del-ps.d.ts → github-workflows/clean-github-actions-caches-cli.d.cts} +0 -0
|
@@ -13,6 +13,173 @@ var init_cjs_shims = __esm({
|
|
|
13
13
|
}
|
|
14
14
|
});
|
|
15
15
|
|
|
16
|
+
// src/utils/index.cjs
|
|
17
|
+
var require_utils = __commonJS({
|
|
18
|
+
"src/utils/index.cjs"(exports2, module2) {
|
|
19
|
+
init_cjs_shims();
|
|
20
|
+
var fs = require("fs");
|
|
21
|
+
var path = require("upath");
|
|
22
|
+
var minimistLib = require("minimist");
|
|
23
|
+
var argv2 = minimistLib(process.argv.slice(2));
|
|
24
|
+
var { exec } = require("child_process");
|
|
25
|
+
var { promisify } = require("util");
|
|
26
|
+
var execAsync = promisify(exec);
|
|
27
|
+
async function parseGitRemotes2() {
|
|
28
|
+
try {
|
|
29
|
+
const { stdout } = await execAsync("git remote -v");
|
|
30
|
+
const lines = stdout.split("\n");
|
|
31
|
+
const remotes = {};
|
|
32
|
+
lines.forEach((line) => {
|
|
33
|
+
const [name, url] = line.split(" ");
|
|
34
|
+
if (name && url) {
|
|
35
|
+
const [repoUrl] = url.split(" ");
|
|
36
|
+
try {
|
|
37
|
+
const parsedUrl = new URL(repoUrl);
|
|
38
|
+
const pathParts = parsedUrl.pathname.split("/").filter(Boolean);
|
|
39
|
+
if (parsedUrl.hostname === "github.com" && pathParts.length === 2) {
|
|
40
|
+
let repoPath = pathParts.join("/");
|
|
41
|
+
if (repoPath.endsWith(".git")) {
|
|
42
|
+
repoPath = repoPath.slice(0, -4);
|
|
43
|
+
}
|
|
44
|
+
remotes[name] = repoPath;
|
|
45
|
+
}
|
|
46
|
+
} catch (e) {
|
|
47
|
+
console.error("URL Parsing Error:", e.message);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
return remotes;
|
|
52
|
+
} catch (error) {
|
|
53
|
+
console.error("Error:", error.message);
|
|
54
|
+
return {};
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
module2.exports.parseGitRemotes = parseGitRemotes2;
|
|
58
|
+
function getArgs2(opts) {
|
|
59
|
+
if (opts) {
|
|
60
|
+
return minimistLib(process.argv.slice(2), opts);
|
|
61
|
+
}
|
|
62
|
+
return argv2;
|
|
63
|
+
}
|
|
64
|
+
module2.exports.getArgs = getArgs2;
|
|
65
|
+
function del(fullPath) {
|
|
66
|
+
try {
|
|
67
|
+
if (!fs.existsSync(fullPath)) return;
|
|
68
|
+
const stat = fs.lstatSync(fullPath);
|
|
69
|
+
if (stat.isSymbolicLink()) {
|
|
70
|
+
try {
|
|
71
|
+
fs.unlinkSync(fullPath);
|
|
72
|
+
console.log("deleted symlink", fullPath);
|
|
73
|
+
} catch (e) {
|
|
74
|
+
console.log("failed delete symlink", fullPath, e && e.message);
|
|
75
|
+
}
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
if (stat.isDirectory()) {
|
|
79
|
+
const subdir = fs.readdirSync(fullPath).map((dirPath) => path.resolve(fullPath, dirPath));
|
|
80
|
+
for (let i = 0; i < subdir.length; i++) {
|
|
81
|
+
del(subdir[i]);
|
|
82
|
+
}
|
|
83
|
+
try {
|
|
84
|
+
fs.rmdirSync(fullPath);
|
|
85
|
+
console.log("deleted", fullPath);
|
|
86
|
+
} catch (_e) {
|
|
87
|
+
try {
|
|
88
|
+
fs.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7e3 });
|
|
89
|
+
console.log("deleted", fullPath);
|
|
90
|
+
} catch (ee) {
|
|
91
|
+
console.log("failed delete", fullPath, ee && ee.message);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
try {
|
|
97
|
+
fs.unlinkSync(fullPath);
|
|
98
|
+
console.log("deleted", fullPath);
|
|
99
|
+
} catch (_e) {
|
|
100
|
+
try {
|
|
101
|
+
fs.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7e3 });
|
|
102
|
+
console.log("deleted", fullPath);
|
|
103
|
+
} catch (ee) {
|
|
104
|
+
console.log("failed delete", fullPath, ee && ee.message);
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
} catch (err) {
|
|
108
|
+
console.log("failed delete", fullPath, err && err.message);
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
module2.exports.del = del;
|
|
112
|
+
function delStream(globStream) {
|
|
113
|
+
globStream.stream().on("data", (result) => {
|
|
114
|
+
const fullPath = path.resolve(process.cwd(), result);
|
|
115
|
+
try {
|
|
116
|
+
if (fs.existsSync(fullPath)) {
|
|
117
|
+
const stat = fs.lstatSync(fullPath);
|
|
118
|
+
if (stat.isSymbolicLink()) {
|
|
119
|
+
try {
|
|
120
|
+
fs.unlinkSync(fullPath);
|
|
121
|
+
console.log("deleted symlink", fullPath);
|
|
122
|
+
} catch (e) {
|
|
123
|
+
console.log("failed delete symlink", fullPath, e && e.message);
|
|
124
|
+
}
|
|
125
|
+
return;
|
|
126
|
+
}
|
|
127
|
+
if (stat.isDirectory()) {
|
|
128
|
+
const subdir = fs.readdirSync(fullPath).map((dirPath) => path.resolve(fullPath, dirPath));
|
|
129
|
+
for (let i = 0; i < subdir.length; i++) {
|
|
130
|
+
del(subdir[i]);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
del(fullPath);
|
|
135
|
+
} catch (err) {
|
|
136
|
+
console.log("failed processing", fullPath, err && err.message);
|
|
137
|
+
}
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
module2.exports.delStream = delStream;
|
|
141
|
+
function getFileTreeString(hashArray) {
|
|
142
|
+
const tree = {};
|
|
143
|
+
const hashMap = {};
|
|
144
|
+
for (const entry of hashArray) {
|
|
145
|
+
const [filePath, hash] = entry.split(" ");
|
|
146
|
+
hashMap[filePath] = hash;
|
|
147
|
+
const parts = filePath.split("/");
|
|
148
|
+
let current = tree;
|
|
149
|
+
for (let i = 0; i < parts.length; i++) {
|
|
150
|
+
const part = parts[i];
|
|
151
|
+
if (i === parts.length - 1) {
|
|
152
|
+
current[part] = null;
|
|
153
|
+
} else {
|
|
154
|
+
current[part] = current[part] || {};
|
|
155
|
+
current = current[part];
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
function printNode(node, prefix = "", parentPath = "") {
|
|
160
|
+
const keys = Object.keys(node).sort();
|
|
161
|
+
let lines = [];
|
|
162
|
+
keys.forEach((key, idx) => {
|
|
163
|
+
const isLast = idx === keys.length - 1;
|
|
164
|
+
const branch = isLast ? "\u2514\u2500\u2500 " : "\u251C\u2500\u2500 ";
|
|
165
|
+
const currentPath = parentPath ? parentPath + "/" + key : key;
|
|
166
|
+
if (node[key] === null) {
|
|
167
|
+
lines.push(prefix + branch + key + " [" + (hashMap[currentPath] || "") + "]");
|
|
168
|
+
} else {
|
|
169
|
+
lines.push(prefix + branch + key + "/");
|
|
170
|
+
lines = lines.concat(printNode(node[key], prefix + (isLast ? " " : "\u2502 "), currentPath));
|
|
171
|
+
}
|
|
172
|
+
});
|
|
173
|
+
return lines;
|
|
174
|
+
}
|
|
175
|
+
return printNode(tree, "", "").join("\n");
|
|
176
|
+
}
|
|
177
|
+
module2.exports.getFileTreeString = getFileTreeString;
|
|
178
|
+
var delay = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
179
|
+
module2.exports.delay = delay;
|
|
180
|
+
}
|
|
181
|
+
});
|
|
182
|
+
|
|
16
183
|
// src/utils/findEnvFiles.cjs
|
|
17
184
|
var require_findEnvFiles = __commonJS({
|
|
18
185
|
"src/utils/findEnvFiles.cjs"(exports2, module2) {
|
|
@@ -91,6 +258,9 @@ var require_findEnvFiles = __commonJS({
|
|
|
91
258
|
return envFiles.find((file) => {
|
|
92
259
|
try {
|
|
93
260
|
const content = fs.readFileSync(file, "utf-8");
|
|
261
|
+
if (tokenName instanceof RegExp) {
|
|
262
|
+
return tokenName.test(content);
|
|
263
|
+
}
|
|
94
264
|
const regex = new RegExp(`^\\s*${tokenName}\\s*=`, "m");
|
|
95
265
|
return regex.test(content);
|
|
96
266
|
} catch (err) {
|
|
@@ -108,19 +278,44 @@ var require_findEnvFiles = __commonJS({
|
|
|
108
278
|
}
|
|
109
279
|
});
|
|
110
280
|
|
|
111
|
-
// src/
|
|
112
|
-
var
|
|
113
|
-
"src/
|
|
281
|
+
// src/binary-collections/config.cjs
|
|
282
|
+
var require_config = __commonJS({
|
|
283
|
+
"src/binary-collections/config.cjs"(exports2, module2) {
|
|
114
284
|
init_cjs_shims();
|
|
115
|
-
var
|
|
116
|
-
var
|
|
285
|
+
var path = require("upath");
|
|
286
|
+
var minimistLib = require("minimist");
|
|
117
287
|
var { findEnvWithToken } = require_findEnvFiles();
|
|
118
|
-
require("dotenv")
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
288
|
+
var dotenv = require("dotenv");
|
|
289
|
+
var loadDotenv = (tokenKey = /ACCESS_TOKEN|GITHUB_TOKEN/) => dotenv.config({ path: findEnvWithToken(void 0, tokenKey), quiet: true, overwrite: true });
|
|
290
|
+
loadDotenv();
|
|
291
|
+
var cliArgv = minimistLib(process.argv.slice(2), {
|
|
292
|
+
string: ["token"]
|
|
122
293
|
});
|
|
123
|
-
var
|
|
294
|
+
var GITHUB_ACCESS_TOKEN = cliArgv.token || process.env.ACCESS_TOKEN || process.env.GITHUB_TOKEN || process.env.GH_TOKEN;
|
|
295
|
+
function getTempDir() {
|
|
296
|
+
return process.env.TEMP_DIR || path.join(process.cwd(), "tmp");
|
|
297
|
+
}
|
|
298
|
+
function getTempPath(...segments) {
|
|
299
|
+
return path.join(getTempDir(), ...segments);
|
|
300
|
+
}
|
|
301
|
+
var TEMP_BASE_DIR = getTempDir();
|
|
302
|
+
module2.exports = {
|
|
303
|
+
getTempDir,
|
|
304
|
+
getTempPath,
|
|
305
|
+
TEMP_BASE_DIR,
|
|
306
|
+
GITHUB_ACCESS_TOKEN,
|
|
307
|
+
loadDotenv
|
|
308
|
+
};
|
|
309
|
+
}
|
|
310
|
+
});
|
|
311
|
+
|
|
312
|
+
// src/github-workflows/clean-github-actions-caches.cjs
|
|
313
|
+
var require_clean_github_actions_caches = __commonJS({
|
|
314
|
+
"src/github-workflows/clean-github-actions-caches.cjs"(exports2, module2) {
|
|
315
|
+
init_cjs_shims();
|
|
316
|
+
var axios = require("axios");
|
|
317
|
+
var { getArgs: getArgs2 } = require_utils();
|
|
318
|
+
var { GITHUB_ACCESS_TOKEN: ACCESS_TOKEN } = require_config();
|
|
124
319
|
if (!ACCESS_TOKEN) {
|
|
125
320
|
throw new Error(
|
|
126
321
|
"Access token is not provided. Please set ACCESS_TOKEN or GITHUB_TOKEN in your environment variables."
|
|
@@ -143,6 +338,9 @@ Options:
|
|
|
143
338
|
-r, --repo <repo> GitHub repository (owner/repo). If omitted, the tool will
|
|
144
339
|
attempt to infer the repository from the current working
|
|
145
340
|
directory's git remotes.
|
|
341
|
+
-p, --prefix-depth <n>
|
|
342
|
+
Number of leading cache key segments to use as the
|
|
343
|
+
grouping prefix when splitting on /[-_]/. Default: 3.
|
|
146
344
|
|
|
147
345
|
Environment Variables:
|
|
148
346
|
ACCESS_TOKEN GitHub access token (preferred)
|
|
@@ -159,25 +357,26 @@ Examples:
|
|
|
159
357
|
clean-github-actions-caches --repo octocat/hello-world
|
|
160
358
|
|
|
161
359
|
# Run via npx without installing
|
|
162
|
-
|
|
360
|
+
npx --legacy-peer-deps -y binary-collections@https://raw.githubusercontent.com/dimaslanjaka/bin/master/releases/bin.tgz clean-github-actions-caches --repo owner/repo --prefix-depth 3
|
|
163
361
|
|
|
164
362
|
# Run via yarn dlx
|
|
165
|
-
|
|
363
|
+
yarn dlx binary-collections@https://raw.githubusercontent.com/dimaslanjaka/bin/master/releases/bin.tgz clean-github-actions-caches --prefix-depth 3
|
|
166
364
|
|
|
167
365
|
Notes:
|
|
168
366
|
- Ensure ACCESS_TOKEN or GITHUB_TOKEN is set and has permissions to manage Actions caches.
|
|
169
367
|
- Intended for repository maintainers with appropriate permissions.
|
|
170
368
|
`);
|
|
171
369
|
}
|
|
172
|
-
var
|
|
370
|
+
var argv2 = getArgs2({
|
|
173
371
|
alias: {
|
|
174
372
|
h: "help",
|
|
373
|
+
p: "prefix-depth",
|
|
175
374
|
r: "repo"
|
|
176
375
|
},
|
|
177
|
-
string: ["repo"],
|
|
376
|
+
string: ["prefix-depth", "repo"],
|
|
178
377
|
boolean: ["help"]
|
|
179
378
|
});
|
|
180
|
-
if (
|
|
379
|
+
if (argv2.help) {
|
|
181
380
|
printHelp();
|
|
182
381
|
process.exit(0);
|
|
183
382
|
}
|
|
@@ -203,7 +402,53 @@ Notes:
|
|
|
203
402
|
});
|
|
204
403
|
});
|
|
205
404
|
}
|
|
206
|
-
function
|
|
405
|
+
function normalizePrefixDepth(prefixDepth) {
|
|
406
|
+
const parsed = Number(prefixDepth);
|
|
407
|
+
if (!Number.isFinite(parsed) || parsed < 1) {
|
|
408
|
+
return 3;
|
|
409
|
+
}
|
|
410
|
+
return Math.floor(parsed);
|
|
411
|
+
}
|
|
412
|
+
function isChecksumSegment(segment) {
|
|
413
|
+
return /^[a-f0-9]{32,}$/i.test(segment);
|
|
414
|
+
}
|
|
415
|
+
function getMeaningfulCacheKeyParts(key) {
|
|
416
|
+
return String(key).split(/[-_]/).filter(Boolean).filter((segment) => !isChecksumSegment(segment));
|
|
417
|
+
}
|
|
418
|
+
function getCachePrefix(key, prefixDepth = 3) {
|
|
419
|
+
const normalizedDepth = normalizePrefixDepth(prefixDepth);
|
|
420
|
+
const parts = String(key).split(/[-_]/).filter(Boolean);
|
|
421
|
+
const meaningfulParts = getMeaningfulCacheKeyParts(key);
|
|
422
|
+
if (meaningfulParts.length !== parts.length) {
|
|
423
|
+
if (meaningfulParts.length < normalizedDepth) {
|
|
424
|
+
return `${meaningfulParts.join("-")}-`;
|
|
425
|
+
}
|
|
426
|
+
return meaningfulParts.join("-");
|
|
427
|
+
}
|
|
428
|
+
if (parts.length <= normalizedDepth) {
|
|
429
|
+
return parts.join("-");
|
|
430
|
+
}
|
|
431
|
+
return parts.slice(0, normalizedDepth).join("-");
|
|
432
|
+
}
|
|
433
|
+
function groupCachesByPrefix(caches, prefixDepth = 3) {
|
|
434
|
+
return caches.reduce(
|
|
435
|
+
/**
|
|
436
|
+
* @param {Record<string, Record<string, any>[]>} acc
|
|
437
|
+
* @param {Record<string, any>} item
|
|
438
|
+
* @returns {Record<string, Record<string, any>[]>}
|
|
439
|
+
*/
|
|
440
|
+
(acc, item) => {
|
|
441
|
+
const prefix = getCachePrefix(item.key, prefixDepth);
|
|
442
|
+
if (!acc[prefix]) {
|
|
443
|
+
acc[prefix] = [];
|
|
444
|
+
}
|
|
445
|
+
acc[prefix].push(item);
|
|
446
|
+
return acc;
|
|
447
|
+
},
|
|
448
|
+
{}
|
|
449
|
+
);
|
|
450
|
+
}
|
|
451
|
+
function get_caches2(GH_REPO, prefixDepth = 3) {
|
|
207
452
|
const url = `https://api.github.com/repos/${GH_REPO}/actions/caches`;
|
|
208
453
|
return new Promise((resolve, reject) => {
|
|
209
454
|
axios.get(url, {
|
|
@@ -213,227 +458,45 @@ Notes:
|
|
|
213
458
|
}
|
|
214
459
|
}).then((response) => {
|
|
215
460
|
const data = response.data.actions_caches;
|
|
216
|
-
const
|
|
217
|
-
const split = key.split(/[-_]/);
|
|
218
|
-
if (split.length === 3) {
|
|
219
|
-
return `${split[0]}-${split[1]}`;
|
|
220
|
-
}
|
|
221
|
-
if (split.length > 3) {
|
|
222
|
-
return `${split[0]}-${split[1]}-${split[2]}`;
|
|
223
|
-
}
|
|
224
|
-
return split[0];
|
|
225
|
-
};
|
|
226
|
-
const grouped = data.reduce(
|
|
227
|
-
/**
|
|
228
|
-
* @param {Record<string, Record<string, any>[]>} acc
|
|
229
|
-
* @param {Record<string, any>} item
|
|
230
|
-
* @returns {Record<string, Record<string, any>[]>}
|
|
231
|
-
*/
|
|
232
|
-
(acc, item) => {
|
|
233
|
-
const prefix = getPrefix(item.key);
|
|
234
|
-
if (!acc[prefix]) {
|
|
235
|
-
acc[prefix] = [];
|
|
236
|
-
}
|
|
237
|
-
acc[prefix].push(item);
|
|
238
|
-
return acc;
|
|
239
|
-
},
|
|
240
|
-
{}
|
|
241
|
-
);
|
|
461
|
+
const grouped = groupCachesByPrefix(data, prefixDepth);
|
|
242
462
|
resolve(grouped);
|
|
243
463
|
}).catch((error) => {
|
|
244
|
-
console.error("Error fetching data:", error);
|
|
245
464
|
reject(error);
|
|
246
465
|
});
|
|
247
466
|
});
|
|
248
467
|
}
|
|
249
468
|
module2.exports = {
|
|
250
469
|
deleteGitHubActionsCache: deleteGitHubActionsCache2,
|
|
251
|
-
|
|
470
|
+
getCachePrefix,
|
|
471
|
+
getMeaningfulCacheKeyParts,
|
|
472
|
+
get_caches: get_caches2,
|
|
473
|
+
groupCachesByPrefix,
|
|
474
|
+
isChecksumSegment,
|
|
475
|
+
normalizePrefixDepth
|
|
252
476
|
};
|
|
253
477
|
}
|
|
254
478
|
});
|
|
255
479
|
|
|
256
|
-
// src/
|
|
257
|
-
var require_utils = __commonJS({
|
|
258
|
-
"src/utils/index.cjs"(exports2, module2) {
|
|
259
|
-
init_cjs_shims();
|
|
260
|
-
var fs = require("fs");
|
|
261
|
-
var path = require("upath");
|
|
262
|
-
var argv = require("minimist")(process.argv.slice(2));
|
|
263
|
-
var { exec } = require("child_process");
|
|
264
|
-
var { URL: URL2 } = require("url");
|
|
265
|
-
var { promisify } = require("util");
|
|
266
|
-
var execAsync = promisify(exec);
|
|
267
|
-
async function parseGitRemotes2() {
|
|
268
|
-
try {
|
|
269
|
-
const { stdout } = await execAsync("git remote -v");
|
|
270
|
-
const lines = stdout.split("\n");
|
|
271
|
-
const remotes = {};
|
|
272
|
-
lines.forEach((line) => {
|
|
273
|
-
const [name, url] = line.split(" ");
|
|
274
|
-
if (name && url) {
|
|
275
|
-
const [repoUrl] = url.split(" ");
|
|
276
|
-
try {
|
|
277
|
-
const parsedUrl = new URL2(repoUrl);
|
|
278
|
-
const pathParts = parsedUrl.pathname.split("/").filter(Boolean);
|
|
279
|
-
if (parsedUrl.hostname === "github.com" && pathParts.length === 2) {
|
|
280
|
-
let repoPath = pathParts.join("/");
|
|
281
|
-
if (repoPath.endsWith(".git")) {
|
|
282
|
-
repoPath = repoPath.slice(0, -4);
|
|
283
|
-
}
|
|
284
|
-
remotes[name] = repoPath;
|
|
285
|
-
}
|
|
286
|
-
} catch (e) {
|
|
287
|
-
console.error("URL Parsing Error:", e.message);
|
|
288
|
-
}
|
|
289
|
-
}
|
|
290
|
-
});
|
|
291
|
-
return remotes;
|
|
292
|
-
} catch (error) {
|
|
293
|
-
console.error("Error:", error.message);
|
|
294
|
-
return {};
|
|
295
|
-
}
|
|
296
|
-
}
|
|
297
|
-
module2.exports.parseGitRemotes = parseGitRemotes2;
|
|
298
|
-
function joinPathPreserveDriveLetter(...segments) {
|
|
299
|
-
let fullPath = require("path").join(...segments);
|
|
300
|
-
if (/^[a-z]:\\/.test(fullPath)) {
|
|
301
|
-
fullPath = fullPath.charAt(0).toUpperCase() + fullPath.slice(1);
|
|
302
|
-
}
|
|
303
|
-
return fullPath;
|
|
304
|
-
}
|
|
305
|
-
module2.exports.joinPathPreserveDriveLetter = joinPathPreserveDriveLetter;
|
|
306
|
-
function getArgs() {
|
|
307
|
-
return argv;
|
|
308
|
-
}
|
|
309
|
-
module2.exports.getArgs = getArgs;
|
|
310
|
-
function del(fullPath) {
|
|
311
|
-
try {
|
|
312
|
-
if (!fs.existsSync(fullPath)) return;
|
|
313
|
-
const stat = fs.lstatSync(fullPath);
|
|
314
|
-
if (stat.isSymbolicLink()) {
|
|
315
|
-
try {
|
|
316
|
-
fs.unlinkSync(fullPath);
|
|
317
|
-
console.log("deleted symlink", fullPath);
|
|
318
|
-
} catch (e) {
|
|
319
|
-
console.log("failed delete symlink", fullPath, e && e.message);
|
|
320
|
-
}
|
|
321
|
-
return;
|
|
322
|
-
}
|
|
323
|
-
if (stat.isDirectory()) {
|
|
324
|
-
const subdir = fs.readdirSync(fullPath).map((dirPath) => path.resolve(fullPath, dirPath));
|
|
325
|
-
for (let i = 0; i < subdir.length; i++) {
|
|
326
|
-
del(subdir[i]);
|
|
327
|
-
}
|
|
328
|
-
try {
|
|
329
|
-
fs.rmdirSync(fullPath);
|
|
330
|
-
console.log("deleted", fullPath);
|
|
331
|
-
} catch (_e) {
|
|
332
|
-
try {
|
|
333
|
-
fs.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7e3 });
|
|
334
|
-
console.log("deleted", fullPath);
|
|
335
|
-
} catch (ee) {
|
|
336
|
-
console.log("failed delete", fullPath, ee && ee.message);
|
|
337
|
-
}
|
|
338
|
-
}
|
|
339
|
-
return;
|
|
340
|
-
}
|
|
341
|
-
try {
|
|
342
|
-
fs.unlinkSync(fullPath);
|
|
343
|
-
console.log("deleted", fullPath);
|
|
344
|
-
} catch (_e) {
|
|
345
|
-
try {
|
|
346
|
-
fs.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7e3 });
|
|
347
|
-
console.log("deleted", fullPath);
|
|
348
|
-
} catch (ee) {
|
|
349
|
-
console.log("failed delete", fullPath, ee && ee.message);
|
|
350
|
-
}
|
|
351
|
-
}
|
|
352
|
-
} catch (err) {
|
|
353
|
-
console.log("failed delete", fullPath, err && err.message);
|
|
354
|
-
}
|
|
355
|
-
}
|
|
356
|
-
module2.exports.del = del;
|
|
357
|
-
function delStream(globStream) {
|
|
358
|
-
globStream.stream().on("data", (result) => {
|
|
359
|
-
const fullPath = path.resolve(process.cwd(), result);
|
|
360
|
-
try {
|
|
361
|
-
if (fs.existsSync(fullPath)) {
|
|
362
|
-
const stat = fs.lstatSync(fullPath);
|
|
363
|
-
if (stat.isSymbolicLink()) {
|
|
364
|
-
try {
|
|
365
|
-
fs.unlinkSync(fullPath);
|
|
366
|
-
console.log("deleted symlink", fullPath);
|
|
367
|
-
} catch (e) {
|
|
368
|
-
console.log("failed delete symlink", fullPath, e && e.message);
|
|
369
|
-
}
|
|
370
|
-
return;
|
|
371
|
-
}
|
|
372
|
-
if (stat.isDirectory()) {
|
|
373
|
-
const subdir = fs.readdirSync(fullPath).map((dirPath) => path.resolve(fullPath, dirPath));
|
|
374
|
-
for (let i = 0; i < subdir.length; i++) {
|
|
375
|
-
del(subdir[i]);
|
|
376
|
-
}
|
|
377
|
-
}
|
|
378
|
-
}
|
|
379
|
-
del(fullPath);
|
|
380
|
-
} catch (err) {
|
|
381
|
-
console.log("failed processing", fullPath, err && err.message);
|
|
382
|
-
}
|
|
383
|
-
});
|
|
384
|
-
}
|
|
385
|
-
module2.exports.delStream = delStream;
|
|
386
|
-
function getFileTreeString(hashArray) {
|
|
387
|
-
const tree = {};
|
|
388
|
-
const hashMap = {};
|
|
389
|
-
for (const entry of hashArray) {
|
|
390
|
-
const [filePath, hash] = entry.split(" ");
|
|
391
|
-
hashMap[filePath] = hash;
|
|
392
|
-
const parts = filePath.split("/");
|
|
393
|
-
let current = tree;
|
|
394
|
-
for (let i = 0; i < parts.length; i++) {
|
|
395
|
-
const part = parts[i];
|
|
396
|
-
if (i === parts.length - 1) {
|
|
397
|
-
current[part] = null;
|
|
398
|
-
} else {
|
|
399
|
-
current[part] = current[part] || {};
|
|
400
|
-
current = current[part];
|
|
401
|
-
}
|
|
402
|
-
}
|
|
403
|
-
}
|
|
404
|
-
function printNode(node, prefix = "", parentPath = "") {
|
|
405
|
-
const keys = Object.keys(node).sort();
|
|
406
|
-
let lines = [];
|
|
407
|
-
keys.forEach((key, idx) => {
|
|
408
|
-
const isLast = idx === keys.length - 1;
|
|
409
|
-
const branch = isLast ? "\u2514\u2500\u2500 " : "\u251C\u2500\u2500 ";
|
|
410
|
-
const currentPath = parentPath ? parentPath + "/" + key : key;
|
|
411
|
-
if (node[key] === null) {
|
|
412
|
-
lines.push(prefix + branch + key + " [" + (hashMap[currentPath] || "") + "]");
|
|
413
|
-
} else {
|
|
414
|
-
lines.push(prefix + branch + key + "/");
|
|
415
|
-
lines = lines.concat(printNode(node[key], prefix + (isLast ? " " : "\u2502 "), currentPath));
|
|
416
|
-
}
|
|
417
|
-
});
|
|
418
|
-
return lines;
|
|
419
|
-
}
|
|
420
|
-
return printNode(tree, "", "").join("\n");
|
|
421
|
-
}
|
|
422
|
-
module2.exports.getFileTreeString = getFileTreeString;
|
|
423
|
-
var delay = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
424
|
-
module2.exports.delay = delay;
|
|
425
|
-
}
|
|
426
|
-
});
|
|
427
|
-
|
|
428
|
-
// src/clean-github-actions-caches-cli.cjs
|
|
480
|
+
// src/github-workflows/clean-github-actions-caches-cli.cjs
|
|
429
481
|
init_cjs_shims();
|
|
430
482
|
var { get_caches, deleteGitHubActionsCache } = require_clean_github_actions_caches();
|
|
431
|
-
var { parseGitRemotes } = require_utils();
|
|
483
|
+
var { getArgs, parseGitRemotes } = require_utils();
|
|
484
|
+
var argv = getArgs({
|
|
485
|
+
alias: {
|
|
486
|
+
p: "prefix-depth",
|
|
487
|
+
r: "repo"
|
|
488
|
+
},
|
|
489
|
+
string: ["prefix-depth", "repo"]
|
|
490
|
+
});
|
|
432
491
|
(async () => {
|
|
492
|
+
var _a, _b, _c, _d;
|
|
433
493
|
try {
|
|
434
494
|
const remotes = await parseGitRemotes();
|
|
435
|
-
const GH_REPO = remotes.origin;
|
|
436
|
-
|
|
495
|
+
const GH_REPO = argv.repo || remotes.origin;
|
|
496
|
+
if (!GH_REPO) {
|
|
497
|
+
throw new Error("Repository is not provided and origin remote could not be inferred. Use --repo owner/repo.");
|
|
498
|
+
}
|
|
499
|
+
const caches = await get_caches(GH_REPO, argv["prefix-depth"]);
|
|
437
500
|
for (const key in caches) {
|
|
438
501
|
if (Object.hasOwnProperty.call(caches, key)) {
|
|
439
502
|
const items = caches[key].sort((a, b) => new Date(b.created_at) - new Date(a.created_at)).map((item) => ({
|
|
@@ -448,7 +511,10 @@ var { parseGitRemotes } = require_utils();
|
|
|
448
511
|
try {
|
|
449
512
|
await deleteGitHubActionsCache(GH_REPO, id);
|
|
450
513
|
} catch (err) {
|
|
451
|
-
|
|
514
|
+
const code = ((_a = err.response) == null ? void 0 : _a.status) || err.code || "UNKNOWN";
|
|
515
|
+
const message = ((_b = err.response) == null ? void 0 : _b.statusText) || err.message || "Unknown error";
|
|
516
|
+
console.error(`Error deleting cache ${id}: [${code}] [${message}]
|
|
517
|
+
${err.stack}`);
|
|
452
518
|
}
|
|
453
519
|
}
|
|
454
520
|
} else {
|
|
@@ -460,6 +526,10 @@ var { parseGitRemotes } = require_utils();
|
|
|
460
526
|
}
|
|
461
527
|
}
|
|
462
528
|
} catch (e) {
|
|
463
|
-
|
|
529
|
+
const code = ((_c = e.response) == null ? void 0 : _c.status) || e.code || "UNKNOWN";
|
|
530
|
+
const message = ((_d = e.response) == null ? void 0 : _d.statusText) || e.message || "Unknown error";
|
|
531
|
+
console.error(`[${code}] [${message}]
|
|
532
|
+
${e.stack}`);
|
|
533
|
+
process.exit(1);
|
|
464
534
|
}
|
|
465
535
|
})();
|
|
@@ -1,27 +1,39 @@
|
|
|
1
1
|
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
3
|
require_clean_github_actions_caches
|
|
4
|
-
} from "
|
|
5
|
-
import "
|
|
4
|
+
} from "../chunk-BEUM4LH4.mjs";
|
|
5
|
+
import "../chunk-SARIXFHP.mjs";
|
|
6
|
+
import "../chunk-J4M5EL5P.mjs";
|
|
6
7
|
import {
|
|
7
8
|
require_utils
|
|
8
|
-
} from "
|
|
9
|
+
} from "../chunk-6RK5UCTP.mjs";
|
|
9
10
|
import {
|
|
10
11
|
__commonJS,
|
|
11
12
|
init_esm_shims
|
|
12
|
-
} from "
|
|
13
|
+
} from "../chunk-QQ4A6DLD.mjs";
|
|
13
14
|
|
|
14
|
-
// src/clean-github-actions-caches-cli.cjs
|
|
15
|
+
// src/github-workflows/clean-github-actions-caches-cli.cjs
|
|
15
16
|
var require_clean_github_actions_caches_cli = __commonJS({
|
|
16
|
-
"src/clean-github-actions-caches-cli.cjs"() {
|
|
17
|
+
"src/github-workflows/clean-github-actions-caches-cli.cjs"() {
|
|
17
18
|
init_esm_shims();
|
|
18
19
|
var { get_caches, deleteGitHubActionsCache } = require_clean_github_actions_caches();
|
|
19
|
-
var { parseGitRemotes } = require_utils();
|
|
20
|
+
var { getArgs, parseGitRemotes } = require_utils();
|
|
21
|
+
var argv = getArgs({
|
|
22
|
+
alias: {
|
|
23
|
+
p: "prefix-depth",
|
|
24
|
+
r: "repo"
|
|
25
|
+
},
|
|
26
|
+
string: ["prefix-depth", "repo"]
|
|
27
|
+
});
|
|
20
28
|
(async () => {
|
|
29
|
+
var _a, _b, _c, _d;
|
|
21
30
|
try {
|
|
22
31
|
const remotes = await parseGitRemotes();
|
|
23
|
-
const GH_REPO = remotes.origin;
|
|
24
|
-
|
|
32
|
+
const GH_REPO = argv.repo || remotes.origin;
|
|
33
|
+
if (!GH_REPO) {
|
|
34
|
+
throw new Error("Repository is not provided and origin remote could not be inferred. Use --repo owner/repo.");
|
|
35
|
+
}
|
|
36
|
+
const caches = await get_caches(GH_REPO, argv["prefix-depth"]);
|
|
25
37
|
for (const key in caches) {
|
|
26
38
|
if (Object.hasOwnProperty.call(caches, key)) {
|
|
27
39
|
const items = caches[key].sort((a, b) => new Date(b.created_at) - new Date(a.created_at)).map((item) => ({
|
|
@@ -36,7 +48,10 @@ var require_clean_github_actions_caches_cli = __commonJS({
|
|
|
36
48
|
try {
|
|
37
49
|
await deleteGitHubActionsCache(GH_REPO, id);
|
|
38
50
|
} catch (err) {
|
|
39
|
-
|
|
51
|
+
const code = ((_a = err.response) == null ? void 0 : _a.status) || err.code || "UNKNOWN";
|
|
52
|
+
const message = ((_b = err.response) == null ? void 0 : _b.statusText) || err.message || "Unknown error";
|
|
53
|
+
console.error(`Error deleting cache ${id}: [${code}] [${message}]
|
|
54
|
+
${err.stack}`);
|
|
40
55
|
}
|
|
41
56
|
}
|
|
42
57
|
} else {
|
|
@@ -48,7 +63,11 @@ var require_clean_github_actions_caches_cli = __commonJS({
|
|
|
48
63
|
}
|
|
49
64
|
}
|
|
50
65
|
} catch (e) {
|
|
51
|
-
|
|
66
|
+
const code = ((_c = e.response) == null ? void 0 : _c.status) || e.code || "UNKNOWN";
|
|
67
|
+
const message = ((_d = e.response) == null ? void 0 : _d.statusText) || e.message || "Unknown error";
|
|
68
|
+
console.error(`[${code}] [${message}]
|
|
69
|
+
${e.stack}`);
|
|
70
|
+
process.exit(1);
|
|
52
71
|
}
|
|
53
72
|
})();
|
|
54
73
|
}
|