binary-collections 2.0.9 → 2.0.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.puppeterrc.cjs +25 -0
- package/binaries/binary-executor.cjs +178 -0
- package/{bin → binaries}/clean-nodemodule +0 -0
- package/binaries/clean-nodemodule.cjs +178 -0
- package/binaries/clean-nodemodule.cmd +4 -0
- package/{bin → binaries}/clean-nodemodules +0 -0
- package/binaries/clean-nodemodules.cjs +178 -0
- package/binaries/clean-nodemodules.cmd +5 -0
- package/{bin → binaries}/dev +0 -0
- package/binaries/dev.cjs +178 -0
- package/{bin → binaries}/empty +0 -0
- package/binaries/empty.cjs +178 -0
- package/{bin → binaries}/git-reduce-size +0 -0
- package/binaries/git-reduce-size.cjs +178 -0
- package/binaries/javakill.cjs +178 -0
- package/{bin → binaries}/javakill.cmd +0 -0
- package/binaries/kill-night-crows.bat +7 -0
- package/binaries/kill-night-crows.ps1 +172 -0
- package/{bin → binaries}/kill-process +0 -0
- package/binaries/kill-process.cjs +178 -0
- package/binaries/nodekill.cjs +178 -0
- package/{bin → binaries}/nodekill.ps1 +0 -0
- package/{bin → binaries}/prod +0 -0
- package/binaries/prod.cjs +178 -0
- package/binaries/py +111 -0
- package/binaries/py.cjs +178 -0
- package/binaries/py.cmd +49 -0
- package/{bin → binaries}/rmfind +0 -0
- package/binaries/rmfind.cjs +178 -0
- package/{bin → binaries}/rmx +0 -0
- package/binaries/rmx.cjs +178 -0
- package/{bin → binaries}/submodule-token +0 -0
- package/binaries/submodule-token.cjs +178 -0
- package/binaries/test-cjs +10 -0
- package/binaries/test-cjs.cjs +178 -0
- package/binaries/test-cjs.cmd +11 -0
- package/binaries/yarn-clean +32 -0
- package/binaries/yarn-clean.cjs +178 -0
- package/binaries/yarn-clean.cmd +30 -0
- package/binaries/yarn-clean.py +148 -0
- package/docs-src/clean-github-actions-caches.md +26 -0
- package/docs-src/free-chatgpt.md +26 -0
- package/lib/binary-collections-config.cjs +3 -2
- package/lib/binary-collections-config.mjs +2 -2
- package/lib/binary-collections.cjs +513 -105
- package/lib/binary-collections.mjs +178 -117
- package/lib/changelog.cjs +64 -16
- package/lib/changelog.mjs +177 -171
- package/lib/{chunk-VVEZVNIV.mjs → chunk-2CBJCW7E.mjs} +3 -3
- package/lib/chunk-34IQDTLZ.mjs +27 -0
- package/lib/chunk-3HFFECCI.mjs +27 -0
- package/lib/chunk-4UHL4WVN.mjs +136 -0
- package/lib/{chunk-4BYBVEYC.mjs → chunk-66PAU5PS.mjs} +5 -4
- package/lib/chunk-6HHJRKFB.mjs +59 -0
- package/lib/chunk-6S4NXESK.mjs +26 -0
- package/lib/chunk-7XTEJHOE.mjs +193 -0
- package/lib/{chunk-ZYAQRPUL.mjs → chunk-7YD7IPFF.mjs} +2 -2
- package/lib/{chunk-SH3L6HHV.mjs → chunk-A2JQXI5Z.mjs} +2 -2
- package/lib/{chunk-EGSSKVDH.mjs → chunk-A3VUZEJK.mjs} +1 -1
- package/lib/chunk-AJDD5DZM.mjs +109 -0
- package/lib/chunk-BZWVHODJ.mjs +62 -0
- package/lib/chunk-FCDQGYBF.mjs +136 -0
- package/lib/chunk-FKI7IEB5.mjs +172 -0
- package/lib/chunk-GEYA2USY.mjs +207 -0
- package/lib/chunk-GJTGHXRA.mjs +356 -0
- package/lib/{chunk-YV7DO3YV.mjs → chunk-HLGOWBEO.mjs} +1 -1
- package/lib/chunk-ID2WBTE2.mjs +80 -0
- package/lib/chunk-JXFOHKDM.mjs +239 -0
- package/lib/{chunk-YX5U7XDR.mjs → chunk-M3YIYRHT.mjs} +6 -5
- package/lib/chunk-N436BNBK.mjs +514 -0
- package/lib/chunk-NCXAP7AA.mjs +31 -0
- package/lib/chunk-PDN26I7O.mjs +188 -0
- package/lib/{chunk-JGR2NW6D.mjs → chunk-PDSXF5HY.mjs} +3 -3
- package/lib/{chunk-AASHBCRW.mjs → chunk-QQ4A6DLD.mjs} +8 -0
- package/lib/{chunk-ONIBBBQ3.mjs → chunk-RWLXRTYP.mjs} +4 -3
- package/lib/chunk-TOIVAQF7.mjs +136 -0
- package/lib/chunk-V5SKYJUB.mjs +136 -0
- package/lib/chunk-WSRETQCA.mjs +59 -0
- package/lib/chunk-XA3SNBPA.mjs +184 -0
- package/lib/chunk-XVBFFVCJ.mjs +209 -0
- package/lib/chunk-YYLIQQKF.mjs +31 -0
- package/lib/{chunk-APBWENF6.mjs → chunk-Z6JLYU2J.mjs} +63 -16
- package/lib/chunk-ZDMWBSYF.mjs +81 -0
- package/lib/clean-github-actions-caches.cjs +291 -148
- package/lib/clean-github-actions-caches.mjs +4 -3
- package/lib/del-gradle.cjs +63 -15
- package/lib/del-gradle.js +2 -1
- package/lib/del-gradle.mjs +2 -2
- package/lib/del-node-modules.cjs +143 -148
- package/lib/del-node-modules.js +210 -14
- package/lib/del-node-modules.mjs +149 -18
- package/lib/del-ps.cjs +90 -21
- package/lib/del-ps.js +3 -2
- package/lib/del-ps.mjs +7 -5
- package/lib/del-yarn-caches.cjs +87 -18
- package/lib/del-yarn-caches.js +38 -3
- package/lib/del-yarn-caches.mjs +6 -6
- package/lib/find-node-modules-cli.cjs +5 -4
- package/lib/find-node-modules-cli.js +2 -1
- package/lib/find-node-modules-cli.mjs +2 -2
- package/lib/find-node-modules.cjs +4 -3
- package/lib/{find-node-modules.d.ts → find-node-modules.d.cts} +1 -1
- package/lib/find-node-modules.mjs +2 -2
- package/lib/free-chatgpt.cjs +754 -0
- package/lib/free-chatgpt.js +51 -0
- package/lib/free-chatgpt.mjs +50 -0
- package/lib/git/gitattributes.cjs +2 -1
- package/lib/git/{gitattributes.d.ts → gitattributes.d.cts} +7 -2
- package/lib/git/gitattributes.mjs +2 -2
- package/lib/git/line-endings.cjs +298 -64
- package/lib/git/line-endings.mjs +4 -4
- package/lib/git/normalize.cjs +26 -36
- package/lib/git/normalize.mjs +2 -2
- package/lib/git/permissions.cjs +77 -11
- package/lib/git/permissions.mjs +3 -3
- package/lib/git/pull-strategy.cjs +76 -9
- package/lib/git/pull-strategy.mjs +3 -3
- package/lib/git/undo-commit-cli.cjs +110 -0
- package/lib/git/undo-commit-cli.d.ts +1 -0
- package/lib/git/undo-commit-cli.js +4 -0
- package/lib/git/undo-commit-cli.mjs +14 -0
- package/lib/git/undo-commit.cjs +81 -0
- package/lib/git/undo-commit.d.cts +1 -0
- package/lib/git/undo-commit.mjs +7 -0
- package/lib/git/undo-staged-cli.cjs +110 -0
- package/lib/git/undo-staged-cli.d.ts +1 -0
- package/lib/git/undo-staged-cli.js +4 -0
- package/lib/git/undo-staged-cli.mjs +14 -0
- package/lib/git/undo-staged.cjs +81 -0
- package/lib/git/undo-staged.d.cts +1 -0
- package/lib/git/undo-staged.mjs +7 -0
- package/lib/git/user-config.cjs +313 -83
- package/lib/git/user-config.mjs +4 -4
- package/lib/git/utils.cjs +40 -60
- package/lib/git/utils.mjs +2 -2
- package/lib/git-diff-cli.cjs +857 -0
- package/lib/git-diff-cli.js +16 -0
- package/lib/git-diff-cli.mjs +17 -0
- package/lib/git-diff.cjs +862 -58
- package/lib/git-diff.d.ts +38 -83
- package/lib/git-diff.js +152 -0
- package/lib/git-diff.mjs +23 -85
- package/lib/git-fix.cjs +733 -97
- package/lib/git-fix.mjs +10 -9
- package/lib/git-purge.cjs +64 -16
- package/lib/git-purge.d.cts +1 -0
- package/lib/git-purge.mjs +43 -37
- package/lib/index.cjs +7 -6
- package/lib/index.d.ts +1 -1
- package/lib/index.js +2 -5
- package/lib/index.mjs +4 -4
- package/lib/kill-night-crows.cjs +87 -0
- package/lib/kill-night-crows.d.mts +1 -0
- package/lib/kill-night-crows.mjs +65 -0
- package/lib/npm-run-series.cjs +63 -16
- package/lib/npm-run-series.mjs +42 -36
- package/lib/package-resolutions-updater-cli.cjs +560 -0
- package/lib/package-resolutions-updater-cli.d.mts +1 -0
- package/lib/package-resolutions-updater-cli.mjs +124 -0
- package/lib/package-resolutions-updater.cjs +178 -158
- package/lib/package-resolutions-updater.d.mts +32 -1
- package/lib/package-resolutions-updater.mjs +17 -338
- package/lib/php-cs-fixer-staged.cjs +105 -0
- package/lib/php-cs-fixer-staged.d.cts +2 -0
- package/lib/php-cs-fixer-staged.mjs +117 -0
- package/lib/print-directory-tree.cjs +320 -207
- package/lib/print-directory-tree.mjs +3 -3
- package/lib/ps/connected-domain.cjs +25 -2
- package/lib/ps/connected-domain.d.ts +10 -2
- package/lib/ps/connected-domain.js +5 -2
- package/lib/ps/connected-domain.mjs +8 -4
- package/lib/ps/index.cjs +345 -322
- package/lib/ps/index.d.mjs +1 -1
- package/lib/ps/index.js +2 -1
- package/lib/ps/index.mjs +179 -182
- package/lib/ps/isWin.cjs +24 -1
- package/lib/ps/isWin.d.ts +1 -1
- package/lib/ps/isWin.js +3 -1
- package/lib/ps/isWin.mjs +8 -4
- package/lib/ps/table-parser.cjs +167 -159
- package/lib/ps/table-parser.d.ts +5 -0
- package/lib/ps/table-parser.js +10 -4
- package/lib/ps/table-parser.mjs +9 -5
- package/lib/remove-module.cjs +310 -0
- package/lib/remove-module.d.mts +1 -0
- package/lib/remove-module.mjs +111 -0
- package/lib/rmpath.cjs +322 -0
- package/lib/rmpath.d.mts +3 -0
- package/lib/rmpath.mjs +108 -0
- package/lib/submodule-install.cjs +311 -86
- package/lib/submodule-install.mjs +53 -5
- package/lib/submodule-remove-cli.cjs +107 -0
- package/lib/submodule-remove-cli.d.ts +1 -0
- package/lib/submodule-remove-cli.js +31 -0
- package/lib/submodule-remove-cli.mjs +28 -0
- package/lib/submodule-remove.cjs +46 -0
- package/lib/submodule-remove.d.cts +2 -0
- package/lib/submodule-remove.mjs +6 -0
- package/lib/utils/chatgpt.cjs +541 -0
- package/lib/utils/chatgpt.d.ts +31 -0
- package/lib/utils/chatgpt.js +708 -0
- package/lib/utils/chatgpt.mjs +8 -0
- package/lib/utils/findEnvFiles.cjs +107 -0
- package/lib/utils/findEnvFiles.d.ts +8 -0
- package/lib/utils/findEnvFiles.js +121 -0
- package/lib/utils/findEnvFiles.mjs +8 -0
- package/lib/utils/findWorkspaceRoot.cjs +70 -0
- package/lib/utils/findWorkspaceRoot.d.ts +9 -0
- package/lib/utils/findWorkspaceRoot.js +57 -0
- package/lib/utils/findWorkspaceRoot.mjs +40 -0
- package/lib/{utils.cjs → utils/index.cjs} +61 -14
- package/lib/{utils.mjs → utils/index.mjs} +2 -2
- package/lib/utils/isGithubTokenValid.cjs +64 -0
- package/lib/utils/isGithubTokenValid.d.ts +7 -0
- package/lib/utils/isGithubTokenValid.js +48 -0
- package/lib/utils/isGithubTokenValid.mjs +36 -0
- package/lib/yarn-reinstall.cjs +220 -38
- package/lib/yarn-reinstall.mjs +2 -2
- package/package.json +138 -104
- package/readme.md +48 -75
- package/releases/readme.md +36 -0
- package/requirements.txt +1 -0
- package/test/README.md +101 -0
- package/test/package.json +2 -1
- package/test-project/readme.md +26 -0
- package/tmp/test-repo/README.md +35 -0
- package/tmp/test-repo/package.json +1 -1
- package/tmp/typedoc/readme.md +320 -0
- package/bin/bash-dummy +0 -56
- package/bin/bash-dummy.cmd +0 -25
- package/bin/dir-tree.cmd +0 -7
- package/bin/git-diff +0 -4
- package/bin/git-diff.cmd +0 -7
- package/bin/git-fix +0 -36
- package/bin/git-fix.cmd +0 -7
- package/bin/rmpath +0 -70
- package/bin/submodule-install.txt +0 -118
- package/bin/submodule-remove +0 -46
- package/bin/submodule.txt +0 -172
- package/lib/binary-collections-config.d.mts +0 -18
- package/lib/binary-collections-config.js +0 -39
- package/lib/binary-collections.d.mts +0 -137
- package/lib/binary-collections.d.ts +0 -137
- package/lib/changelog.d.mts +0 -2
- package/lib/changelog.js +0 -226
- package/lib/chunk-DPKAJKFO.mjs +0 -171
- package/lib/chunk-G3THLIDT.mjs +0 -200
- package/lib/chunk-W3ENOM53.mjs +0 -18
- package/lib/clean-github-actions-caches.d.mts +0 -169
- package/lib/clean-github-actions-caches.d.ts +0 -169
- package/lib/del-gradle.d.mts +0 -2
- package/lib/del-node-modules.d.mts +0 -2
- package/lib/del-ps.d.mts +0 -2
- package/lib/del-yarn-caches.d.mts +0 -2
- package/lib/find-node-modules-cli.d.mts +0 -1
- package/lib/find-node-modules.d.mts +0 -13
- package/lib/find-node-modules.js +0 -53
- package/lib/git/gitattributes.d.mts +0 -35
- package/lib/git/gitattributes.js +0 -223
- package/lib/git/line-endings.d.mts +0 -83
- package/lib/git/line-endings.d.ts +0 -83
- package/lib/git/normalize.d.mts +0 -43
- package/lib/git/normalize.d.ts +0 -43
- package/lib/git/permissions.d.mts +0 -17
- package/lib/git/permissions.d.ts +0 -17
- package/lib/git/pull-strategy.d.mts +0 -15
- package/lib/git/pull-strategy.d.ts +0 -15
- package/lib/git/user-config.d.mts +0 -105
- package/lib/git/user-config.d.ts +0 -105
- package/lib/git/utils.d.mts +0 -69
- package/lib/git/utils.d.ts +0 -69
- package/lib/git-diff.d.mts +0 -84
- package/lib/git-fix.d.mts +0 -141
- package/lib/git-fix.d.ts +0 -141
- package/lib/git-purge.d.mts +0 -2
- package/lib/git-purge.js +0 -59
- package/lib/index.d.mts +0 -1
- package/lib/npm-run-series.d.mts +0 -1
- package/lib/npm-run-series.js +0 -86
- package/lib/package-resolutions-updater.d.ts +0 -352
- package/lib/print-directory-tree.d.mts +0 -234
- package/lib/print-directory-tree.d.ts +0 -234
- package/lib/ps/connected-domain.d.mts +0 -3
- package/lib/ps/index.d.d.mts +0 -26
- package/lib/ps/index.d.d.ts +0 -26
- package/lib/ps/index.d.mts +0 -26
- package/lib/ps/isWin.d.mts +0 -3
- package/lib/ps/table-parser.d.mts +0 -3
- package/lib/submodule-install.d.mts +0 -121
- package/lib/submodule-install.d.ts +0 -121
- package/lib/utils.d.mts +0 -40
- package/lib/utils.js +0 -181
- package/lib/yarn-reinstall.d.mts +0 -49
- package/lib/yarn-reinstall.d.ts +0 -49
- package/src/package-resolutions-updater.mjs +0 -350
- package/src/print-directory-tree.cjs +0 -234
- package/src/ps/index.js +0 -286
- package/src/yarn-reinstall.cjs +0 -49
- /package/{bin → binaries}/nodekill +0 -0
- /package/{bin → binaries}/nodekill.cmd +0 -0
- /package/lib/{binary-collections-config.d.ts → binary-collections-config.d.cts} +0 -0
- /package/lib/{changelog.d.ts → changelog.d.cts} +0 -0
- /package/lib/{git-purge.d.ts → free-chatgpt.d.ts} +0 -0
- /package/lib/{git-diff.d.cts → git-diff-cli.d.ts} +0 -0
- /package/lib/{npm-run-series.d.ts → npm-run-series.d.cts} +0 -0
- /package/lib/{utils.d.ts → utils/index.d.cts} +0 -0
package/lib/changelog.mjs
CHANGED
|
@@ -1,199 +1,205 @@
|
|
|
1
1
|
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
3
|
require_utils
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-Z6JLYU2J.mjs";
|
|
5
5
|
import {
|
|
6
|
+
__commonJS,
|
|
6
7
|
__dirname,
|
|
7
8
|
__require,
|
|
8
9
|
init_esm_shims
|
|
9
|
-
} from "./chunk-
|
|
10
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
10
11
|
|
|
11
|
-
// src/changelog.
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
var
|
|
16
|
-
var
|
|
17
|
-
var
|
|
18
|
-
var
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
12
|
+
// src/changelog.cjs
|
|
13
|
+
var require_changelog = __commonJS({
|
|
14
|
+
"src/changelog.cjs"() {
|
|
15
|
+
init_esm_shims();
|
|
16
|
+
var fs = __require("fs");
|
|
17
|
+
var path = __require("path");
|
|
18
|
+
var { EOL } = __require("os");
|
|
19
|
+
var { getArgs } = require_utils();
|
|
20
|
+
var spawn = __require("child_process").spawn;
|
|
21
|
+
var pkgPath = path.join(process.cwd(), "package.json");
|
|
22
|
+
if (!fs.existsSync(pkgPath)) {
|
|
23
|
+
throw new Error(`package.json not found at ${pkgPath}`);
|
|
24
|
+
}
|
|
25
|
+
var pkg = JSON.parse(fs.readFileSync(pkgPath, "utf8"));
|
|
26
|
+
var args = getArgs();
|
|
27
|
+
if (args.help || args.h) {
|
|
28
|
+
showHelp();
|
|
29
|
+
}
|
|
30
|
+
function showHelp() {
|
|
31
|
+
console.log(`
|
|
29
32
|
Usage: node changelog.js [options]
|
|
30
33
|
`);
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
+
console.log(`Options:`);
|
|
35
|
+
console.log(` --help, -h Show this help message and exit`);
|
|
36
|
+
console.log(`
|
|
34
37
|
Description:`);
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
38
|
+
console.log(` Generates a CHANGELOG.md file from git commit history.`);
|
|
39
|
+
console.log(` - Looks for version bumps and groups commits by version.`);
|
|
40
|
+
console.log(` - Skips dependabot and irrelevant commits.`);
|
|
41
|
+
console.log(` - Outputs the original git log to tmp/original.md for reference.`);
|
|
42
|
+
console.log(`
|
|
40
43
|
Example:`);
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
}
|
|
44
|
-
var gitExec = (command) => new Promise((resolve, reject) => {
|
|
45
|
-
const thread = spawn("git", command, { stdio: ["inherit", "pipe", "pipe"] });
|
|
46
|
-
const stdOut = [];
|
|
47
|
-
const stdErr = [];
|
|
48
|
-
thread.stdout.on("data", (data) => {
|
|
49
|
-
stdOut.push(data.toString("utf8"));
|
|
50
|
-
});
|
|
51
|
-
thread.stderr.on("data", (data) => {
|
|
52
|
-
stdErr.push(data.toString("utf8"));
|
|
53
|
-
});
|
|
54
|
-
thread.on("close", () => {
|
|
55
|
-
if (stdErr.length) {
|
|
56
|
-
reject(stdErr.join(""));
|
|
57
|
-
return;
|
|
44
|
+
console.log(` node changelog.js`);
|
|
45
|
+
console.log(``);
|
|
58
46
|
}
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
(
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
47
|
+
var gitExec = (command) => new Promise((resolve, reject) => {
|
|
48
|
+
const thread = spawn("git", command, { stdio: ["inherit", "pipe", "pipe"] });
|
|
49
|
+
const stdOut = [];
|
|
50
|
+
const stdErr = [];
|
|
51
|
+
thread.stdout.on("data", (data) => {
|
|
52
|
+
stdOut.push(data.toString("utf8"));
|
|
53
|
+
});
|
|
54
|
+
thread.stderr.on("data", (data) => {
|
|
55
|
+
stdErr.push(data.toString("utf8"));
|
|
56
|
+
});
|
|
57
|
+
thread.on("close", () => {
|
|
58
|
+
if (stdErr.length) {
|
|
59
|
+
reject(stdErr.join(""));
|
|
60
|
+
return;
|
|
61
|
+
}
|
|
62
|
+
resolve(stdOut.join());
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
function extractVersions(str) {
|
|
66
|
+
const regex = /\bv?(\d+\.\d+\.\d+)\b/g;
|
|
67
|
+
const matches = [];
|
|
68
|
+
let match;
|
|
69
|
+
while ((match = regex.exec(str)) !== null) {
|
|
70
|
+
matches.push(match[1]);
|
|
71
|
+
}
|
|
72
|
+
return Array.from(new Set(matches));
|
|
73
|
+
}
|
|
74
|
+
(async () => {
|
|
75
|
+
const log = await gitExec([
|
|
76
|
+
"log",
|
|
77
|
+
"--reverse",
|
|
78
|
+
`--pretty=format:"=!=%h !|! %ad !|! %an !|! %cn !|! %s !|! %B !|! %d=!="`,
|
|
79
|
+
`--date=format:"%Y-%m-%d %H:%M:%S"`
|
|
80
|
+
]);
|
|
81
|
+
let markdown = `## CHANGELOG of ${pkg.name}
|
|
79
82
|
|
|
80
83
|
`;
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
}
|
|
103
|
-
if (/^\d+\.\d+\.\d+$/.test(o.summary.trim())) {
|
|
104
|
-
isBumped = true;
|
|
105
|
-
}
|
|
106
|
-
if (o.summary.trim().startsWith("fix:")) {
|
|
107
|
-
isBumped = false;
|
|
108
|
-
}
|
|
109
|
-
if (isBumped && !extractVersions(o.summary).length > 0) isBumped = false;
|
|
110
|
-
if (o.hash && o.date && o.message) {
|
|
111
|
-
if (o.authorName === "dependabot[bot]") {
|
|
112
|
-
continue;
|
|
113
|
-
}
|
|
114
|
-
if (/^chore\(tarball\): update|merge pull request|merge branch|^migrate from|^update$|^update build from https?:\/\//i.test(
|
|
115
|
-
o.message
|
|
116
|
-
)) {
|
|
117
|
-
continue;
|
|
118
|
-
}
|
|
119
|
-
if (/^Build\s+\w{3}\s+\w{3}\s+\d{1,2}\s+\d{2}:\d{2}:\d{2}\s+\w+\s+\d{4}$/i.test(o.summary)) {
|
|
120
|
-
continue;
|
|
121
|
-
}
|
|
122
|
-
if (/initial commit/i.test(o.message)) {
|
|
123
|
-
versionsCommits["0.0.0"] = [];
|
|
124
|
-
currentVersionCommit = "0.0.0";
|
|
125
|
-
continue;
|
|
126
|
-
}
|
|
127
|
-
if (isBumped) {
|
|
128
|
-
console.log(`Detected version bump: ${o.summary}`);
|
|
129
|
-
const v = extractVersions(o.message).join(", ");
|
|
130
|
-
versionsCommits[v] = [];
|
|
131
|
-
currentVersionCommit = v;
|
|
132
|
-
} else {
|
|
133
|
-
if (!currentVersionCommit) {
|
|
134
|
-
throw new Error(`No current version commit set for message: ${o.message} (hash: ${o.hash})`);
|
|
84
|
+
const repo = await gitExec(["remote", "get-url", "origin"]);
|
|
85
|
+
const repoUrl = repo.trim().replace(/\.git$/, "");
|
|
86
|
+
console.log(`Repository URL: ${repoUrl}`);
|
|
87
|
+
const matches = [...log.matchAll(/=!=(.*?)(?:=!=|=!=,)/gs)];
|
|
88
|
+
const results = matches.map((m) => m[1].trim());
|
|
89
|
+
const versionsCommits = {};
|
|
90
|
+
let currentVersionCommit = "";
|
|
91
|
+
for (const str of results) {
|
|
92
|
+
const splitx = str.split("!|!").map((s) => s.trim());
|
|
93
|
+
const o = {
|
|
94
|
+
hash: splitx[0] ? splitx[0] : "",
|
|
95
|
+
date: splitx[1] ? splitx[1].replace(/^"|"$/g, "") : "",
|
|
96
|
+
authorName: splitx[2] ? splitx[2] : "",
|
|
97
|
+
committerName: splitx[3] ? splitx[3] : "",
|
|
98
|
+
summary: splitx[4] ? splitx[4] : "",
|
|
99
|
+
message: splitx[5] ? splitx[5] : "",
|
|
100
|
+
ref: splitx[6] ? splitx[6] : ""
|
|
101
|
+
};
|
|
102
|
+
let isBumped = /chore\(bump\)|chore: release/i.test(o.summary) || /release/i.test(o.summary) || /tag: v/i.test(o.summary);
|
|
103
|
+
if (o.summary.trim().startsWith("v")) {
|
|
104
|
+
isBumped = true;
|
|
135
105
|
}
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
106
|
+
if (/^\d+\.\d+\.\d+$/.test(o.summary.trim())) {
|
|
107
|
+
isBumped = true;
|
|
108
|
+
}
|
|
109
|
+
if (o.summary.trim().startsWith("fix:")) {
|
|
110
|
+
isBumped = false;
|
|
111
|
+
}
|
|
112
|
+
if (isBumped && !extractVersions(o.summary).length > 0) isBumped = false;
|
|
113
|
+
if (o.hash && o.date && o.message) {
|
|
114
|
+
if (o.authorName === "dependabot[bot]") {
|
|
115
|
+
continue;
|
|
116
|
+
}
|
|
117
|
+
if (/^chore\(tarball\): update|merge pull request|merge branch|^migrate from|^update$|^update build from https?:\/\//i.test(
|
|
118
|
+
o.message
|
|
119
|
+
)) {
|
|
120
|
+
continue;
|
|
121
|
+
}
|
|
122
|
+
if (/^Build\s+\w{3}\s+\w{3}\s+\d{1,2}\s+\d{2}:\d{2}:\d{2}\s+\w+\s+\d{4}$/i.test(o.summary)) {
|
|
123
|
+
continue;
|
|
124
|
+
}
|
|
125
|
+
if (/initial commit/i.test(o.message)) {
|
|
126
|
+
versionsCommits["0.0.0"] = [];
|
|
127
|
+
currentVersionCommit = "0.0.0";
|
|
128
|
+
continue;
|
|
129
|
+
}
|
|
130
|
+
if (isBumped) {
|
|
131
|
+
console.log(`Detected version bump: ${o.summary}`);
|
|
132
|
+
const v = extractVersions(o.message).join(", ");
|
|
133
|
+
versionsCommits[v] = [];
|
|
134
|
+
currentVersionCommit = v;
|
|
135
|
+
} else {
|
|
136
|
+
if (!currentVersionCommit) {
|
|
137
|
+
throw new Error(`No current version commit set for message: ${o.message} (hash: ${o.hash})`);
|
|
138
|
+
}
|
|
139
|
+
const cleanMsg = o.message.replace(/["'\s,]+$/g, "");
|
|
140
|
+
const commitsArr = versionsCommits[currentVersionCommit];
|
|
141
|
+
const prevIdx = commitsArr.findIndex((entry) => {
|
|
142
|
+
const parts = entry.split(/\r?\n/);
|
|
143
|
+
let msgLine = "";
|
|
144
|
+
for (let i = 1; i < parts.length; i++) {
|
|
145
|
+
if (parts[i].trim() !== "") {
|
|
146
|
+
msgLine = parts[i].trim();
|
|
147
|
+
break;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
return msgLine === cleanMsg;
|
|
151
|
+
});
|
|
152
|
+
let newEntry;
|
|
153
|
+
if (cleanMsg.includes("\n")) {
|
|
154
|
+
newEntry = `- [ _${o.date}_ ] [${o.hash}](<${repoUrl}/commit/${o.hash}>)` + EOL + EOL + `${cleanMsg}`;
|
|
155
|
+
} else {
|
|
156
|
+
newEntry = `- [ _${o.date}_ ] [${o.hash}](<${repoUrl}/commit/${o.hash}>) ${cleanMsg}`;
|
|
157
|
+
}
|
|
158
|
+
if (prevIdx !== -1) {
|
|
159
|
+
commitsArr[prevIdx] = newEntry;
|
|
160
|
+
} else {
|
|
161
|
+
commitsArr.push(newEntry);
|
|
145
162
|
}
|
|
146
163
|
}
|
|
147
|
-
return msgLine === cleanMsg;
|
|
148
|
-
});
|
|
149
|
-
let newEntry;
|
|
150
|
-
if (cleanMsg.includes("\n")) {
|
|
151
|
-
newEntry = `- [ _${o.date}_ ] [${o.hash}](<${repoUrl}/commit/${o.hash}>)` + EOL + EOL + `${cleanMsg}`;
|
|
152
|
-
} else {
|
|
153
|
-
newEntry = `- [ _${o.date}_ ] [${o.hash}](<${repoUrl}/commit/${o.hash}>) ${cleanMsg}`;
|
|
154
164
|
}
|
|
155
|
-
if (prevIdx !== -1) {
|
|
156
|
-
commitsArr[prevIdx] = newEntry;
|
|
157
|
-
} else {
|
|
158
|
-
commitsArr.push(newEntry);
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
const versions = Object.keys(versionsCommits).sort((a, b) => {
|
|
164
|
-
const aParts = a.split(".").map(Number);
|
|
165
|
-
const bParts = b.split(".").map(Number);
|
|
166
|
-
for (let i = 0; i < Math.max(aParts.length, bParts.length); i++) {
|
|
167
|
-
const aPart = aParts[i] || 0;
|
|
168
|
-
const bPart = bParts[i] || 0;
|
|
169
|
-
if (aPart !== bPart) {
|
|
170
|
-
return bPart - aPart;
|
|
171
165
|
}
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
166
|
+
const versions = Object.keys(versionsCommits).sort((a, b) => {
|
|
167
|
+
const aParts = a.split(".").map(Number);
|
|
168
|
+
const bParts = b.split(".").map(Number);
|
|
169
|
+
for (let i = 0; i < Math.max(aParts.length, bParts.length); i++) {
|
|
170
|
+
const aPart = aParts[i] || 0;
|
|
171
|
+
const bPart = bParts[i] || 0;
|
|
172
|
+
if (aPart !== bPart) {
|
|
173
|
+
return bPart - aPart;
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
return 0;
|
|
177
|
+
});
|
|
178
|
+
for (const version of versions) {
|
|
179
|
+
if (versionsCommits[version].length > 0) {
|
|
180
|
+
markdown += `
|
|
178
181
|
### ${version}
|
|
179
182
|
|
|
180
183
|
`;
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
184
|
+
markdown += versionsCommits[version].map((str) => {
|
|
185
|
+
const lines = str.trim().split(/\r?\n/);
|
|
186
|
+
return [lines[0], ...lines.slice(1).map((line) => " " + line)].join(EOL);
|
|
187
|
+
}).join(EOL);
|
|
188
|
+
} else {
|
|
189
|
+
markdown += `
|
|
187
190
|
### ${version}
|
|
188
191
|
|
|
189
192
|
`;
|
|
190
|
-
|
|
193
|
+
markdown += `- No changes recorded for this version.
|
|
191
194
|
`;
|
|
192
|
-
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
fs.mkdirSync(path.join(__dirname, "tmp"), { recursive: true });
|
|
198
|
+
fs.writeFileSync(path.join(__dirname, "tmp/original.md"), log);
|
|
199
|
+
fs.writeFileSync(path.join(__dirname, "CHANGELOG.md"), markdown);
|
|
200
|
+
console.log(`Original log written to tmp/original.md`);
|
|
201
|
+
console.log(`Changelog updated successfully. You can find it at CHANGELOG.md`);
|
|
202
|
+
})();
|
|
193
203
|
}
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
fs.writeFileSync(path.join(__dirname, "CHANGELOG.md"), markdown);
|
|
197
|
-
console.log(`Original log written to tmp/original.md`);
|
|
198
|
-
console.log(`Changelog updated successfully. You can find it at CHANGELOG.md`);
|
|
199
|
-
})();
|
|
204
|
+
});
|
|
205
|
+
export default require_changelog();
|
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
3
|
require_gitattributes
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-PDSXF5HY.mjs";
|
|
5
5
|
import {
|
|
6
6
|
require_utils
|
|
7
|
-
} from "./chunk-
|
|
7
|
+
} from "./chunk-A3VUZEJK.mjs";
|
|
8
8
|
import {
|
|
9
9
|
__commonJS,
|
|
10
10
|
__require,
|
|
11
11
|
init_esm_shims
|
|
12
|
-
} from "./chunk-
|
|
12
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
13
13
|
|
|
14
14
|
// src/git/line-endings.cjs
|
|
15
15
|
var require_line_endings = __commonJS({
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
require_utils
|
|
4
|
+
} from "./chunk-A3VUZEJK.mjs";
|
|
5
|
+
import {
|
|
6
|
+
__commonJS,
|
|
7
|
+
init_esm_shims
|
|
8
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
9
|
+
|
|
10
|
+
// src/git/undo-commit.cjs
|
|
11
|
+
var require_undo_commit = __commonJS({
|
|
12
|
+
"src/git/undo-commit.cjs"(exports, module) {
|
|
13
|
+
init_esm_shims();
|
|
14
|
+
var { runGitCommand } = require_utils();
|
|
15
|
+
function undoLastCommit() {
|
|
16
|
+
console.log("\n=== Undoing Last Commit ===");
|
|
17
|
+
runGitCommand(["reset", "--soft", "HEAD~1"], "Undo last commit while keeping changes staged");
|
|
18
|
+
}
|
|
19
|
+
module.exports = {
|
|
20
|
+
undoLastCommit
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
export {
|
|
26
|
+
require_undo_commit
|
|
27
|
+
};
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
require_utils
|
|
4
|
+
} from "./chunk-A3VUZEJK.mjs";
|
|
5
|
+
import {
|
|
6
|
+
__commonJS,
|
|
7
|
+
init_esm_shims
|
|
8
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
9
|
+
|
|
10
|
+
// src/git/undo-staged.cjs
|
|
11
|
+
var require_undo_staged = __commonJS({
|
|
12
|
+
"src/git/undo-staged.cjs"(exports, module) {
|
|
13
|
+
init_esm_shims();
|
|
14
|
+
var { runGitCommand } = require_utils();
|
|
15
|
+
function undoStagedChanges() {
|
|
16
|
+
console.log("\n=== Undoing Staged Changes ===");
|
|
17
|
+
runGitCommand(["reset", "HEAD", "."], "Undo staged changes");
|
|
18
|
+
}
|
|
19
|
+
module.exports = {
|
|
20
|
+
undoStagedChanges
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
export {
|
|
26
|
+
require_undo_staged
|
|
27
|
+
};
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
runChatGpt
|
|
4
|
+
} from "./chunk-GJTGHXRA.mjs";
|
|
5
|
+
import {
|
|
6
|
+
require_binary_collections_config
|
|
7
|
+
} from "./chunk-66PAU5PS.mjs";
|
|
8
|
+
import {
|
|
9
|
+
require_utils
|
|
10
|
+
} from "./chunk-Z6JLYU2J.mjs";
|
|
11
|
+
import {
|
|
12
|
+
__toESM,
|
|
13
|
+
init_esm_shims
|
|
14
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
15
|
+
|
|
16
|
+
// src/git-diff.js
|
|
17
|
+
init_esm_shims();
|
|
18
|
+
var import_binary_collections_config = __toESM(require_binary_collections_config(), 1);
|
|
19
|
+
import { execSync } from "child_process";
|
|
20
|
+
import fs from "fs-extra";
|
|
21
|
+
import path from "upath";
|
|
22
|
+
import { fileURLToPath } from "url";
|
|
23
|
+
var import_utils = __toESM(require_utils(), 1);
|
|
24
|
+
var __filename = fileURLToPath(import.meta.url);
|
|
25
|
+
var __dirname = path.dirname(__filename);
|
|
26
|
+
var DIFF_OUTPUT = (0, import_binary_collections_config.getTempPath)("git-diff.txt");
|
|
27
|
+
var GPT_DIFF_OUTPUT = (0, import_binary_collections_config.getTempPath)("gpt-question.txt");
|
|
28
|
+
var CACHE_DIR = path.dirname(DIFF_OUTPUT);
|
|
29
|
+
var DIFF_OUTPUT_RELATIVE = path.relative(process.cwd(), DIFF_OUTPUT);
|
|
30
|
+
var GPT_DIFF_OUTPUT_RELATIVE = path.relative(process.cwd(), GPT_DIFF_OUTPUT);
|
|
31
|
+
if (!fs.existsSync(CACHE_DIR)) {
|
|
32
|
+
fs.mkdirSync(CACHE_DIR, { recursive: true });
|
|
33
|
+
}
|
|
34
|
+
function showHelp() {
|
|
35
|
+
console.log("\u{1F4DD} Git Diff Helper");
|
|
36
|
+
console.log("\u{1F4C4} Usage:");
|
|
37
|
+
console.log(" \u{1F4C2} git-diff FILE Show staged diff of specified file");
|
|
38
|
+
console.log(" \u{1F4C2} git-diff --staged-only Show staged diff of all files");
|
|
39
|
+
console.log(" \u{1F4C2} git-diff -s | -S Same as --staged-only");
|
|
40
|
+
console.log(" \u{1F4C2} git-diff --ai Run ChatGPT automation for commit message");
|
|
41
|
+
console.log(" \u{1F4C2} git-diff --help | -h Show this help message");
|
|
42
|
+
console.log("");
|
|
43
|
+
console.log(`\u{1F4BE} Output is saved to: ${DIFF_OUTPUT_RELATIVE}`);
|
|
44
|
+
console.log(`\u{1F916} GPT prompt is saved to: ${GPT_DIFF_OUTPUT_RELATIVE}`);
|
|
45
|
+
process.exit(0);
|
|
46
|
+
}
|
|
47
|
+
function runGitDiff(command, successMessage, errorMessage) {
|
|
48
|
+
try {
|
|
49
|
+
console.log(`\u{1F50D} [i] Running command: ${command}`);
|
|
50
|
+
const result = execSync(command, {
|
|
51
|
+
encoding: "utf8",
|
|
52
|
+
maxBuffer: 1024 * 1024 * 10
|
|
53
|
+
// 10MB buffer to handle large diffs
|
|
54
|
+
});
|
|
55
|
+
if (!result || result.trim() === "") {
|
|
56
|
+
console.log(`\u2139\uFE0F [i] No changes found for the specified criteria`);
|
|
57
|
+
fs.writeFileSync(DIFF_OUTPUT, "# No changes found\n");
|
|
58
|
+
console.log(`\u2705 Empty diff saved to "${DIFF_OUTPUT_RELATIVE}"`);
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
fs.writeFileSync(DIFF_OUTPUT, result);
|
|
62
|
+
fs.writeFileSync(
|
|
63
|
+
GPT_DIFF_OUTPUT,
|
|
64
|
+
`Hello, ChatGPT!
|
|
65
|
+
Can you create a conventional commit message by diff content below:
|
|
66
|
+
|
|
67
|
+
\`\`\`${result}
|
|
68
|
+
\`\`\`
|
|
69
|
+
|
|
70
|
+
Give me result as codeblock with language "text" only.
|
|
71
|
+
|
|
72
|
+
Thank you!`
|
|
73
|
+
);
|
|
74
|
+
console.log(`\u2705 ${successMessage}`);
|
|
75
|
+
console.log(`\u{1F4BE} GPT diff prompt saved to "${GPT_DIFF_OUTPUT_RELATIVE}"`);
|
|
76
|
+
} catch (error) {
|
|
77
|
+
console.error(`\u274C ${errorMessage}`);
|
|
78
|
+
console.error(`\u{1F4DD} Command: ${command}`);
|
|
79
|
+
console.error(`\u26A0\uFE0F Error: ${error.message}`);
|
|
80
|
+
if (error.message.includes("not a git repository")) {
|
|
81
|
+
console.error("\u{1F6A7} Make sure you are in a git repository");
|
|
82
|
+
}
|
|
83
|
+
process.exit(1);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
async function mainGitDiff() {
|
|
87
|
+
const args = (0, import_utils.getArgs)();
|
|
88
|
+
const positional = args._ || [];
|
|
89
|
+
if (args.help || args.h) {
|
|
90
|
+
showHelp();
|
|
91
|
+
}
|
|
92
|
+
if (args["staged-only"] || args.s || args.S) {
|
|
93
|
+
runGitDiff(
|
|
94
|
+
"git --no-pager diff --staged",
|
|
95
|
+
`Full staged diff saved to "${DIFF_OUTPUT_RELATIVE}"`,
|
|
96
|
+
"Failed to save staged diff"
|
|
97
|
+
);
|
|
98
|
+
} else {
|
|
99
|
+
const file = positional[0];
|
|
100
|
+
if (!file) {
|
|
101
|
+
runGitDiff(
|
|
102
|
+
"git --no-pager diff",
|
|
103
|
+
`Full staged diff saved to "${DIFF_OUTPUT_RELATIVE}"`,
|
|
104
|
+
"Failed to save all diff's"
|
|
105
|
+
);
|
|
106
|
+
} else {
|
|
107
|
+
runGitDiff(
|
|
108
|
+
`git --no-pager diff --cached -- "${file}"`,
|
|
109
|
+
`Staged diff of "${file}" saved to "${DIFF_OUTPUT_RELATIVE}"`,
|
|
110
|
+
`Failed to generate diff for "${file}"`
|
|
111
|
+
);
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
if (args.ai) {
|
|
115
|
+
try {
|
|
116
|
+
await runChatGpt({ headless: true, questionFile: GPT_DIFF_OUTPUT });
|
|
117
|
+
} catch (error) {
|
|
118
|
+
console.error("\u274C Error running ChatGPT:", error.message);
|
|
119
|
+
console.error("\u{1F4A1} Try running with visible browser mode or check if Chrome is installed");
|
|
120
|
+
}
|
|
121
|
+
} else {
|
|
122
|
+
console.log("\u{1F4A1} Tip: Use --ai flag to generate commit message with ChatGPT");
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
var git_diff_default = runGitDiff;
|
|
126
|
+
|
|
127
|
+
export {
|
|
128
|
+
DIFF_OUTPUT,
|
|
129
|
+
GPT_DIFF_OUTPUT,
|
|
130
|
+
CACHE_DIR,
|
|
131
|
+
DIFF_OUTPUT_RELATIVE,
|
|
132
|
+
GPT_DIFF_OUTPUT_RELATIVE,
|
|
133
|
+
runGitDiff,
|
|
134
|
+
mainGitDiff,
|
|
135
|
+
git_diff_default
|
|
136
|
+
};
|
|
@@ -3,15 +3,16 @@ import {
|
|
|
3
3
|
__commonJS,
|
|
4
4
|
__require,
|
|
5
5
|
init_esm_shims
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
7
7
|
|
|
8
|
-
// src/binary-collections-config.
|
|
8
|
+
// src/binary-collections-config.cjs
|
|
9
9
|
var require_binary_collections_config = __commonJS({
|
|
10
|
-
"src/binary-collections-config.
|
|
10
|
+
"src/binary-collections-config.cjs"(exports, module) {
|
|
11
11
|
init_esm_shims();
|
|
12
12
|
var path = __require("path");
|
|
13
|
+
__require("dotenv").config({ path: path.join(process.cwd(), ".env") });
|
|
13
14
|
function getTempDir() {
|
|
14
|
-
return process.env.TEMP_DIR || "tmp";
|
|
15
|
+
return process.env.TEMP_DIR || path.join(process.cwd(), "tmp");
|
|
15
16
|
}
|
|
16
17
|
function getTempPath(...segments) {
|
|
17
18
|
return path.join(getTempDir(), ...segments);
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
__commonJS,
|
|
4
|
+
__require,
|
|
5
|
+
init_esm_shims
|
|
6
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
7
|
+
|
|
8
|
+
// src/submodule-remove.cjs
|
|
9
|
+
var require_submodule_remove = __commonJS({
|
|
10
|
+
"src/submodule-remove.cjs"(exports, module) {
|
|
11
|
+
init_esm_shims();
|
|
12
|
+
var { spawnAsync } = __require("cross-spawn");
|
|
13
|
+
var path = __require("upath");
|
|
14
|
+
var fs = __require("fs-extra");
|
|
15
|
+
var dotenv = __require("dotenv");
|
|
16
|
+
dotenv.config({ path: path.resolve(process.cwd(), ".env") });
|
|
17
|
+
async function removeSubmodule(submodulePath) {
|
|
18
|
+
try {
|
|
19
|
+
await spawnAsync("git", ["submodule", "deinit", "-f", submodulePath], { stdio: "inherit" });
|
|
20
|
+
} catch (error) {
|
|
21
|
+
console.warn(`Warning: Could not deinitialize submodule "${submodulePath}". It may not exist.`);
|
|
22
|
+
console.warn(error.message);
|
|
23
|
+
}
|
|
24
|
+
try {
|
|
25
|
+
await spawnAsync("git", ["config", "--remove-section", `submodule.${submodulePath}`], { stdio: "inherit" });
|
|
26
|
+
} catch (error) {
|
|
27
|
+
console.warn(`Warning: Could not remove git config section for submodule "${submodulePath}". It may not exist.`);
|
|
28
|
+
console.warn(error.message);
|
|
29
|
+
}
|
|
30
|
+
const gitModulesPath = path.resolve(".git", "modules", submodulePath);
|
|
31
|
+
if (fs.existsSync(gitModulesPath)) {
|
|
32
|
+
fs.rmSync(gitModulesPath, { recursive: true, force: true });
|
|
33
|
+
console.log(`Removed .git/modules entry for submodule "${submodulePath}".`);
|
|
34
|
+
} else {
|
|
35
|
+
console.warn(`Warning: The path "${gitModulesPath}" does not exist. Skipping removal of .git/modules entry.`);
|
|
36
|
+
}
|
|
37
|
+
const gitmodulesPath = path.resolve(".gitmodules");
|
|
38
|
+
if (fs.existsSync(gitmodulesPath)) {
|
|
39
|
+
let gitmodulesContent = fs.readFileSync(gitmodulesPath, "utf-8");
|
|
40
|
+
const submoduleSectionRegex = new RegExp(
|
|
41
|
+
`\\[submodule "${submodulePath.replace(/[-/\\^$*+?.()|[\]{}]/g, "\\$&")}"]([\\s\\S]*?)(?=\\[|$)`,
|
|
42
|
+
"g"
|
|
43
|
+
);
|
|
44
|
+
gitmodulesContent = gitmodulesContent.replace(submoduleSectionRegex, "").trim();
|
|
45
|
+
fs.writeFileSync(gitmodulesPath, gitmodulesContent);
|
|
46
|
+
console.log(`Removed submodule "${submodulePath}" from .gitmodules.`);
|
|
47
|
+
} else {
|
|
48
|
+
console.warn(`Warning: The .gitmodules file does not exist. Skipping removal of submodule "${submodulePath}".`);
|
|
49
|
+
}
|
|
50
|
+
fs.rmSync(path.resolve(submodulePath), { recursive: true, force: true });
|
|
51
|
+
console.log(`Submodule "${submodulePath}" has been removed.`);
|
|
52
|
+
}
|
|
53
|
+
module.exports = removeSubmodule;
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
export {
|
|
58
|
+
require_submodule_remove
|
|
59
|
+
};
|