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
|
@@ -1,26 +1,32 @@
|
|
|
1
1
|
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
require_config
|
|
4
|
+
} from "./chunk-PAZH45HS.mjs";
|
|
2
5
|
import {
|
|
3
6
|
require_findEnvFiles
|
|
4
7
|
} from "./chunk-H44UWUFY.mjs";
|
|
8
|
+
import {
|
|
9
|
+
require_utils
|
|
10
|
+
} from "./chunk-6RK5UCTP.mjs";
|
|
5
11
|
import {
|
|
6
12
|
__commonJS,
|
|
7
13
|
__require,
|
|
8
14
|
init_esm_shims
|
|
9
15
|
} from "./chunk-QQ4A6DLD.mjs";
|
|
10
16
|
|
|
11
|
-
// src/clean-github-actions-caches.cjs
|
|
17
|
+
// src/github-workflows/clean-github-actions-caches.cjs
|
|
12
18
|
var require_clean_github_actions_caches = __commonJS({
|
|
13
|
-
"src/clean-github-actions-caches.cjs"(exports, module) {
|
|
19
|
+
"src/github-workflows/clean-github-actions-caches.cjs"(exports, module) {
|
|
14
20
|
init_esm_shims();
|
|
15
21
|
var axios = __require("axios");
|
|
16
|
-
var
|
|
22
|
+
var { getArgs } = require_utils();
|
|
23
|
+
var { GITHUB_ACCESS_TOKEN: ACCESS_TOKEN } = require_config();
|
|
17
24
|
var { findEnvWithToken } = require_findEnvFiles();
|
|
18
25
|
__require("dotenv").config({
|
|
19
26
|
path: findEnvWithToken(),
|
|
20
27
|
quiet: true,
|
|
21
28
|
overwrite: true
|
|
22
29
|
});
|
|
23
|
-
var ACCESS_TOKEN = process.env.GITHUB_TOKEN || process.env.ACCESS_TOKEN;
|
|
24
30
|
if (!ACCESS_TOKEN) {
|
|
25
31
|
throw new Error(
|
|
26
32
|
"Access token is not provided. Please set ACCESS_TOKEN or GITHUB_TOKEN in your environment variables."
|
|
@@ -43,6 +49,9 @@ Options:
|
|
|
43
49
|
-r, --repo <repo> GitHub repository (owner/repo). If omitted, the tool will
|
|
44
50
|
attempt to infer the repository from the current working
|
|
45
51
|
directory's git remotes.
|
|
52
|
+
-p, --prefix-depth <n>
|
|
53
|
+
Number of leading cache key segments to use as the
|
|
54
|
+
grouping prefix when splitting on /[-_]/. Default: 3.
|
|
46
55
|
|
|
47
56
|
Environment Variables:
|
|
48
57
|
ACCESS_TOKEN GitHub access token (preferred)
|
|
@@ -59,22 +68,23 @@ Examples:
|
|
|
59
68
|
clean-github-actions-caches --repo octocat/hello-world
|
|
60
69
|
|
|
61
70
|
# Run via npx without installing
|
|
62
|
-
|
|
71
|
+
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
|
|
63
72
|
|
|
64
73
|
# Run via yarn dlx
|
|
65
|
-
|
|
74
|
+
yarn dlx binary-collections@https://raw.githubusercontent.com/dimaslanjaka/bin/master/releases/bin.tgz clean-github-actions-caches --prefix-depth 3
|
|
66
75
|
|
|
67
76
|
Notes:
|
|
68
77
|
- Ensure ACCESS_TOKEN or GITHUB_TOKEN is set and has permissions to manage Actions caches.
|
|
69
78
|
- Intended for repository maintainers with appropriate permissions.
|
|
70
79
|
`);
|
|
71
80
|
}
|
|
72
|
-
var argv =
|
|
81
|
+
var argv = getArgs({
|
|
73
82
|
alias: {
|
|
74
83
|
h: "help",
|
|
84
|
+
p: "prefix-depth",
|
|
75
85
|
r: "repo"
|
|
76
86
|
},
|
|
77
|
-
string: ["repo"],
|
|
87
|
+
string: ["prefix-depth", "repo"],
|
|
78
88
|
boolean: ["help"]
|
|
79
89
|
});
|
|
80
90
|
if (argv.help) {
|
|
@@ -103,7 +113,53 @@ Notes:
|
|
|
103
113
|
});
|
|
104
114
|
});
|
|
105
115
|
}
|
|
106
|
-
function
|
|
116
|
+
function normalizePrefixDepth(prefixDepth) {
|
|
117
|
+
const parsed = Number(prefixDepth);
|
|
118
|
+
if (!Number.isFinite(parsed) || parsed < 1) {
|
|
119
|
+
return 3;
|
|
120
|
+
}
|
|
121
|
+
return Math.floor(parsed);
|
|
122
|
+
}
|
|
123
|
+
function isChecksumSegment(segment) {
|
|
124
|
+
return /^[a-f0-9]{32,}$/i.test(segment);
|
|
125
|
+
}
|
|
126
|
+
function getMeaningfulCacheKeyParts(key) {
|
|
127
|
+
return String(key).split(/[-_]/).filter(Boolean).filter((segment) => !isChecksumSegment(segment));
|
|
128
|
+
}
|
|
129
|
+
function getCachePrefix(key, prefixDepth = 3) {
|
|
130
|
+
const normalizedDepth = normalizePrefixDepth(prefixDepth);
|
|
131
|
+
const parts = String(key).split(/[-_]/).filter(Boolean);
|
|
132
|
+
const meaningfulParts = getMeaningfulCacheKeyParts(key);
|
|
133
|
+
if (meaningfulParts.length !== parts.length) {
|
|
134
|
+
if (meaningfulParts.length < normalizedDepth) {
|
|
135
|
+
return `${meaningfulParts.join("-")}-`;
|
|
136
|
+
}
|
|
137
|
+
return meaningfulParts.join("-");
|
|
138
|
+
}
|
|
139
|
+
if (parts.length <= normalizedDepth) {
|
|
140
|
+
return parts.join("-");
|
|
141
|
+
}
|
|
142
|
+
return parts.slice(0, normalizedDepth).join("-");
|
|
143
|
+
}
|
|
144
|
+
function groupCachesByPrefix(caches, prefixDepth = 3) {
|
|
145
|
+
return caches.reduce(
|
|
146
|
+
/**
|
|
147
|
+
* @param {Record<string, Record<string, any>[]>} acc
|
|
148
|
+
* @param {Record<string, any>} item
|
|
149
|
+
* @returns {Record<string, Record<string, any>[]>}
|
|
150
|
+
*/
|
|
151
|
+
(acc, item) => {
|
|
152
|
+
const prefix = getCachePrefix(item.key, prefixDepth);
|
|
153
|
+
if (!acc[prefix]) {
|
|
154
|
+
acc[prefix] = [];
|
|
155
|
+
}
|
|
156
|
+
acc[prefix].push(item);
|
|
157
|
+
return acc;
|
|
158
|
+
},
|
|
159
|
+
{}
|
|
160
|
+
);
|
|
161
|
+
}
|
|
162
|
+
function get_caches(GH_REPO, prefixDepth = 3) {
|
|
107
163
|
const url = `https://api.github.com/repos/${GH_REPO}/actions/caches`;
|
|
108
164
|
return new Promise((resolve, reject) => {
|
|
109
165
|
axios.get(url, {
|
|
@@ -113,42 +169,21 @@ Notes:
|
|
|
113
169
|
}
|
|
114
170
|
}).then((response) => {
|
|
115
171
|
const data = response.data.actions_caches;
|
|
116
|
-
const
|
|
117
|
-
const split = key.split(/[-_]/);
|
|
118
|
-
if (split.length === 3) {
|
|
119
|
-
return `${split[0]}-${split[1]}`;
|
|
120
|
-
}
|
|
121
|
-
if (split.length > 3) {
|
|
122
|
-
return `${split[0]}-${split[1]}-${split[2]}`;
|
|
123
|
-
}
|
|
124
|
-
return split[0];
|
|
125
|
-
};
|
|
126
|
-
const grouped = data.reduce(
|
|
127
|
-
/**
|
|
128
|
-
* @param {Record<string, Record<string, any>[]>} acc
|
|
129
|
-
* @param {Record<string, any>} item
|
|
130
|
-
* @returns {Record<string, Record<string, any>[]>}
|
|
131
|
-
*/
|
|
132
|
-
(acc, item) => {
|
|
133
|
-
const prefix = getPrefix(item.key);
|
|
134
|
-
if (!acc[prefix]) {
|
|
135
|
-
acc[prefix] = [];
|
|
136
|
-
}
|
|
137
|
-
acc[prefix].push(item);
|
|
138
|
-
return acc;
|
|
139
|
-
},
|
|
140
|
-
{}
|
|
141
|
-
);
|
|
172
|
+
const grouped = groupCachesByPrefix(data, prefixDepth);
|
|
142
173
|
resolve(grouped);
|
|
143
174
|
}).catch((error) => {
|
|
144
|
-
console.error("Error fetching data:", error);
|
|
145
175
|
reject(error);
|
|
146
176
|
});
|
|
147
177
|
});
|
|
148
178
|
}
|
|
149
179
|
module.exports = {
|
|
150
180
|
deleteGitHubActionsCache,
|
|
151
|
-
|
|
181
|
+
getCachePrefix,
|
|
182
|
+
getMeaningfulCacheKeyParts,
|
|
183
|
+
get_caches,
|
|
184
|
+
groupCachesByPrefix,
|
|
185
|
+
isChecksumSegment,
|
|
186
|
+
normalizePrefixDepth
|
|
152
187
|
};
|
|
153
188
|
}
|
|
154
189
|
});
|
|
@@ -0,0 +1,225 @@
|
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
SQLite
|
|
4
|
+
} from "./chunk-56BVU63B.mjs";
|
|
5
|
+
import {
|
|
6
|
+
DATABASE_PATH
|
|
7
|
+
} from "./chunk-XW5NZAKI.mjs";
|
|
8
|
+
import {
|
|
9
|
+
init_esm_shims
|
|
10
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
11
|
+
|
|
12
|
+
// src/opencode/database.ts
|
|
13
|
+
init_esm_shims();
|
|
14
|
+
import fs from "fs-extra";
|
|
15
|
+
import { execSync } from "child_process";
|
|
16
|
+
async function checkDatabase() {
|
|
17
|
+
if (!fs.existsSync(DATABASE_PATH)) {
|
|
18
|
+
console.error("No OpenCode database found. Run opencode (v1.2.0+) at least once to create the database.");
|
|
19
|
+
return false;
|
|
20
|
+
}
|
|
21
|
+
try {
|
|
22
|
+
const db = new SQLite(DATABASE_PATH);
|
|
23
|
+
try {
|
|
24
|
+
const rows = db.all("SELECT name FROM sqlite_master WHERE type='table' AND name='session'");
|
|
25
|
+
if (rows.length === 0) {
|
|
26
|
+
console.error(
|
|
27
|
+
"OpenCode database exists but is missing expected tables. Try running opencode to complete the migration."
|
|
28
|
+
);
|
|
29
|
+
return false;
|
|
30
|
+
}
|
|
31
|
+
return true;
|
|
32
|
+
} finally {
|
|
33
|
+
db.close();
|
|
34
|
+
}
|
|
35
|
+
} catch (error) {
|
|
36
|
+
if (error instanceof Error) {
|
|
37
|
+
console.error(`Could not open OpenCode database: ${error.message}`);
|
|
38
|
+
} else {
|
|
39
|
+
console.error("Could not open OpenCode database.");
|
|
40
|
+
}
|
|
41
|
+
return false;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
function toProject(row) {
|
|
45
|
+
let sandboxes = [];
|
|
46
|
+
try {
|
|
47
|
+
sandboxes = JSON.parse(row.sandboxes);
|
|
48
|
+
} catch {
|
|
49
|
+
}
|
|
50
|
+
return {
|
|
51
|
+
id: row.id,
|
|
52
|
+
worktree: row.worktree,
|
|
53
|
+
vcs: row.vcs,
|
|
54
|
+
name: row.name,
|
|
55
|
+
sandboxes,
|
|
56
|
+
time: {
|
|
57
|
+
created: row.time_created,
|
|
58
|
+
updated: row.time_updated
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
function toSession(row) {
|
|
63
|
+
const session = {
|
|
64
|
+
id: row.id,
|
|
65
|
+
slug: row.slug,
|
|
66
|
+
version: row.version,
|
|
67
|
+
projectID: row.project_id,
|
|
68
|
+
directory: row.directory,
|
|
69
|
+
parentID: row.parent_id ?? void 0,
|
|
70
|
+
title: row.title,
|
|
71
|
+
time: {
|
|
72
|
+
created: row.time_created,
|
|
73
|
+
updated: row.time_updated,
|
|
74
|
+
compacting: row.time_compacting ?? void 0,
|
|
75
|
+
archived: row.time_archived ?? void 0
|
|
76
|
+
}
|
|
77
|
+
};
|
|
78
|
+
if (row.summary_files != null) {
|
|
79
|
+
session.summary = {
|
|
80
|
+
additions: row.summary_additions ?? 0,
|
|
81
|
+
deletions: row.summary_deletions ?? 0,
|
|
82
|
+
files: row.summary_files
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
if (row.share_url) {
|
|
86
|
+
session.share = { url: row.share_url };
|
|
87
|
+
}
|
|
88
|
+
return session;
|
|
89
|
+
}
|
|
90
|
+
function toMessage(id, sessionID, dataJson) {
|
|
91
|
+
const data = JSON.parse(dataJson);
|
|
92
|
+
return {
|
|
93
|
+
id,
|
|
94
|
+
sessionID,
|
|
95
|
+
role: data.role,
|
|
96
|
+
time: data.time,
|
|
97
|
+
parentID: data.parentID,
|
|
98
|
+
modelID: data.modelID,
|
|
99
|
+
providerID: data.providerID,
|
|
100
|
+
agent: data.agent,
|
|
101
|
+
mode: data.mode,
|
|
102
|
+
cost: data.cost,
|
|
103
|
+
tokens: data.tokens,
|
|
104
|
+
finish: data.finish
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
function toPart(id, messageID, sessionID, dataJson) {
|
|
108
|
+
const data = JSON.parse(dataJson);
|
|
109
|
+
return {
|
|
110
|
+
id,
|
|
111
|
+
messageID,
|
|
112
|
+
sessionID,
|
|
113
|
+
type: data.type,
|
|
114
|
+
text: data.text,
|
|
115
|
+
tool: data.tool,
|
|
116
|
+
state: data.state
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
async function loadProjects() {
|
|
120
|
+
const rows = query("SELECT id, worktree, vcs, name, time_created, time_updated, sandboxes FROM project");
|
|
121
|
+
return rows.map(toProject);
|
|
122
|
+
}
|
|
123
|
+
async function loadSessions() {
|
|
124
|
+
const rows = query(
|
|
125
|
+
`SELECT id, project_id, parent_id, slug, directory, title, version,
|
|
126
|
+
share_url, summary_additions, summary_deletions, summary_files,
|
|
127
|
+
time_created, time_updated, time_compacting, time_archived
|
|
128
|
+
FROM session
|
|
129
|
+
WHERE parent_id IS NULL
|
|
130
|
+
ORDER BY time_updated DESC`
|
|
131
|
+
);
|
|
132
|
+
return rows.map(toSession);
|
|
133
|
+
}
|
|
134
|
+
async function loadMessages(sessionID) {
|
|
135
|
+
const rows = query(
|
|
136
|
+
`SELECT id, session_id, data FROM message WHERE session_id = '${escapeSql(sessionID)}' ORDER BY id ASC`
|
|
137
|
+
);
|
|
138
|
+
return rows.map((row) => toMessage(row.id, row.session_id, row.data));
|
|
139
|
+
}
|
|
140
|
+
async function loadParts(messageID) {
|
|
141
|
+
const rows = query(
|
|
142
|
+
`SELECT id, message_id, session_id, data FROM part WHERE message_id = '${escapeSql(messageID)}' ORDER BY id ASC`
|
|
143
|
+
);
|
|
144
|
+
return rows.map((row) => toPart(row.id, row.message_id, row.session_id, row.data));
|
|
145
|
+
}
|
|
146
|
+
async function loadTranscript(sessionID) {
|
|
147
|
+
const sid = escapeSql(sessionID);
|
|
148
|
+
const rows = query(
|
|
149
|
+
`SELECT m.id AS message_id, m.data AS message_data,
|
|
150
|
+
p.id AS part_id, p.message_id AS part_message_id,
|
|
151
|
+
p.session_id AS part_session_id, p.data AS part_data
|
|
152
|
+
FROM message m
|
|
153
|
+
LEFT JOIN part p ON p.message_id = m.id
|
|
154
|
+
WHERE m.session_id = '${sid}'
|
|
155
|
+
ORDER BY m.id ASC, p.id ASC`
|
|
156
|
+
);
|
|
157
|
+
const entriesMap = /* @__PURE__ */ new Map();
|
|
158
|
+
for (const row of rows) {
|
|
159
|
+
let entry = entriesMap.get(row.message_id);
|
|
160
|
+
if (!entry) {
|
|
161
|
+
entry = {
|
|
162
|
+
message: toMessage(row.message_id, sessionID, row.message_data),
|
|
163
|
+
parts: []
|
|
164
|
+
};
|
|
165
|
+
entriesMap.set(row.message_id, entry);
|
|
166
|
+
}
|
|
167
|
+
if (row.part_id && row.part_data && row.part_message_id && row.part_session_id) {
|
|
168
|
+
const part = toPart(row.part_id, row.part_message_id, row.part_session_id, row.part_data);
|
|
169
|
+
if (part.type === "text" && part.text || part.type === "tool") {
|
|
170
|
+
entry.parts.push(part);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
return Array.from(entriesMap.values()).filter((entry) => entry.parts.length > 0);
|
|
175
|
+
}
|
|
176
|
+
function runSql(query2) {
|
|
177
|
+
const dbPath = DATABASE_PATH;
|
|
178
|
+
execSync(`sqlite3 "${dbPath}"`, {
|
|
179
|
+
input: query2,
|
|
180
|
+
timeout: 1e4
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
async function deleteSession(session) {
|
|
184
|
+
const sid = escapeSql(session.id);
|
|
185
|
+
runSql(
|
|
186
|
+
`WITH RECURSIVE descendants(id) AS (SELECT id FROM session WHERE id = '${sid}' UNION ALL SELECT s.id FROM session s JOIN descendants d ON s.parent_id = d.id) DELETE FROM session WHERE id IN (SELECT id FROM descendants);`
|
|
187
|
+
);
|
|
188
|
+
}
|
|
189
|
+
async function deleteSessionById(id) {
|
|
190
|
+
const sid = escapeSql(id);
|
|
191
|
+
runSql(
|
|
192
|
+
`WITH RECURSIVE descendants(id) AS (SELECT id FROM session WHERE id = '${sid}' UNION ALL SELECT s.id FROM session s JOIN descendants d ON s.parent_id = d.id) DELETE FROM session WHERE id IN (SELECT id FROM descendants);`
|
|
193
|
+
);
|
|
194
|
+
}
|
|
195
|
+
async function deleteAllSessions() {
|
|
196
|
+
runSql(`DELETE FROM part; DELETE FROM message; DELETE FROM session;`);
|
|
197
|
+
}
|
|
198
|
+
async function deleteAllProjectSessions(projectID) {
|
|
199
|
+
const pid = escapeSql(projectID);
|
|
200
|
+
runSql(`DELETE FROM session WHERE project_id = '${pid}'; DELETE FROM project WHERE id = '${pid}';`);
|
|
201
|
+
}
|
|
202
|
+
function query(sql) {
|
|
203
|
+
const db = new SQLite(DATABASE_PATH);
|
|
204
|
+
try {
|
|
205
|
+
return db.all(sql);
|
|
206
|
+
} finally {
|
|
207
|
+
db.close();
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
function escapeSql(value) {
|
|
211
|
+
return value.replace(/'/g, "''");
|
|
212
|
+
}
|
|
213
|
+
|
|
214
|
+
export {
|
|
215
|
+
checkDatabase,
|
|
216
|
+
loadProjects,
|
|
217
|
+
loadSessions,
|
|
218
|
+
loadMessages,
|
|
219
|
+
loadParts,
|
|
220
|
+
loadTranscript,
|
|
221
|
+
deleteSession,
|
|
222
|
+
deleteSessionById,
|
|
223
|
+
deleteAllSessions,
|
|
224
|
+
deleteAllProjectSessions
|
|
225
|
+
};
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
getCacheFile,
|
|
4
|
+
loadCache,
|
|
5
|
+
saveCache
|
|
6
|
+
} from "./chunk-QD4T255Z.mjs";
|
|
7
|
+
import {
|
|
8
|
+
buildChecksum,
|
|
9
|
+
getAllFiles
|
|
10
|
+
} from "./chunk-WSHVPGNM.mjs";
|
|
11
|
+
import {
|
|
12
|
+
init_esm_shims
|
|
13
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
14
|
+
|
|
15
|
+
// src/run-by-checksum/run.js
|
|
16
|
+
init_esm_shims();
|
|
17
|
+
import { spawn } from "child_process";
|
|
18
|
+
async function runChecksum({
|
|
19
|
+
patterns = [],
|
|
20
|
+
ignore = [],
|
|
21
|
+
exec,
|
|
22
|
+
cwd = process.env.INIT_CWD || process.cwd(),
|
|
23
|
+
dryRun = false
|
|
24
|
+
}) {
|
|
25
|
+
if (!patterns.length && !exec) {
|
|
26
|
+
console.log("No patterns or command provided, skipping checksum runner.");
|
|
27
|
+
process.exit(1);
|
|
28
|
+
}
|
|
29
|
+
if (!exec) {
|
|
30
|
+
console.log("No command provided, skipping checksum runner.");
|
|
31
|
+
process.exit(1);
|
|
32
|
+
}
|
|
33
|
+
if (!patterns.length) {
|
|
34
|
+
console.log("No patterns provided, skipping checksum runner.");
|
|
35
|
+
process.exit(1);
|
|
36
|
+
}
|
|
37
|
+
const files = getAllFiles({ patterns, ignore, cwd });
|
|
38
|
+
const checksum = buildChecksum(files);
|
|
39
|
+
const cacheFile = getCacheFile({ patterns, ignore, cwd });
|
|
40
|
+
const cache = loadCache(cacheFile);
|
|
41
|
+
if ((cache == null ? void 0 : cache.checksum) === checksum) {
|
|
42
|
+
return {
|
|
43
|
+
changed: false,
|
|
44
|
+
cacheFile,
|
|
45
|
+
files
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
if (dryRun) {
|
|
49
|
+
return {
|
|
50
|
+
changed: true,
|
|
51
|
+
cacheFile,
|
|
52
|
+
files,
|
|
53
|
+
skipped: true
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
await runCommand(exec, cwd);
|
|
57
|
+
saveCache(cacheFile, {
|
|
58
|
+
checksum,
|
|
59
|
+
files,
|
|
60
|
+
patterns,
|
|
61
|
+
ignore,
|
|
62
|
+
updatedAt: (/* @__PURE__ */ new Date()).toISOString()
|
|
63
|
+
});
|
|
64
|
+
return {
|
|
65
|
+
changed: true,
|
|
66
|
+
cacheFile,
|
|
67
|
+
files
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
function runCommand(command, cwd) {
|
|
71
|
+
return new Promise((resolve, reject) => {
|
|
72
|
+
const child = spawn(command, {
|
|
73
|
+
shell: true,
|
|
74
|
+
stdio: "inherit",
|
|
75
|
+
cwd
|
|
76
|
+
});
|
|
77
|
+
child.on("exit", (code) => {
|
|
78
|
+
if (code === 0 || code === null) resolve();
|
|
79
|
+
else reject(new Error(`Command failed: ${code}`));
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
export {
|
|
85
|
+
runChecksum
|
|
86
|
+
};
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
init_esm_shims
|
|
4
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
5
|
+
|
|
6
|
+
// src/run-by-checksum/hash.js
|
|
7
|
+
init_esm_shims();
|
|
8
|
+
import fs from "fs-extra";
|
|
9
|
+
import * as glob from "glob";
|
|
10
|
+
import upath from "upath";
|
|
11
|
+
import path from "upath";
|
|
12
|
+
import crypto from "crypto";
|
|
13
|
+
function getAllFiles({ patterns, ignore, cwd }) {
|
|
14
|
+
const files = /* @__PURE__ */ new Set();
|
|
15
|
+
const root = cwd || process.cwd();
|
|
16
|
+
for (const pattern of patterns) {
|
|
17
|
+
const matched = glob.sync(pattern, {
|
|
18
|
+
cwd: root,
|
|
19
|
+
nodir: true,
|
|
20
|
+
ignore
|
|
21
|
+
});
|
|
22
|
+
for (const f of matched) {
|
|
23
|
+
files.add(upath.normalize(path.resolve(root, f)));
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
return [...files].sort();
|
|
27
|
+
}
|
|
28
|
+
function isBinaryFile(filePath, bytesToCheck = 8e3) {
|
|
29
|
+
const buffer = fs.readFileSync(filePath, { length: bytesToCheck });
|
|
30
|
+
for (let i = 0; i < buffer.length; i++) {
|
|
31
|
+
if (buffer[i] === 0) {
|
|
32
|
+
return true;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
return false;
|
|
36
|
+
}
|
|
37
|
+
function hashFile(file) {
|
|
38
|
+
const isBin = isBinaryFile(file);
|
|
39
|
+
if (!isBin) {
|
|
40
|
+
const content = fs.readFileSync(file, { encoding: "utf-8" });
|
|
41
|
+
const normalized = content.toString().replace(/\s+/g, " ").trim();
|
|
42
|
+
return crypto.createHash("sha256").update(normalized).digest("hex");
|
|
43
|
+
} else {
|
|
44
|
+
const stats = fs.statSync(file);
|
|
45
|
+
return crypto.createHash("sha256").update(file).update(String(stats.size)).digest("hex");
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
function buildChecksum(files) {
|
|
49
|
+
const hash = crypto.createHash("sha256");
|
|
50
|
+
for (const file of files) {
|
|
51
|
+
hash.update(file);
|
|
52
|
+
hash.update(hashFile(file));
|
|
53
|
+
}
|
|
54
|
+
return hash.digest("hex");
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
export {
|
|
58
|
+
getAllFiles,
|
|
59
|
+
buildChecksum
|
|
60
|
+
};
|
|
@@ -4,7 +4,7 @@ import {
|
|
|
4
4
|
} from "./chunk-A3VUZEJK.mjs";
|
|
5
5
|
import {
|
|
6
6
|
require_utils
|
|
7
|
-
} from "./chunk-
|
|
7
|
+
} from "./chunk-6RK5UCTP.mjs";
|
|
8
8
|
import {
|
|
9
9
|
__commonJS,
|
|
10
10
|
__require,
|
|
@@ -18,7 +18,7 @@ var require_user_config = __commonJS({
|
|
|
18
18
|
var gch = __require("git-command-helper");
|
|
19
19
|
var { runGitCommand, runGitCommandOutput } = require_utils2();
|
|
20
20
|
var { getArgs } = require_utils();
|
|
21
|
-
__require("dotenv").config({ path: __require("
|
|
21
|
+
__require("dotenv").config({ path: __require("upath").join(process.cwd(), ".env"), quiet: true });
|
|
22
22
|
function configureGitUser(cliUser = null, cliEmail = null, options = {}) {
|
|
23
23
|
console.log("\n=== Configuring Git User ===");
|
|
24
24
|
let username, email;
|