binary-collections 2.0.8 → 2.0.10
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 +43 -0
- package/{bin → binaries}/clean-nodemodule +0 -0
- package/binaries/clean-nodemodule.cjs +43 -0
- package/binaries/clean-nodemodule.cmd +4 -0
- package/{bin → binaries}/clean-nodemodules +0 -0
- package/binaries/clean-nodemodules.cjs +43 -0
- package/binaries/clean-nodemodules.cmd +5 -0
- package/{bin → binaries}/dev +0 -0
- package/binaries/dev.cjs +43 -0
- package/{bin → binaries}/empty +0 -0
- package/binaries/empty.cjs +43 -0
- package/{bin → binaries}/git-reduce-size +0 -0
- package/binaries/git-reduce-size.cjs +43 -0
- package/binaries/javakill.cjs +43 -0
- package/{bin → binaries}/javakill.cmd +0 -0
- package/{bin → binaries}/kill-process +0 -0
- package/binaries/kill-process.cjs +43 -0
- package/binaries/nodekill.cjs +43 -0
- package/{bin → binaries}/nodekill.ps1 +0 -0
- package/{bin → binaries}/prod +0 -0
- package/binaries/prod.cjs +43 -0
- package/{bin → binaries}/rmfind +0 -0
- package/binaries/rmfind.cjs +43 -0
- package/{bin → binaries}/rmx +0 -0
- package/binaries/rmx.cjs +43 -0
- package/{bin → binaries}/submodule-token +0 -0
- package/binaries/submodule-token.cjs +43 -0
- package/docs-src/clean-github-actions-caches.md +26 -0
- package/docs-src/free-chatgpt.md +26 -0
- package/lib/binary-collections-config.cjs +3 -2
- package/lib/binary-collections-config.mjs +2 -2
- package/lib/binary-collections.cjs +452 -87
- package/lib/binary-collections.mjs +247 -8
- package/lib/changelog.cjs +328 -0
- package/lib/changelog.mjs +205 -0
- package/lib/chunk-4EWQC6GZ.mjs +382 -0
- package/lib/chunk-4ZI7BQKQ.mjs +381 -0
- package/lib/chunk-5J2BEPY5.mjs +83 -0
- package/lib/{chunk-4BYBVEYC.mjs → chunk-66PAU5PS.mjs} +5 -4
- package/lib/chunk-6HHJRKFB.mjs +59 -0
- package/lib/chunk-6S4NXESK.mjs +26 -0
- package/lib/{chunk-ZYAQRPUL.mjs → chunk-7YD7IPFF.mjs} +2 -2
- package/lib/{chunk-SH3L6HHV.mjs → chunk-A2JQXI5Z.mjs} +2 -2
- package/lib/{chunk-EGSSKVDH.mjs → chunk-A3VUZEJK.mjs} +1 -1
- package/lib/chunk-AGZYRDC2.mjs +323 -0
- package/lib/{chunk-VVEZVNIV.mjs → chunk-AI4CVPJ7.mjs} +6 -6
- package/lib/chunk-BDCHCWHD.mjs +136 -0
- package/lib/chunk-BEZKJ25G.mjs +140 -0
- package/lib/chunk-DI5MDPSN.mjs +386 -0
- package/lib/{chunk-ONIBBBQ3.mjs → chunk-E6FDDAOO.mjs} +4 -3
- package/lib/chunk-FKI7IEB5.mjs +172 -0
- package/lib/chunk-GJTGHXRA.mjs +356 -0
- package/lib/{chunk-YV7DO3YV.mjs → chunk-HLGOWBEO.mjs} +1 -1
- package/lib/chunk-HMRMTYZM.mjs +40 -0
- package/lib/chunk-HN52G2YL.mjs +305 -0
- package/lib/chunk-HO6GHCOB.mjs +385 -0
- package/lib/chunk-LEM5OMRP.mjs +384 -0
- package/lib/{chunk-YX5U7XDR.mjs → chunk-M3YIYRHT.mjs} +6 -5
- package/lib/chunk-O6SWBEOQ.mjs +81 -0
- package/lib/{chunk-JGR2NW6D.mjs → chunk-PDSXF5HY.mjs} +3 -3
- package/lib/{chunk-AASHBCRW.mjs → chunk-QQ4A6DLD.mjs} +8 -0
- package/lib/chunk-RCP7DHVY.mjs +190 -0
- package/lib/chunk-SBNDSKG5.mjs +136 -0
- package/lib/chunk-U6SO4QEV.mjs +320 -0
- package/lib/{chunk-APBWENF6.mjs → chunk-V3N3JEUF.mjs} +3 -3
- package/lib/chunk-XD6BJK6Q.mjs +351 -0
- package/lib/chunk-XVBFFVCJ.mjs +209 -0
- package/lib/chunk-YXSFGA2D.mjs +383 -0
- package/lib/clean-github-actions-caches.cjs +243 -148
- package/lib/clean-github-actions-caches.mjs +4 -3
- package/lib/del-gradle.cjs +2 -2
- package/lib/del-gradle.js +1 -1
- package/lib/del-gradle.mjs +2 -2
- package/lib/del-node-modules.cjs +2 -2
- package/lib/del-node-modules.js +1 -1
- package/lib/del-node-modules.mjs +2 -2
- package/lib/del-ps.cjs +29 -8
- package/lib/del-ps.js +2 -2
- package/lib/del-ps.mjs +7 -5
- package/lib/del-yarn-caches.cjs +26 -5
- package/lib/del-yarn-caches.js +38 -3
- package/lib/del-yarn-caches.mjs +6 -6
- package/lib/find-node-modules-cli.cjs +5 -4
- package/lib/find-node-modules-cli.js +1 -1
- package/lib/find-node-modules-cli.mjs +2 -2
- package/lib/find-node-modules.cjs +4 -3
- package/lib/{find-node-modules.d.ts → find-node-modules.d.cts} +1 -1
- package/lib/find-node-modules.mjs +2 -2
- package/lib/free-chatgpt.cjs +548 -0
- package/lib/free-chatgpt.d.ts +1 -0
- package/lib/free-chatgpt.js +51 -0
- package/lib/free-chatgpt.mjs +50 -0
- package/lib/git/gitattributes.cjs +1 -1
- package/lib/git/{gitattributes.d.mts → gitattributes.d.cts} +5 -7
- package/lib/git/gitattributes.mjs +2 -2
- package/lib/git/line-endings.cjs +297 -64
- package/lib/git/line-endings.mjs +4 -4
- package/lib/git/normalize.cjs +26 -36
- package/lib/git/normalize.mjs +2 -2
- package/lib/git/permissions.cjs +77 -11
- package/lib/git/permissions.mjs +3 -3
- package/lib/git/pull-strategy.cjs +76 -9
- package/lib/git/pull-strategy.mjs +3 -3
- package/lib/git/user-config.cjs +266 -83
- package/lib/git/user-config.mjs +4 -4
- package/lib/git/utils.cjs +40 -60
- package/lib/git/utils.mjs +2 -2
- package/lib/git-diff-cli.cjs +651 -0
- package/lib/git-diff-cli.d.ts +1 -0
- package/lib/git-diff-cli.js +15 -0
- package/lib/git-diff-cli.mjs +16 -0
- package/lib/git-diff.cjs +657 -58
- package/lib/git-diff.d.ts +38 -83
- package/lib/git-diff.js +152 -0
- package/lib/git-diff.mjs +23 -85
- package/lib/git-fix.cjs +685 -97
- package/lib/git-fix.mjs +12 -11
- package/lib/git-purge.cjs +3 -3
- package/lib/git-purge.d.cts +1 -0
- package/lib/git-purge.mjs +43 -37
- package/lib/index.cjs +7 -6
- package/lib/index.d.ts +1 -1
- package/lib/index.js +2 -5
- package/lib/index.mjs +4 -4
- package/lib/npm-run-series.cjs +3 -3
- package/lib/npm-run-series.mjs +42 -36
- package/lib/package-resolutions-updater.cjs +174 -1
- package/lib/package-resolutions-updater.mjs +270 -290
- package/lib/print-directory-tree.cjs +275 -210
- package/lib/print-directory-tree.mjs +2 -2
- package/lib/ps/connected-domain.cjs +25 -2
- package/lib/ps/connected-domain.d.ts +10 -2
- package/lib/ps/connected-domain.js +5 -2
- package/lib/ps/connected-domain.mjs +8 -4
- package/lib/ps/index.cjs +345 -322
- package/lib/ps/index.d.mjs +1 -1
- package/lib/ps/index.js +1 -1
- package/lib/ps/index.mjs +179 -182
- package/lib/ps/isWin.cjs +24 -1
- package/lib/ps/isWin.d.ts +1 -1
- package/lib/ps/isWin.js +3 -1
- package/lib/ps/isWin.mjs +8 -4
- package/lib/ps/table-parser.cjs +167 -159
- package/lib/ps/table-parser.d.ts +5 -0
- package/lib/ps/table-parser.js +10 -4
- package/lib/ps/table-parser.mjs +9 -5
- package/lib/remove-module.cjs +262 -0
- package/lib/remove-module.d.mts +1 -0
- package/lib/remove-module.mjs +111 -0
- package/lib/rmpath.cjs +274 -0
- package/lib/rmpath.d.mts +3 -0
- package/lib/rmpath.mjs +108 -0
- package/lib/submodule-install.cjs +264 -85
- package/lib/submodule-install.mjs +56 -7
- package/lib/submodule-remove-cli.cjs +103 -0
- package/lib/submodule-remove-cli.d.ts +1 -0
- package/lib/submodule-remove-cli.js +31 -0
- package/lib/submodule-remove-cli.mjs +28 -0
- package/lib/submodule-remove.cjs +43 -0
- package/lib/submodule-remove.d.cts +2 -0
- package/lib/submodule-remove.mjs +6 -0
- package/lib/utils/chatgpt.cjs +383 -0
- package/lib/utils/chatgpt.d.ts +31 -0
- package/lib/utils/chatgpt.js +541 -0
- package/lib/utils/chatgpt.mjs +8 -0
- package/lib/{utils.cjs → utils/index.cjs} +1 -1
- package/lib/{utils.mjs → utils/index.mjs} +2 -2
- package/lib/yarn-reinstall.cjs +172 -38
- package/lib/yarn-reinstall.mjs +2 -2
- package/package.json +91 -71
- package/readme.md +43 -69
- package/releases/readme.md +36 -0
- package/test/README.md +101 -0
- package/test/package.json +2 -1
- package/test-project/readme.md +26 -0
- package/tmp/test-repo/README.md +35 -0
- package/tmp/typedoc/readme.md +320 -0
- package/bin/bash-dummy +0 -56
- package/bin/bash-dummy.cmd +0 -25
- package/bin/dir-tree.cmd +0 -7
- package/bin/git-diff +0 -4
- package/bin/git-diff.cmd +0 -7
- package/bin/git-fix +0 -36
- package/bin/git-fix.cmd +0 -7
- package/bin/rmpath +0 -70
- package/bin/submodule-install.txt +0 -118
- package/bin/submodule-remove +0 -46
- package/bin/submodule.txt +0 -172
- package/lib/binary-collections-config.d.mts +0 -18
- package/lib/binary-collections-config.js +0 -39
- package/lib/binary-collections.d.mts +0 -121
- package/lib/binary-collections.d.ts +0 -121
- package/lib/chunk-DPKAJKFO.mjs +0 -171
- package/lib/chunk-G3THLIDT.mjs +0 -200
- package/lib/chunk-W3ENOM53.mjs +0 -18
- package/lib/clean-github-actions-caches.d.mts +0 -169
- package/lib/clean-github-actions-caches.d.ts +0 -169
- package/lib/del-gradle.d.mts +0 -2
- package/lib/del-node-modules.d.mts +0 -2
- package/lib/del-ps.d.mts +0 -2
- package/lib/del-yarn-caches.d.mts +0 -2
- package/lib/find-node-modules-cli.d.mts +0 -1
- package/lib/find-node-modules.d.mts +0 -13
- package/lib/find-node-modules.js +0 -53
- package/lib/git/line-endings.d.mts +0 -83
- package/lib/git/line-endings.d.ts +0 -83
- package/lib/git/normalize.d.mts +0 -43
- package/lib/git/normalize.d.ts +0 -43
- package/lib/git/permissions.d.mts +0 -17
- package/lib/git/permissions.d.ts +0 -17
- package/lib/git/pull-strategy.d.mts +0 -15
- package/lib/git/pull-strategy.d.ts +0 -15
- package/lib/git/user-config.d.mts +0 -105
- package/lib/git/user-config.d.ts +0 -105
- package/lib/git/utils.d.mts +0 -69
- package/lib/git/utils.d.ts +0 -69
- package/lib/git-diff.d.mts +0 -84
- package/lib/git-fix.d.mts +0 -141
- package/lib/git-fix.d.ts +0 -141
- package/lib/git-purge.d.mts +0 -2
- package/lib/git-purge.js +0 -59
- package/lib/index.d.mts +0 -1
- package/lib/npm-run-series.d.mts +0 -1
- package/lib/npm-run-series.d.ts +0 -2
- package/lib/npm-run-series.js +0 -86
- package/lib/package-resolutions-updater.d.ts +0 -326
- package/lib/print-directory-tree.d.mts +0 -234
- package/lib/print-directory-tree.d.ts +0 -234
- package/lib/ps/connected-domain.d.mts +0 -3
- package/lib/ps/index.d.d.mts +0 -26
- package/lib/ps/index.d.d.ts +0 -26
- package/lib/ps/index.d.mts +0 -26
- package/lib/ps/isWin.d.mts +0 -3
- package/lib/ps/table-parser.d.mts +0 -3
- package/lib/submodule-install.d.mts +0 -121
- package/lib/submodule-install.d.ts +0 -121
- package/lib/utils.d.mts +0 -40
- package/lib/utils.js +0 -181
- package/lib/yarn-reinstall.d.mts +0 -49
- package/lib/yarn-reinstall.d.ts +0 -49
- package/src/package-resolutions-updater.mjs +0 -325
- package/src/print-directory-tree.cjs +0 -234
- package/src/ps/index.js +0 -286
- package/src/yarn-reinstall.cjs +0 -49
- /package/{bin → binaries}/nodekill +0 -0
- /package/{bin → binaries}/nodekill.cmd +0 -0
- /package/lib/{binary-collections-config.d.ts → binary-collections-config.d.cts} +0 -0
- /package/lib/{git-purge.d.ts → changelog.d.cts} +0 -0
- /package/lib/{git-diff.d.cts → npm-run-series.d.cts} +0 -0
- /package/lib/{utils.d.ts → utils/index.d.cts} +0 -0
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
const path = require("upath");
|
|
2
|
-
const fs = require("fs");
|
|
3
|
-
const { runGitCommand } = require("./utils.cjs");
|
|
4
|
-
const { updateGitAttributes } = require("./gitattributes.js");
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* Force LF line endings configuration
|
|
8
|
-
* - Sets core.autocrlf = false
|
|
9
|
-
* - Sets core.eol = lf
|
|
10
|
-
* - Creates/updates .gitattributes with proper line ending rules
|
|
11
|
-
*/
|
|
12
|
-
function forceLfLineEndings() {
|
|
13
|
-
console.log("\n=== Configuring LF Line Endings ===");
|
|
14
|
-
|
|
15
|
-
// Force LF line endings
|
|
16
|
-
runGitCommand(["config", "core.autocrlf", "false"], "Disable automatic CRLF conversion");
|
|
17
|
-
runGitCommand(["config", "core.eol", "lf"], "Set end-of-line to LF");
|
|
18
|
-
|
|
19
|
-
// Create or update .gitattributes
|
|
20
|
-
const gitattributesPath = path.join(process.cwd(), ".gitattributes");
|
|
21
|
-
|
|
22
|
-
// Always ensure the universal LF rule is present, even if file exists
|
|
23
|
-
if (fs.existsSync(gitattributesPath)) {
|
|
24
|
-
let content = fs.readFileSync(gitattributesPath, "utf8");
|
|
25
|
-
// Match * text=auto eol=lf with any whitespace (space or tab) between tokens
|
|
26
|
-
if (!/^\*\s+text=auto\s+eol=lf/m.test(content)) {
|
|
27
|
-
content = `* text=auto eol=lf\n` + content;
|
|
28
|
-
fs.writeFileSync(gitattributesPath, content);
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
// Define desired rules with priorities
|
|
33
|
-
const desiredRules = [
|
|
34
|
-
{ pattern: "*", attributes: "text=auto eol=lf", priority: 1 },
|
|
35
|
-
{
|
|
36
|
-
pattern: "*.{cmd,bat,ps1,sh,cmd1,cmd2,bat1,bat2,vbs}",
|
|
37
|
-
attributes: "text eol=crlf",
|
|
38
|
-
priority: 2
|
|
39
|
-
},
|
|
40
|
-
{
|
|
41
|
-
pattern: "*.{png,jpg,jpeg,gif,ico,svg,bmp,webp,avif,tiff,tif,psd,ai,eps,raw}",
|
|
42
|
-
attributes: "binary",
|
|
43
|
-
priority: 3
|
|
44
|
-
},
|
|
45
|
-
{
|
|
46
|
-
pattern:
|
|
47
|
-
"*.{zip,tar,gz,7z,rar,exe,dll,so,bin,jar,war,ear,apk,msi,deb,rpm,iso,img,dmg,pdf,mp3,mp4,mov,avi,mkv,flv,wmv,ogg,webm,wav,aac,m4a,otf,ttf,woff,woff2,eot}",
|
|
48
|
-
attributes: "binary",
|
|
49
|
-
priority: 3
|
|
50
|
-
}
|
|
51
|
-
];
|
|
52
|
-
|
|
53
|
-
// Update .gitattributes using the dedicated module
|
|
54
|
-
const result = updateGitAttributes(gitattributesPath, desiredRules);
|
|
55
|
-
|
|
56
|
-
// Report results
|
|
57
|
-
if (result.error) {
|
|
58
|
-
console.log(`[✗] Error updating .gitattributes: ${result.error}`);
|
|
59
|
-
return;
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
// Report conflicts if any
|
|
63
|
-
if (result.conflicts.length > 0) {
|
|
64
|
-
console.log("\n[!] Detected conflicts in .gitattributes:");
|
|
65
|
-
result.conflicts.forEach((conflict) => {
|
|
66
|
-
console.log(` ${conflict.pattern}: ${conflict.existing} -> ${conflict.proposed} (${conflict.action})`);
|
|
67
|
-
});
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
// Report changes
|
|
71
|
-
if (result.success) {
|
|
72
|
-
console.log(`[✓] ${result.message}:`);
|
|
73
|
-
result.changes.forEach((change) => {
|
|
74
|
-
console.log(` ${change.action}: ${change.pattern} ${change.attributes}`);
|
|
75
|
-
});
|
|
76
|
-
} else {
|
|
77
|
-
console.log(`[i] ${result.message}`);
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
module.exports = {
|
|
82
|
-
forceLfLineEndings
|
|
83
|
-
};
|
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
const path = require("upath");
|
|
2
|
-
const fs = require("fs");
|
|
3
|
-
const { runGitCommand } = require("./utils.cjs");
|
|
4
|
-
const { updateGitAttributes } = require("./gitattributes.js");
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* Force LF line endings configuration
|
|
8
|
-
* - Sets core.autocrlf = false
|
|
9
|
-
* - Sets core.eol = lf
|
|
10
|
-
* - Creates/updates .gitattributes with proper line ending rules
|
|
11
|
-
*/
|
|
12
|
-
function forceLfLineEndings() {
|
|
13
|
-
console.log("\n=== Configuring LF Line Endings ===");
|
|
14
|
-
|
|
15
|
-
// Force LF line endings
|
|
16
|
-
runGitCommand(["config", "core.autocrlf", "false"], "Disable automatic CRLF conversion");
|
|
17
|
-
runGitCommand(["config", "core.eol", "lf"], "Set end-of-line to LF");
|
|
18
|
-
|
|
19
|
-
// Create or update .gitattributes
|
|
20
|
-
const gitattributesPath = path.join(process.cwd(), ".gitattributes");
|
|
21
|
-
|
|
22
|
-
// Always ensure the universal LF rule is present, even if file exists
|
|
23
|
-
if (fs.existsSync(gitattributesPath)) {
|
|
24
|
-
let content = fs.readFileSync(gitattributesPath, "utf8");
|
|
25
|
-
// Match * text=auto eol=lf with any whitespace (space or tab) between tokens
|
|
26
|
-
if (!/^\*\s+text=auto\s+eol=lf/m.test(content)) {
|
|
27
|
-
content = `* text=auto eol=lf\n` + content;
|
|
28
|
-
fs.writeFileSync(gitattributesPath, content);
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
// Define desired rules with priorities
|
|
33
|
-
const desiredRules = [
|
|
34
|
-
{ pattern: "*", attributes: "text=auto eol=lf", priority: 1 },
|
|
35
|
-
{
|
|
36
|
-
pattern: "*.{cmd,bat,ps1,sh,cmd1,cmd2,bat1,bat2,vbs}",
|
|
37
|
-
attributes: "text eol=crlf",
|
|
38
|
-
priority: 2
|
|
39
|
-
},
|
|
40
|
-
{
|
|
41
|
-
pattern: "*.{png,jpg,jpeg,gif,ico,svg,bmp,webp,avif,tiff,tif,psd,ai,eps,raw}",
|
|
42
|
-
attributes: "binary",
|
|
43
|
-
priority: 3
|
|
44
|
-
},
|
|
45
|
-
{
|
|
46
|
-
pattern:
|
|
47
|
-
"*.{zip,tar,gz,7z,rar,exe,dll,so,bin,jar,war,ear,apk,msi,deb,rpm,iso,img,dmg,pdf,mp3,mp4,mov,avi,mkv,flv,wmv,ogg,webm,wav,aac,m4a,otf,ttf,woff,woff2,eot}",
|
|
48
|
-
attributes: "binary",
|
|
49
|
-
priority: 3
|
|
50
|
-
}
|
|
51
|
-
];
|
|
52
|
-
|
|
53
|
-
// Update .gitattributes using the dedicated module
|
|
54
|
-
const result = updateGitAttributes(gitattributesPath, desiredRules);
|
|
55
|
-
|
|
56
|
-
// Report results
|
|
57
|
-
if (result.error) {
|
|
58
|
-
console.log(`[✗] Error updating .gitattributes: ${result.error}`);
|
|
59
|
-
return;
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
// Report conflicts if any
|
|
63
|
-
if (result.conflicts.length > 0) {
|
|
64
|
-
console.log("\n[!] Detected conflicts in .gitattributes:");
|
|
65
|
-
result.conflicts.forEach((conflict) => {
|
|
66
|
-
console.log(` ${conflict.pattern}: ${conflict.existing} -> ${conflict.proposed} (${conflict.action})`);
|
|
67
|
-
});
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
// Report changes
|
|
71
|
-
if (result.success) {
|
|
72
|
-
console.log(`[✓] ${result.message}:`);
|
|
73
|
-
result.changes.forEach((change) => {
|
|
74
|
-
console.log(` ${change.action}: ${change.pattern} ${change.attributes}`);
|
|
75
|
-
});
|
|
76
|
-
} else {
|
|
77
|
-
console.log(`[i] ${result.message}`);
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
module.exports = {
|
|
82
|
-
forceLfLineEndings
|
|
83
|
-
};
|
package/lib/git/normalize.d.mts
DELETED
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
const { execSync } = require("child_process");
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Normalize line endings in existing tracked files
|
|
5
|
-
* - Refreshes the git index to detect line ending changes
|
|
6
|
-
* - Applies renormalization to all tracked files
|
|
7
|
-
*/
|
|
8
|
-
function normalizeLineEndings() {
|
|
9
|
-
console.log("\n=== Normalizing Existing Files ===");
|
|
10
|
-
|
|
11
|
-
try {
|
|
12
|
-
// Check if there are any tracked files
|
|
13
|
-
const result = execSync("git ls-files", { encoding: "utf-8", stdio: "pipe" });
|
|
14
|
-
if (!result.trim()) {
|
|
15
|
-
console.log("[i] No tracked files to normalize");
|
|
16
|
-
return;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
console.log("[i] Refreshing index to detect line ending changes...");
|
|
20
|
-
execSync("git add --renormalize .", { stdio: "pipe" });
|
|
21
|
-
|
|
22
|
-
// Check if there are changes after normalization
|
|
23
|
-
try {
|
|
24
|
-
const statusResult = execSync("git status --porcelain", { encoding: "utf-8", stdio: "pipe" });
|
|
25
|
-
if (statusResult.trim()) {
|
|
26
|
-
console.log("[✓] Line endings normalized for tracked files");
|
|
27
|
-
console.log("[i] Files with updated line endings are now staged");
|
|
28
|
-
console.log("[i] Run 'git status' to see the changes");
|
|
29
|
-
} else {
|
|
30
|
-
console.log("[✓] All files already have correct line endings");
|
|
31
|
-
}
|
|
32
|
-
} catch {
|
|
33
|
-
console.log("[✓] Line ending normalization completed");
|
|
34
|
-
}
|
|
35
|
-
} catch (error) {
|
|
36
|
-
console.error("[✗] Failed to normalize line endings");
|
|
37
|
-
console.error(`Error: ${error.message}`);
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
module.exports = {
|
|
42
|
-
normalizeLineEndings
|
|
43
|
-
};
|
package/lib/git/normalize.d.ts
DELETED
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
const { execSync } = require("child_process");
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Normalize line endings in existing tracked files
|
|
5
|
-
* - Refreshes the git index to detect line ending changes
|
|
6
|
-
* - Applies renormalization to all tracked files
|
|
7
|
-
*/
|
|
8
|
-
function normalizeLineEndings() {
|
|
9
|
-
console.log("\n=== Normalizing Existing Files ===");
|
|
10
|
-
|
|
11
|
-
try {
|
|
12
|
-
// Check if there are any tracked files
|
|
13
|
-
const result = execSync("git ls-files", { encoding: "utf-8", stdio: "pipe" });
|
|
14
|
-
if (!result.trim()) {
|
|
15
|
-
console.log("[i] No tracked files to normalize");
|
|
16
|
-
return;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
console.log("[i] Refreshing index to detect line ending changes...");
|
|
20
|
-
execSync("git add --renormalize .", { stdio: "pipe" });
|
|
21
|
-
|
|
22
|
-
// Check if there are changes after normalization
|
|
23
|
-
try {
|
|
24
|
-
const statusResult = execSync("git status --porcelain", { encoding: "utf-8", stdio: "pipe" });
|
|
25
|
-
if (statusResult.trim()) {
|
|
26
|
-
console.log("[✓] Line endings normalized for tracked files");
|
|
27
|
-
console.log("[i] Files with updated line endings are now staged");
|
|
28
|
-
console.log("[i] Run 'git status' to see the changes");
|
|
29
|
-
} else {
|
|
30
|
-
console.log("[✓] All files already have correct line endings");
|
|
31
|
-
}
|
|
32
|
-
} catch {
|
|
33
|
-
console.log("[✓] Line ending normalization completed");
|
|
34
|
-
}
|
|
35
|
-
} catch (error) {
|
|
36
|
-
console.error("[✗] Failed to normalize line endings");
|
|
37
|
-
console.error(`Error: ${error.message}`);
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
module.exports = {
|
|
42
|
-
normalizeLineEndings
|
|
43
|
-
};
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
const { runGitCommand } = require("./utils.cjs");
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Configure git to ignore file permission changes
|
|
5
|
-
* - Sets core.filemode = false
|
|
6
|
-
* - Sets diff.ignoreSubmodules = dirty
|
|
7
|
-
*/
|
|
8
|
-
function ignoreFilePermissions() {
|
|
9
|
-
console.log("\n=== Configuring File Permissions ===");
|
|
10
|
-
|
|
11
|
-
runGitCommand(["config", "core.filemode", "false"], "Ignore file permission changes");
|
|
12
|
-
runGitCommand(["config", "diff.ignoreSubmodules", "dirty"], "Ignore submodule permission changes");
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
module.exports = {
|
|
16
|
-
ignoreFilePermissions
|
|
17
|
-
};
|
package/lib/git/permissions.d.ts
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
const { runGitCommand } = require("./utils.cjs");
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Configure git to ignore file permission changes
|
|
5
|
-
* - Sets core.filemode = false
|
|
6
|
-
* - Sets diff.ignoreSubmodules = dirty
|
|
7
|
-
*/
|
|
8
|
-
function ignoreFilePermissions() {
|
|
9
|
-
console.log("\n=== Configuring File Permissions ===");
|
|
10
|
-
|
|
11
|
-
runGitCommand(["config", "core.filemode", "false"], "Ignore file permission changes");
|
|
12
|
-
runGitCommand(["config", "diff.ignoreSubmodules", "dirty"], "Ignore submodule permission changes");
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
module.exports = {
|
|
16
|
-
ignoreFilePermissions
|
|
17
|
-
};
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
const { runGitCommand } = require("./utils.cjs");
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Set git pull strategy to disable automatic rebase
|
|
5
|
-
* - Sets pull.rebase = false
|
|
6
|
-
*/
|
|
7
|
-
function setPullStrategy() {
|
|
8
|
-
console.log("\n=== Configuring Pull Strategy ===");
|
|
9
|
-
|
|
10
|
-
runGitCommand(["config", "pull.rebase", "false"], "Disable automatic rebase on pull");
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
module.exports = {
|
|
14
|
-
setPullStrategy
|
|
15
|
-
};
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
const { runGitCommand } = require("./utils.cjs");
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Set git pull strategy to disable automatic rebase
|
|
5
|
-
* - Sets pull.rebase = false
|
|
6
|
-
*/
|
|
7
|
-
function setPullStrategy() {
|
|
8
|
-
console.log("\n=== Configuring Pull Strategy ===");
|
|
9
|
-
|
|
10
|
-
runGitCommand(["config", "pull.rebase", "false"], "Disable automatic rebase on pull");
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
module.exports = {
|
|
14
|
-
setPullStrategy
|
|
15
|
-
};
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
const gch = require("git-command-helper");
|
|
2
|
-
const { runGitCommand, runGitCommandOutput } = require("./utils.cjs");
|
|
3
|
-
const { getArgs } = require("../utils.js");
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* Configure Git user from CLI arguments or environment variables
|
|
7
|
-
* @param {string|null} cliUser - Username from CLI arguments
|
|
8
|
-
* @param {string|null} cliEmail - Email from CLI arguments
|
|
9
|
-
* @param {object} [options] - Options object
|
|
10
|
-
* @param {boolean} [options.updateRemote] - If true, update remote URL without prompt
|
|
11
|
-
*/
|
|
12
|
-
function configureGitUser(cliUser = null, cliEmail = null, options = {}) {
|
|
13
|
-
console.log("\n=== Configuring Git User ===");
|
|
14
|
-
|
|
15
|
-
// Determine user and email with CLI args taking precedence
|
|
16
|
-
let username, email;
|
|
17
|
-
|
|
18
|
-
if (cliUser && cliEmail) {
|
|
19
|
-
username = cliUser.trim();
|
|
20
|
-
email = cliEmail.trim();
|
|
21
|
-
console.log("[i] Using CLI-provided user configuration");
|
|
22
|
-
} else {
|
|
23
|
-
username = process.env.GITHUB_USER ? process.env.GITHUB_USER.trim() : undefined;
|
|
24
|
-
email = process.env.GITHUB_EMAIL ? process.env.GITHUB_EMAIL.trim() : undefined;
|
|
25
|
-
if (username || email) {
|
|
26
|
-
console.log("[i] Using environment variable user configuration");
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
if (!username && !email) {
|
|
31
|
-
console.log("[i] No Git user configuration needed (no CLI args or environment variables set)");
|
|
32
|
-
return;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
if (username) {
|
|
36
|
-
const success = runGitCommand(["config", "user.name", username], `Set Git username to "${username}"`);
|
|
37
|
-
if (!success) {
|
|
38
|
-
console.log("[i] Failed to set Git username, but continuing...");
|
|
39
|
-
}
|
|
40
|
-
} else {
|
|
41
|
-
console.log("[i] No username provided, skipping username configuration");
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
if (email) {
|
|
45
|
-
const success = runGitCommand(["config", "user.email", email], `Set Git email to "${email}"`);
|
|
46
|
-
if (!success) {
|
|
47
|
-
console.log("[i] Failed to set Git email, but continuing...");
|
|
48
|
-
}
|
|
49
|
-
} else {
|
|
50
|
-
console.log("[i] No email provided, skipping email configuration");
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
if (username || email) {
|
|
54
|
-
console.log("[✓] Git user configuration completed");
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
if (username) {
|
|
58
|
-
// Ask user to modify the origin remote URL if it doesn't match the username
|
|
59
|
-
const remoteUrl = runGitCommandOutput(["remote", "get-url", "origin"], "Fetching remote URL for verification");
|
|
60
|
-
if (remoteUrl) {
|
|
61
|
-
console.log(`[i] Remote URL: ${remoteUrl}`);
|
|
62
|
-
const parsedUrl = gch.parseGitHubUrl(remoteUrl);
|
|
63
|
-
if (parsedUrl && parsedUrl.owner && username && parsedUrl.owner.toLowerCase() !== username.toLowerCase()) {
|
|
64
|
-
console.warn(
|
|
65
|
-
`\n[!] The GitHub remote owner ("${parsedUrl.owner}") does not match the configured username ("${username}").`
|
|
66
|
-
);
|
|
67
|
-
console.warn(`[!] If this is not intentional, consider updating the remote URL to use your username.`);
|
|
68
|
-
console.warn(`[!] Example: git remote set-url origin https://github.com/${username}/<repo>.git\n`);
|
|
69
|
-
// Check for --update-remote CLI argument or options.updateRemote
|
|
70
|
-
const args = getArgs();
|
|
71
|
-
const updateRemote = options.updateRemote || args["update-remote"] === true;
|
|
72
|
-
if (updateRemote) {
|
|
73
|
-
// Only update the username in the URL, not the repo path
|
|
74
|
-
let newUrl = remoteUrl;
|
|
75
|
-
// Handle https:// and git@ URLs
|
|
76
|
-
if (/^https:\/\//.test(remoteUrl)) {
|
|
77
|
-
newUrl = remoteUrl.replace(/https:\/\/(?:[^@]+@)?github.com/, `https://${username}@github.com`);
|
|
78
|
-
} else if (/^git@github.com:/.test(remoteUrl)) {
|
|
79
|
-
// For git@github.com:user/repo.git, do not change path, just warn user to use HTTPS with username if needed
|
|
80
|
-
console.warn(
|
|
81
|
-
`[!] For SSH remotes, set your SSH config or use HTTPS with username if you want to change authentication user.`
|
|
82
|
-
);
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
if (newUrl !== remoteUrl) {
|
|
86
|
-
const updated = runGitCommand(["remote", "set-url", "origin", newUrl], `Set origin to ${newUrl}`);
|
|
87
|
-
if (updated) {
|
|
88
|
-
console.log(`[✓] Remote URL updated to: ${newUrl}`);
|
|
89
|
-
} else {
|
|
90
|
-
console.warn(`[!] Failed to update remote URL. Please update it manually if needed.`);
|
|
91
|
-
}
|
|
92
|
-
} else {
|
|
93
|
-
console.log(`[i] Remote URL does not use HTTPS or already contains the username.`);
|
|
94
|
-
}
|
|
95
|
-
} else {
|
|
96
|
-
console.log(`[i] Remote URL not changed. Use --update-remote to update automatically.`);
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
module.exports = {
|
|
104
|
-
configureGitUser
|
|
105
|
-
};
|
package/lib/git/user-config.d.ts
DELETED
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
const gch = require("git-command-helper");
|
|
2
|
-
const { runGitCommand, runGitCommandOutput } = require("./utils.cjs");
|
|
3
|
-
const { getArgs } = require("../utils.js");
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* Configure Git user from CLI arguments or environment variables
|
|
7
|
-
* @param {string|null} cliUser - Username from CLI arguments
|
|
8
|
-
* @param {string|null} cliEmail - Email from CLI arguments
|
|
9
|
-
* @param {object} [options] - Options object
|
|
10
|
-
* @param {boolean} [options.updateRemote] - If true, update remote URL without prompt
|
|
11
|
-
*/
|
|
12
|
-
function configureGitUser(cliUser = null, cliEmail = null, options = {}) {
|
|
13
|
-
console.log("\n=== Configuring Git User ===");
|
|
14
|
-
|
|
15
|
-
// Determine user and email with CLI args taking precedence
|
|
16
|
-
let username, email;
|
|
17
|
-
|
|
18
|
-
if (cliUser && cliEmail) {
|
|
19
|
-
username = cliUser.trim();
|
|
20
|
-
email = cliEmail.trim();
|
|
21
|
-
console.log("[i] Using CLI-provided user configuration");
|
|
22
|
-
} else {
|
|
23
|
-
username = process.env.GITHUB_USER ? process.env.GITHUB_USER.trim() : undefined;
|
|
24
|
-
email = process.env.GITHUB_EMAIL ? process.env.GITHUB_EMAIL.trim() : undefined;
|
|
25
|
-
if (username || email) {
|
|
26
|
-
console.log("[i] Using environment variable user configuration");
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
if (!username && !email) {
|
|
31
|
-
console.log("[i] No Git user configuration needed (no CLI args or environment variables set)");
|
|
32
|
-
return;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
if (username) {
|
|
36
|
-
const success = runGitCommand(["config", "user.name", username], `Set Git username to "${username}"`);
|
|
37
|
-
if (!success) {
|
|
38
|
-
console.log("[i] Failed to set Git username, but continuing...");
|
|
39
|
-
}
|
|
40
|
-
} else {
|
|
41
|
-
console.log("[i] No username provided, skipping username configuration");
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
if (email) {
|
|
45
|
-
const success = runGitCommand(["config", "user.email", email], `Set Git email to "${email}"`);
|
|
46
|
-
if (!success) {
|
|
47
|
-
console.log("[i] Failed to set Git email, but continuing...");
|
|
48
|
-
}
|
|
49
|
-
} else {
|
|
50
|
-
console.log("[i] No email provided, skipping email configuration");
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
if (username || email) {
|
|
54
|
-
console.log("[✓] Git user configuration completed");
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
if (username) {
|
|
58
|
-
// Ask user to modify the origin remote URL if it doesn't match the username
|
|
59
|
-
const remoteUrl = runGitCommandOutput(["remote", "get-url", "origin"], "Fetching remote URL for verification");
|
|
60
|
-
if (remoteUrl) {
|
|
61
|
-
console.log(`[i] Remote URL: ${remoteUrl}`);
|
|
62
|
-
const parsedUrl = gch.parseGitHubUrl(remoteUrl);
|
|
63
|
-
if (parsedUrl && parsedUrl.owner && username && parsedUrl.owner.toLowerCase() !== username.toLowerCase()) {
|
|
64
|
-
console.warn(
|
|
65
|
-
`\n[!] The GitHub remote owner ("${parsedUrl.owner}") does not match the configured username ("${username}").`
|
|
66
|
-
);
|
|
67
|
-
console.warn(`[!] If this is not intentional, consider updating the remote URL to use your username.`);
|
|
68
|
-
console.warn(`[!] Example: git remote set-url origin https://github.com/${username}/<repo>.git\n`);
|
|
69
|
-
// Check for --update-remote CLI argument or options.updateRemote
|
|
70
|
-
const args = getArgs();
|
|
71
|
-
const updateRemote = options.updateRemote || args["update-remote"] === true;
|
|
72
|
-
if (updateRemote) {
|
|
73
|
-
// Only update the username in the URL, not the repo path
|
|
74
|
-
let newUrl = remoteUrl;
|
|
75
|
-
// Handle https:// and git@ URLs
|
|
76
|
-
if (/^https:\/\//.test(remoteUrl)) {
|
|
77
|
-
newUrl = remoteUrl.replace(/https:\/\/(?:[^@]+@)?github.com/, `https://${username}@github.com`);
|
|
78
|
-
} else if (/^git@github.com:/.test(remoteUrl)) {
|
|
79
|
-
// For git@github.com:user/repo.git, do not change path, just warn user to use HTTPS with username if needed
|
|
80
|
-
console.warn(
|
|
81
|
-
`[!] For SSH remotes, set your SSH config or use HTTPS with username if you want to change authentication user.`
|
|
82
|
-
);
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
if (newUrl !== remoteUrl) {
|
|
86
|
-
const updated = runGitCommand(["remote", "set-url", "origin", newUrl], `Set origin to ${newUrl}`);
|
|
87
|
-
if (updated) {
|
|
88
|
-
console.log(`[✓] Remote URL updated to: ${newUrl}`);
|
|
89
|
-
} else {
|
|
90
|
-
console.warn(`[!] Failed to update remote URL. Please update it manually if needed.`);
|
|
91
|
-
}
|
|
92
|
-
} else {
|
|
93
|
-
console.log(`[i] Remote URL does not use HTTPS or already contains the username.`);
|
|
94
|
-
}
|
|
95
|
-
} else {
|
|
96
|
-
console.log(`[i] Remote URL not changed. Use --update-remote to update automatically.`);
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
module.exports = {
|
|
104
|
-
configureGitUser
|
|
105
|
-
};
|
package/lib/git/utils.d.mts
DELETED
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
const { execSync, spawnSync } = require("child_process");
|
|
2
|
-
/**
|
|
3
|
-
* Execute a git command with proper error handling and logging
|
|
4
|
-
* @param {string[]} args - Git command arguments
|
|
5
|
-
* @param {string} description - Description of the operation for logging
|
|
6
|
-
* @returns {boolean} - True if successful, false otherwise
|
|
7
|
-
*/
|
|
8
|
-
function runGitCommand(args, description) {
|
|
9
|
-
try {
|
|
10
|
-
console.log(`[i] ${description}`);
|
|
11
|
-
const result = spawnSync("git", args, { encoding: "utf-8" });
|
|
12
|
-
if (result.status !== 0) {
|
|
13
|
-
console.error(`[✗] Failed: ${description}`);
|
|
14
|
-
console.error(`Error: ${result.stderr || result.stdout}`);
|
|
15
|
-
return false;
|
|
16
|
-
}
|
|
17
|
-
console.log(`[✓] ${description}`);
|
|
18
|
-
return true;
|
|
19
|
-
} catch (error) {
|
|
20
|
-
console.error(`[✗] Failed: ${description}`);
|
|
21
|
-
console.error(`Error: ${error.message}`);
|
|
22
|
-
return false;
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* Check if the given cwd (or current directory) is a git repository
|
|
28
|
-
* @param {string} [cwd] - Directory to check (defaults to current directory at call time)
|
|
29
|
-
* @returns {boolean} - True if in a git repository, false otherwise
|
|
30
|
-
*/
|
|
31
|
-
function isGitRepository(cwd) {
|
|
32
|
-
const dir = typeof cwd === "string" ? cwd : process.cwd();
|
|
33
|
-
try {
|
|
34
|
-
execSync("git rev-parse --git-dir", { stdio: "pipe", cwd: dir });
|
|
35
|
-
return true;
|
|
36
|
-
} catch {
|
|
37
|
-
return false;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* Execute a git command and return stdout (or null on error)
|
|
43
|
-
* @param {string[]} args - Git command arguments
|
|
44
|
-
* @param {string} description - Description of the operation for logging
|
|
45
|
-
* @returns {string|null} - stdout string if successful, null otherwise
|
|
46
|
-
*/
|
|
47
|
-
function runGitCommandOutput(args, description) {
|
|
48
|
-
try {
|
|
49
|
-
console.log(`[i] ${description}`);
|
|
50
|
-
const result = spawnSync("git", args, { encoding: "utf-8" });
|
|
51
|
-
if (result.status !== 0) {
|
|
52
|
-
console.error(`[✗] Failed: ${description}`);
|
|
53
|
-
console.error(`Error: ${result.stderr || result.stdout}`);
|
|
54
|
-
return null;
|
|
55
|
-
}
|
|
56
|
-
console.log(`[✓] ${description}`);
|
|
57
|
-
return result.stdout.trim();
|
|
58
|
-
} catch (error) {
|
|
59
|
-
console.error(`[✗] Failed: ${description}`);
|
|
60
|
-
console.error(`Error: ${error.message}`);
|
|
61
|
-
return null;
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
module.exports = {
|
|
66
|
-
runGitCommand,
|
|
67
|
-
runGitCommandOutput,
|
|
68
|
-
isGitRepository
|
|
69
|
-
};
|
package/lib/git/utils.d.ts
DELETED
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
const { execSync, spawnSync } = require("child_process");
|
|
2
|
-
/**
|
|
3
|
-
* Execute a git command with proper error handling and logging
|
|
4
|
-
* @param {string[]} args - Git command arguments
|
|
5
|
-
* @param {string} description - Description of the operation for logging
|
|
6
|
-
* @returns {boolean} - True if successful, false otherwise
|
|
7
|
-
*/
|
|
8
|
-
function runGitCommand(args, description) {
|
|
9
|
-
try {
|
|
10
|
-
console.log(`[i] ${description}`);
|
|
11
|
-
const result = spawnSync("git", args, { encoding: "utf-8" });
|
|
12
|
-
if (result.status !== 0) {
|
|
13
|
-
console.error(`[✗] Failed: ${description}`);
|
|
14
|
-
console.error(`Error: ${result.stderr || result.stdout}`);
|
|
15
|
-
return false;
|
|
16
|
-
}
|
|
17
|
-
console.log(`[✓] ${description}`);
|
|
18
|
-
return true;
|
|
19
|
-
} catch (error) {
|
|
20
|
-
console.error(`[✗] Failed: ${description}`);
|
|
21
|
-
console.error(`Error: ${error.message}`);
|
|
22
|
-
return false;
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* Check if the given cwd (or current directory) is a git repository
|
|
28
|
-
* @param {string} [cwd] - Directory to check (defaults to current directory at call time)
|
|
29
|
-
* @returns {boolean} - True if in a git repository, false otherwise
|
|
30
|
-
*/
|
|
31
|
-
function isGitRepository(cwd) {
|
|
32
|
-
const dir = typeof cwd === "string" ? cwd : process.cwd();
|
|
33
|
-
try {
|
|
34
|
-
execSync("git rev-parse --git-dir", { stdio: "pipe", cwd: dir });
|
|
35
|
-
return true;
|
|
36
|
-
} catch {
|
|
37
|
-
return false;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* Execute a git command and return stdout (or null on error)
|
|
43
|
-
* @param {string[]} args - Git command arguments
|
|
44
|
-
* @param {string} description - Description of the operation for logging
|
|
45
|
-
* @returns {string|null} - stdout string if successful, null otherwise
|
|
46
|
-
*/
|
|
47
|
-
function runGitCommandOutput(args, description) {
|
|
48
|
-
try {
|
|
49
|
-
console.log(`[i] ${description}`);
|
|
50
|
-
const result = spawnSync("git", args, { encoding: "utf-8" });
|
|
51
|
-
if (result.status !== 0) {
|
|
52
|
-
console.error(`[✗] Failed: ${description}`);
|
|
53
|
-
console.error(`Error: ${result.stderr || result.stdout}`);
|
|
54
|
-
return null;
|
|
55
|
-
}
|
|
56
|
-
console.log(`[✓] ${description}`);
|
|
57
|
-
return result.stdout.trim();
|
|
58
|
-
} catch (error) {
|
|
59
|
-
console.error(`[✗] Failed: ${description}`);
|
|
60
|
-
console.error(`Error: ${error.message}`);
|
|
61
|
-
return null;
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
module.exports = {
|
|
66
|
-
runGitCommand,
|
|
67
|
-
runGitCommandOutput,
|
|
68
|
-
isGitRepository
|
|
69
|
-
};
|