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.
Files changed (250) hide show
  1. package/binaries/binary-executor.cjs +43 -0
  2. package/{bin → binaries}/clean-nodemodule +0 -0
  3. package/binaries/clean-nodemodule.cjs +43 -0
  4. package/binaries/clean-nodemodule.cmd +4 -0
  5. package/{bin → binaries}/clean-nodemodules +0 -0
  6. package/binaries/clean-nodemodules.cjs +43 -0
  7. package/binaries/clean-nodemodules.cmd +5 -0
  8. package/{bin → binaries}/dev +0 -0
  9. package/binaries/dev.cjs +43 -0
  10. package/{bin → binaries}/empty +0 -0
  11. package/binaries/empty.cjs +43 -0
  12. package/{bin → binaries}/git-reduce-size +0 -0
  13. package/binaries/git-reduce-size.cjs +43 -0
  14. package/binaries/javakill.cjs +43 -0
  15. package/{bin → binaries}/javakill.cmd +0 -0
  16. package/{bin → binaries}/kill-process +0 -0
  17. package/binaries/kill-process.cjs +43 -0
  18. package/binaries/nodekill.cjs +43 -0
  19. package/{bin → binaries}/nodekill.ps1 +0 -0
  20. package/{bin → binaries}/prod +0 -0
  21. package/binaries/prod.cjs +43 -0
  22. package/{bin → binaries}/rmfind +0 -0
  23. package/binaries/rmfind.cjs +43 -0
  24. package/{bin → binaries}/rmx +0 -0
  25. package/binaries/rmx.cjs +43 -0
  26. package/{bin → binaries}/submodule-token +0 -0
  27. package/binaries/submodule-token.cjs +43 -0
  28. package/docs-src/clean-github-actions-caches.md +26 -0
  29. package/docs-src/free-chatgpt.md +26 -0
  30. package/lib/binary-collections-config.cjs +3 -2
  31. package/lib/binary-collections-config.mjs +2 -2
  32. package/lib/binary-collections.cjs +452 -87
  33. package/lib/binary-collections.mjs +247 -8
  34. package/lib/changelog.cjs +328 -0
  35. package/lib/changelog.mjs +205 -0
  36. package/lib/chunk-4EWQC6GZ.mjs +382 -0
  37. package/lib/chunk-4ZI7BQKQ.mjs +381 -0
  38. package/lib/chunk-5J2BEPY5.mjs +83 -0
  39. package/lib/{chunk-4BYBVEYC.mjs → chunk-66PAU5PS.mjs} +5 -4
  40. package/lib/chunk-6HHJRKFB.mjs +59 -0
  41. package/lib/chunk-6S4NXESK.mjs +26 -0
  42. package/lib/{chunk-ZYAQRPUL.mjs → chunk-7YD7IPFF.mjs} +2 -2
  43. package/lib/{chunk-SH3L6HHV.mjs → chunk-A2JQXI5Z.mjs} +2 -2
  44. package/lib/{chunk-EGSSKVDH.mjs → chunk-A3VUZEJK.mjs} +1 -1
  45. package/lib/chunk-AGZYRDC2.mjs +323 -0
  46. package/lib/{chunk-VVEZVNIV.mjs → chunk-AI4CVPJ7.mjs} +6 -6
  47. package/lib/chunk-BDCHCWHD.mjs +136 -0
  48. package/lib/chunk-BEZKJ25G.mjs +140 -0
  49. package/lib/chunk-DI5MDPSN.mjs +386 -0
  50. package/lib/{chunk-ONIBBBQ3.mjs → chunk-E6FDDAOO.mjs} +4 -3
  51. package/lib/chunk-FKI7IEB5.mjs +172 -0
  52. package/lib/chunk-GJTGHXRA.mjs +356 -0
  53. package/lib/{chunk-YV7DO3YV.mjs → chunk-HLGOWBEO.mjs} +1 -1
  54. package/lib/chunk-HMRMTYZM.mjs +40 -0
  55. package/lib/chunk-HN52G2YL.mjs +305 -0
  56. package/lib/chunk-HO6GHCOB.mjs +385 -0
  57. package/lib/chunk-LEM5OMRP.mjs +384 -0
  58. package/lib/{chunk-YX5U7XDR.mjs → chunk-M3YIYRHT.mjs} +6 -5
  59. package/lib/chunk-O6SWBEOQ.mjs +81 -0
  60. package/lib/{chunk-JGR2NW6D.mjs → chunk-PDSXF5HY.mjs} +3 -3
  61. package/lib/{chunk-AASHBCRW.mjs → chunk-QQ4A6DLD.mjs} +8 -0
  62. package/lib/chunk-RCP7DHVY.mjs +190 -0
  63. package/lib/chunk-SBNDSKG5.mjs +136 -0
  64. package/lib/chunk-U6SO4QEV.mjs +320 -0
  65. package/lib/{chunk-APBWENF6.mjs → chunk-V3N3JEUF.mjs} +3 -3
  66. package/lib/chunk-XD6BJK6Q.mjs +351 -0
  67. package/lib/chunk-XVBFFVCJ.mjs +209 -0
  68. package/lib/chunk-YXSFGA2D.mjs +383 -0
  69. package/lib/clean-github-actions-caches.cjs +243 -148
  70. package/lib/clean-github-actions-caches.mjs +4 -3
  71. package/lib/del-gradle.cjs +2 -2
  72. package/lib/del-gradle.js +1 -1
  73. package/lib/del-gradle.mjs +2 -2
  74. package/lib/del-node-modules.cjs +2 -2
  75. package/lib/del-node-modules.js +1 -1
  76. package/lib/del-node-modules.mjs +2 -2
  77. package/lib/del-ps.cjs +29 -8
  78. package/lib/del-ps.js +2 -2
  79. package/lib/del-ps.mjs +7 -5
  80. package/lib/del-yarn-caches.cjs +26 -5
  81. package/lib/del-yarn-caches.js +38 -3
  82. package/lib/del-yarn-caches.mjs +6 -6
  83. package/lib/find-node-modules-cli.cjs +5 -4
  84. package/lib/find-node-modules-cli.js +1 -1
  85. package/lib/find-node-modules-cli.mjs +2 -2
  86. package/lib/find-node-modules.cjs +4 -3
  87. package/lib/{find-node-modules.d.ts → find-node-modules.d.cts} +1 -1
  88. package/lib/find-node-modules.mjs +2 -2
  89. package/lib/free-chatgpt.cjs +548 -0
  90. package/lib/free-chatgpt.d.ts +1 -0
  91. package/lib/free-chatgpt.js +51 -0
  92. package/lib/free-chatgpt.mjs +50 -0
  93. package/lib/git/gitattributes.cjs +1 -1
  94. package/lib/git/{gitattributes.d.mts → gitattributes.d.cts} +5 -7
  95. package/lib/git/gitattributes.mjs +2 -2
  96. package/lib/git/line-endings.cjs +297 -64
  97. package/lib/git/line-endings.mjs +4 -4
  98. package/lib/git/normalize.cjs +26 -36
  99. package/lib/git/normalize.mjs +2 -2
  100. package/lib/git/permissions.cjs +77 -11
  101. package/lib/git/permissions.mjs +3 -3
  102. package/lib/git/pull-strategy.cjs +76 -9
  103. package/lib/git/pull-strategy.mjs +3 -3
  104. package/lib/git/user-config.cjs +266 -83
  105. package/lib/git/user-config.mjs +4 -4
  106. package/lib/git/utils.cjs +40 -60
  107. package/lib/git/utils.mjs +2 -2
  108. package/lib/git-diff-cli.cjs +651 -0
  109. package/lib/git-diff-cli.d.ts +1 -0
  110. package/lib/git-diff-cli.js +15 -0
  111. package/lib/git-diff-cli.mjs +16 -0
  112. package/lib/git-diff.cjs +657 -58
  113. package/lib/git-diff.d.ts +38 -83
  114. package/lib/git-diff.js +152 -0
  115. package/lib/git-diff.mjs +23 -85
  116. package/lib/git-fix.cjs +685 -97
  117. package/lib/git-fix.mjs +12 -11
  118. package/lib/git-purge.cjs +3 -3
  119. package/lib/git-purge.d.cts +1 -0
  120. package/lib/git-purge.mjs +43 -37
  121. package/lib/index.cjs +7 -6
  122. package/lib/index.d.ts +1 -1
  123. package/lib/index.js +2 -5
  124. package/lib/index.mjs +4 -4
  125. package/lib/npm-run-series.cjs +3 -3
  126. package/lib/npm-run-series.mjs +42 -36
  127. package/lib/package-resolutions-updater.cjs +174 -1
  128. package/lib/package-resolutions-updater.mjs +270 -290
  129. package/lib/print-directory-tree.cjs +275 -210
  130. package/lib/print-directory-tree.mjs +2 -2
  131. package/lib/ps/connected-domain.cjs +25 -2
  132. package/lib/ps/connected-domain.d.ts +10 -2
  133. package/lib/ps/connected-domain.js +5 -2
  134. package/lib/ps/connected-domain.mjs +8 -4
  135. package/lib/ps/index.cjs +345 -322
  136. package/lib/ps/index.d.mjs +1 -1
  137. package/lib/ps/index.js +1 -1
  138. package/lib/ps/index.mjs +179 -182
  139. package/lib/ps/isWin.cjs +24 -1
  140. package/lib/ps/isWin.d.ts +1 -1
  141. package/lib/ps/isWin.js +3 -1
  142. package/lib/ps/isWin.mjs +8 -4
  143. package/lib/ps/table-parser.cjs +167 -159
  144. package/lib/ps/table-parser.d.ts +5 -0
  145. package/lib/ps/table-parser.js +10 -4
  146. package/lib/ps/table-parser.mjs +9 -5
  147. package/lib/remove-module.cjs +262 -0
  148. package/lib/remove-module.d.mts +1 -0
  149. package/lib/remove-module.mjs +111 -0
  150. package/lib/rmpath.cjs +274 -0
  151. package/lib/rmpath.d.mts +3 -0
  152. package/lib/rmpath.mjs +108 -0
  153. package/lib/submodule-install.cjs +264 -85
  154. package/lib/submodule-install.mjs +56 -7
  155. package/lib/submodule-remove-cli.cjs +103 -0
  156. package/lib/submodule-remove-cli.d.ts +1 -0
  157. package/lib/submodule-remove-cli.js +31 -0
  158. package/lib/submodule-remove-cli.mjs +28 -0
  159. package/lib/submodule-remove.cjs +43 -0
  160. package/lib/submodule-remove.d.cts +2 -0
  161. package/lib/submodule-remove.mjs +6 -0
  162. package/lib/utils/chatgpt.cjs +383 -0
  163. package/lib/utils/chatgpt.d.ts +31 -0
  164. package/lib/utils/chatgpt.js +541 -0
  165. package/lib/utils/chatgpt.mjs +8 -0
  166. package/lib/{utils.cjs → utils/index.cjs} +1 -1
  167. package/lib/{utils.mjs → utils/index.mjs} +2 -2
  168. package/lib/yarn-reinstall.cjs +172 -38
  169. package/lib/yarn-reinstall.mjs +2 -2
  170. package/package.json +91 -71
  171. package/readme.md +43 -69
  172. package/releases/readme.md +36 -0
  173. package/test/README.md +101 -0
  174. package/test/package.json +2 -1
  175. package/test-project/readme.md +26 -0
  176. package/tmp/test-repo/README.md +35 -0
  177. package/tmp/typedoc/readme.md +320 -0
  178. package/bin/bash-dummy +0 -56
  179. package/bin/bash-dummy.cmd +0 -25
  180. package/bin/dir-tree.cmd +0 -7
  181. package/bin/git-diff +0 -4
  182. package/bin/git-diff.cmd +0 -7
  183. package/bin/git-fix +0 -36
  184. package/bin/git-fix.cmd +0 -7
  185. package/bin/rmpath +0 -70
  186. package/bin/submodule-install.txt +0 -118
  187. package/bin/submodule-remove +0 -46
  188. package/bin/submodule.txt +0 -172
  189. package/lib/binary-collections-config.d.mts +0 -18
  190. package/lib/binary-collections-config.js +0 -39
  191. package/lib/binary-collections.d.mts +0 -121
  192. package/lib/binary-collections.d.ts +0 -121
  193. package/lib/chunk-DPKAJKFO.mjs +0 -171
  194. package/lib/chunk-G3THLIDT.mjs +0 -200
  195. package/lib/chunk-W3ENOM53.mjs +0 -18
  196. package/lib/clean-github-actions-caches.d.mts +0 -169
  197. package/lib/clean-github-actions-caches.d.ts +0 -169
  198. package/lib/del-gradle.d.mts +0 -2
  199. package/lib/del-node-modules.d.mts +0 -2
  200. package/lib/del-ps.d.mts +0 -2
  201. package/lib/del-yarn-caches.d.mts +0 -2
  202. package/lib/find-node-modules-cli.d.mts +0 -1
  203. package/lib/find-node-modules.d.mts +0 -13
  204. package/lib/find-node-modules.js +0 -53
  205. package/lib/git/line-endings.d.mts +0 -83
  206. package/lib/git/line-endings.d.ts +0 -83
  207. package/lib/git/normalize.d.mts +0 -43
  208. package/lib/git/normalize.d.ts +0 -43
  209. package/lib/git/permissions.d.mts +0 -17
  210. package/lib/git/permissions.d.ts +0 -17
  211. package/lib/git/pull-strategy.d.mts +0 -15
  212. package/lib/git/pull-strategy.d.ts +0 -15
  213. package/lib/git/user-config.d.mts +0 -105
  214. package/lib/git/user-config.d.ts +0 -105
  215. package/lib/git/utils.d.mts +0 -69
  216. package/lib/git/utils.d.ts +0 -69
  217. package/lib/git-diff.d.mts +0 -84
  218. package/lib/git-fix.d.mts +0 -141
  219. package/lib/git-fix.d.ts +0 -141
  220. package/lib/git-purge.d.mts +0 -2
  221. package/lib/git-purge.js +0 -59
  222. package/lib/index.d.mts +0 -1
  223. package/lib/npm-run-series.d.mts +0 -1
  224. package/lib/npm-run-series.d.ts +0 -2
  225. package/lib/npm-run-series.js +0 -86
  226. package/lib/package-resolutions-updater.d.ts +0 -326
  227. package/lib/print-directory-tree.d.mts +0 -234
  228. package/lib/print-directory-tree.d.ts +0 -234
  229. package/lib/ps/connected-domain.d.mts +0 -3
  230. package/lib/ps/index.d.d.mts +0 -26
  231. package/lib/ps/index.d.d.ts +0 -26
  232. package/lib/ps/index.d.mts +0 -26
  233. package/lib/ps/isWin.d.mts +0 -3
  234. package/lib/ps/table-parser.d.mts +0 -3
  235. package/lib/submodule-install.d.mts +0 -121
  236. package/lib/submodule-install.d.ts +0 -121
  237. package/lib/utils.d.mts +0 -40
  238. package/lib/utils.js +0 -181
  239. package/lib/yarn-reinstall.d.mts +0 -49
  240. package/lib/yarn-reinstall.d.ts +0 -49
  241. package/src/package-resolutions-updater.mjs +0 -325
  242. package/src/print-directory-tree.cjs +0 -234
  243. package/src/ps/index.js +0 -286
  244. package/src/yarn-reinstall.cjs +0 -49
  245. /package/{bin → binaries}/nodekill +0 -0
  246. /package/{bin → binaries}/nodekill.cmd +0 -0
  247. /package/lib/{binary-collections-config.d.ts → binary-collections-config.d.cts} +0 -0
  248. /package/lib/{git-purge.d.ts → changelog.d.cts} +0 -0
  249. /package/lib/{git-diff.d.cts → npm-run-series.d.cts} +0 -0
  250. /package/lib/{utils.d.ts → utils/index.d.cts} +0 -0
