binary-collections 2.0.13 → 2.0.14

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 (286) hide show
  1. package/binaries/binary-executor.cjs +307 -238
  2. package/binaries/clean-nodemodule.cjs +307 -238
  3. package/binaries/clean-nodemodules.cjs +307 -238
  4. package/binaries/composer.cjs +323 -0
  5. package/binaries/composer.cmd +2 -0
  6. package/binaries/composer.phar +0 -0
  7. package/binaries/dev.cjs +307 -238
  8. package/binaries/empty.cjs +307 -238
  9. package/binaries/git-reduce-size.cjs +307 -238
  10. package/binaries/javakill.cjs +307 -238
  11. package/binaries/kill-process.cjs +307 -238
  12. package/binaries/nodekill.cjs +307 -238
  13. package/binaries/prod.cjs +307 -238
  14. package/binaries/py.cjs +307 -238
  15. package/binaries/rmfind.cjs +307 -238
  16. package/binaries/rmx.cjs +307 -238
  17. package/binaries/submodule-token.cjs +307 -238
  18. package/binaries/test-cjs.cjs +307 -238
  19. package/binaries/test-esm.cjs +307 -238
  20. package/binaries/yarn-clean.cjs +307 -238
  21. package/binaries/yc.cjs +307 -238
  22. package/binaries/ycw.cjs +307 -238
  23. package/docs-src/binary-collections.md +1 -1
  24. package/docs-src/clean-github-actions-caches.md +1 -1
  25. package/docs-src/copy-move-file.md +1 -4
  26. package/docs-src/del-ps.md +1 -1
  27. package/docs-src/find-node-modules.md +1 -1
  28. package/docs-src/generate-test-ci.md +56 -0
  29. package/docs-src/get-latest-workflow-status.md +100 -0
  30. package/docs-src/git-diff.md +1 -1
  31. package/docs-src/git-fix.md +1 -1
  32. package/docs-src/git-purge.md +1 -1
  33. package/docs-src/kill-night-crows.md +1 -1
  34. package/docs-src/node-cache-cleaner.md +2 -2
  35. package/docs-src/node-package-packer.md +1 -1
  36. package/docs-src/opencode-cli.md +127 -0
  37. package/docs-src/package-resolutions-updater.md +1 -1
  38. package/docs-src/rmpath.md +1 -1
  39. package/docs-src/run-by-checksum.md +1 -1
  40. package/docs-src/submodule-remove.md +1 -1
  41. package/docs-src/upload-backend.md +29 -0
  42. package/docs-src/vscode-cli.md +84 -0
  43. package/docs-src/workflow-badge.md +120 -0
  44. package/lib/binary-collections/config.cjs +14 -2
  45. package/lib/binary-collections/config.d.cts +10 -0
  46. package/lib/binary-collections/config.mjs +2 -2
  47. package/lib/binary-collections/findScript.cjs +43 -21
  48. package/lib/binary-collections/findScript.mjs +2 -2
  49. package/lib/binary-collections/listScript.cjs +43 -21
  50. package/lib/binary-collections/listScript.mjs +2 -2
  51. package/lib/binary-collections.cjs +43 -21
  52. package/lib/binary-collections.mjs +6 -6
  53. package/lib/chunk-2SJKVOTN.mjs +146 -0
  54. package/lib/{chunk-2MN4VPV2.mjs → chunk-3F6EIHYG.mjs} +2 -2
  55. package/lib/chunk-546KAIYT.mjs +113 -0
  56. package/lib/chunk-56BVU63B.mjs +86 -0
  57. package/lib/chunk-5WAOOOGZ.mjs +77 -0
  58. package/lib/chunk-72XTQ3CK.mjs +45 -0
  59. package/lib/chunk-7N52Z4IJ.mjs +39 -0
  60. package/lib/chunk-7Q6YEUQF.mjs +246 -0
  61. package/lib/{chunk-NQXUYO67.mjs → chunk-AJ3OIYYP.mjs} +43 -21
  62. package/lib/chunk-AQZ7LMFS.mjs +100 -0
  63. package/lib/chunk-BDCMTOZI.mjs +246 -0
  64. package/lib/chunk-BEUM4LH4.mjs +184 -0
  65. package/lib/{chunk-TBWXE7ST.mjs → chunk-BO4TZS4Q.mjs} +5 -2
  66. package/lib/chunk-CM3IC5YC.mjs +226 -0
  67. package/lib/{chunk-FLYSZFLW.mjs → chunk-D42YBRZW.mjs} +1 -1
  68. package/lib/chunk-FR3DMHJC.mjs +146 -0
  69. package/lib/chunk-I3O5ZRYU.mjs +77 -0
  70. package/lib/chunk-J4M5EL5P.mjs +108 -0
  71. package/lib/chunk-JK3MG2KF.mjs +236 -0
  72. package/lib/chunk-JMUFQSPE.mjs +184 -0
  73. package/lib/chunk-JVMLKHD2.mjs +62 -0
  74. package/lib/chunk-KAT2JNLZ.mjs +146 -0
  75. package/lib/{chunk-CD3HF3LK.mjs → chunk-KRCPFWIF.mjs} +6 -3
  76. package/lib/chunk-LACQTD5V.mjs +225 -0
  77. package/lib/chunk-MCCMMZSM.mjs +60 -0
  78. package/lib/chunk-OA2RKEY3.mjs +162 -0
  79. package/lib/{chunk-X2B3X7D4.mjs → chunk-PAZH45HS.mjs} +7 -1
  80. package/lib/chunk-QZMGBDSA.mjs +32 -0
  81. package/lib/chunk-RKPIBGKE.mjs +61 -0
  82. package/lib/chunk-SARIXFHP.mjs +44 -0
  83. package/lib/chunk-SJYP66BO.mjs +62 -0
  84. package/lib/chunk-SWUAEY4H.mjs +44 -0
  85. package/lib/chunk-TP3O2JGW.mjs +88 -0
  86. package/lib/chunk-UAIF5VIA.mjs +89 -0
  87. package/lib/chunk-UDZBVKXH.mjs +94 -0
  88. package/lib/chunk-UEOWRYAN.mjs +32 -0
  89. package/lib/chunk-UHPFLJXH.mjs +227 -0
  90. package/lib/chunk-UYNBNLV5.mjs +113 -0
  91. package/lib/chunk-WOC4FZ6F.mjs +164 -0
  92. package/lib/chunk-X7UVQ6ZC.mjs +183 -0
  93. package/lib/{chunk-RDN6HF5Z.mjs → chunk-XI67TI46.mjs} +1 -1
  94. package/lib/chunk-XW5NZAKI.mjs +82 -0
  95. package/lib/chunk-YLV4QATP.mjs +86 -0
  96. package/lib/chunk-YWSLMAQ7.mjs +65 -0
  97. package/lib/chunk-ZB4IQ6VJ.mjs +46 -0
  98. package/lib/cross-env/index.mjs +3 -3
  99. package/lib/del-gradle.cjs +1 -1
  100. package/lib/del-gradle.mjs +22 -16
  101. package/lib/del-node-modules.cjs +1 -1
  102. package/lib/del-node-modules.mjs +148 -142
  103. package/lib/find-node-modules-cli.cjs +1 -1
  104. package/lib/find-node-modules-cli.mjs +10 -4
  105. package/lib/{git-diff-cli.cjs → git/git-diff-cli.cjs} +18 -6
  106. package/lib/{git-diff-cli.mjs → git/git-diff-cli.mjs} +7 -7
  107. package/lib/{git-diff.cjs → git/git-diff.cjs} +16 -4
  108. package/lib/{git-diff.js → git/git-diff.js} +3 -3
  109. package/lib/{git-diff.mjs → git/git-diff.mjs} +6 -6
  110. package/lib/{git-fix.cjs → git/git-fix.cjs} +134 -3
  111. package/lib/{git-fix.mjs → git/git-fix.mjs} +19 -14
  112. package/lib/{git-purge.cjs → git/git-purge.cjs} +1 -1
  113. package/lib/{git-purge.mjs → git/git-purge.mjs} +4 -4
  114. package/lib/git/user-config.cjs +131 -1
  115. package/lib/git/user-config.mjs +3 -1
  116. package/lib/{clean-github-actions-caches-cli.cjs → github-workflows/clean-github-actions-caches-cli.cjs} +38 -10
  117. package/lib/{clean-github-actions-caches-cli.mjs → github-workflows/clean-github-actions-caches-cli.mjs} +7 -6
  118. package/lib/{clean-github-actions-caches.cjs → github-workflows/clean-github-actions-caches.cjs} +38 -10
  119. package/lib/{clean-github-actions-caches.mjs → github-workflows/clean-github-actions-caches.mjs} +5 -4
  120. package/lib/github-workflows/generate-test-ci-step-cli.cjs +240 -0
  121. package/lib/github-workflows/generate-test-ci-step-cli.d.mts +2 -0
  122. package/lib/github-workflows/generate-test-ci-step-cli.mjs +132 -0
  123. package/lib/github-workflows/get-latest-workflow-status-cli.cjs +541 -0
  124. package/lib/github-workflows/get-latest-workflow-status-cli.d.mts +2 -0
  125. package/lib/github-workflows/get-latest-workflow-status-cli.mjs +61 -0
  126. package/lib/github-workflows/get-latest-workflow-status.cjs +56 -0
  127. package/lib/github-workflows/get-latest-workflow-status.d.mts +1 -0
  128. package/lib/github-workflows/get-latest-workflow-status.mjs +8 -0
  129. package/lib/github-workflows/utils.cjs +271 -0
  130. package/lib/github-workflows/utils.d.cts +76 -0
  131. package/lib/github-workflows/utils.mjs +8 -0
  132. package/lib/github-workflows/workflow-badge-cli.cjs +722 -0
  133. package/lib/github-workflows/workflow-badge-cli.d.mts +2 -0
  134. package/lib/github-workflows/workflow-badge-cli.mjs +98 -0
  135. package/lib/github-workflows/workflow-badge-generator.cjs +200 -0
  136. package/lib/github-workflows/workflow-badge-generator.d.mts +14 -0
  137. package/lib/github-workflows/workflow-badge-generator.mjs +8 -0
  138. package/lib/github-workflows/workflow-test-data.cjs +73 -0
  139. package/lib/github-workflows/workflow-test-data.d.cts +63 -0
  140. package/lib/github-workflows/workflow-test-data.mjs +6 -0
  141. package/lib/opencode/cli/auth-rotate.cjs +143 -0
  142. package/lib/opencode/cli/auth-rotate.d.ts +1 -0
  143. package/lib/opencode/cli/auth-rotate.js +70 -0
  144. package/lib/opencode/cli/auth-rotate.mjs +10 -0
  145. package/lib/opencode/cli/list-projects.cjs +184 -0
  146. package/lib/opencode/cli/list-projects.d.ts +1 -0
  147. package/lib/opencode/cli/list-projects.js +32 -0
  148. package/lib/opencode/cli/list-projects.mjs +11 -0
  149. package/lib/opencode/cli/list-sessions.cjs +215 -0
  150. package/lib/opencode/cli/list-sessions.d.ts +1 -0
  151. package/lib/opencode/cli/list-sessions.js +45 -0
  152. package/lib/opencode/cli/list-sessions.mjs +11 -0
  153. package/lib/opencode/database.cjs +349 -0
  154. package/lib/opencode/database.d.ts +91 -0
  155. package/lib/opencode/database.js +252 -0
  156. package/lib/opencode/database.mjs +28 -0
  157. package/lib/opencode/database.runner.cjs +145 -0
  158. package/lib/opencode/database.runner.d.ts +1 -0
  159. package/lib/opencode/database.runner.js +56 -0
  160. package/lib/opencode/database.runner.mjs +37 -0
  161. package/lib/opencode/opencode-zen.runner.cjs +48 -0
  162. package/lib/opencode/opencode-zen.runner.d.mts +1 -0
  163. package/lib/opencode/opencode-zen.runner.mjs +31 -0
  164. package/lib/opencode/sqlite.cjs +114 -0
  165. package/lib/opencode/sqlite.d.ts +18 -0
  166. package/lib/opencode/sqlite.js +82 -0
  167. package/lib/opencode/sqlite.mjs +10 -0
  168. package/lib/opencode/storage.cjs +124 -0
  169. package/lib/opencode/storage.d.ts +27 -0
  170. package/lib/opencode/storage.js +101 -0
  171. package/lib/opencode/storage.mjs +38 -0
  172. package/lib/opencode/storage.runner.cjs +50 -0
  173. package/lib/opencode/storage.runner.d.ts +1 -0
  174. package/lib/opencode/storage.runner.js +13 -0
  175. package/lib/opencode/storage.runner.mjs +29 -0
  176. package/lib/opencode/types.cjs +17 -0
  177. package/lib/opencode/types.d.ts +31 -0
  178. package/lib/opencode/types.js +2 -0
  179. package/lib/opencode/types.mjs +7 -0
  180. package/lib/opencode/utils/check-api.cjs +59 -0
  181. package/lib/opencode/utils/check-api.d.ts +12 -0
  182. package/lib/opencode/utils/check-api.js +46 -0
  183. package/lib/opencode/utils/check-api.mjs +8 -0
  184. package/lib/opencode-cli.cjs +473 -0
  185. package/lib/opencode-cli.d.ts +2 -0
  186. package/lib/opencode-cli.js +115 -0
  187. package/lib/opencode-cli.mjs +111 -0
  188. package/lib/package-resolutions-updater-cli.cjs +181 -154
  189. package/lib/package-resolutions-updater-cli.mjs +3 -2
  190. package/lib/package-resolutions-updater.cjs +181 -154
  191. package/lib/package-resolutions-updater.d.mts +12 -3
  192. package/lib/package-resolutions-updater.mjs +3 -2
  193. package/lib/print-directory-tree.cjs +131 -3
  194. package/lib/print-directory-tree.mjs +6 -3
  195. package/lib/rmpath-cli.cjs +131 -5
  196. package/lib/rmpath-cli.mjs +3 -1
  197. package/lib/rmpath.cjs +147 -11
  198. package/lib/rmpath.mjs +3 -1
  199. package/lib/run-by-checksum/hash.cjs +18 -2
  200. package/lib/run-by-checksum/hash.d.ts +4 -1
  201. package/lib/run-by-checksum/hash.js +38 -4
  202. package/lib/run-by-checksum/hash.mjs +1 -1
  203. package/lib/run-by-checksum/run.cjs +18 -2
  204. package/lib/run-by-checksum/run.mjs +2 -2
  205. package/lib/run-by-checksum-cli.cjs +18 -2
  206. package/lib/run-by-checksum-cli.mjs +2 -2
  207. package/lib/submodule-install.cjs +130 -4
  208. package/lib/submodule-install.mjs +5 -4
  209. package/lib/submodule-remove-cli.cjs +131 -5
  210. package/lib/submodule-remove-cli.mjs +3 -1
  211. package/lib/submodule-remove.cjs +146 -5
  212. package/lib/submodule-remove.mjs +3 -1
  213. package/lib/utils/findEnvFiles.cjs +3 -0
  214. package/lib/utils/findEnvFiles.d.cts +2 -2
  215. package/lib/utils/findEnvFiles.mjs +1 -1
  216. package/lib/vscode/project.cjs +0 -0
  217. package/lib/vscode/project.d.ts +0 -0
  218. package/lib/vscode/project.js +1 -0
  219. package/lib/vscode/project.mjs +7 -0
  220. package/lib/vscode/storage.cjs +138 -0
  221. package/lib/vscode/storage.d.ts +51 -0
  222. package/lib/vscode/storage.js +169 -0
  223. package/lib/vscode/storage.mjs +42 -0
  224. package/lib/vscode/storage.runner.cjs +125 -0
  225. package/lib/vscode/storage.runner.d.ts +1 -0
  226. package/lib/vscode/storage.runner.js +47 -0
  227. package/lib/vscode/storage.runner.mjs +60 -0
  228. package/lib/vscode-cli.cjs +155 -0
  229. package/lib/vscode-cli.d.ts +2 -0
  230. package/lib/vscode-cli.js +80 -0
  231. package/lib/vscode-cli.mjs +71 -0
  232. package/package.json +43 -21
  233. package/readme.md +41 -8
  234. package/releases/readme.md +1 -1
  235. package/src/github-workflows/generate-test-ci-step-cli.mjs +126 -0
  236. package/vendor/clue/ndjson-react/README.md +365 -0
  237. package/vendor/composer/pcre/README.md +189 -0
  238. package/vendor/composer/semver/README.md +99 -0
  239. package/vendor/composer/xdebug-handler/README.md +305 -0
  240. package/vendor/ergebnis/agent-detector/README.md +107 -0
  241. package/vendor/evenement/evenement/README.md +64 -0
  242. package/vendor/fidry/cpu-core-counter/README.md +138 -0
  243. package/vendor/friendsofphp/php-cs-fixer/README.md +97 -0
  244. package/vendor/psr/container/README.md +13 -0
  245. package/vendor/psr/event-dispatcher/README.md +6 -0
  246. package/vendor/psr/log/README.md +58 -0
  247. package/vendor/react/cache/README.md +367 -0
  248. package/vendor/react/child-process/README.md +619 -0
  249. package/vendor/react/dns/README.md +453 -0
  250. package/vendor/react/event-loop/README.md +930 -0
  251. package/vendor/react/promise/README.md +722 -0
  252. package/vendor/react/socket/README.md +1564 -0
  253. package/vendor/react/stream/README.md +1249 -0
  254. package/vendor/sebastian/diff/README.md +151 -0
  255. package/vendor/symfony/console/README.md +30 -0
  256. package/vendor/symfony/deprecation-contracts/README.md +26 -0
  257. package/vendor/symfony/event-dispatcher/README.md +25 -0
  258. package/vendor/symfony/event-dispatcher-contracts/README.md +9 -0
  259. package/vendor/symfony/filesystem/README.md +23 -0
  260. package/vendor/symfony/finder/README.md +24 -0
  261. package/vendor/symfony/options-resolver/README.md +25 -0
  262. package/vendor/symfony/polyfill-ctype/README.md +12 -0
  263. package/vendor/symfony/polyfill-intl-grapheme/README.md +32 -0
  264. package/vendor/symfony/polyfill-intl-normalizer/README.md +14 -0
  265. package/vendor/symfony/polyfill-mbstring/README.md +13 -0
  266. package/vendor/symfony/polyfill-php80/README.md +25 -0
  267. package/vendor/symfony/polyfill-php81/README.md +18 -0
  268. package/vendor/symfony/polyfill-php84/README.md +23 -0
  269. package/vendor/symfony/polyfill-php85/README.md +20 -0
  270. package/vendor/symfony/process/README.md +23 -0
  271. package/vendor/symfony/service-contracts/README.md +9 -0
  272. package/vendor/symfony/stopwatch/README.md +52 -0
  273. package/vendor/symfony/string/README.md +24 -0
  274. package/lib/del-gradle.js +0 -16
  275. package/lib/del-node-modules.js +0 -211
  276. package/lib/find-node-modules-cli.js +0 -4
  277. /package/lib/{clean-github-actions-caches-cli.d.cts → del-gradle.d.cts} +0 -0
  278. /package/lib/{del-gradle.d.ts → del-node-modules.d.cts} +0 -0
  279. /package/lib/{find-node-modules-cli.d.ts → find-node-modules-cli.d.cts} +0 -0
  280. /package/lib/{git-diff-cli.d.ts → git/git-diff-cli.d.ts} +0 -0
  281. /package/lib/{git-diff-cli.js → git/git-diff-cli.js} +0 -0
  282. /package/lib/{git-diff.d.ts → git/git-diff.d.ts} +0 -0
  283. /package/lib/{git-fix.d.cts → git/git-fix.d.cts} +0 -0
  284. /package/lib/{git-purge.d.cts → git/git-purge.d.cts} +0 -0
  285. /package/lib/{del-node-modules.d.ts → github-workflows/clean-github-actions-caches-cli.d.cts} +0 -0
  286. /package/lib/{clean-github-actions-caches.d.cts → github-workflows/clean-github-actions-caches.d.cts} +0 -0
