binary-collections 2.0.9 → 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 (253) 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 -105
  33. package/lib/binary-collections.mjs +131 -84
  34. package/lib/changelog.cjs +3 -3
  35. package/lib/changelog.mjs +177 -171
  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 +3 -2
  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.js +51 -0
  91. package/lib/free-chatgpt.mjs +50 -0
  92. package/lib/git/gitattributes.cjs +1 -1
  93. package/lib/git/{gitattributes.d.mts → gitattributes.d.cts} +5 -7
  94. package/lib/git/gitattributes.mjs +2 -2
  95. package/lib/git/line-endings.cjs +297 -64
  96. package/lib/git/line-endings.mjs +4 -4
  97. package/lib/git/normalize.cjs +26 -36
  98. package/lib/git/normalize.mjs +2 -2
  99. package/lib/git/permissions.cjs +77 -11
  100. package/lib/git/permissions.mjs +3 -3
  101. package/lib/git/pull-strategy.cjs +76 -9
  102. package/lib/git/pull-strategy.mjs +3 -3
  103. package/lib/git/user-config.cjs +266 -83
  104. package/lib/git/user-config.mjs +4 -4
  105. package/lib/git/utils.cjs +40 -60
  106. package/lib/git/utils.mjs +2 -2
  107. package/lib/git-diff-cli.cjs +651 -0
  108. package/lib/git-diff-cli.d.ts +1 -0
  109. package/lib/git-diff-cli.js +15 -0
  110. package/lib/git-diff-cli.mjs +16 -0
  111. package/lib/git-diff.cjs +657 -58
  112. package/lib/git-diff.d.ts +38 -83
  113. package/lib/git-diff.js +152 -0
  114. package/lib/git-diff.mjs +23 -85
  115. package/lib/git-fix.cjs +685 -97
  116. package/lib/git-fix.mjs +14 -13
  117. package/lib/git-purge.cjs +3 -3
  118. package/lib/git-purge.d.cts +1 -0
  119. package/lib/git-purge.mjs +43 -37
  120. package/lib/index.cjs +7 -6
  121. package/lib/index.d.ts +1 -1
  122. package/lib/index.js +2 -5
  123. package/lib/index.mjs +4 -4
  124. package/lib/npm-run-series.cjs +3 -3
  125. package/lib/npm-run-series.mjs +42 -36
  126. package/lib/package-resolutions-updater.cjs +5 -5
  127. package/lib/package-resolutions-updater.mjs +266 -309
  128. package/lib/print-directory-tree.cjs +275 -210
  129. package/lib/print-directory-tree.mjs +2 -2
  130. package/lib/ps/connected-domain.cjs +25 -2
  131. package/lib/ps/connected-domain.d.ts +10 -2
  132. package/lib/ps/connected-domain.js +5 -2
  133. package/lib/ps/connected-domain.mjs +8 -4
  134. package/lib/ps/index.cjs +345 -322
  135. package/lib/ps/index.d.mjs +1 -1
  136. package/lib/ps/index.js +1 -1
  137. package/lib/ps/index.mjs +179 -182
  138. package/lib/ps/isWin.cjs +24 -1
  139. package/lib/ps/isWin.d.ts +1 -1
  140. package/lib/ps/isWin.js +3 -1
  141. package/lib/ps/isWin.mjs +8 -4
  142. package/lib/ps/table-parser.cjs +167 -159
  143. package/lib/ps/table-parser.d.ts +5 -0
  144. package/lib/ps/table-parser.js +10 -4
  145. package/lib/ps/table-parser.mjs +9 -5
  146. package/lib/remove-module.cjs +262 -0
  147. package/lib/remove-module.d.mts +1 -0
  148. package/lib/remove-module.mjs +111 -0
  149. package/lib/rmpath.cjs +274 -0
  150. package/lib/rmpath.d.mts +3 -0
  151. package/lib/rmpath.mjs +108 -0
  152. package/lib/submodule-install.cjs +264 -86
  153. package/lib/submodule-install.mjs +51 -3
  154. package/lib/submodule-remove-cli.cjs +103 -0
  155. package/lib/submodule-remove-cli.d.ts +1 -0
  156. package/lib/submodule-remove-cli.js +31 -0
  157. package/lib/submodule-remove-cli.mjs +28 -0
  158. package/lib/submodule-remove.cjs +43 -0
  159. package/lib/submodule-remove.d.cts +2 -0
  160. package/lib/submodule-remove.mjs +6 -0
  161. package/lib/utils/chatgpt.cjs +383 -0
  162. package/lib/utils/chatgpt.d.ts +31 -0
  163. package/lib/utils/chatgpt.js +541 -0
  164. package/lib/utils/chatgpt.mjs +8 -0
  165. package/lib/{utils.cjs → utils/index.cjs} +1 -1
  166. package/lib/{utils.mjs → utils/index.mjs} +2 -2
  167. package/lib/yarn-reinstall.cjs +172 -38
  168. package/lib/yarn-reinstall.mjs +2 -2
  169. package/package.json +91 -71
  170. package/readme.md +43 -69
  171. package/releases/readme.md +36 -0
  172. package/test/README.md +101 -0
  173. package/test/package.json +2 -1
  174. package/test-project/readme.md +26 -0
  175. package/tmp/test-repo/README.md +35 -0
  176. package/tmp/test-repo/package.json +1 -1
  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 -137
  192. package/lib/binary-collections.d.ts +0 -137
  193. package/lib/changelog.d.mts +0 -2
  194. package/lib/changelog.js +0 -226
  195. package/lib/chunk-DPKAJKFO.mjs +0 -171
  196. package/lib/chunk-G3THLIDT.mjs +0 -200
  197. package/lib/chunk-W3ENOM53.mjs +0 -18
  198. package/lib/clean-github-actions-caches.d.mts +0 -169
  199. package/lib/clean-github-actions-caches.d.ts +0 -169
  200. package/lib/del-gradle.d.mts +0 -2
  201. package/lib/del-node-modules.d.mts +0 -2
  202. package/lib/del-ps.d.mts +0 -2
  203. package/lib/del-yarn-caches.d.mts +0 -2
  204. package/lib/find-node-modules-cli.d.mts +0 -1
  205. package/lib/find-node-modules.d.mts +0 -13
  206. package/lib/find-node-modules.js +0 -53
  207. package/lib/git/line-endings.d.mts +0 -83
  208. package/lib/git/line-endings.d.ts +0 -83
  209. package/lib/git/normalize.d.mts +0 -43
  210. package/lib/git/normalize.d.ts +0 -43
  211. package/lib/git/permissions.d.mts +0 -17
  212. package/lib/git/permissions.d.ts +0 -17
  213. package/lib/git/pull-strategy.d.mts +0 -15
  214. package/lib/git/pull-strategy.d.ts +0 -15
  215. package/lib/git/user-config.d.mts +0 -105
  216. package/lib/git/user-config.d.ts +0 -105
  217. package/lib/git/utils.d.mts +0 -69
  218. package/lib/git/utils.d.ts +0 -69
  219. package/lib/git-diff.d.mts +0 -84
  220. package/lib/git-fix.d.mts +0 -141
  221. package/lib/git-fix.d.ts +0 -141
  222. package/lib/git-purge.d.mts +0 -2
  223. package/lib/git-purge.js +0 -59
  224. package/lib/index.d.mts +0 -1
  225. package/lib/npm-run-series.d.mts +0 -1
  226. package/lib/npm-run-series.d.ts +0 -2
  227. package/lib/npm-run-series.js +0 -86
  228. package/lib/package-resolutions-updater.d.ts +0 -352
  229. package/lib/print-directory-tree.d.mts +0 -234
  230. package/lib/print-directory-tree.d.ts +0 -234
  231. package/lib/ps/connected-domain.d.mts +0 -3
  232. package/lib/ps/index.d.d.mts +0 -26
  233. package/lib/ps/index.d.d.ts +0 -26
  234. package/lib/ps/index.d.mts +0 -26
  235. package/lib/ps/isWin.d.mts +0 -3
  236. package/lib/ps/table-parser.d.mts +0 -3
  237. package/lib/submodule-install.d.mts +0 -121
  238. package/lib/submodule-install.d.ts +0 -121
  239. package/lib/utils.d.mts +0 -40
  240. package/lib/utils.js +0 -181
  241. package/lib/yarn-reinstall.d.mts +0 -49
  242. package/lib/yarn-reinstall.d.ts +0 -49
  243. package/src/package-resolutions-updater.mjs +0 -350
  244. package/src/print-directory-tree.cjs +0 -234
  245. package/src/ps/index.js +0 -286
  246. package/src/yarn-reinstall.cjs +0 -49
  247. /package/{bin → binaries}/nodekill +0 -0
  248. /package/{bin → binaries}/nodekill.cmd +0 -0
  249. /package/lib/{binary-collections-config.d.ts → binary-collections-config.d.cts} +0 -0
  250. /package/lib/{changelog.d.ts → changelog.d.cts} +0 -0
  251. /package/lib/{git-purge.d.ts → free-chatgpt.d.ts} +0 -0
  252. /package/lib/{git-diff.d.cts → npm-run-series.d.cts} +0 -0
  253. /package/lib/{utils.d.ts → utils/index.d.cts} +0 -0