@@ -1,13 +1,80 @@
1
- "use strict";
2
- const { runGitCommand } = require("./utils.cjs");
3
- /**
4
- * Set git pull strategy to disable automatic rebase
5
- * - Sets pull.rebase = false
6
- */
1
+ var __getOwnPropNames = Object.getOwnPropertyNames;
2
+ var __esm = (fn, res) => function __init() {
3
+ return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
4
+ };
5
+ var __commonJS = (cb, mod) => function __require() {
6
+ return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
7
+ };
8
+
9
+ // node_modules/tsup/assets/cjs_shims.js
10
+ var init_cjs_shims = __esm({
11
+ "node_modules/tsup/assets/cjs_shims.js"() {
12
+ }
13
+ });
14
+
15
+ // src/git/utils.cjs
16
+ var require_utils = __commonJS({
17
+ "src/git/utils.cjs"(exports2, module2) {
18
+ init_cjs_shims();
19
+ var { execSync, spawnSync } = require("child_process");
20
+ function runGitCommand2(args, description) {
21
+ try {
22
+ console.log(`[i] ${description}`);
23
+ const result = spawnSync("git", args, { encoding: "utf-8" });
24
+ if (result.status !== 0) {
25
+ console.error(`[\u2717] Failed: ${description}`);
26
+ console.error(`Error: ${result.stderr || result.stdout}`);
27
+ return false;
28
+ }
29
+ console.log(`[\u2713] ${description}`);
30
+ return true;
31
+ } catch (error) {
32
+ console.error(`[\u2717] Failed: ${description}`);
33
+ console.error(`Error: ${error.message}`);
34
+ return false;
35
+ }
36
+ }
37
+ function isGitRepository(cwd) {
38
+ const dir = typeof cwd === "string" ? cwd : process.cwd();
39
+ try {
40
+ execSync("git rev-parse --git-dir", { stdio: "pipe", cwd: dir });
41
+ return true;
42
+ } catch {
43
+ return false;
44
+ }
45
+ }
46
+ function runGitCommandOutput(args, description) {
47
+ try {
48
+ console.log(`[i] ${description}`);
49
+ const result = spawnSync("git", args, { encoding: "utf-8" });
50
+ if (result.status !== 0) {
51
+ console.error(`[\u2717] Failed: ${description}`);
52
+ console.error(`Error: ${result.stderr || result.stdout}`);
53
+ return null;
54
+ }
55
+ console.log(`[\u2713] ${description}`);
56
+ return result.stdout.trim();
57
+ } catch (error) {
58
+ console.error(`[\u2717] Failed: ${description}`);
59
+ console.error(`Error: ${error.message}`);
60
+ return null;
61
+ }
62
+ }
63
+ module2.exports = {
64
+ runGitCommand: runGitCommand2,
65
+ runGitCommandOutput,
66
+ isGitRepository
67
+ };
68
+ }
69
+ });
70
+
71
+ // src/git/pull-strategy.cjs
72
+ init_cjs_shims();
73
+ var { runGitCommand } = require_utils();
7
74
  function setPullStrategy() {
8
- console.log("\n=== Configuring Pull Strategy ===");
9
- runGitCommand(["config", "pull.rebase", "false"], "Disable automatic rebase on pull");
75
+ console.log("\n=== Configuring Pull Strategy ===");
76
+ runGitCommand(["config", "pull.rebase", "false"], "Disable automatic rebase on pull");
10
77
  }