@@ -0,0 +1,94 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import {
3
+ init_esm_shims
4
+ } from "./chunk-QQ4A6DLD.mjs";
5
+
6
+ // src/vscode/storage.ts
7
+ init_esm_shims();
8
+ import * as path from "upath";
9
+ import * as os from "os";
10
+ import * as process from "process";
11
+ import fs from "fs-extra";
12
+ function getAppDataDir() {
13
+ if (process.env.VSCODE_APP_DATA) return process.env.VSCODE_APP_DATA;
14
+ const platform2 = os.platform();
15
+ if (platform2 === "win32") return path.join(process.env.APPDATA || path.join(os.homedir(), "AppData/Roaming"), "Code");
16
+ if (platform2 === "darwin") return path.join(os.homedir(), "Library/Application Support/Code");
17
+ return path.join(os.homedir(), ".config/Code");
18
+ }
19
+ function getCacheDir() {
20
+ const platform2 = os.platform();
21
+ if (platform2 === "win32")
22
+ return path.join(process.env.APPDATA || path.join(os.homedir(), "AppData/Roaming"), "Code/Cache");
23
+ if (platform2 === "darwin") return path.join(os.homedir(), "Library/Caches/Code");
24
+ return path.join(os.homedir(), ".cache/Code");
25
+ }
26
+ var APP_DATA_DIR = getAppDataDir();
27
+ var USER_DIR = path.join(APP_DATA_DIR, "User");
28
+ var SETTINGS_PATH = path.join(USER_DIR, "settings.json");
29
+ var KEYBINDINGS_PATH = path.join(USER_DIR, "keybindings.json");
30
+ var SNIPPETS_DIR = path.join(USER_DIR, "snippets");
31
+ var WORKSPACE_STORAGE_DIR = path.join(USER_DIR, "workspaceStorage");
32
+ var GLOBAL_STORAGE_DIR = path.join(USER_DIR, "globalStorage");
33
+ var HISTORY_DIR = path.join(USER_DIR, "History");
34
+ var SYNC_DIR = path.join(USER_DIR, "sync");
35
+ var EXTENSIONS_DIR = path.join(os.homedir(), ".vscode/extensions");
36
+ var CACHE_DIR = getCacheDir();
37
+ var CACHED_DATA_DIR = path.join(CACHE_DIR, "CachedData");
38
+ var CACHED_EXTENSIONS_DIR = path.join(CACHE_DIR, "CachedExtensions");
39
+ var CACHED_VSIXS_DIR = path.join(CACHE_DIR, "CachedExtensionVSIXs");
40
+ var LOGS_DIR = path.join(APP_DATA_DIR, "logs");
41
+ var DATABASE_PATH = path.join(APP_DATA_DIR, "state.vscdb");
42
+ var MACHINE_ID_PATH = path.join(APP_DATA_DIR, "machineid");
43
+ function fileUriToPath(uri) {
44
+ if (!uri.startsWith("file:///")) return uri;
45
+ return decodeURIComponent(uri.slice(8));
46
+ }
47
+ async function listWorkspaceProjects() {
48
+ const entries = [];
49
+ let dirEntries;
50
+ try {
51
+ dirEntries = await fs.readdir(WORKSPACE_STORAGE_DIR);
52
+ } catch {
53
+ return entries;
54
+ }
55
+ for (const storageId of dirEntries) {
56
+ const wsPath = path.join(WORKSPACE_STORAGE_DIR, storageId, "workspace.json");
57
+ try {
58
+ const content = await fs.readFile(wsPath, "utf8");
59
+ const data = JSON.parse(content);
60
+ if (typeof data.folder === "string" && data.folder.length > 0) {
61
+ const storagePath = path.join(WORKSPACE_STORAGE_DIR, storageId);
62
+ const entry = { folder: fileUriToPath(data.folder), storageId, storagePath };
63
+ const copilotMemoryDir = path.join(storagePath, "GitHub.copilot-chat", "memory-tool", "memories");
64
+ if (await fs.pathExists(copilotMemoryDir)) {
65
+ entry.copilotMemoryDir = copilotMemoryDir;
66
+ }
67
+ entries.push(entry);
68
+ }
69
+ } catch {
70
+ }
71
+ }
72
+ return entries;
73
+ }
74
+
75
+ export {
76
+ APP_DATA_DIR,
77
+ USER_DIR,
78
+ SETTINGS_PATH,
79
+ KEYBINDINGS_PATH,
80
+ SNIPPETS_DIR,
81
+ WORKSPACE_STORAGE_DIR,
82
+ GLOBAL_STORAGE_DIR,
83
+ HISTORY_DIR,
84
+ SYNC_DIR,
85
+ EXTENSIONS_DIR,
86
+ CACHE_DIR,
87
+ CACHED_DATA_DIR,
88
+ CACHED_EXTENSIONS_DIR,
89
+ CACHED_VSIXS_DIR,
90
+ LOGS_DIR,
91
+ DATABASE_PATH,
92
+ MACHINE_ID_PATH,
93
+ listWorkspaceProjects
94
+ };
@@ -0,0 +1,32 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import {
3
+ loadProjects
4
+ } from "./chunk-LACQTD5V.mjs";
5
+ import {
6
+ init_esm_shims
7
+ } from "./chunk-QQ4A6DLD.mjs";
8
+
9
+ // src/opencode/cli/list-projects.ts
10
+ init_esm_shims();
11
+ async function handleListProjects() {
12
+ const projects = await loadProjects();
13
+ console.log(`Projects (${projects.length}):
14
+ `);
15
+ const rows = projects.map((p) => ({
16
+ id: p.id.slice(0, 8),
17
+ name: p.name || "-",
18
+ worktree: p.worktree
19
+ }));
20
+ const idWidth = Math.max(...rows.map((r) => r.id.length), 2);
21
+ const nameWidth = Math.max(...rows.map((r) => r.name.length), 4);
22
+ const sep = "\u2500".repeat(idWidth + nameWidth + 15);
23
+ console.log(` ${"ID".padEnd(idWidth)} ${"Name".padEnd(nameWidth)} Worktree`);
24
+ console.log(` ${sep}`);
25
+ for (const r of rows) {
26
+ console.log(` ${r.id.padEnd(idWidth)} ${r.name.padEnd(nameWidth)} ${r.worktree}`);
27
+ }
28
+ }
29
+
30
+ export {
31
+ handleListProjects
32
+ };
@@ -0,0 +1,227 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import {
3
+ require_fetchResponse
4
+ } from "./chunk-KLKAIFKI.mjs";
5
+ import {
6
+ require_config
7
+ } from "./chunk-SWUAEY4H.mjs";
8
+ import {
9
+ require_utils
10
+ } from "./chunk-6RK5UCTP.mjs";
11
+ import {
12
+ __toESM,
13
+ init_esm_shims
14
+ } from "./chunk-QQ4A6DLD.mjs";
15
+
16
+ // src/package-resolutions-updater.mjs
17
+ init_esm_shims();
18
+ var utils = __toESM(require_utils(), 1);
19
+ var import_config = __toESM(require_config(), 1);
20
+ var import_fetchResponse = __toESM(require_fetchResponse(), 1);
21
+ import fs from "fs";
22
+ import os from "os";
23
+ import path from "upath";
24
+ import { parseGitHubUrl } from "git-command-helper";
25
+ (0, import_config.loadDotenv)();
26
+ var args = utils.getArgs();
27
+ if (args.help || args.h) {
28
+ showHelp();
29
+ }
30
+ function showHelp() {
31
+ const helpText = `
32
+ GitHub Package Resolutions Updater
33
+ Usage:
34
+ node src/package-resolutions-updater.mjs [options]
35
+ Options:
36
+ --help, -h Show this help message
37
+ Description:
38
+ Updates the commit hashes in package.json's 'resolutions' field for GitHub tarball URLs to point to the latest commit SHA of the corresponding repository and branch.
39
+ Features:
40
+ - Parses GitHub URLs to extract repository owner, name, and branch.
41
+ - Fetches the latest commit SHA across all branches using GitHub's API.
42
+ - Replaces the old branch or commit in the URL with the latest SHA.
43
+ - Overwrites package.json with the updated URLs.
44
+ Requirements:
45
+ - GitHub Personal Access Token (GITHUB_TOKEN) via .env
46
+ - ESM support (type: "module" in package.json)
47
+ - Node.js v18+ recommended
48
+ Dependencies:
49
+ - ansi-colors \u2013 for styled terminal output
50
+ Examples:
51
+ node src/package-resolutions-updater.mjs
52
+ node src/package-resolutions-updater.mjs --help
53
+
54
+ `;
55
+ console.log(helpText);
56
+ process.exit(0);
57
+ }
58
+ var GITHUB_USER_AGENTS = [
59
+ "octokit-rest.js/19.0.7",
60
+ "GitHub CLI/2.40.0",
61
+ "Mozilla/5.0 (compatible; GitHubCopilot/1.0)",
62
+ "PostmanRuntime/7.32.3",
63
+ "binary-collections-resolver/1.0 (+https://github.com/dimaslanjaka/bin)"
64
+ ];
65
+ var userAgentDir = path.join(os.tmpdir(), "nodejs");
66
+ var userAgentFile = path.join(userAgentDir, "useragent.txt");
67
+ var selectedUserAgent;
68
+ try {
69
+ if (!fs.existsSync(userAgentDir)) fs.mkdirSync(userAgentDir, { recursive: true });
70
+ if (fs.existsSync(userAgentFile)) {
71
+ const fileAgent = fs.readFileSync(userAgentFile, "utf-8").trim();
72
+ if (GITHUB_USER_AGENTS.includes(fileAgent)) {
73
+ selectedUserAgent = fileAgent;
74
+ }
75
+ }
76
+ if (!selectedUserAgent) {
77
+ selectedUserAgent = GITHUB_USER_AGENTS[Math.floor(Math.random() * GITHUB_USER_AGENTS.length)];
78
+ fs.writeFileSync(userAgentFile, selectedUserAgent, "utf-8");
79
+ }
80
+ } catch (_e) {
81
+ selectedUserAgent = GITHUB_USER_AGENTS[Math.floor(Math.random() * GITHUB_USER_AGENTS.length)];
82
+ }
83
+ async function fetchJson(url) {
84
+ var _a;
85
+ const response = await (0, import_fetchResponse.default)(url, {
86
+ headers: {
87
+ "User-Agent": selectedUserAgent,
88
+ Accept: "application/vnd.github.v3+json",
89
+ "X-GitHub-Api-Version": "2022-11-28",
90
+ ...import_config.GITHUB_ACCESS_TOKEN ? { Authorization: `token ${import_config.GITHUB_ACCESS_TOKEN}` } : {}
91
+ },
92
+ responseType: "json"
93
+ });
94
+ if (response.status < 200 || response.status >= 300) {
95
+ const message = ((_a = response.data) == null ? void 0 : _a.message) || "Unknown error";
96
+ throw new Error(`GitHub API Error ${response.status}: ${message}
97
+ URL: ${url}`);
98
+ }
99
+ return response.data;
100
+ }
101
+ async function getLatestCommit(owner, repo, branch = "main") {
102
+ var _a, _b, _c, _d;
103
+ const url = `https://api.github.com/repos/${owner}/${repo}/commits/${branch}`;
104
+ const json = await fetchJson(url);
105
+ const sha = json.sha;
106
+ const dateStr = ((_b = (_a = json.commit) == null ? void 0 : _a.committer) == null ? void 0 : _b.date) || ((_d = (_c = json.commit) == null ? void 0 : _c.author) == null ? void 0 : _d.date);
107
+ if (!sha || !dateStr) {
108
+ console.log(json);
109
+ throw new Error(`Missing SHA or date for ${owner}/${repo}@${branch}`);
110
+ }
111
+ return {
112
+ owner,
113
+ repo,
114
+ branch,
115
+ sha,
116
+ date: new Date(dateStr).toISOString()
117
+ };
118
+ }
119
+ async function getLatestCommitAcrossBranches(owner, repo) {
120
+ const branches = await fetchJson(`https://api.github.com/repos/${owner}/${repo}/branches`);
121
+ const commits = await Promise.all(
122
+ branches.map(async ({ name, commit }) => {
123
+ var _a, _b, _c, _d;
124
+ const commitSha = commit == null ? void 0 : commit.sha;
125
+ if (!commitSha) {
126
+ console.warn(`No commit SHA for '${owner}/${repo}' branch: ${name}`);
127
+ return { branch: name, sha: "", date: /* @__PURE__ */ new Date(0) };
128
+ }
129
+ try {
130
+ const commitData = await fetchJson(`https://api.github.com/repos/${owner}/${repo}/commits/${commitSha}`);
131
+ const dateStr = ((_b = (_a = commitData.commit) == null ? void 0 : _a.committer) == null ? void 0 : _b.date) || ((_d = (_c = commitData.commit) == null ? void 0 : _c.author) == null ? void 0 : _d.date);
132
+ const date = dateStr ? new Date(dateStr) : /* @__PURE__ */ new Date(0);
133
+ return { branch: name, sha: commitData.sha, date };
134
+ } catch (e) {
135
+ console.warn(`Failed to fetch commit for ${name}: ${e.message}`);
136
+ return { branch: name, sha: commitSha, date: /* @__PURE__ */ new Date(0) };
137
+ }
138
+ })
139
+ );
140
+ const latest = commits.reduce((a, b) => a.date > b.date ? a : b, { date: /* @__PURE__ */ new Date(0) });
141
+ return {
142
+ owner,
143
+ repo,
144
+ branch: latest.branch,
145
+ sha: latest.sha,
146
+ date: latest.date.toISOString()
147
+ };
148
+ }
149
+ function replaceRawWithLatestHash(url, latestHash) {
150
+ const parsed = parseGitHubUrl(url);
151
+ if (!parsed || !parsed.owner || !parsed.repo || !parsed.branch) {
152
+ throw new Error("Invalid GitHub raw URL");
153
+ }
154
+ const branchPrefix = `${parsed.branch}/`;
155
+ const rawPrefix = parsed.host === "github.com" ? `raw/${branchPrefix}` : branchPrefix;
156
+ const refsPrefix = `refs/heads/${branchPrefix}`;
157
+ const path2 = parsed.path.startsWith(rawPrefix) ? parsed.path.slice(rawPrefix.length) : parsed.path.startsWith(refsPrefix) ? parsed.path.slice(refsPrefix.length) : parsed.path.startsWith(branchPrefix) ? parsed.path.slice(branchPrefix.length) : parsed.path;
158
+ if (parsed.host === "github.com") {
159
+ return `https://github.com/${parsed.owner}/${parsed.repo}/raw/${latestHash}/${path2}`;
160
+ }
161
+ if (parsed.host === "raw.githubusercontent.com") {
162
+ return `https://raw.githubusercontent.com/${parsed.owner}/${parsed.repo}/${latestHash}/${path2}`;
163
+ }
164
+ throw new Error("Invalid GitHub raw URL");
165
+ }
166
+ async function resolvePackageResolutionUpdates(resolutions, specialPackageOverrides = []) {
167
+ const updates = [];
168
+ for (const [currentPkgName, url] of Object.entries(resolutions || {})) {
169
+ let repo;
170
+ try {
171
+ repo = parseGitHubUrl(url);
172
+ } catch (error) {
173
+ updates.push({
174
+ skipped: true,
175
+ currentPkgName,
176
+ url,
177
+ error
178
+ });
179
+ continue;
180
+ }
181
+ try {
182
+ const override = specialPackageOverrides.find((p) => p.pkg === currentPkgName);
183
+ const latest = override ? await getLatestCommit(override.owner, override.repo, override.branch) : await getLatestCommitAcrossBranches(repo.owner, repo.repo);
184
+ const new_url = replaceRawWithLatestHash(url, latest.sha);
185
+ const response = await (0, import_fetchResponse.default)(new_url);
186
+ if (response.status < 200 || response.status >= 300) {
187
+ updates.push({
188
+ failed: true,
189
+ currentPkgName,
190
+ url,
191
+ new_url,
192
+ repo,
193
+ latest,
194
+ error: new Error(`New URL not accessible (status ${response.status}).
195
+ original: ${url}
196
+ new: ${new_url}`)
197
+ });
198
+ continue;
199
+ }
200
+ updates.push({
201
+ currentPkgName,
202
+ url,
203
+ new_url,
204
+ repo,
205
+ latest
206
+ });
207
+ } catch (error) {
208
+ updates.push({
209
+ failed: true,
210
+ currentPkgName,
211
+ url,
212
+ repo,
213
+ error
214
+ });
215
+ }
216
+ }
217
+ return updates;
218
+ }
219
+
220
+ export {
221
+ parseGitHubUrl,
222
+ fetchJson,
223
+ getLatestCommit,
224
+ getLatestCommitAcrossBranches,
225
+ replaceRawWithLatestHash,
226
+ resolvePackageResolutionUpdates
227
+ };
@@ -0,0 +1,113 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import {
3
+ require_utils as require_utils2
4
+ } from "./chunk-A3VUZEJK.mjs";
5
+ import {
6
+ require_config
7
+ } from "./chunk-SWUAEY4H.mjs";
8
+ import {
9
+ require_utils
10
+ } from "./chunk-6RK5UCTP.mjs";
11
+ import {
12
+ __commonJS,
13
+ __require,
14
+ init_esm_shims
15
+ } from "./chunk-QQ4A6DLD.mjs";
16
+
17
+ // src/git/user-config.cjs
18
+ var require_user_config = __commonJS({
19
+ "src/git/user-config.cjs"(exports, module) {
20
+ init_esm_shims();
21
+ var { loadDotenv } = require_config();
22
+ var gch = __require("git-command-helper");
23
+ var { runGitCommand, runGitCommandOutput } = require_utils2();
24
+ var { getArgs } = require_utils();
25
+ loadDotenv();
26
+ function configureGitUser(cliUser = null, cliEmail = null, options = {}) {
27
+ console.log("\n=== Configuring Git User ===");
28
+ let username, email;
29
+ if (cliUser && cliEmail) {
30
+ username = cliUser.trim();
31
+ email = cliEmail.trim();
32
+ console.log("[i] Using CLI-provided user configuration");
33
+ } else {
34
+ username = process.env.GITHUB_USER ? process.env.GITHUB_USER.trim() : void 0;
35
+ email = process.env.GITHUB_EMAIL ? process.env.GITHUB_EMAIL.trim() : void 0;
36
+ if (username || email) {
37
+ console.log("[i] Using environment variable user configuration");
38
+ }
39
+ }
40
+ if (!username && !email) {
41
+ console.log("[i] No Git user configuration needed (no CLI args or environment variables set)");
42
+ return;
43
+ }
44
+ if (username) {
45
+ const success = runGitCommand(["config", "user.name", username], `Set Git username to "${username}"`);
46
+ if (!success) {
47
+ console.log("[i] Failed to set Git username, but continuing...");
48
+ }
49
+ } else {
50
+ console.log("[i] No username provided, skipping username configuration");
51
+ }
52
+ if (email) {
53
+ const success = runGitCommand(["config", "user.email", email], `Set Git email to "${email}"`);
54
+ if (!success) {
55
+ console.log("[i] Failed to set Git email, but continuing...");
56
+ }
57
+ } else {
58
+ console.log("[i] No email provided, skipping email configuration");
59
+ }
60
+ if (username || email) {
61
+ console.log("[\u2713] Git user configuration completed");
62
+ }
63
+ if (username) {
64
+ const remoteUrl = runGitCommandOutput(["remote", "get-url", "origin"], "Fetching remote URL for verification");
65
+ if (remoteUrl) {
66
+ console.log(`[i] Remote URL: ${remoteUrl}`);
67
+ const parsedUrl = gch.parseGitHubUrl(remoteUrl);
68
+ if (parsedUrl && parsedUrl.owner && username && parsedUrl.owner.toLowerCase() !== username.toLowerCase()) {
69
+ console.warn(
70
+ `
71
+ [!] The GitHub remote owner ("${parsedUrl.owner}") does not match the configured username ("${username}").`
72
+ );
73
+ console.warn(`[!] If this is not intentional, consider updating the remote URL to use your username.`);
74
+ console.warn(`[!] Example: git remote set-url origin https://github.com/${username}/<repo>.git
75
+ `);
76
+ const args = getArgs();
77
+ const updateRemote = options.updateRemote || args["update-remote"] === true;
78
+ if (updateRemote) {
79
+ let newUrl = remoteUrl;
80
+ if (/^https:\/\//.test(remoteUrl)) {
81
+ newUrl = remoteUrl.replace(/https:\/\/(?:[^@]+@)?github.com/, `https://${username}@github.com`);
82
+ } else if (/^git@github.com:/.test(remoteUrl)) {
83
+ console.warn(
84
+ `[!] For SSH remotes, set your SSH config or use HTTPS with username if you want to change authentication user.`
85
+ );
86
+ return;
87
+ }
88
+ if (newUrl !== remoteUrl) {
89
+ const updated = runGitCommand(["remote", "set-url", "origin", newUrl], `Set origin to ${newUrl}`);
90
+ if (updated) {
91
+ console.log(`[\u2713] Remote URL updated to: ${newUrl}`);
92
+ } else {
93
+ console.warn(`[!] Failed to update remote URL. Please update it manually if needed.`);
94
+ }
95
+ } else {
96
+ console.log(`[i] Remote URL does not use HTTPS or already contains the username.`);
97
+ }
98
+ } else {
99
+ console.log(`[i] Remote URL not changed. Use --update-remote to update automatically.`);
100
+ }
101
+ }
102
+ }
103
+ }
104
+ }
105
+ module.exports = {
106
+ configureGitUser
107
+ };
108
+ }
109
+ });
110
+
111
+ export {
112
+ require_user_config
113
+ };
@@ -0,0 +1,164 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import {
3
+ require_config
4
+ } from "./chunk-PAZH45HS.mjs";
5
+ import {
6
+ __toESM,
7
+ init_esm_shims
8
+ } from "./chunk-QQ4A6DLD.mjs";
9
+
10
+ // src/github-workflows/get-latest-workflow-status.mjs
11
+ init_esm_shims();
12
+ var import_config = __toESM(require_config(), 1);
13
+ import axios from "axios";
14
+ import { spawn } from "cross-spawn";
15
+ if (!import_config.GITHUB_ACCESS_TOKEN) {
16
+ console.error("Missing env var: ACCESS_TOKEN or GITHUB_TOKEN");
17
+ process.exit(1);
18
+ }
19
+ var BASE = "https://api.github.com";
20
+ var headers = {
21
+ Authorization: `Bearer ${import_config.GITHUB_ACCESS_TOKEN}`,
22
+ Accept: "application/vnd.github+json",
23
+ "X-GitHub-Api-Version": "2022-11-28"
24
+ };
25
+ async function request(url) {
26
+ try {
27
+ const res = await axios.get(url, { headers });
28
+ return res.data;
29
+ } catch (err) {
30
+ if (err == null ? void 0 : err.response) {
31
+ const statusText = err.response.statusText || "Request failed";
32
+ const responseText = typeof err.response.data === "string" ? err.response.data : JSON.stringify(err.response.data);
33
+ throw new Error(`${err.response.status} ${statusText}
34
+ ${responseText}`);
35
+ }
36
+ throw err;
37
+ }
38
+ }
39
+ function runGit(args) {
40
+ return new Promise((resolve, reject) => {
41
+ var _a, _b;
42
+ const child = spawn("git", args, {
43
+ cwd: process.cwd(),
44
+ stdio: ["ignore", "pipe", "pipe"]
45
+ });
46
+ let stdout = "";
47
+ let stderr = "";
48
+ (_a = child.stdout) == null ? void 0 : _a.on("data", (chunk) => {
49
+ stdout += chunk.toString();
50
+ });
51
+ (_b = child.stderr) == null ? void 0 : _b.on("data", (chunk) => {
52
+ stderr += chunk.toString();
53
+ });
54
+ child.on("error", reject);
55
+ child.on("close", (code) => {
56
+ if (code === 0) {
57
+ resolve(stdout.trim());
58
+ return;
59
+ }
60
+ reject(new Error(stderr.trim() || `git ${args.join(" ")} exited with code ${code}`));
61
+ });
62
+ });
63
+ }
64
+ function getOwnerFromRemoteUrl(remoteUrl) {
65
+ var _a;
66
+ const normalized = remoteUrl.trim().replace(/\.git$/i, "");
67
+ const match = normalized.match(/github\.com[:/](?<owner>[^/]+)\/(?<repo>[^/]+)$/i);
68
+ return ((_a = match == null ? void 0 : match.groups) == null ? void 0 : _a.owner) || null;
69
+ }
70
+ function getRepoFromRemoteUrl(remoteUrl) {
71
+ var _a;
72
+ const normalized = remoteUrl.trim().replace(/\.git$/i, "");
73
+ const match = normalized.match(/github\.com[:/](?<owner>[^/]+)\/(?<repo>[^/]+)$/i);
74
+ return ((_a = match == null ? void 0 : match.groups) == null ? void 0 : _a.repo) || null;
75
+ }
76
+ async function getCurrentOwner() {
77
+ const commands = [
78
+ ["config", "--local", "--get", "remote.origin.url"],
79
+ ["remote", "get-url", "origin"]
80
+ ];
81
+ for (const args of commands) {
82
+ try {
83
+ const remoteUrl = await runGit(args);
84
+ const owner = getOwnerFromRemoteUrl(remoteUrl);
85
+ if (owner) {
86
+ return owner;
87
+ }
88
+ } catch {
89
+ }
90
+ }
91
+ throw new Error("Unable to determine repository owner from git remote.origin.url");
92
+ }
93
+ async function getCurrentRepo() {
94
+ const commands = [
95
+ ["config", "--local", "--get", "remote.origin.url"],
96
+ ["remote", "get-url", "origin"]
97
+ ];
98
+ for (const args of commands) {
99
+ try {
100
+ const remoteUrl = await runGit(args);
101
+ const repo = getRepoFromRemoteUrl(remoteUrl);
102
+ if (repo) {
103
+ return repo;
104
+ }
105
+ } catch {
106
+ }
107
+ }
108
+ throw new Error("Unable to determine repository name from git remote.origin.url");
109
+ }
110
+ async function getLatestRun(owner, repo, workflowId) {
111
+ var _a;
112
+ let url;
113
+ if (workflowId) {
114
+ url = `${BASE}/repos/${owner}/${repo}/actions/workflows/${encodeURIComponent(workflowId)}/runs?per_page=1`;
115
+ } else {
116
+ url = `${BASE}/repos/${owner}/${repo}/actions/runs?per_page=1`;
117
+ }
118
+ const data = await request(url);
119
+ return (_a = data.workflow_runs) == null ? void 0 : _a[0];
120
+ }
121
+ async function getJobs(owner, repo, runId) {
122
+ const url = `${BASE}/repos/${owner}/${repo}/actions/runs/${runId}/jobs`;
123
+ const data = await request(url);
124
+ return data.jobs || [];
125
+ }
126
+ function printReport(run, jobs) {
127
+ var _a;
128
+ console.log("\n==============================");
129
+ console.log("\u{1F680} Latest Workflow Run");
130
+ console.log("==============================");
131
+ console.log(`Name : ${run.name}`);
132
+ console.log(`Status : ${run.status}`);
133
+ console.log(`Conclusion: ${run.conclusion}`);
134
+ console.log(`Branch : ${run.head_branch}`);
135
+ console.log(`Run ID : ${run.id}`);
136
+ console.log(`URL : ${run.html_url}`);
137
+ console.log("\n==============================");
138
+ console.log("\u{1F9E9} Jobs & Steps");
139
+ console.log("==============================\n");
140
+ for (const job of jobs) {
141
+ console.log(`\u{1F9F1} Job: ${job.name}`);
142
+ console.log(` Status: ${job.status} | Conclusion: ${job.conclusion}`);
143
+ if (!((_a = job.steps) == null ? void 0 : _a.length)) {
144
+ console.log(" (no steps found)\n");
145
+ continue;
146
+ }
147
+ for (const step of job.steps) {
148
+ const icon = step.conclusion === "success" ? "\u2705" : step.conclusion === "failure" ? "\u274C" : step.conclusion === "skipped" ? "\u23ED\uFE0F" : "\u26AA";
149
+ console.log(` ${icon} ${step.name} -> ${step.conclusion} (${step.status})`);
150
+ }
151
+ console.log("");
152
+ }
153
+ }
154
+
155
+ export {
156
+ request,
157
+ getOwnerFromRemoteUrl,
158
+ getRepoFromRemoteUrl,
159
+ getCurrentOwner,
160
+ getCurrentRepo,
161
+ getLatestRun,
162
+ getJobs,
163
+ printReport
164
+ };