binary-collections 2.0.11 → 2.0.13
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 +89 -13
- package/binaries/clean-nodemodule.cjs +89 -13
- package/binaries/clean-nodemodules.cjs +89 -13
- package/binaries/dev.cjs +89 -13
- package/binaries/empty.cjs +89 -13
- package/binaries/git-reduce-size.cjs +89 -13
- package/binaries/javakill.cjs +89 -13
- package/binaries/kill-process.cjs +89 -13
- package/binaries/nodekill.cjs +89 -13
- package/binaries/prod.cjs +89 -13
- package/binaries/py.cjs +89 -13
- package/binaries/rmfind.cjs +89 -13
- package/binaries/rmx +15 -1
- package/binaries/rmx.cjs +89 -13
- package/binaries/rmx.cmd +12 -0
- package/binaries/submodule-token.cjs +89 -13
- package/binaries/test-cjs +9 -1
- package/binaries/test-cjs.cjs +89 -13
- package/binaries/test-cjs.cmd +16 -1
- package/binaries/test-esm +16 -0
- package/binaries/test-esm.cjs +254 -0
- package/binaries/test-esm.cmd +23 -0
- package/binaries/yarn-clean +1 -1
- package/binaries/yarn-clean.cjs +89 -13
- package/binaries/yarn-clean.cmd +1 -1
- package/binaries/yarn-clean.py +33 -15
- package/binaries/yc +131 -0
- package/binaries/yc.cjs +254 -0
- package/binaries/ycw +256 -0
- package/binaries/ycw.cjs +254 -0
- package/docs-src/binary-collections.md +34 -0
- package/docs-src/changelog.md +26 -0
- package/docs-src/clean-github-actions-caches.md +91 -2
- package/docs-src/copy-move-file.md +59 -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/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/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/yarn-install.md +31 -0
- package/docs-src/yarn-reinstall.md +27 -0
- package/lib/binary-collections/config.cjs +126 -0
- package/lib/binary-collections/config.mjs +7 -0
- package/lib/binary-collections/executeScript.cjs +19 -0
- package/lib/binary-collections/executeScript.d.cts +12 -0
- package/lib/binary-collections/executeScript.mjs +6 -0
- package/lib/binary-collections/findScript.cjs +309 -0
- package/lib/binary-collections/findScript.d.cts +12 -0
- package/lib/binary-collections/findScript.mjs +7 -0
- package/lib/binary-collections/listScript.cjs +291 -0
- package/lib/binary-collections/listScript.d.cts +19 -0
- package/lib/binary-collections/listScript.mjs +7 -0
- package/lib/binary-collections.cjs +264 -157
- package/lib/binary-collections.mjs +26 -286
- package/lib/changelog.cjs +9 -14
- package/lib/changelog.mjs +2 -2
- package/lib/chunk-2MN4VPV2.mjs +246 -0
- package/lib/chunk-6C7KTYGZ.mjs +41 -0
- package/lib/{chunk-Z6JLYU2J.mjs → chunk-6RK5UCTP.mjs} +7 -12
- package/lib/chunk-CD3HF3LK.mjs +190 -0
- package/lib/chunk-FLYSZFLW.mjs +61 -0
- package/lib/{chunk-N436BNBK.mjs → chunk-GAGABICI.mjs} +19 -13
- package/lib/chunk-H44UWUFY.mjs +105 -0
- package/lib/chunk-KLKAIFKI.mjs +40 -0
- package/lib/chunk-LVSPEFU2.mjs +86 -0
- package/lib/{chunk-RWLXRTYP.mjs → chunk-MGPYPKIE.mjs} +2 -2
- package/lib/chunk-NGFK3EYW.mjs +28 -0
- package/lib/chunk-NQXUYO67.mjs +253 -0
- package/lib/chunk-NVEG3LEZ.mjs +143 -0
- package/lib/chunk-OBXLTXFJ.mjs +34 -0
- package/lib/chunk-OGXVGBRI.mjs +29 -0
- package/lib/chunk-OXV52GD5.mjs +62 -0
- package/lib/chunk-PXBMHE7O.mjs +35 -0
- package/lib/chunk-QD4T255Z.mjs +40 -0
- package/lib/chunk-QII2EKCS.mjs +26 -0
- package/lib/chunk-R5FJOR63.mjs +47 -0
- package/lib/chunk-RDGDLSPD.mjs +76 -0
- package/lib/chunk-RDN6HF5Z.mjs +79 -0
- package/lib/chunk-RJKTSUAX.mjs +123 -0
- package/lib/{chunk-XA3SNBPA.mjs → chunk-TBWXE7ST.mjs} +97 -38
- package/lib/chunk-UXCFNAR6.mjs +55 -0
- package/lib/{chunk-M3YIYRHT.mjs → chunk-UY5VUEA3.mjs} +1 -1
- package/lib/chunk-WSHVPGNM.mjs +44 -0
- package/lib/{chunk-66PAU5PS.mjs → chunk-X2B3X7D4.mjs} +10 -6
- package/lib/clean-github-actions-caches-cli.cjs +507 -0
- package/lib/clean-github-actions-caches-cli.mjs +74 -0
- package/lib/clean-github-actions-caches.cjs +246 -106
- package/lib/clean-github-actions-caches.d.cts +53 -1
- package/lib/clean-github-actions-caches.mjs +5 -130
- package/lib/cross-env/command.cjs +63 -0
- package/lib/cross-env/command.d.ts +8 -0
- package/lib/cross-env/command.js +45 -0
- package/lib/{ps/isWin.mjs → cross-env/command.mjs} +4 -5
- package/lib/cross-env/index.cjs +178 -0
- package/lib/cross-env/index.d.ts +8 -0
- package/lib/cross-env/index.js +102 -0
- package/lib/cross-env/index.mjs +101 -0
- package/lib/cross-env/variable.cjs +60 -0
- package/lib/cross-env/variable.d.ts +7 -0
- package/lib/cross-env/variable.js +59 -0
- package/lib/cross-env/variable.mjs +9 -0
- package/lib/del-gradle.cjs +8 -13
- package/lib/del-gradle.js +8 -8
- package/lib/del-gradle.mjs +1 -1
- package/lib/del-node-modules.cjs +185 -3
- package/lib/del-node-modules.js +25 -25
- package/lib/del-node-modules.mjs +6 -3
- package/lib/{del-ps.cjs → del-ps-cli.cjs} +38 -43
- package/lib/del-ps-cli.d.mts +1 -0
- package/lib/del-ps-cli.mjs +44 -0
- package/lib/del-yarn-caches.cjs +8 -13
- package/lib/del-yarn-caches.js +2 -2
- package/lib/del-yarn-caches.mjs +1 -1
- package/lib/downloader-cli.cjs +256 -0
- package/lib/downloader-cli.d.cts +2 -0
- package/lib/downloader-cli.mjs +90 -0
- package/lib/file/copy-cli.cjs +273 -0
- package/lib/file/copy-cli.d.mts +1 -0
- package/lib/file/copy-cli.mjs +59 -0
- package/lib/file/copy.cjs +56 -0
- package/lib/file/copy.d.mts +1 -0
- package/lib/file/copy.mjs +8 -0
- package/lib/file/move-cli.cjs +272 -0
- package/lib/file/move-cli.d.mts +1 -0
- package/lib/file/move-cli.mjs +59 -0
- package/lib/file/move.cjs +55 -0
- package/lib/file/move.d.mts +1 -0
- package/lib/file/move.mjs +8 -0
- package/lib/find-node-modules-cli.cjs +1 -1
- package/lib/find-node-modules-cli.js +1 -1
- package/lib/find-node-modules-cli.mjs +1 -1
- package/lib/find-node-modules.cjs +1 -1
- package/lib/find-node-modules.mjs +1 -1
- package/lib/free-chatgpt.cjs +27 -26
- package/lib/free-chatgpt.js +10 -10
- package/lib/free-chatgpt.mjs +2 -2
- package/lib/git/user-config.cjs +9 -14
- package/lib/git/user-config.mjs +2 -2
- package/lib/git-diff-cli.cjs +273 -66
- package/lib/git-diff-cli.mjs +5 -4
- package/lib/git-diff.cjs +273 -66
- package/lib/git-diff.d.ts +2 -1
- package/lib/git-diff.js +153 -39
- package/lib/git-diff.mjs +5 -4
- package/lib/git-fix.cjs +9 -14
- package/lib/git-fix.mjs +2 -2
- package/lib/git-purge.cjs +9 -14
- package/lib/git-purge.mjs +2 -2
- package/lib/index.cjs +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/index.mjs +1 -1
- package/lib/kill-night-crows.cjs +7 -7
- package/lib/kill-night-crows.mjs +7 -7
- package/lib/node-cache-cleaner/npm.cjs +65 -0
- package/lib/node-cache-cleaner/npm.d.ts +2 -0
- package/lib/node-cache-cleaner/npm.js +41 -0
- package/lib/node-cache-cleaner/npm.mjs +10 -0
- package/lib/node-cache-cleaner/npx.cjs +89 -0
- package/lib/node-cache-cleaner/npx.d.ts +4 -0
- package/lib/node-cache-cleaner/npx.js +82 -0
- package/lib/{ps/index.d.mjs → node-cache-cleaner/npx.mjs} +6 -5
- package/lib/node-cache-cleaner/yarn.cjs +73 -0
- package/lib/node-cache-cleaner/yarn.d.ts +2 -0
- package/lib/node-cache-cleaner/yarn.js +62 -0
- package/lib/node-cache-cleaner/yarn.mjs +10 -0
- package/lib/node-cache-cleaner-cli.cjs +365 -0
- package/lib/node-cache-cleaner-cli.d.ts +2 -0
- package/lib/node-cache-cleaner-cli.js +57 -0
- package/lib/node-cache-cleaner-cli.mjs +60 -0
- package/lib/node-executor.cjs +272 -0
- package/lib/node-executor.d.cts +2 -0
- package/lib/node-executor.mjs +106 -0
- 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 +28 -40
- package/lib/npm-run-series.mjs +21 -7
- package/lib/package-resolutions-updater-cli.cjs +255 -173
- package/lib/package-resolutions-updater-cli.mjs +19 -40
- package/lib/package-resolutions-updater.cjs +244 -141
- package/lib/package-resolutions-updater.d.mts +54 -1
- package/lib/package-resolutions-updater.mjs +8 -5
- package/lib/php-cs-fixer-staged.cjs +1 -1
- package/lib/php-cs-fixer-staged.mjs +1 -1
- package/lib/print-directory-tree.cjs +18 -20
- package/lib/print-directory-tree.mjs +11 -8
- 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/connected-domain.js +10 -10
- package/lib/ps/index.cjs +11 -11
- package/lib/ps/index.mjs +180 -174
- package/lib/ps/table-parser.d.ts +3 -4
- package/lib/ps/table-parser.js +15 -22
- package/lib/remove-module.cjs +19 -24
- package/lib/remove-module.mjs +2 -2
- package/lib/rm-node-module-cli.cjs +389 -0
- package/lib/rm-node-module-cli.d.cts +1 -0
- package/lib/rm-node-module-cli.mjs +92 -0
- package/lib/rm-node-modules.cjs +127 -0
- package/lib/rm-node-modules.d.cts +35 -0
- package/lib/{binary-collections-config.mjs → rm-node-modules.mjs} +3 -3
- package/lib/rmpath-cli.cjs +285 -0
- package/lib/rmpath-cli.d.mts +1 -0
- package/lib/rmpath-cli.mjs +23 -0
- package/lib/rmpath.cjs +6 -217
- package/lib/rmpath.mjs +5 -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 +72 -0
- package/lib/run-by-checksum/hash.d.ts +14 -0
- package/lib/run-by-checksum/hash.js +85 -0
- package/lib/run-by-checksum/hash.mjs +10 -0
- package/lib/run-by-checksum/run.cjs +169 -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 +382 -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 +55 -47
- package/lib/submodule-install.mjs +48 -35
- package/lib/submodule-remove-cli.cjs +170 -4
- package/lib/submodule-remove-cli.js +5 -5
- package/lib/submodule-remove-cli.mjs +6 -4
- package/lib/utils/chatgpt.cjs +19 -13
- package/lib/utils/chatgpt.js +94 -94
- package/lib/utils/chatgpt.mjs +1 -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 +28 -46
- package/lib/utils/findEnvFiles.d.cts +19 -0
- package/lib/utils/findEnvFiles.mjs +3 -5
- package/lib/utils/findWorkspaceRoot.js +4 -4
- package/lib/utils/index.cjs +7 -12
- package/lib/utils/index.d.cts +2 -9
- package/lib/utils/index.mjs +1 -1
- package/lib/utils/isGithubTokenValid.js +7 -7
- package/lib/{ps/isWin.cjs → utils/isWindows.cjs} +12 -7
- package/lib/utils/isWindows.d.ts +5 -0
- package/lib/utils/isWindows.js +10 -0
- package/lib/utils/isWindows.mjs +10 -0
- package/lib/utils/runBash.cjs +53 -0
- package/lib/utils/runBash.d.cts +12 -0
- package/lib/utils/runBash.mjs +66 -0
- package/lib/yarn-per-branch-lock-installer.cjs +288 -0
- package/lib/yarn-per-branch-lock-installer.d.cts +2 -0
- package/lib/yarn-per-branch-lock-installer.mjs +122 -0
- package/lib/yarn-reinstall.cjs +8 -13
- package/lib/yarn-reinstall.mjs +1 -1
- package/package.json +91 -57
- package/readme.html +784 -0
- package/readme.md +107 -219
- package/releases/readme.md +6 -3
- package/test/README.md +2 -2
- package/test-project/workspaces/workspace-a/readme.md +20 -0
- package/test-project/workspaces/workspace-a/release/readme.md +42 -0
- package/test-project/workspaces/workspace-a/test/readme.md +12 -0
- package/test-project/workspaces/workspace-b/readme.md +94 -0
- package/test-project/workspaces/workspace-b/requirements.txt +1 -0
- package/test-project/workspaces/workspace-b/themes/hexo-theme-flowbite/readme.md +156 -0
- package/tmp/test-repo/README.md +2 -35
- 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/lib/binary-collections-config.cjs +0 -15
- package/lib/chunk-2CBJCW7E.mjs +0 -81
- package/lib/chunk-4UHL4WVN.mjs +0 -136
- package/lib/chunk-6HHJRKFB.mjs +0 -59
- package/lib/chunk-6S4NXESK.mjs +0 -26
- package/lib/chunk-7XTEJHOE.mjs +0 -193
- package/lib/chunk-AJDD5DZM.mjs +0 -109
- package/lib/chunk-FCDQGYBF.mjs +0 -136
- package/lib/chunk-GEYA2USY.mjs +0 -207
- package/lib/chunk-GJTGHXRA.mjs +0 -356
- package/lib/chunk-ID2WBTE2.mjs +0 -80
- package/lib/chunk-JXFOHKDM.mjs +0 -239
- package/lib/chunk-NCXAP7AA.mjs +0 -31
- package/lib/chunk-PDSXF5HY.mjs +0 -187
- package/lib/chunk-TOIVAQF7.mjs +0 -136
- package/lib/chunk-V5SKYJUB.mjs +0 -136
- package/lib/chunk-WSRETQCA.mjs +0 -59
- package/lib/chunk-YYLIQQKF.mjs +0 -31
- package/lib/del-ps.js +0 -32
- package/lib/del-ps.mjs +0 -43
- package/lib/ps/index.d.cjs +0 -17
- package/lib/ps/index.d.ts +0 -2
- package/lib/ps/index.js +0 -254
- package/lib/ps/isWin.d.ts +0 -2
- package/lib/ps/isWin.js +0 -4
- package/lib/utils/findEnvFiles.d.ts +0 -8
- package/lib/utils/findEnvFiles.js +0 -121
- package/test/package.json +0 -20
- package/test-project/package.json +0 -16
- package/tmp/test-repo/package.json +0 -7
- package/tmp/typedoc/readme.md +0 -320
- /package/lib/{binary-collections-config.d.cts → binary-collections/config.d.cts} +0 -0
- /package/lib/{del-ps.d.ts → clean-github-actions-caches-cli.d.cts} +0 -0
package/binaries/nodekill.cjs
CHANGED
|
@@ -12,9 +12,11 @@
|
|
|
12
12
|
* - fs:
|
|
13
13
|
* Used to check whether files exist.
|
|
14
14
|
*/
|
|
15
|
-
const { spawnSync } = require(
|
|
16
|
-
const path = require(
|
|
17
|
-
const fs = require(
|
|
15
|
+
const { spawnSync } = require('child_process');
|
|
16
|
+
const path = require('path');
|
|
17
|
+
const fs = require('fs');
|
|
18
|
+
const which = require('which');
|
|
19
|
+
const { isWindows } = require('../src/utils/isWindows.js');
|
|
18
20
|
|
|
19
21
|
/**
|
|
20
22
|
* __dirname
|
|
@@ -49,7 +51,7 @@ const base = path.basename(__filename, path.extname(__filename));
|
|
|
49
51
|
* .sh
|
|
50
52
|
* executable file without extension
|
|
51
53
|
*/
|
|
52
|
-
const candidates = process.platform ===
|
|
54
|
+
const candidates = process.platform === 'win32' ? ['.cmd', '.bat', '.ps1', '.vbs'] : ['.sh', ''];
|
|
53
55
|
|
|
54
56
|
/**
|
|
55
57
|
* Search for the first matching script
|
|
@@ -72,13 +74,32 @@ let found = null;
|
|
|
72
74
|
|
|
73
75
|
for (const ext of candidates) {
|
|
74
76
|
const script = path.join(binDir, base + ext);
|
|
75
|
-
|
|
76
|
-
|
|
77
|
+
const exists = fs.existsSync(script);
|
|
78
|
+
// console.log(`Checking for ${script}: ${exists ? 'found' : 'not found'}`);
|
|
79
|
+
if (exists) {
|
|
77
80
|
found = script;
|
|
78
81
|
break;
|
|
79
82
|
}
|
|
80
83
|
}
|
|
81
84
|
|
|
85
|
+
/**
|
|
86
|
+
* If no matching script was found,
|
|
87
|
+
* try check if `bash` is available and if so, check for a .sh script.
|
|
88
|
+
*/
|
|
89
|
+
if (!found) {
|
|
90
|
+
try {
|
|
91
|
+
spawnSync('bash', ['--version'], { stdio: 'ignore' });
|
|
92
|
+
const bashScript = [path.join(binDir, base), path.join(binDir, base + '.sh')].find((script) =>
|
|
93
|
+
fs.existsSync(script)
|
|
94
|
+
);
|
|
95
|
+
if (bashScript) {
|
|
96
|
+
found = bashScript;
|
|
97
|
+
}
|
|
98
|
+
} catch {
|
|
99
|
+
// bash is not available, do nothing
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
|
|
82
103
|
/**
|
|
83
104
|
* If no matching script was found,
|
|
84
105
|
* print an error and exit with failure code 1.
|
|
@@ -92,8 +113,9 @@ if (!found) {
|
|
|
92
113
|
* Detect special script types
|
|
93
114
|
* that require a shell/interpreter.
|
|
94
115
|
*/
|
|
95
|
-
const isPs1 = found.endsWith(
|
|
96
|
-
const isCmd = found.endsWith(
|
|
116
|
+
const isPs1 = found.endsWith('.ps1');
|
|
117
|
+
const isCmd = found.endsWith('.cmd');
|
|
118
|
+
const isUnixShell = found.endsWith('.sh') || path.extname(found) === '';
|
|
97
119
|
|
|
98
120
|
/**
|
|
99
121
|
* cmd
|
|
@@ -124,9 +146,9 @@ let cmd, args;
|
|
|
124
146
|
* Forward all user-provided command-line arguments.
|
|
125
147
|
*/
|
|
126
148
|
if (isPs1) {
|
|
127
|
-
cmd =
|
|
149
|
+
cmd = 'powershell.exe';
|
|
128
150
|
|
|
129
|
-
args = [
|
|
151
|
+
args = ['-NoProfile', '-ExecutionPolicy', 'Bypass', '-File', found, ...process.argv.slice(2)];
|
|
130
152
|
|
|
131
153
|
/**
|
|
132
154
|
* CMD batch files:
|
|
@@ -137,9 +159,9 @@ if (isPs1) {
|
|
|
137
159
|
* "execute command and terminate"
|
|
138
160
|
*/
|
|
139
161
|
} else if (isCmd) {
|
|
140
|
-
cmd =
|
|
162
|
+
cmd = 'cmd.exe';
|
|
141
163
|
|
|
142
|
-
args = [
|
|
164
|
+
args = ['/c', found, ...process.argv.slice(2)];
|
|
143
165
|
|
|
144
166
|
/**
|
|
145
167
|
* Other scripts:
|
|
@@ -150,11 +172,65 @@ if (isPs1) {
|
|
|
150
172
|
*
|
|
151
173
|
* These can be executed directly.
|
|
152
174
|
*/
|
|
175
|
+
} else if (isUnixShell) {
|
|
176
|
+
// Capture shebang scripts (no extension) and .sh scripts
|
|
177
|
+
const shebang = fs.readFileSync(found, 'utf8').split('\n')[0].trim();
|
|
178
|
+
const interpreter = shebang.startsWith('#!')
|
|
179
|
+
? shebang
|
|
180
|
+
.slice(2)
|
|
181
|
+
.trim()
|
|
182
|
+
.replace(/^\/usr\/bin\/env\s+/, '')
|
|
183
|
+
.replace(/^\/bin\/env\s+/, '')
|
|
184
|
+
.replace(/^\/usr\/bin\//, '')
|
|
185
|
+
.replace(/^\/bin\//, '')
|
|
186
|
+
: null;
|
|
187
|
+
|
|
188
|
+
if (interpreter) {
|
|
189
|
+
const resolvedOrNull = which.sync(interpreter, { nothrow: true });
|
|
190
|
+
if (!resolvedOrNull) {
|
|
191
|
+
if (['bash', 'sh'].includes(interpreter) && isWindows()) {
|
|
192
|
+
const locationsToCheck = [
|
|
193
|
+
'C:\\Program Files\\Git\\usr\\bin',
|
|
194
|
+
'C:\\Program Files\\Git\\bin',
|
|
195
|
+
'C:\\Program Files (x86)\\Git\\usr\\bin',
|
|
196
|
+
'C:\\msys64\\usr\\bin',
|
|
197
|
+
'C:\\msys64\\bin',
|
|
198
|
+
'C:\\cygwin64\\bin',
|
|
199
|
+
'C:\\cygwin\\bin',
|
|
200
|
+
'C:\\MinGW\\bin',
|
|
201
|
+
'C:\\MinGW\\msys\\1.0\\bin'
|
|
202
|
+
];
|
|
203
|
+
for (const location of locationsToCheck) {
|
|
204
|
+
const potentialPath = path.join(location, 'bash.exe');
|
|
205
|
+
if (fs.existsSync(potentialPath)) {
|
|
206
|
+
cmd = potentialPath;
|
|
207
|
+
args = [found, ...process.argv.slice(2)];
|
|
208
|
+
break;
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
} else {
|
|
213
|
+
cmd = resolvedOrNull || interpreter;
|
|
214
|
+
args = [found, ...process.argv.slice(2)];
|
|
215
|
+
}
|
|
216
|
+
} else {
|
|
217
|
+
cmd = found;
|
|
218
|
+
args = process.argv.slice(2);
|
|
219
|
+
}
|
|
153
220
|
} else {
|
|
154
221
|
cmd = found;
|
|
155
222
|
args = process.argv.slice(2);
|
|
156
223
|
}
|
|
157
224
|
|
|
225
|
+
console.log(
|
|
226
|
+
`Executing: ${path.isAbsolute(cmd) ? path.relative(process.cwd(), cmd) : cmd} ${args
|
|
227
|
+
.map((f) => {
|
|
228
|
+
if (path.isAbsolute(f)) return path.relative(process.cwd(), f);
|
|
229
|
+
return f;
|
|
230
|
+
})
|
|
231
|
+
.join(' ')}`
|
|
232
|
+
);
|
|
233
|
+
|
|
158
234
|
/**
|
|
159
235
|
* Execute the selected script synchronously.
|
|
160
236
|
*
|
|
@@ -165,7 +241,7 @@ if (isPs1) {
|
|
|
165
241
|
* spawnSync waits until the child process exits.
|
|
166
242
|
*/
|
|
167
243
|
const result = spawnSync(cmd, args, {
|
|
168
|
-
stdio:
|
|
244
|
+
stdio: 'inherit'
|
|
169
245
|
});
|
|
170
246
|
|
|
171
247
|
/**
|
package/binaries/prod.cjs
CHANGED
|
@@ -12,9 +12,11 @@
|
|
|
12
12
|
* - fs:
|
|
13
13
|
* Used to check whether files exist.
|
|
14
14
|
*/
|
|
15
|
-
const { spawnSync } = require(
|
|
16
|
-
const path = require(
|
|
17
|
-
const fs = require(
|
|
15
|
+
const { spawnSync } = require('child_process');
|
|
16
|
+
const path = require('path');
|
|
17
|
+
const fs = require('fs');
|
|
18
|
+
const which = require('which');
|
|
19
|
+
const { isWindows } = require('../src/utils/isWindows.js');
|
|
18
20
|
|
|
19
21
|
/**
|
|
20
22
|
* __dirname
|
|
@@ -49,7 +51,7 @@ const base = path.basename(__filename, path.extname(__filename));
|
|
|
49
51
|
* .sh
|
|
50
52
|
* executable file without extension
|
|
51
53
|
*/
|
|
52
|
-
const candidates = process.platform ===
|
|
54
|
+
const candidates = process.platform === 'win32' ? ['.cmd', '.bat', '.ps1', '.vbs'] : ['.sh', ''];
|
|
53
55
|
|
|
54
56
|
/**
|
|
55
57
|
* Search for the first matching script
|
|
@@ -72,13 +74,32 @@ let found = null;
|
|
|
72
74
|
|
|
73
75
|
for (const ext of candidates) {
|
|
74
76
|
const script = path.join(binDir, base + ext);
|
|
75
|
-
|
|
76
|
-
|
|
77
|
+
const exists = fs.existsSync(script);
|
|
78
|
+
// console.log(`Checking for ${script}: ${exists ? 'found' : 'not found'}`);
|
|
79
|
+
if (exists) {
|
|
77
80
|
found = script;
|
|
78
81
|
break;
|
|
79
82
|
}
|
|
80
83
|
}
|
|
81
84
|
|
|
85
|
+
/**
|
|
86
|
+
* If no matching script was found,
|
|
87
|
+
* try check if `bash` is available and if so, check for a .sh script.
|
|
88
|
+
*/
|
|
89
|
+
if (!found) {
|
|
90
|
+
try {
|
|
91
|
+
spawnSync('bash', ['--version'], { stdio: 'ignore' });
|
|
92
|
+
const bashScript = [path.join(binDir, base), path.join(binDir, base + '.sh')].find((script) =>
|
|
93
|
+
fs.existsSync(script)
|
|
94
|
+
);
|
|
95
|
+
if (bashScript) {
|
|
96
|
+
found = bashScript;
|
|
97
|
+
}
|
|
98
|
+
} catch {
|
|
99
|
+
// bash is not available, do nothing
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
|
|
82
103
|
/**
|
|
83
104
|
* If no matching script was found,
|
|
84
105
|
* print an error and exit with failure code 1.
|
|
@@ -92,8 +113,9 @@ if (!found) {
|
|
|
92
113
|
* Detect special script types
|
|
93
114
|
* that require a shell/interpreter.
|
|
94
115
|
*/
|
|
95
|
-
const isPs1 = found.endsWith(
|
|
96
|
-
const isCmd = found.endsWith(
|
|
116
|
+
const isPs1 = found.endsWith('.ps1');
|
|
117
|
+
const isCmd = found.endsWith('.cmd');
|
|
118
|
+
const isUnixShell = found.endsWith('.sh') || path.extname(found) === '';
|
|
97
119
|
|
|
98
120
|
/**
|
|
99
121
|
* cmd
|
|
@@ -124,9 +146,9 @@ let cmd, args;
|
|
|
124
146
|
* Forward all user-provided command-line arguments.
|
|
125
147
|
*/
|
|
126
148
|
if (isPs1) {
|
|
127
|
-
cmd =
|
|
149
|
+
cmd = 'powershell.exe';
|
|
128
150
|
|
|
129
|
-
args = [
|
|
151
|
+
args = ['-NoProfile', '-ExecutionPolicy', 'Bypass', '-File', found, ...process.argv.slice(2)];
|
|
130
152
|
|
|
131
153
|
/**
|
|
132
154
|
* CMD batch files:
|
|
@@ -137,9 +159,9 @@ if (isPs1) {
|
|
|
137
159
|
* "execute command and terminate"
|
|
138
160
|
*/
|
|
139
161
|
} else if (isCmd) {
|
|
140
|
-
cmd =
|
|
162
|
+
cmd = 'cmd.exe';
|
|
141
163
|
|
|
142
|
-
args = [
|
|
164
|
+
args = ['/c', found, ...process.argv.slice(2)];
|
|
143
165
|
|
|
144
166
|
/**
|
|
145
167
|
* Other scripts:
|
|
@@ -150,11 +172,65 @@ if (isPs1) {
|
|
|
150
172
|
*
|
|
151
173
|
* These can be executed directly.
|
|
152
174
|
*/
|
|
175
|
+
} else if (isUnixShell) {
|
|
176
|
+
// Capture shebang scripts (no extension) and .sh scripts
|
|
177
|
+
const shebang = fs.readFileSync(found, 'utf8').split('\n')[0].trim();
|
|
178
|
+
const interpreter = shebang.startsWith('#!')
|
|
179
|
+
? shebang
|
|
180
|
+
.slice(2)
|
|
181
|
+
.trim()
|
|
182
|
+
.replace(/^\/usr\/bin\/env\s+/, '')
|
|
183
|
+
.replace(/^\/bin\/env\s+/, '')
|
|
184
|
+
.replace(/^\/usr\/bin\//, '')
|
|
185
|
+
.replace(/^\/bin\//, '')
|
|
186
|
+
: null;
|
|
187
|
+
|
|
188
|
+
if (interpreter) {
|
|
189
|
+
const resolvedOrNull = which.sync(interpreter, { nothrow: true });
|
|
190
|
+
if (!resolvedOrNull) {
|
|
191
|
+
if (['bash', 'sh'].includes(interpreter) && isWindows()) {
|
|
192
|
+
const locationsToCheck = [
|
|
193
|
+
'C:\\Program Files\\Git\\usr\\bin',
|
|
194
|
+
'C:\\Program Files\\Git\\bin',
|
|
195
|
+
'C:\\Program Files (x86)\\Git\\usr\\bin',
|
|
196
|
+
'C:\\msys64\\usr\\bin',
|
|
197
|
+
'C:\\msys64\\bin',
|
|
198
|
+
'C:\\cygwin64\\bin',
|
|
199
|
+
'C:\\cygwin\\bin',
|
|
200
|
+
'C:\\MinGW\\bin',
|
|
201
|
+
'C:\\MinGW\\msys\\1.0\\bin'
|
|
202
|
+
];
|
|
203
|
+
for (const location of locationsToCheck) {
|
|
204
|
+
const potentialPath = path.join(location, 'bash.exe');
|
|
205
|
+
if (fs.existsSync(potentialPath)) {
|
|
206
|
+
cmd = potentialPath;
|
|
207
|
+
args = [found, ...process.argv.slice(2)];
|
|
208
|
+
break;
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
} else {
|
|
213
|
+
cmd = resolvedOrNull || interpreter;
|
|
214
|
+
args = [found, ...process.argv.slice(2)];
|
|
215
|
+
}
|
|
216
|
+
} else {
|
|
217
|
+
cmd = found;
|
|
218
|
+
args = process.argv.slice(2);
|
|
219
|
+
}
|
|
153
220
|
} else {
|
|
154
221
|
cmd = found;
|
|
155
222
|
args = process.argv.slice(2);
|
|
156
223
|
}
|
|
157
224
|
|
|
225
|
+
console.log(
|
|
226
|
+
`Executing: ${path.isAbsolute(cmd) ? path.relative(process.cwd(), cmd) : cmd} ${args
|
|
227
|
+
.map((f) => {
|
|
228
|
+
if (path.isAbsolute(f)) return path.relative(process.cwd(), f);
|
|
229
|
+
return f;
|
|
230
|
+
})
|
|
231
|
+
.join(' ')}`
|
|
232
|
+
);
|
|
233
|
+
|
|
158
234
|
/**
|
|
159
235
|
* Execute the selected script synchronously.
|
|
160
236
|
*
|
|
@@ -165,7 +241,7 @@ if (isPs1) {
|
|
|
165
241
|
* spawnSync waits until the child process exits.
|
|
166
242
|
*/
|
|
167
243
|
const result = spawnSync(cmd, args, {
|
|
168
|
-
stdio:
|
|
244
|
+
stdio: 'inherit'
|
|
169
245
|
});
|
|
170
246
|
|
|
171
247
|
/**
|
package/binaries/py.cjs
CHANGED
|
@@ -12,9 +12,11 @@
|
|
|
12
12
|
* - fs:
|
|
13
13
|
* Used to check whether files exist.
|
|
14
14
|
*/
|
|
15
|
-
const { spawnSync } = require(
|
|
16
|
-
const path = require(
|
|
17
|
-
const fs = require(
|
|
15
|
+
const { spawnSync } = require('child_process');
|
|
16
|
+
const path = require('path');
|
|
17
|
+
const fs = require('fs');
|
|
18
|
+
const which = require('which');
|
|
19
|
+
const { isWindows } = require('../src/utils/isWindows.js');
|
|
18
20
|
|
|
19
21
|
/**
|
|
20
22
|
* __dirname
|
|
@@ -49,7 +51,7 @@ const base = path.basename(__filename, path.extname(__filename));
|
|
|
49
51
|
* .sh
|
|
50
52
|
* executable file without extension
|
|
51
53
|
*/
|
|
52
|
-
const candidates = process.platform ===
|
|
54
|
+
const candidates = process.platform === 'win32' ? ['.cmd', '.bat', '.ps1', '.vbs'] : ['.sh', ''];
|
|
53
55
|
|
|
54
56
|
/**
|
|
55
57
|
* Search for the first matching script
|
|
@@ -72,13 +74,32 @@ let found = null;
|
|
|
72
74
|
|
|
73
75
|
for (const ext of candidates) {
|
|
74
76
|
const script = path.join(binDir, base + ext);
|
|
75
|
-
|
|
76
|
-
|
|
77
|
+
const exists = fs.existsSync(script);
|
|
78
|
+
// console.log(`Checking for ${script}: ${exists ? 'found' : 'not found'}`);
|
|
79
|
+
if (exists) {
|
|
77
80
|
found = script;
|
|
78
81
|
break;
|
|
79
82
|
}
|
|
80
83
|
}
|
|
81
84
|
|
|
85
|
+
/**
|
|
86
|
+
* If no matching script was found,
|
|
87
|
+
* try check if `bash` is available and if so, check for a .sh script.
|
|
88
|
+
*/
|
|
89
|
+
if (!found) {
|
|
90
|
+
try {
|
|
91
|
+
spawnSync('bash', ['--version'], { stdio: 'ignore' });
|
|
92
|
+
const bashScript = [path.join(binDir, base), path.join(binDir, base + '.sh')].find((script) =>
|
|
93
|
+
fs.existsSync(script)
|
|
94
|
+
);
|
|
95
|
+
if (bashScript) {
|
|
96
|
+
found = bashScript;
|
|
97
|
+
}
|
|
98
|
+
} catch {
|
|
99
|
+
// bash is not available, do nothing
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
|
|
82
103
|
/**
|
|
83
104
|
* If no matching script was found,
|
|
84
105
|
* print an error and exit with failure code 1.
|
|
@@ -92,8 +113,9 @@ if (!found) {
|
|
|
92
113
|
* Detect special script types
|
|
93
114
|
* that require a shell/interpreter.
|
|
94
115
|
*/
|
|
95
|
-
const isPs1 = found.endsWith(
|
|
96
|
-
const isCmd = found.endsWith(
|
|
116
|
+
const isPs1 = found.endsWith('.ps1');
|
|
117
|
+
const isCmd = found.endsWith('.cmd');
|
|
118
|
+
const isUnixShell = found.endsWith('.sh') || path.extname(found) === '';
|
|
97
119
|
|
|
98
120
|
/**
|
|
99
121
|
* cmd
|
|
@@ -124,9 +146,9 @@ let cmd, args;
|
|
|
124
146
|
* Forward all user-provided command-line arguments.
|
|
125
147
|
*/
|
|
126
148
|
if (isPs1) {
|
|
127
|
-
cmd =
|
|
149
|
+
cmd = 'powershell.exe';
|
|
128
150
|
|
|
129
|
-
args = [
|
|
151
|
+
args = ['-NoProfile', '-ExecutionPolicy', 'Bypass', '-File', found, ...process.argv.slice(2)];
|
|
130
152
|
|
|
131
153
|
/**
|
|
132
154
|
* CMD batch files:
|
|
@@ -137,9 +159,9 @@ if (isPs1) {
|
|
|
137
159
|
* "execute command and terminate"
|
|
138
160
|
*/
|
|
139
161
|
} else if (isCmd) {
|
|
140
|
-
cmd =
|
|
162
|
+
cmd = 'cmd.exe';
|
|
141
163
|
|
|
142
|
-
args = [
|
|
164
|
+
args = ['/c', found, ...process.argv.slice(2)];
|
|
143
165
|
|
|
144
166
|
/**
|
|
145
167
|
* Other scripts:
|
|
@@ -150,11 +172,65 @@ if (isPs1) {
|
|
|
150
172
|
*
|
|
151
173
|
* These can be executed directly.
|
|
152
174
|
*/
|
|
175
|
+
} else if (isUnixShell) {
|
|
176
|
+
// Capture shebang scripts (no extension) and .sh scripts
|
|
177
|
+
const shebang = fs.readFileSync(found, 'utf8').split('\n')[0].trim();
|
|
178
|
+
const interpreter = shebang.startsWith('#!')
|
|
179
|
+
? shebang
|
|
180
|
+
.slice(2)
|
|
181
|
+
.trim()
|
|
182
|
+
.replace(/^\/usr\/bin\/env\s+/, '')
|
|
183
|
+
.replace(/^\/bin\/env\s+/, '')
|
|
184
|
+
.replace(/^\/usr\/bin\//, '')
|
|
185
|
+
.replace(/^\/bin\//, '')
|
|
186
|
+
: null;
|
|
187
|
+
|
|
188
|
+
if (interpreter) {
|
|
189
|
+
const resolvedOrNull = which.sync(interpreter, { nothrow: true });
|
|
190
|
+
if (!resolvedOrNull) {
|
|
191
|
+
if (['bash', 'sh'].includes(interpreter) && isWindows()) {
|
|
192
|
+
const locationsToCheck = [
|
|
193
|
+
'C:\\Program Files\\Git\\usr\\bin',
|
|
194
|
+
'C:\\Program Files\\Git\\bin',
|
|
195
|
+
'C:\\Program Files (x86)\\Git\\usr\\bin',
|
|
196
|
+
'C:\\msys64\\usr\\bin',
|
|
197
|
+
'C:\\msys64\\bin',
|
|
198
|
+
'C:\\cygwin64\\bin',
|
|
199
|
+
'C:\\cygwin\\bin',
|
|
200
|
+
'C:\\MinGW\\bin',
|
|
201
|
+
'C:\\MinGW\\msys\\1.0\\bin'
|
|
202
|
+
];
|
|
203
|
+
for (const location of locationsToCheck) {
|
|
204
|
+
const potentialPath = path.join(location, 'bash.exe');
|
|
205
|
+
if (fs.existsSync(potentialPath)) {
|
|
206
|
+
cmd = potentialPath;
|
|
207
|
+
args = [found, ...process.argv.slice(2)];
|
|
208
|
+
break;
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
} else {
|
|
213
|
+
cmd = resolvedOrNull || interpreter;
|
|
214
|
+
args = [found, ...process.argv.slice(2)];
|
|
215
|
+
}
|
|
216
|
+
} else {
|
|
217
|
+
cmd = found;
|
|
218
|
+
args = process.argv.slice(2);
|
|
219
|
+
}
|
|
153
220
|
} else {
|
|
154
221
|
cmd = found;
|
|
155
222
|
args = process.argv.slice(2);
|
|
156
223
|
}
|
|
157
224
|
|
|
225
|
+
console.log(
|
|
226
|
+
`Executing: ${path.isAbsolute(cmd) ? path.relative(process.cwd(), cmd) : cmd} ${args
|
|
227
|
+
.map((f) => {
|
|
228
|
+
if (path.isAbsolute(f)) return path.relative(process.cwd(), f);
|
|
229
|
+
return f;
|
|
230
|
+
})
|
|
231
|
+
.join(' ')}`
|
|
232
|
+
);
|
|
233
|
+
|
|
158
234
|
/**
|
|
159
235
|
* Execute the selected script synchronously.
|
|
160
236
|
*
|
|
@@ -165,7 +241,7 @@ if (isPs1) {
|
|
|
165
241
|
* spawnSync waits until the child process exits.
|
|
166
242
|
*/
|
|
167
243
|
const result = spawnSync(cmd, args, {
|
|
168
|
-
stdio:
|
|
244
|
+
stdio: 'inherit'
|
|
169
245
|
});
|
|
170
246
|
|
|
171
247
|
/**
|
package/binaries/rmfind.cjs
CHANGED
|
@@ -12,9 +12,11 @@
|
|
|
12
12
|
* - fs:
|
|
13
13
|
* Used to check whether files exist.
|
|
14
14
|
*/
|
|
15
|
-
const { spawnSync } = require(
|
|
16
|
-
const path = require(
|
|
17
|
-
const fs = require(
|
|
15
|
+
const { spawnSync } = require('child_process');
|
|
16
|
+
const path = require('path');
|
|
17
|
+
const fs = require('fs');
|
|
18
|
+
const which = require('which');
|
|
19
|
+
const { isWindows } = require('../src/utils/isWindows.js');
|
|
18
20
|
|
|
19
21
|
/**
|
|
20
22
|
* __dirname
|
|
@@ -49,7 +51,7 @@ const base = path.basename(__filename, path.extname(__filename));
|
|
|
49
51
|
* .sh
|
|
50
52
|
* executable file without extension
|
|
51
53
|
*/
|
|
52
|
-
const candidates = process.platform ===
|
|
54
|
+
const candidates = process.platform === 'win32' ? ['.cmd', '.bat', '.ps1', '.vbs'] : ['.sh', ''];
|
|
53
55
|
|
|
54
56
|
/**
|
|
55
57
|
* Search for the first matching script
|
|
@@ -72,13 +74,32 @@ let found = null;
|
|
|
72
74
|
|
|
73
75
|
for (const ext of candidates) {
|
|
74
76
|
const script = path.join(binDir, base + ext);
|
|
75
|
-
|
|
76
|
-
|
|
77
|
+
const exists = fs.existsSync(script);
|
|
78
|
+
// console.log(`Checking for ${script}: ${exists ? 'found' : 'not found'}`);
|
|
79
|
+
if (exists) {
|
|
77
80
|
found = script;
|
|
78
81
|
break;
|
|
79
82
|
}
|
|
80
83
|
}
|
|
81
84
|
|
|
85
|
+
/**
|
|
86
|
+
* If no matching script was found,
|
|
87
|
+
* try check if `bash` is available and if so, check for a .sh script.
|
|
88
|
+
*/
|
|
89
|
+
if (!found) {
|
|
90
|
+
try {
|
|
91
|
+
spawnSync('bash', ['--version'], { stdio: 'ignore' });
|
|
92
|
+
const bashScript = [path.join(binDir, base), path.join(binDir, base + '.sh')].find((script) =>
|
|
93
|
+
fs.existsSync(script)
|
|
94
|
+
);
|
|
95
|
+
if (bashScript) {
|
|
96
|
+
found = bashScript;
|
|
97
|
+
}
|
|
98
|
+
} catch {
|
|
99
|
+
// bash is not available, do nothing
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
|
|
82
103
|
/**
|
|
83
104
|
* If no matching script was found,
|
|
84
105
|
* print an error and exit with failure code 1.
|
|
@@ -92,8 +113,9 @@ if (!found) {
|
|
|
92
113
|
* Detect special script types
|
|
93
114
|
* that require a shell/interpreter.
|
|
94
115
|
*/
|
|
95
|
-
const isPs1 = found.endsWith(
|
|
96
|
-
const isCmd = found.endsWith(
|
|
116
|
+
const isPs1 = found.endsWith('.ps1');
|
|
117
|
+
const isCmd = found.endsWith('.cmd');
|
|
118
|
+
const isUnixShell = found.endsWith('.sh') || path.extname(found) === '';
|
|
97
119
|
|
|
98
120
|
/**
|
|
99
121
|
* cmd
|
|
@@ -124,9 +146,9 @@ let cmd, args;
|
|
|
124
146
|
* Forward all user-provided command-line arguments.
|
|
125
147
|
*/
|
|
126
148
|
if (isPs1) {
|
|
127
|
-
cmd =
|
|
149
|
+
cmd = 'powershell.exe';
|
|
128
150
|
|
|
129
|
-
args = [
|
|
151
|
+
args = ['-NoProfile', '-ExecutionPolicy', 'Bypass', '-File', found, ...process.argv.slice(2)];
|
|
130
152
|
|
|
131
153
|
/**
|
|
132
154
|
* CMD batch files:
|
|
@@ -137,9 +159,9 @@ if (isPs1) {
|
|
|
137
159
|
* "execute command and terminate"
|
|
138
160
|
*/
|
|
139
161
|
} else if (isCmd) {
|
|
140
|
-
cmd =
|
|
162
|
+
cmd = 'cmd.exe';
|
|
141
163
|
|
|
142
|
-
args = [
|
|
164
|
+
args = ['/c', found, ...process.argv.slice(2)];
|
|
143
165
|
|
|
144
166
|
/**
|
|
145
167
|
* Other scripts:
|
|
@@ -150,11 +172,65 @@ if (isPs1) {
|
|
|
150
172
|
*
|
|
151
173
|
* These can be executed directly.
|
|
152
174
|
*/
|
|
175
|
+
} else if (isUnixShell) {
|
|
176
|
+
// Capture shebang scripts (no extension) and .sh scripts
|
|
177
|
+
const shebang = fs.readFileSync(found, 'utf8').split('\n')[0].trim();
|
|
178
|
+
const interpreter = shebang.startsWith('#!')
|
|
179
|
+
? shebang
|
|
180
|
+
.slice(2)
|
|
181
|
+
.trim()
|
|
182
|
+
.replace(/^\/usr\/bin\/env\s+/, '')
|
|
183
|
+
.replace(/^\/bin\/env\s+/, '')
|
|
184
|
+
.replace(/^\/usr\/bin\//, '')
|
|
185
|
+
.replace(/^\/bin\//, '')
|
|
186
|
+
: null;
|
|
187
|
+
|
|
188
|
+
if (interpreter) {
|
|
189
|
+
const resolvedOrNull = which.sync(interpreter, { nothrow: true });
|
|
190
|
+
if (!resolvedOrNull) {
|
|
191
|
+
if (['bash', 'sh'].includes(interpreter) && isWindows()) {
|
|
192
|
+
const locationsToCheck = [
|
|
193
|
+
'C:\\Program Files\\Git\\usr\\bin',
|
|
194
|
+
'C:\\Program Files\\Git\\bin',
|
|
195
|
+
'C:\\Program Files (x86)\\Git\\usr\\bin',
|
|
196
|
+
'C:\\msys64\\usr\\bin',
|
|
197
|
+
'C:\\msys64\\bin',
|
|
198
|
+
'C:\\cygwin64\\bin',
|
|
199
|
+
'C:\\cygwin\\bin',
|
|
200
|
+
'C:\\MinGW\\bin',
|
|
201
|
+
'C:\\MinGW\\msys\\1.0\\bin'
|
|
202
|
+
];
|
|
203
|
+
for (const location of locationsToCheck) {
|
|
204
|
+
const potentialPath = path.join(location, 'bash.exe');
|
|
205
|
+
if (fs.existsSync(potentialPath)) {
|
|
206
|
+
cmd = potentialPath;
|
|
207
|
+
args = [found, ...process.argv.slice(2)];
|
|
208
|
+
break;
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
} else {
|
|
213
|
+
cmd = resolvedOrNull || interpreter;
|
|
214
|
+
args = [found, ...process.argv.slice(2)];
|
|
215
|
+
}
|
|
216
|
+
} else {
|
|
217
|
+
cmd = found;
|
|
218
|
+
args = process.argv.slice(2);
|
|
219
|
+
}
|
|
153
220
|
} else {
|
|
154
221
|
cmd = found;
|
|
155
222
|
args = process.argv.slice(2);
|
|
156
223
|
}
|
|
157
224
|
|
|
225
|
+
console.log(
|
|
226
|
+
`Executing: ${path.isAbsolute(cmd) ? path.relative(process.cwd(), cmd) : cmd} ${args
|
|
227
|
+
.map((f) => {
|
|
228
|
+
if (path.isAbsolute(f)) return path.relative(process.cwd(), f);
|
|
229
|
+
return f;
|
|
230
|
+
})
|
|
231
|
+
.join(' ')}`
|
|
232
|
+
);
|
|
233
|
+
|
|
158
234
|
/**
|
|
159
235
|
* Execute the selected script synchronously.
|
|
160
236
|
*
|
|
@@ -165,7 +241,7 @@ if (isPs1) {
|
|
|
165
241
|
* spawnSync waits until the child process exits.
|
|
166
242
|
*/
|
|
167
243
|
const result = spawnSync(cmd, args, {
|
|
168
|
-
stdio:
|
|
244
|
+
stdio: 'inherit'
|
|
169
245
|
});
|
|
170
246
|
|
|
171
247
|
/**
|