11
78
  module.exports = {
12
- setPullStrategy
79
+ setPullStrategy
13
80
  };
@@ -1,7 +1,7 @@
1
1
  import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
2
  import {
3
3
  require_pull_strategy
4
- } from "../chunk-SH3L6HHV.mjs";
5
- import "../chunk-EGSSKVDH.mjs";
6
- import "../chunk-AASHBCRW.mjs";
4
+ } from "../chunk-A2JQXI5Z.mjs";
5
+ import "../chunk-A3VUZEJK.mjs";
6
+ import "../chunk-QQ4A6DLD.mjs";
7
7
  export default require_pull_strategy();
@@ -1,100 +1,283 @@
1
- "use strict";
2
- const gch = require("git-command-helper");
3
- const { runGitCommand, runGitCommandOutput } = require("./utils.cjs");
4
- const { getArgs } = require("../utils.js");
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
- // Determine user and email with CLI args taking precedence
15
- let username, email;
16
- if (cliUser && cliEmail) {
17
- username = cliUser.trim();
18
- email = cliEmail.trim();
19
- console.log("[i] Using CLI-provided user configuration");
20
- }
21
- else {
22
- username = process.env.GITHUB_USER ? process.env.GITHUB_USER.trim() : undefined;
23
- email = process.env.GITHUB_EMAIL ? process.env.GITHUB_EMAIL.trim() : undefined;
24
- if (username || email) {
25
- console.log("[i] Using environment variable user configuration");
1
+ var __getOwnPropNames = Object.getOwnPropertyNames;
2
+ var __esm = (fn, res) => function __init() {
3
+ return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
4
+ };
5
+ var __commonJS = (cb, mod) => function __require() {
6
+ return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
7
+ };
8
+
9
+ // node_modules/tsup/assets/cjs_shims.js
10
+ var init_cjs_shims = __esm({
11
+ "node_modules/tsup/assets/cjs_shims.js"() {
12
+ }
13
+ });
14
+
15
+ // src/git/utils.cjs
16
+ var require_utils = __commonJS({
17
+ "src/git/utils.cjs"(exports2, module2) {
18
+ init_cjs_shims();
19
+ var { execSync, spawnSync } = require("child_process");
20
+ function runGitCommand2(args, description) {
21
+ try {
22
+ console.log(`[i] ${description}`);
23
+ const result = spawnSync("git", args, { encoding: "utf-8" });
24
+ if (result.status !== 0) {
25
+ console.error(`[\u2717] Failed: ${description}`);
26
+ console.error(`Error: ${result.stderr || result.stdout}`);
27
+ return false;
26
28
  }
29
+ console.log(`[\u2713] ${description}`);
30
+ return true;
31
+ } catch (error) {
32
+ console.error(`[\u2717] Failed: ${description}`);
33
+ console.error(`Error: ${error.message}`);
34
+ return false;
35
+ }
27
36
  }
28
- if (!username && !email) {
29
- console.log("[i] No Git user configuration needed (no CLI args or environment variables set)");
30
- return;
37
+ function isGitRepository(cwd) {
38
+ const dir = typeof cwd === "string" ? cwd : process.cwd();
39
+ try {
40
+ execSync("git rev-parse --git-dir", { stdio: "pipe", cwd: dir });
41
+ return true;
42
+ } catch {
43
+ return false;
44
+ }
31
45
  }
32
- if (username) {
33
- const success = runGitCommand(["config", "user.name", username], `Set Git username to "${username}"`);
34
- if (!success) {
35
- console.log("[i] Failed to set Git username, but continuing...");
46
+ function runGitCommandOutput2(args, description) {
47
+ try {
48
+ console.log(`[i] ${description}`);
49
+ const result = spawnSync("git", args, { encoding: "utf-8" });
50
+ if (result.status !== 0) {
51
+ console.error(`[\u2717] Failed: ${description}`);
52
+ console.error(`Error: ${result.stderr || result.stdout}`);
53
+ return null;
36
54
  }
55
+ console.log(`[\u2713] ${description}`);
56
+ return result.stdout.trim();
57
+ } catch (error) {
58
+ console.error(`[\u2717] Failed: ${description}`);
59
+ console.error(`Error: ${error.message}`);
60
+ return null;
61
+ }
37
62
  }
38
- else {
39
- console.log("[i] No username provided, skipping username configuration");
63
+ module2.exports = {
64
+ runGitCommand: runGitCommand2,
65
+ runGitCommandOutput: runGitCommandOutput2,
66
+ isGitRepository
67
+ };
68
+ }
69
+ });
70
+
71
+ // src/utils/index.cjs
72
+ var require_utils2 = __commonJS({
73
+ "src/utils/index.cjs"(exports2, module2) {
74
+ init_cjs_shims();
75
+ var fs = require("fs");
76
+ var path = require("upath");
77
+ var argv = require("minimist")(process.argv.slice(2));
78
+ var { exec } = require("child_process");
79
+ var { URL: URL2 } = require("url");
80
+ var { promisify } = require("util");
81
+ var execAsync = promisify(exec);
82
+ async function parseGitRemotes() {
83
+ try {
84
+ const { stdout } = await execAsync("git remote -v");
85
+ const lines = stdout.split("\n");
86
+ const remotes = {};
87
+ lines.forEach((line) => {
88
+ const [name, url] = line.split(" ");
89
+ if (name && url) {
90
+ const [repoUrl] = url.split(" ");
91
+ try {
92
+ const parsedUrl = new URL2(repoUrl);
93
+ const pathParts = parsedUrl.pathname.split("/").filter(Boolean);
94
+ if (parsedUrl.hostname === "github.com" && pathParts.length === 2) {
95
+ let repoPath = pathParts.join("/");
96
+ if (repoPath.endsWith(".git")) {
97
+ repoPath = repoPath.slice(0, -4);
98
+ }
99
+ remotes[name] = repoPath;
100
+ }
101
+ } catch (e) {
102
+ console.error("URL Parsing Error:", e.message);
103
+ }
104
+ }
105
+ });
106
+ return remotes;
107
+ } catch (error) {
108
+ console.error("Error:", error.message);
109
+ return {};
110
+ }
111
+ }
112
+ module2.exports.parseGitRemotes = parseGitRemotes;
113
+ function joinPathPreserveDriveLetter(...segments) {
114
+ let fullPath = require("path").join(...segments);
115
+ if (/^[a-z]:\\/.test(fullPath)) {
116
+ fullPath = fullPath.charAt(0).toUpperCase() + fullPath.slice(1);
117
+ }
118
+ return fullPath;
40
119
  }
41
- if (email) {
42
- const success = runGitCommand(["config", "user.email", email], `Set Git email to "${email}"`);
43
- if (!success) {
44
- console.log("[i] Failed to set Git email, but continuing...");
120
+ module2.exports.joinPathPreserveDriveLetter = joinPathPreserveDriveLetter;
121
+ function getArgs2() {
122
+ return argv;
123
+ }
124
+ module2.exports.getArgs = getArgs2;
125
+ function del(fullPath) {
126
+ if (fs.statSync(fullPath).isDirectory()) {
127
+ const subdir = fs.readdirSync(fullPath).map((dirPath) => path.resolve(fullPath, dirPath));
128
+ for (let i = 0; i < subdir.length; i++) {
129
+ del(subdir[i]);
130
+ }
131
+ } else {
132
+ try {
133
+ fs.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7e3 });
134
+ console.log("deleted", fullPath);
135
+ } catch (_) {
136
+ console.log("failed delete", fullPath);
45
137
  }
138
+ }
46
139
  }
47
- else {
48
- console.log("[i] No email provided, skipping email configuration");
140
+ module2.exports.del = del;
141
+ function delStream(globStream) {
142
+ globStream.stream().on("data", (result) => {
143
+ const fullPath = path.resolve(process.cwd(), result);
144
+ if (fs.statSync(fullPath).isDirectory()) {
145
+ const subdir = fs.readdirSync(fullPath).map((dirPath) => path.resolve(fullPath, dirPath));
146
+ for (let i = 0; i < subdir.length; i++) {
147
+ del(subdir[i]);
148
+ }
149
+ }
150
+ del(fullPath);
151
+ });
152
+ }
153
+ module2.exports.delStream = delStream;
154
+ function getFileTreeString(hashArray) {
155
+ const tree = {};
156
+ const hashMap = {};
157
+ for (const entry of hashArray) {
158
+ const [filePath, hash] = entry.split(" ");
159
+ hashMap[filePath] = hash;
160
+ const parts = filePath.split("/");
161
+ let current = tree;
162
+ for (let i = 0; i < parts.length; i++) {
163
+ const part = parts[i];
164
+ if (i === parts.length - 1) {
165
+ current[part] = null;
166
+ } else {
167
+ current[part] = current[part] || {};
168
+ current = current[part];
169
+ }
170
+ }
171
+ }
172
+ function printNode(node, prefix = "", parentPath = "") {
173
+ const keys = Object.keys(node).sort();
174
+ let lines = [];
175
+ keys.forEach((key, idx) => {
176
+ const isLast = idx === keys.length - 1;
177
+ const branch = isLast ? "\u2514\u2500\u2500 " : "\u251C\u2500\u2500 ";
178
+ const currentPath = parentPath ? parentPath + "/" + key : key;
179
+ if (node[key] === null) {
180
+ lines.push(prefix + branch + key + " [" + (hashMap[currentPath] || "") + "]");
181
+ } else {
182
+ lines.push(prefix + branch + key + "/");
183
+ lines = lines.concat(printNode(node[key], prefix + (isLast ? " " : "\u2502 "), currentPath));
184
+ }
185
+ });
186
+ return lines;
187
+ }
188
+ return printNode(tree, "", "").join("\n");
49
189
  }
190
+ module2.exports.getFileTreeString = getFileTreeString;
191
+ var delay = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
192
+ module2.exports.delay = delay;
193
+ }
194
+ });
195
+
196
+ // src/git/user-config.cjs
197
+ init_cjs_shims();
198
+ var gch = require("git-command-helper");
199
+ var { runGitCommand, runGitCommandOutput } = require_utils();
200
+ var { getArgs } = require_utils2();
201
+ require("dotenv").config({ path: require("path").join(process.cwd(), ".env") });
202
+ function configureGitUser(cliUser = null, cliEmail = null, options = {}) {
203
+ console.log("\n=== Configuring Git User ===");
204
+ let username, email;
205
+ if (cliUser && cliEmail) {
206
+ username = cliUser.trim();
207
+ email = cliEmail.trim();
208
+ console.log("[i] Using CLI-provided user configuration");
209
+ } else {
210
+ username = process.env.GITHUB_USER ? process.env.GITHUB_USER.trim() : void 0;
211
+ email = process.env.GITHUB_EMAIL ? process.env.GITHUB_EMAIL.trim() : void 0;
50
212
  if (username || email) {
51
- console.log("[] Git user configuration completed");
213
+ console.log("[i] Using environment variable user configuration");
52
214
  }
53
- if (username) {
54
- // Ask user to modify the origin remote URL if it doesn't match the username
55
- const remoteUrl = runGitCommandOutput(["remote", "get-url", "origin"], "Fetching remote URL for verification");
56
- if (remoteUrl) {
57
- console.log(`[i] Remote URL: ${remoteUrl}`);
58
- const parsedUrl = gch.parseGitHubUrl(remoteUrl);
59
- if (parsedUrl && parsedUrl.owner && username && parsedUrl.owner.toLowerCase() !== username.toLowerCase()) {
60
- console.warn(`\n[!] The GitHub remote owner ("${parsedUrl.owner}") does not match the configured username ("${username}").`);
61
- console.warn(`[!] If this is not intentional, consider updating the remote URL to use your username.`);
62
- console.warn(`[!] Example: git remote set-url origin https://github.com/${username}/<repo>.git\n`);
63
- // Check for --update-remote CLI argument or options.updateRemote
64
- const args = getArgs();
65
- const updateRemote = options.updateRemote || args["update-remote"] === true;
66
- if (updateRemote) {
67
- // Only update the username in the URL, not the repo path
68
- let newUrl = remoteUrl;
69
- // Handle https:// and git@ URLs
70
- if (/^https:\/\//.test(remoteUrl)) {
71
- newUrl = remoteUrl.replace(/https:\/\/(?:[^@]+@)?github.com/, `https://${username}@github.com`);
72
- }
73
- else if (/^git@github.com:/.test(remoteUrl)) {
74
- // For git@github.com:user/repo.git, do not change path, just warn user to use HTTPS with username if needed
75
- console.warn(`[!] For SSH remotes, set your SSH config or use HTTPS with username if you want to change authentication user.`);
76
- return;
77
- }
78
- if (newUrl !== remoteUrl) {
79
- const updated = runGitCommand(["remote", "set-url", "origin", newUrl], `Set origin to ${newUrl}`);
80
- if (updated) {
81
- console.log(`[✓] Remote URL updated to: ${newUrl}`);
82
- }
83
- else {
84
- console.warn(`[!] Failed to update remote URL. Please update it manually if needed.`);
85
- }
86
- }
87
- else {
88
- console.log(`[i] Remote URL does not use HTTPS or already contains the username.`);
89
- }
90
- }
91
- else {
92
- console.log(`[i] Remote URL not changed. Use --update-remote to update automatically.`);
93
- }
215
+ }
216
+ if (!username && !email) {
217
+ console.log("[i] No Git user configuration needed (no CLI args or environment variables set)");
218
+ return;
219
+ }
220
+ if (username) {
221
+ const success = runGitCommand(["config", "user.name", username], `Set Git username to "${username}"`);
222
+ if (!success) {
223
+ console.log("[i] Failed to set Git username, but continuing...");
224
+ }
225
+ } else {
226
+ console.log("[i] No username provided, skipping username configuration");
227
+ }
228
+ if (email) {
229
+ const success = runGitCommand(["config", "user.email", email], `Set Git email to "${email}"`);
230
+ if (!success) {
231
+ console.log("[i] Failed to set Git email, but continuing...");
232
+ }
233
+ } else {
234
+ console.log("[i] No email provided, skipping email configuration");
235
+ }
236
+ if (username || email) {
237
+ console.log("[\u2713] Git user configuration completed");
238
+ }
239
+ if (username) {
240
+ const remoteUrl = runGitCommandOutput(["remote", "get-url", "origin"], "Fetching remote URL for verification");
241
+ if (remoteUrl) {
242
+ console.log(`[i] Remote URL: ${remoteUrl}`);
243
+ const parsedUrl = gch.parseGitHubUrl(remoteUrl);
244
+ if (parsedUrl && parsedUrl.owner && username && parsedUrl.owner.toLowerCase() !== username.toLowerCase()) {
245
+ console.warn(
246
+ `
247
+ [!] The GitHub remote owner ("${parsedUrl.owner}") does not match the configured username ("${username}").`
248
+ );
249
+ console.warn(`[!] If this is not intentional, consider updating the remote URL to use your username.`);
250
+ console.warn(`[!] Example: git remote set-url origin https://github.com/${username}/<repo>.git
251
+ `);
252
+ const args = getArgs();
253
+ const updateRemote = options.updateRemote || args["update-remote"] === true;
254
+ if (updateRemote) {
255
+ let newUrl = remoteUrl;
256
+ if (/^https:\/\//.test(remoteUrl)) {
257
+ newUrl = remoteUrl.replace(/https:\/\/(?:[^@]+@)?github.com/, `https://${username}@github.com`);
258
+ } else if (/^git@github.com:/.test(remoteUrl)) {
259
+ console.warn(
260
+ `[!] For SSH remotes, set your SSH config or use HTTPS with username if you want to change authentication user.`
261
+ );
262
+ return;
263
+ }
264
+ if (newUrl !== remoteUrl) {
265
+ const updated = runGitCommand(["remote", "set-url", "origin", newUrl], `Set origin to ${newUrl}`);
266
+ if (updated) {
267
+ console.log(`[\u2713] Remote URL updated to: ${newUrl}`);
268
+ } else {
269
+ console.warn(`[!] Failed to update remote URL. Please update it manually if needed.`);
94
270
  }
271
+ } else {
272
+ console.log(`[i] Remote URL does not use HTTPS or already contains the username.`);
273
+ }
274
+ } else {
275
+ console.log(`[i] Remote URL not changed. Use --update-remote to update automatically.`);
95
276
  }
277
+ }
96
278
  }
279
+ }
97
280
  }
98
281
  module.exports = {
99
- configureGitUser
282
+ configureGitUser
100
283
  };
@@ -1,8 +1,8 @@
1
1
  import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
2
  import {
3
3
  require_user_config
4
- } from "../chunk-ONIBBBQ3.mjs";
5
- import "../chunk-EGSSKVDH.mjs";
6
- import "../chunk-APBWENF6.mjs";
7
- import "../chunk-AASHBCRW.mjs";
4
+ } from "../chunk-E6FDDAOO.mjs";
5
+ import "../chunk-A3VUZEJK.mjs";
6
+ import "../chunk-V3N3JEUF.mjs";
7
+ import "../chunk-QQ4A6DLD.mjs";
8
8
  export default require_user_config();
package/lib/git/utils.cjs CHANGED
@@ -1,70 +1,50 @@
1
- "use strict";
2
- const { execSync, spawnSync } = require("child_process");
3
- /**
4
- * Execute a git command with proper error handling and logging
5
- * @param {string[]} args - Git command arguments
6
- * @param {string} description - Description of the operation for logging
7
- * @returns {boolean} - True if successful, false otherwise
8
- */
1
+ // src/git/utils.cjs
2
+ var { execSync, spawnSync } = require("child_process");
9
3
  function runGitCommand(args, description) {
10
- try {
11
- console.log(`[i] ${description}`);
12
- const result = spawnSync("git", args, { encoding: "utf-8" });
13
- if (result.status !== 0) {
14
- console.error(`[] Failed: ${description}`);
15
- console.error(`Error: ${result.stderr || result.stdout}`);
16
- return false;
17
- }
18
- console.log(`[✓] ${description}`);
19
- return true;
20
- }
21
- catch (error) {
22
- console.error(`[✗] Failed: ${description}`);
23
- console.error(`Error: ${error.message}`);
24
- return false;
4
+ try {
5
+ console.log(`[i] ${description}`);
6
+ const result = spawnSync("git", args, { encoding: "utf-8" });
7
+ if (result.status !== 0) {
8
+ console.error(`[\u2717] Failed: ${description}`);
9
+ console.error(`Error: ${result.stderr || result.stdout}`);
10
+ return false;
25
11
  }
12
+ console.log(`[\u2713] ${description}`);
13
+ return true;
14
+ } catch (error) {
15
+ console.error(`[\u2717] Failed: ${description}`);
16
+ console.error(`Error: ${error.message}`);
17
+ return false;
18
+ }
26
19
  }
27
- /**
28
- * Check if the given cwd (or current directory) is a git repository
29
- * @param {string} [cwd] - Directory to check (defaults to current directory at call time)
30
- * @returns {boolean} - True if in a git repository, false otherwise
31
- */
32
20
  function isGitRepository(cwd) {
33
- const dir = typeof cwd === "string" ? cwd : process.cwd();
34
- try {
35
- execSync("git rev-parse --git-dir", { stdio: "pipe", cwd: dir });
36
- return true;
37
- }
38
- catch (_a) {
39
- return false;
40
- }
21
+ const dir = typeof cwd === "string" ? cwd : process.cwd();
22
+ try {
23
+ execSync("git rev-parse --git-dir", { stdio: "pipe", cwd: dir });
24
+ return true;
25
+ } catch {
26
+ return false;
27
+ }
41
28
  }
42
- /**
43
- * Execute a git command and return stdout (or null on error)
44
- * @param {string[]} args - Git command arguments
45
- * @param {string} description - Description of the operation for logging
46
- * @returns {string|null} - stdout string if successful, null otherwise
47
- */
48
29
  function runGitCommandOutput(args, description) {
49
- try {
50
- console.log(`[i] ${description}`);
51
- const result = spawnSync("git", args, { encoding: "utf-8" });
52
- if (result.status !== 0) {
53
- console.error(`[] Failed: ${description}`);
54
- console.error(`Error: ${result.stderr || result.stdout}`);
55
- return null;
56
- }
57
- console.log(`[✓] ${description}`);
58
- return result.stdout.trim();
59
- }
60
- catch (error) {
61
- console.error(`[✗] Failed: ${description}`);
62
- console.error(`Error: ${error.message}`);
63
- return null;
30
+ try {
31
+ console.log(`[i] ${description}`);
32
+ const result = spawnSync("git", args, { encoding: "utf-8" });
33
+ if (result.status !== 0) {
34
+ console.error(`[\u2717] Failed: ${description}`);
35
+ console.error(`Error: ${result.stderr || result.stdout}`);
36
+ return null;
64
37
  }
38
+ console.log(`[\u2713] ${description}`);
39
+ return result.stdout.trim();
40
+ } catch (error) {
41
+ console.error(`[\u2717] Failed: ${description}`);
42
+ console.error(`Error: ${error.message}`);
43
+ return null;
44
+ }
65
45
  }
66
46
  module.exports = {
67
- runGitCommand,
68
- runGitCommandOutput,
69
- isGitRepository
47
+ runGitCommand,
48
+ runGitCommandOutput,
49
+ isGitRepository
70
50
  };
package/lib/git/utils.mjs CHANGED
@@ -1,6 +1,6 @@
1
1
  import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
2
  import {
3
3
  require_utils
4
- } from "../chunk-EGSSKVDH.mjs";
5
- import "../chunk-AASHBCRW.mjs";
4
+ } from "../chunk-A3VUZEJK.mjs";
5
+ import "../chunk-QQ4A6DLD.mjs";
6
6
  export default require_utils();