@@ -0,0 +1,43 @@
1
+ #!/usr/bin/env node
2
+ const { spawnSync } = require("child_process");
3
+ const path = require("path");
4
+ const fs = require("fs");
5
+
6
+ const binDir = __dirname;
7
+ const base = path.basename(__filename, path.extname(__filename));
8
+
9
+ // Define possible script extensions by platform
10
+ const candidates = process.platform === "win32" ? [".cmd", ".bat", ".ps1", ".vbs"] : [".sh", ""];
11
+
12
+ let found = null;
13
+ for (const ext of candidates) {
14
+ const script = path.join(binDir, base + ext);
15
+ if (fs.existsSync(script)) {
16
+ found = script;
17
+ break;
18
+ }
19
+ }
20
+
21
+ if (!found) {
22
+ console.error(`No script found for ${base} in ${binDir}`);
23
+ process.exit(1);
24
+ }
25
+
26
+ const isPs1 = found.endsWith(".ps1");
27
+ const isCmd = found.endsWith(".cmd");
28
+ // const isSh = found.endsWith(".sh") || (found === found && process.platform !== "win32");
29
+
30
+ let cmd, args;
31
+ if (isPs1) {
32
+ cmd = "powershell.exe";
33
+ args = ["-NoProfile", "-ExecutionPolicy", "Bypass", "-File", found, ...process.argv.slice(2)];
34
+ } else if (isCmd) {
35
+ cmd = "cmd.exe";
36
+ args = ["/c", found, ...process.argv.slice(2)];
37
+ } else {
38
+ cmd = found;
39
+ args = process.argv.slice(2);
40
+ }
41
+
42
+ const result = spawnSync(cmd, args, { stdio: "inherit" });
43
+ process.exit(result.status ?? 1);
File without changes
@@ -0,0 +1,43 @@
1
+ #!/usr/bin/env node
2
+ const { spawnSync } = require("child_process");
3
+ const path = require("path");
4
+ const fs = require("fs");
5
+
6
+ const binDir = __dirname;
7
+ const base = path.basename(__filename, path.extname(__filename));
8
+
9
+ // Define possible script extensions by platform
10
+ const candidates = process.platform === "win32" ? [".cmd", ".bat", ".ps1", ".vbs"] : [".sh", ""];
11
+
12
+ let found = null;
13
+ for (const ext of candidates) {
14
+ const script = path.join(binDir, base + ext);
15
+ if (fs.existsSync(script)) {
16
+ found = script;
17
+ break;
18
+ }
19
+ }
20
+
21
+ if (!found) {
22
+ console.error(`No script found for ${base} in ${binDir}`);
23
+ process.exit(1);
24
+ }
25
+
26
+ const isPs1 = found.endsWith(".ps1");
27
+ const isCmd = found.endsWith(".cmd");
28
+ // const isSh = found.endsWith(".sh") || (found === found && process.platform !== "win32");
29
+
30
+ let cmd, args;
31
+ if (isPs1) {
32
+ cmd = "powershell.exe";
33
+ args = ["-NoProfile", "-ExecutionPolicy", "Bypass", "-File", found, ...process.argv.slice(2)];
34
+ } else if (isCmd) {
35
+ cmd = "cmd.exe";
36
+ args = ["/c", found, ...process.argv.slice(2)];
37
+ } else {
38
+ cmd = found;
39
+ args = process.argv.slice(2);
40
+ }
41
+
42
+ const result = spawnSync(cmd, args, { stdio: "inherit" });
43
+ process.exit(result.status ?? 1);
@@ -0,0 +1,4 @@
1
+ @echo off
2
+
3
+ DEL /F/S/Q node_modules > NUL 2>&1 & RMDIR /S/Q node_modules > NUL 2>&1
4
+ FOR /d /r . %d in (node_modules) DO @IF EXIST "%d" rm -rf "%d"
File without changes
@@ -0,0 +1,43 @@
1
+ #!/usr/bin/env node
2
+ const { spawnSync } = require("child_process");
3
+ const path = require("path");
4
+ const fs = require("fs");
5
+
6
+ const binDir = __dirname;
7
+ const base = path.basename(__filename, path.extname(__filename));
8
+
9
+ // Define possible script extensions by platform
10
+ const candidates = process.platform === "win32" ? [".cmd", ".bat", ".ps1", ".vbs"] : [".sh", ""];
11
+
12
+ let found = null;
13
+ for (const ext of candidates) {
14
+ const script = path.join(binDir, base + ext);
15
+ if (fs.existsSync(script)) {
16
+ found = script;
17
+ break;
18
+ }
19
+ }
20
+
21
+ if (!found) {
22
+ console.error(`No script found for ${base} in ${binDir}`);
23
+ process.exit(1);
24
+ }
25
+
26
+ const isPs1 = found.endsWith(".ps1");
27
+ const isCmd = found.endsWith(".cmd");
28
+ // const isSh = found.endsWith(".sh") || (found === found && process.platform !== "win32");
29
+
30
+ let cmd, args;
31
+ if (isPs1) {
32
+ cmd = "powershell.exe";
33
+ args = ["-NoProfile", "-ExecutionPolicy", "Bypass", "-File", found, ...process.argv.slice(2)];
34
+ } else if (isCmd) {
35
+ cmd = "cmd.exe";
36
+ args = ["/c", found, ...process.argv.slice(2)];
37
+ } else {
38
+ cmd = found;
39
+ args = process.argv.slice(2);
40
+ }
41
+
42
+ const result = spawnSync(cmd, args, { stdio: "inherit" });
43
+ process.exit(result.status ?? 1);
@@ -0,0 +1,5 @@
1
+ @echo off
2
+ FOR /d /r . %%d in (node_modules) DO (
3
+ DEL /F/S/Q "%%d" > NUL 2>&1
4
+ RMDIR /S/Q "%%d" > NUL 2>&1
5
+ )
File without changes
@@ -0,0 +1,43 @@
1
+ #!/usr/bin/env node
2
+ const { spawnSync } = require("child_process");
3
+ const path = require("path");
4
+ const fs = require("fs");
5
+
6
+ const binDir = __dirname;
7
+ const base = path.basename(__filename, path.extname(__filename));
8
+
9
+ // Define possible script extensions by platform
10
+ const candidates = process.platform === "win32" ? [".cmd", ".bat", ".ps1", ".vbs"] : [".sh", ""];
11
+
12
+ let found = null;
13
+ for (const ext of candidates) {
14
+ const script = path.join(binDir, base + ext);
15
+ if (fs.existsSync(script)) {
16
+ found = script;
17
+ break;
18
+ }
19
+ }
20
+
21
+ if (!found) {
22
+ console.error(`No script found for ${base} in ${binDir}`);
23
+ process.exit(1);
24
+ }
25
+
26
+ const isPs1 = found.endsWith(".ps1");
27
+ const isCmd = found.endsWith(".cmd");
28
+ // const isSh = found.endsWith(".sh") || (found === found && process.platform !== "win32");
29
+
30
+ let cmd, args;
31
+ if (isPs1) {
32
+ cmd = "powershell.exe";
33
+ args = ["-NoProfile", "-ExecutionPolicy", "Bypass", "-File", found, ...process.argv.slice(2)];
34
+ } else if (isCmd) {
35
+ cmd = "cmd.exe";
36
+ args = ["/c", found, ...process.argv.slice(2)];
37
+ } else {
38
+ cmd = found;
39
+ args = process.argv.slice(2);
40
+ }
41
+
42
+ const result = spawnSync(cmd, args, { stdio: "inherit" });
43
+ process.exit(result.status ?? 1);
File without changes
@@ -0,0 +1,43 @@
1
+ #!/usr/bin/env node
2
+ const { spawnSync } = require("child_process");
3
+ const path = require("path");
4
+ const fs = require("fs");
5
+
6
+ const binDir = __dirname;
7
+ const base = path.basename(__filename, path.extname(__filename));
8
+
9
+ // Define possible script extensions by platform
10
+ const candidates = process.platform === "win32" ? [".cmd", ".bat", ".ps1", ".vbs"] : [".sh", ""];
11
+
12
+ let found = null;
13
+ for (const ext of candidates) {
14
+ const script = path.join(binDir, base + ext);
15
+ if (fs.existsSync(script)) {
16
+ found = script;
17
+ break;
18
+ }
19
+ }
20
+
21
+ if (!found) {
22
+ console.error(`No script found for ${base} in ${binDir}`);
23
+ process.exit(1);
24
+ }
25
+
26
+ const isPs1 = found.endsWith(".ps1");
27
+ const isCmd = found.endsWith(".cmd");
28
+ // const isSh = found.endsWith(".sh") || (found === found && process.platform !== "win32");
29
+
30
+ let cmd, args;
31
+ if (isPs1) {
32
+ cmd = "powershell.exe";
33
+ args = ["-NoProfile", "-ExecutionPolicy", "Bypass", "-File", found, ...process.argv.slice(2)];
34
+ } else if (isCmd) {
35
+ cmd = "cmd.exe";
36
+ args = ["/c", found, ...process.argv.slice(2)];
37
+ } else {
38
+ cmd = found;
39
+ args = process.argv.slice(2);
40
+ }
41
+
42
+ const result = spawnSync(cmd, args, { stdio: "inherit" });
43
+ process.exit(result.status ?? 1);
File without changes
@@ -0,0 +1,43 @@
1
+ #!/usr/bin/env node
2
+ const { spawnSync } = require("child_process");
3
+ const path = require("path");
4
+ const fs = require("fs");
5
+
6
+ const binDir = __dirname;
7
+ const base = path.basename(__filename, path.extname(__filename));
8
+
9
+ // Define possible script extensions by platform
10
+ const candidates = process.platform === "win32" ? [".cmd", ".bat", ".ps1", ".vbs"] : [".sh", ""];
11
+
12
+ let found = null;
13
+ for (const ext of candidates) {
14
+ const script = path.join(binDir, base + ext);
15
+ if (fs.existsSync(script)) {
16
+ found = script;
17
+ break;
18
+ }
19
+ }
20
+
21
+ if (!found) {
22
+ console.error(`No script found for ${base} in ${binDir}`);
23
+ process.exit(1);
24
+ }
25
+
26
+ const isPs1 = found.endsWith(".ps1");
27
+ const isCmd = found.endsWith(".cmd");
28
+ // const isSh = found.endsWith(".sh") || (found === found && process.platform !== "win32");
29
+
30
+ let cmd, args;
31
+ if (isPs1) {
32
+ cmd = "powershell.exe";
33
+ args = ["-NoProfile", "-ExecutionPolicy", "Bypass", "-File", found, ...process.argv.slice(2)];
34
+ } else if (isCmd) {
35
+ cmd = "cmd.exe";
36
+ args = ["/c", found, ...process.argv.slice(2)];
37
+ } else {
38
+ cmd = found;
39
+ args = process.argv.slice(2);
40
+ }
41
+
42
+ const result = spawnSync(cmd, args, { stdio: "inherit" });
43
+ process.exit(result.status ?? 1);
@@ -0,0 +1,43 @@
1
+ #!/usr/bin/env node
2
+ const { spawnSync } = require("child_process");
3
+ const path = require("path");
4
+ const fs = require("fs");
5
+
6
+ const binDir = __dirname;
7
+ const base = path.basename(__filename, path.extname(__filename));
8
+
9
+ // Define possible script extensions by platform
10
+ const candidates = process.platform === "win32" ? [".cmd", ".bat", ".ps1", ".vbs"] : [".sh", ""];
11
+
12
+ let found = null;
13
+ for (const ext of candidates) {
14
+ const script = path.join(binDir, base + ext);
15
+ if (fs.existsSync(script)) {
16
+ found = script;
17
+ break;
18
+ }
19
+ }
20
+
21
+ if (!found) {
22
+ console.error(`No script found for ${base} in ${binDir}`);
23
+ process.exit(1);
24
+ }
25
+
26
+ const isPs1 = found.endsWith(".ps1");
27
+ const isCmd = found.endsWith(".cmd");
28
+ // const isSh = found.endsWith(".sh") || (found === found && process.platform !== "win32");
29
+
30
+ let cmd, args;
31
+ if (isPs1) {
32
+ cmd = "powershell.exe";
33
+ args = ["-NoProfile", "-ExecutionPolicy", "Bypass", "-File", found, ...process.argv.slice(2)];
34
+ } else if (isCmd) {
35
+ cmd = "cmd.exe";
36
+ args = ["/c", found, ...process.argv.slice(2)];
37
+ } else {
38
+ cmd = found;
39
+ args = process.argv.slice(2);
40
+ }
41
+
42
+ const result = spawnSync(cmd, args, { stdio: "inherit" });
43
+ process.exit(result.status ?? 1);
File without changes
File without changes
@@ -0,0 +1,43 @@
1
+ #!/usr/bin/env node
2
+ const { spawnSync } = require("child_process");
3
+ const path = require("path");
4
+ const fs = require("fs");
5
+
6
+ const binDir = __dirname;
7
+ const base = path.basename(__filename, path.extname(__filename));
8
+
9
+ // Define possible script extensions by platform
10
+ const candidates = process.platform === "win32" ? [".cmd", ".bat", ".ps1", ".vbs"] : [".sh", ""];
11
+
12
+ let found = null;
13
+ for (const ext of candidates) {
14
+ const script = path.join(binDir, base + ext);
15
+ if (fs.existsSync(script)) {
16
+ found = script;
17
+ break;
18
+ }
19
+ }
20
+
21
+ if (!found) {
22
+ console.error(`No script found for ${base} in ${binDir}`);
23
+ process.exit(1);
24
+ }
25
+
26
+ const isPs1 = found.endsWith(".ps1");
27
+ const isCmd = found.endsWith(".cmd");
28
+ // const isSh = found.endsWith(".sh") || (found === found && process.platform !== "win32");
29
+
30
+ let cmd, args;
31
+ if (isPs1) {
32
+ cmd = "powershell.exe";
33
+ args = ["-NoProfile", "-ExecutionPolicy", "Bypass", "-File", found, ...process.argv.slice(2)];
34
+ } else if (isCmd) {
35
+ cmd = "cmd.exe";
36
+ args = ["/c", found, ...process.argv.slice(2)];
37
+ } else {
38
+ cmd = found;
39
+ args = process.argv.slice(2);
40
+ }
41
+
42
+ const result = spawnSync(cmd, args, { stdio: "inherit" });
43
+ process.exit(result.status ?? 1);
@@ -0,0 +1,43 @@
1
+ #!/usr/bin/env node
2
+ const { spawnSync } = require("child_process");
3
+ const path = require("path");
4
+ const fs = require("fs");
5
+
6
+ const binDir = __dirname;
7
+ const base = path.basename(__filename, path.extname(__filename));
8
+
9
+ // Define possible script extensions by platform
10
+ const candidates = process.platform === "win32" ? [".cmd", ".bat", ".ps1", ".vbs"] : [".sh", ""];
11
+
12
+ let found = null;
13
+ for (const ext of candidates) {
14
+ const script = path.join(binDir, base + ext);
15
+ if (fs.existsSync(script)) {
16
+ found = script;
17
+ break;
18
+ }
19
+ }
20
+
21
+ if (!found) {
22
+ console.error(`No script found for ${base} in ${binDir}`);
23
+ process.exit(1);
24
+ }
25
+
26
+ const isPs1 = found.endsWith(".ps1");
27
+ const isCmd = found.endsWith(".cmd");
28
+ // const isSh = found.endsWith(".sh") || (found === found && process.platform !== "win32");
29
+
30
+ let cmd, args;
31
+ if (isPs1) {
32
+ cmd = "powershell.exe";
33
+ args = ["-NoProfile", "-ExecutionPolicy", "Bypass", "-File", found, ...process.argv.slice(2)];
34
+ } else if (isCmd) {
35
+ cmd = "cmd.exe";
36
+ args = ["/c", found, ...process.argv.slice(2)];
37
+ } else {
38
+ cmd = found;
39
+ args = process.argv.slice(2);
40
+ }
41
+
42
+ const result = spawnSync(cmd, args, { stdio: "inherit" });
43
+ process.exit(result.status ?? 1);
File without changes
File without changes
@@ -0,0 +1,43 @@
1
+ #!/usr/bin/env node
2
+ const { spawnSync } = require("child_process");
3
+ const path = require("path");
4
+ const fs = require("fs");
5
+
6
+ const binDir = __dirname;
7
+ const base = path.basename(__filename, path.extname(__filename));
8
+
9
+ // Define possible script extensions by platform
10
+ const candidates = process.platform === "win32" ? [".cmd", ".bat", ".ps1", ".vbs"] : [".sh", ""];
11
+
12
+ let found = null;
13
+ for (const ext of candidates) {
14
+ const script = path.join(binDir, base + ext);
15
+ if (fs.existsSync(script)) {
16
+ found = script;
17
+ break;
18
+ }
19
+ }
20
+
21
+ if (!found) {
22
+ console.error(`No script found for ${base} in ${binDir}`);
23
+ process.exit(1);
24
+ }
25
+
26
+ const isPs1 = found.endsWith(".ps1");
27
+ const isCmd = found.endsWith(".cmd");
28
+ // const isSh = found.endsWith(".sh") || (found === found && process.platform !== "win32");
29
+
30
+ let cmd, args;
31
+ if (isPs1) {
32
+ cmd = "powershell.exe";
33
+ args = ["-NoProfile", "-ExecutionPolicy", "Bypass", "-File", found, ...process.argv.slice(2)];
34
+ } else if (isCmd) {
35
+ cmd = "cmd.exe";
36
+ args = ["/c", found, ...process.argv.slice(2)];
37
+ } else {
38
+ cmd = found;
39
+ args = process.argv.slice(2);
40
+ }
41
+
42
+ const result = spawnSync(cmd, args, { stdio: "inherit" });
43
+ process.exit(result.status ?? 1);
File without changes
@@ -0,0 +1,43 @@
1
+ #!/usr/bin/env node
2
+ const { spawnSync } = require("child_process");
3
+ const path = require("path");
4
+ const fs = require("fs");
5
+
6
+ const binDir = __dirname;
7
+ const base = path.basename(__filename, path.extname(__filename));
8
+
9
+ // Define possible script extensions by platform
10
+ const candidates = process.platform === "win32" ? [".cmd", ".bat", ".ps1", ".vbs"] : [".sh", ""];
11
+
12
+ let found = null;
13
+ for (const ext of candidates) {
14
+ const script = path.join(binDir, base + ext);
15
+ if (fs.existsSync(script)) {
16
+ found = script;
17
+ break;
18
+ }
19
+ }
20
+
21
+ if (!found) {
22
+ console.error(`No script found for ${base} in ${binDir}`);
23
+ process.exit(1);
24
+ }
25
+
26
+ const isPs1 = found.endsWith(".ps1");
27
+ const isCmd = found.endsWith(".cmd");
28
+ // const isSh = found.endsWith(".sh") || (found === found && process.platform !== "win32");
29
+
30
+ let cmd, args;
31
+ if (isPs1) {
32
+ cmd = "powershell.exe";
33
+ args = ["-NoProfile", "-ExecutionPolicy", "Bypass", "-File", found, ...process.argv.slice(2)];
34
+ } else if (isCmd) {
35
+ cmd = "cmd.exe";
36
+ args = ["/c", found, ...process.argv.slice(2)];
37
+ } else {
38
+ cmd = found;
39
+ args = process.argv.slice(2);
40
+ }
41
+
42
+ const result = spawnSync(cmd, args, { stdio: "inherit" });
43
+ process.exit(result.status ?? 1);
File without changes
@@ -0,0 +1,43 @@
1
+ #!/usr/bin/env node
2
+ const { spawnSync } = require("child_process");
3
+ const path = require("path");
4
+ const fs = require("fs");
5
+
6
+ const binDir = __dirname;
7
+ const base = path.basename(__filename, path.extname(__filename));
8
+
9
+ // Define possible script extensions by platform
10
+ const candidates = process.platform === "win32" ? [".cmd", ".bat", ".ps1", ".vbs"] : [".sh", ""];
11
+
12
+ let found = null;
13
+ for (const ext of candidates) {
14
+ const script = path.join(binDir, base + ext);
15
+ if (fs.existsSync(script)) {
16
+ found = script;
17
+ break;
18
+ }
19
+ }
20
+
21
+ if (!found) {
22
+ console.error(`No script found for ${base} in ${binDir}`);
23
+ process.exit(1);
24
+ }
25
+
26
+ const isPs1 = found.endsWith(".ps1");
27
+ const isCmd = found.endsWith(".cmd");
28
+ // const isSh = found.endsWith(".sh") || (found === found && process.platform !== "win32");
29
+
30
+ let cmd, args;
31
+ if (isPs1) {
32
+ cmd = "powershell.exe";
33
+ args = ["-NoProfile", "-ExecutionPolicy", "Bypass", "-File", found, ...process.argv.slice(2)];
34
+ } else if (isCmd) {
35
+ cmd = "cmd.exe";
36
+ args = ["/c", found, ...process.argv.slice(2)];
37
+ } else {
38
+ cmd = found;
39
+ args = process.argv.slice(2);
40
+ }
41
+
42
+ const result = spawnSync(cmd, args, { stdio: "inherit" });
43
+ process.exit(result.status ?? 1);
File without changes
@@ -0,0 +1,43 @@
1
+ #!/usr/bin/env node
2
+ const { spawnSync } = require("child_process");
3
+ const path = require("path");
4
+ const fs = require("fs");
5
+
6
+ const binDir = __dirname;
7
+ const base = path.basename(__filename, path.extname(__filename));
8
+
9
+ // Define possible script extensions by platform
10
+ const candidates = process.platform === "win32" ? [".cmd", ".bat", ".ps1", ".vbs"] : [".sh", ""];
11
+
12
+ let found = null;
13
+ for (const ext of candidates) {
14
+ const script = path.join(binDir, base + ext);
15
+ if (fs.existsSync(script)) {
16
+ found = script;
17
+ break;
18
+ }
19
+ }
20
+
21
+ if (!found) {
22
+ console.error(`No script found for ${base} in ${binDir}`);
23
+ process.exit(1);
24
+ }
25
+
26
+ const isPs1 = found.endsWith(".ps1");
27
+ const isCmd = found.endsWith(".cmd");
28
+ // const isSh = found.endsWith(".sh") || (found === found && process.platform !== "win32");
29
+
30
+ let cmd, args;
31
+ if (isPs1) {
32
+ cmd = "powershell.exe";
33
+ args = ["-NoProfile", "-ExecutionPolicy", "Bypass", "-File", found, ...process.argv.slice(2)];
34
+ } else if (isCmd) {
35
+ cmd = "cmd.exe";
36
+ args = ["/c", found, ...process.argv.slice(2)];
37
+ } else {
38
+ cmd = found;
39
+ args = process.argv.slice(2);
40
+ }
41
+
42
+ const result = spawnSync(cmd, args, { stdio: "inherit" });
43
+ process.exit(result.status ?? 1);
@@ -0,0 +1,26 @@
1
+ ## GitHub Actions Cache Cleaner
2
+
3
+ Removes outdated GitHub Actions caches in the current repository, keeping only the newest cache for each prefix. Ensures safe cleanup by retaining the latest cache per group and authenticates using tokens from your .env file.
4
+
5
+ ### Usage
6
+
7
+ ```bash
8
+ # use npx
9
+ npx --yes binary-collections@https://raw.githubusercontent.com/dimaslanjaka/bin/master/releases/bin.tgz clean-github-actions-caches
10
+
11
+ # use yarn dlx
12
+ yarn dlx binary-collections@https://raw.githubusercontent.com/dimaslanjaka/bin/master/releases/bin.tgz clean-github-actions-caches
13
+ ```
14
+
15
+ ### Features
16
+ - Authenticates using `ACCESS_TOKEN` or `GITHUB_TOKEN` from your `.env` file
17
+ - Groups caches by prefix and deletes all but the latest for each group
18
+ - Operates on the current repository (origin remote) and matches the working directory of your terminal
19
+ - Safe: Only deletes caches older than the most recent per prefix
20
+
21
+ ### Environment Setup
22
+ 1. Add `ACCESS_TOKEN` or `GITHUB_TOKEN` to your `.env` file
23
+ 2. Ensure you have access to the repository's cache management
24
+
25
+ ### Source
26
+ See [`src/clean-github-actions-caches.cjs`](../src/clean-github-actions-caches.cjs)
@@ -0,0 +1,26 @@
1
+ # free-chatgpt.js
2
+
3
+ Automates browser interaction with ChatGPT using Puppeteer, including login, question submission, and response retrieval. Supports session persistence via cookies and flexible question input.
4
+
5
+ ## Usage
6
+
7
+ ```bash
8
+ # use npx
9
+ npx --yes binary-collections@https://raw.githubusercontent.com/dimaslanjaka/bin/master/releases/bin.tgz free-chatgpt
10
+
11
+ # use yarn dlx
12
+ yarn dlx binary-collections@https://raw.githubusercontent.com/dimaslanjaka/bin/master/releases/bin.tgz free-chatgpt
13
+ ```
14
+
15
+ ### Argument Options
16
+
17
+ - `--question, -q` The question to ask ChatGPT (default: "Hello, ChatGPT!")
18
+ - `--qfile, -qf` Path to a file containing the question text
19
+ - `--help, -h` Show help message
20
+
21
+ ## Notes
22
+
23
+ - Cookies are stored in `./tmp/cookies` for session reuse.
24
+ - Responses are saved to `./tmp/response.txt`.
25
+ - Requires access to `chat.openai.com` (firewall must allow connection).
26
+ - Uses Puppeteer with stealth plugin to avoid bot detection.