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,234 +0,0 @@
1
- const fs = require("fs").promises;
2
- const path = require("path");
3
- const crypto = require("crypto");
4
- const { execSync } = require("child_process");
5
- const glob = require("glob");
6
- const { getArgs } = require("./utils.js");
7
- const sbgUtil = require("sbg-utility");
8
- const dotenv = require("dotenv");
9
-
10
- const projectDir = process.cwd();
11
- const envPath = path.join(projectDir, ".env");
12
-
13
- // Load the .env file using dotenv (ESM import)
14
- if (fs.existsSync(envPath)) dotenv.config({ path: envPath });
15
-
16
- // Parse CLI arguments
17
- const argv = getArgs();
18
-
19
- // Main logic wrapped in an async function
20
- async function main() {
21
- // Determine output file from CLI args
22
- let relativeOutputFile = "tmp/directory-structure.txt";
23
- if (argv.output || argv.o) {
24
- relativeOutputFile = argv.output || argv.o;
25
- }
26
- // If not absolute, resolve relative to projectDir
27
- const outputFile = path.isAbsolute(relativeOutputFile)
28
- ? relativeOutputFile
29
- : path.join(projectDir, relativeOutputFile);
30
-
31
- // Create or clear the hash file
32
- sbgUtil.writefile(outputFile, "");
33
-
34
- /**
35
- * List of file extensions to include
36
- * @type {string[]}
37
- */
38
- let extensions = [];
39
- if (argv.ext) {
40
- extensions = argv.ext
41
- .split(",")
42
- .map((e) => e.trim().replace(/^\./, ""))
43
- .filter(Boolean);
44
- }
45
-
46
- // Directories to exclude
47
- let excludeDirs = [
48
- "node_modules",
49
- "vendor",
50
- "venv",
51
- ".venv",
52
- ".git",
53
- ".hg",
54
- ".svn",
55
- ".idea",
56
- ".vscode",
57
- "dist",
58
- "build",
59
- "out",
60
- "coverage",
61
- ".DS_Store"
62
- ];
63
- if (argv.exclude) {
64
- const userExcludes = argv.exclude
65
- .split(",")
66
- .map((d) => d.trim())
67
- .filter(Boolean);
68
- if (argv["override-exclude"] || argv.we) {
69
- // Override the default excludes with user-provided ones
70
- excludeDirs = userExcludes;
71
- } else {
72
- // Append user-provided excludes to the default ones
73
- excludeDirs = excludeDirs.concat(userExcludes);
74
- }
75
- }
76
-
77
- // Convert excludeDirs into glob ignore patterns
78
- const ignorePatterns = excludeDirs.map((dir) => `**/${dir}/**`);
79
-
80
- // Initialize an array to hold the formatted outputs
81
- let hashArray = [];
82
-
83
- // Helper function to hash and add file if not already processed
84
- const processedFiles = new Set();
85
- /**
86
- * Hashes a file and pushes its relative path and hash to the hashArray.
87
- * @param {string} file - The absolute path to the file.
88
- * @returns {Promise<void>} Resolves when the file has been processed and added to hashArray.
89
- */
90
- async function hashAndPush(file) {
91
- if (processedFiles.has(file)) return;
92
- processedFiles.add(file);
93
- let relativePath = path.relative(projectDir, file);
94
- relativePath = relativePath.split(path.sep).join("/");
95
- try {
96
- const stats = await fs.stat(file);
97
- const pseudoHash = `${stats.size}-${stats.mtimeMs}`;
98
- const hash = crypto.createHash("sha256").update(pseudoHash).digest("hex");
99
- hashArray.push(`${relativePath} ${hash.slice(0, 8)}`);
100
- } catch (err) {
101
- console.error(`Error processing file: ${file}`, err instanceof Error ? err.message : "<unknown error>");
102
- if (err && err.code === "ENOENT") {
103
- hashArray.push(`${relativePath} <file not found>`);
104
- } else {
105
- hashArray.push(`${relativePath} <error: ${err && err.code ? `code ${err.code}` : "unknown"}>`);
106
- }
107
- }
108
- }
109
-
110
- // Collect all files to process (extensions + special files)
111
- const initialFiles = [
112
- path.join(projectDir, "package.json"),
113
- path.join(projectDir, "composer.json"),
114
- path.join(projectDir, "requirements.txt")
115
- ];
116
- let patterns = [];
117
- if (argv.pattern) {
118
- if (Array.isArray(argv.pattern)) {
119
- patterns = argv.pattern.map((p) => p.trim()).filter(Boolean);
120
- } else {
121
- patterns = [argv.pattern.trim()];
122
- }
123
- } else if (extensions.length === 0) {
124
- patterns = ["**/*.*"];
125
- } else {
126
- patterns = extensions.map((ext) => `**/*.${ext}`);
127
- }
128
- const globFiles = glob.sync(patterns.length === 1 ? patterns[0] : `{${patterns.join(",")}}`, {
129
- cwd: projectDir,
130
- ignore: ignorePatterns,
131
- absolute: true,
132
- nodir: true
133
- });
134
- const allFiles = new Set([...initialFiles, ...globFiles]);
135
-
136
- // Hash all unique files
137
- await Promise.all(Array.from(allFiles).map(hashAndPush));
138
-
139
- // Sort the hashArray by file paths
140
- hashArray.sort((a, b) => a.localeCompare(b));
141
-
142
- /**
143
- * Generates a directory/file tree string from a hash array of file paths and hashes.
144
- *
145
- * @param {string[]} hashArray - Array of strings in the format 'relative/path/to/file hash'.
146
- * @returns {string} The directory/file tree as a string, with file hashes.
147
- */
148
- function getFileTreeString(hashArray) {
149
- const tree = {};
150
- // Map file paths to hashes for quick lookup
151
- const hashMap = {};
152
- for (const entry of hashArray) {
153
- const [filePath, hash] = entry.split(" ");
154
- hashMap[filePath] = hash;
155
- const parts = filePath.split("/");
156
- let current = tree;
157
- for (let i = 0; i < parts.length; i++) {
158
- const part = parts[i];
159
- if (i === parts.length - 1) {
160
- current[part] = null; // file
161
- } else {
162
- current[part] = current[part] || {};
163
- current = current[part];
164
- }
165
- }
166
- }
167
- /**
168
- * Recursively builds the tree string for a given node.
169
- *
170
- * @param {Object} node - The current node in the tree.
171
- * @param {string} prefix - The prefix for the current tree level.
172
- * @param {string} parentPath - The path to the current node.
173
- * @returns {string[]} Array of lines representing the tree structure.
174
- */
175
- function printNode(node, prefix = "", parentPath = "") {
176
- const keys = Object.keys(node).sort();
177
- let lines = [];
178
- keys.forEach((key, idx) => {
179
- const isLast = idx === keys.length - 1;
180
- const branch = isLast ? "└── " : "├── ";
181
- const currentPath = parentPath ? parentPath + "/" + key : key;
182
- if (node[key] === null) {
183
- // file: show hash
184
- lines.push(prefix + branch + key + " [" + (hashMap[currentPath] || "") + "]");
185
- } else {
186
- lines.push(prefix + branch + key + "/");
187
- lines = lines.concat(printNode(node[key], prefix + (isLast ? " " : "│ "), currentPath));
188
- }
189
- });
190
- return lines;
191
- }
192
- return printNode(tree, "", "").join("\n");
193
- }
194
-
195
- // Write directory/file tree to the output file (hashes are included in the tree)
196
- const fileTreeString = getFileTreeString(hashArray);
197
- await fs.writeFile(outputFile, fileTreeString + "\n", "utf-8");
198
-
199
- // Add the hash file to the commit if --git-add is present
200
- if (argv["git-add"]) {
201
- execSync(`git add ${relativeOutputFile}`);
202
- console.log(`Directory tree written to ${relativeOutputFile} and staged for git.`);
203
- } else {
204
- console.log(`Directory tree written to ${relativeOutputFile}.`);
205
- }
206
- }
207
-
208
- if (argv.help || argv.h) {
209
- console.log(`
210
- Usage: node print-directory-tree.cjs [options]
211
-
212
- Options:
213
- --output, -o <file> Output file path (default: tmp/directory-structure.txt)
214
- --ext <exts> Comma-separated list of file extensions (no dot, e.g. js,ts)
215
- --pattern <glob> Glob pattern(s) for files (can be repeated)
216
- --exclude <dirs> Comma-separated list of directories to exclude (appends to default)
217
- --override-exclude, -we Override default exclude directories with --exclude
218
- --git-add Add output file to git after writing
219
- --help, -h Show this help message
220
-
221
- Examples:
222
- node print-directory-tree.cjs --ext=js,ts
223
- node print-directory-tree.cjs --pattern=src/**/*.js --pattern=test/**/*.js
224
- node print-directory-tree.cjs --exclude=dist,build
225
- node print-directory-tree.cjs --output=tmp/tree.txt
226
- `);
227
- process.exit(0);
228
- }
229
-
230
- // Execute the main function
231
- main().catch((err) => {
232
- console.error(err);
233
- process.exit(1);
234
- });
@@ -1,3 +0,0 @@
1
- declare function _exports(tdArray: any[], indicator: Function, hardlink: boolean): any;
2
-
3
- export { _exports as default };
@@ -1,26 +0,0 @@
1
- interface Program {
2
- arguments: string[];
3
- command: string;
4
- pid: number;
5
- }
6
-
7
- interface Query {
8
- pid?: string | string[] | number | undefined;
9
- ppid?: number | undefined;
10
- command?: string | RegExp | undefined;
11
- arguments?: string | RegExp | undefined;
12
- psargs?: string | string[] | undefined;
13
- }
14
-
15
- interface Signal {
16
- signal: string;
17
- timeout: number;
18
- }
19
-
20
- /** Query Process: Focus on pid & cmd */
21
- declare function lookup(query: Query, cb: (err: Error, list: Program[]) => void): void;
22
-
23
- declare function kill(pID: number | string, cb?: (err?: Error) => void): void;
24
- declare function kill(pID: number | string, signal?: string | Signal, cb?: (err?: Error) => void): void;
25
-
26
- export { type Program, type Query, type Signal, kill, lookup };
@@ -1,26 +0,0 @@
1
- interface Program {
2
- arguments: string[];
3
- command: string;
4
- pid: number;
5
- }
6
-
7
- interface Query {
8
- pid?: string | string[] | number | undefined;
9
- ppid?: number | undefined;
10
- command?: string | RegExp | undefined;
11
- arguments?: string | RegExp | undefined;
12
- psargs?: string | string[] | undefined;
13
- }
14
-
15
- interface Signal {
16
- signal: string;
17
- timeout: number;
18
- }
19
-
20
- /** Query Process: Focus on pid & cmd */
21
- declare function lookup(query: Query, cb: (err: Error, list: Program[]) => void): void;
22
-
23
- declare function kill(pID: number | string, cb?: (err?: Error) => void): void;
24
- declare function kill(pID: number | string, signal?: string | Signal, cb?: (err?: Error) => void): void;
25
-
26
- export { type Program, type Query, type Signal, kill, lookup };
@@ -1,26 +0,0 @@
1
- interface Program {
2
- arguments: string[];
3
- command: string;
4
- pid: number;
5
- }
6
-
7
- interface Query {
8
- pid?: string | string[] | number | undefined;
9
- ppid?: number | undefined;
10
- command?: string | RegExp | undefined;
11
- arguments?: string | RegExp | undefined;
12
- psargs?: string | string[] | undefined;
13
- }
14
-
15
- interface Signal {
16
- signal: string;
17
- timeout: number;
18
- }
19
-
20
- /** Query Process: Focus on pid & cmd */
21
- declare function lookup(query: Query, cb: (err: Error, list: Program[]) => void): void;
22
-
23
- declare function kill(pID: number | string, cb?: (err?: Error) => void): void;
24
- declare function kill(pID: number | string, signal?: string | Signal, cb?: (err?: Error) => void): void;
25
-
26
- export { type Program, type Query, type Signal, kill, lookup };
@@ -1,3 +0,0 @@
1
- declare const isWin: boolean;
2
-
3
- export { isWin as default };
@@ -1,3 +0,0 @@
1
- declare function parse(output: any): any[];
2
-
3
- export { parse };
@@ -1,121 +0,0 @@
1
- #!/usr/bin/env node
2
- const { spawnSync } = require("child_process");
3
-
4
- const fs = require("fs");
5
- const path = require("path");
6
- const dotenv = require("dotenv");
7
-
8
- // Load .env using dotenv from process.cwd()
9
- const envPath = path.resolve(process.cwd(), ".env");
10
- if (fs.existsSync(envPath)) dotenv.config({ path: envPath });
11
-
12
- const { getArgs } = require("./utils.js");
13
- const args = getArgs();
14
- const positional = args._ || [];
15
-
16
- let ROOT = runGit(["rev-parse", "--show-toplevel"]).trim();
17
- let REPO_PATH = ROOT;
18
-
19
- if (args.cwd) {
20
- ROOT = path.resolve(args.cwd);
21
- } else if (positional.length > 0) {
22
- ROOT = path.resolve(positional[0]);
23
- }
24
-
25
- console.log(`Installing submodules at ${ROOT}`);
26
-
27
- // Get submodule paths
28
- const submoduleList = runGit([
29
- "-C",
30
- REPO_PATH,
31
- "config",
32
- "-f",
33
- ".gitmodules",
34
- "--get-regexp",
35
- "^submodule\\..*\\.path$"
36
- ])
37
- .split("\n")
38
- .filter(Boolean);
39
-
40
- for (const line of submoduleList) {
41
- const [KEY, MODULE_PATH] = line.trim().split(/\s+/);
42
- const RELATIVE_MODULE_PATH = path.join(ROOT, MODULE_PATH);
43
-
44
- if (fs.existsSync(RELATIVE_MODULE_PATH)) {
45
- console.log(`Deleting ${RELATIVE_MODULE_PATH}`);
46
- fs.rmSync(RELATIVE_MODULE_PATH, { recursive: true, force: true });
47
- }
48
-
49
- const NAME = KEY.match(/^submodule\.(.*)\.path$/)[1];
50
- const URL = runGit(["config", "-f", ".gitmodules", "--get", `submodule.${NAME}.url`]).trim();
51
-
52
- let BRANCH = "master";
53
- try {
54
- BRANCH = runGit(["config", "-f", ".gitmodules", "--get", `submodule.${NAME}.branch`]).trim();
55
- } catch {
56
- // silently ignore if branch is not set
57
- }
58
-
59
- const addResult = runGit(
60
- ["-C", REPO_PATH, "submodule", "add", "--force", "-b", BRANCH, "--name", NAME, URL, MODULE_PATH],
61
- true
62
- );
63
-
64
- if (addResult.status !== 0) {
65
- console.warn(`Cannot add submodule ${MODULE_PATH}`);
66
- continue;
67
- }
68
-
69
- const GIT_MODULES = path.join(RELATIVE_MODULE_PATH, ".gitmodules");
70
-
71
- if (process.env.ACCESS_TOKEN) {
72
- let URL_WITH_TOKEN = "";
73
- let repoInfo;
74
-
75
- if (URL.includes("github.com")) {
76
- repoInfo = URL.replace("https://github.com/", "");
77
- URL_WITH_TOKEN = `https://${process.env.ACCESS_TOKEN}@github.com/${repoInfo}`;
78
- } else if (URL.includes("gitlab.com") && typeof process.env.GITLAB_TOKEN === "string") {
79
- repoInfo = URL.replace("https://gitlab.com/", "");
80
- URL_WITH_TOKEN = `https://oauth2:${process.env.ACCESS_TOKEN}@gitlab.com/${repoInfo}`;
81
- } else {
82
- // For other Git providers, try a generic approach
83
- const urlObj = new URL(URL);
84
- repoInfo = urlObj.pathname.substring(1); // Remove leading slash
85
- URL_WITH_TOKEN = `${urlObj.protocol}//${process.env.ACCESS_TOKEN}@${urlObj.host}${urlObj.pathname}`;
86
- }
87
-
88
- if (URL_WITH_TOKEN && URL_WITH_TOKEN.length > 0) {
89
- console.log(`Apply token for ${repoInfo} at ${MODULE_PATH} branch ${BRANCH}`);
90
- runGit(["-C", RELATIVE_MODULE_PATH, "remote", "set-url", "origin", URL_WITH_TOKEN]);
91
- }
92
- }
93
-
94
- runGit(["-C", RELATIVE_MODULE_PATH, "fetch", "--all"]);
95
- runGit(["-C", RELATIVE_MODULE_PATH, "pull", "origin", BRANCH, "-X", "theirs"]);
96
-
97
- if (fs.existsSync(GIT_MODULES)) {
98
- console.log(`${MODULE_PATH} has submodules`);
99
- const result = spawnSync("node", [__filename, "-cwd", RELATIVE_MODULE_PATH], { stdio: "inherit" });
100
- if (result.status !== 0) {
101
- console.error(`Recursive submodule failed for ${RELATIVE_MODULE_PATH}`);
102
- process.exit(result.status);
103
- }
104
- }
105
- }
106
-
107
- runGit(["-C", REPO_PATH, "submodule", "update", "--init", "--recursive"]);
108
-
109
- // ----------- Helper Functions -----------
110
-
111
- function runGit(args, returnResult = false) {
112
- const result = spawnSync("git", args, { encoding: "utf-8" });
113
-
114
- if (returnResult) return result;
115
-
116
- if (result.status !== 0) {
117
- throw new Error(result.stderr || `git ${args.join(" ")} failed`);
118
- }
119
-
120
- return result.stdout || "";
121
- }
@@ -1,121 +0,0 @@
1
- #!/usr/bin/env node
2
- const { spawnSync } = require("child_process");
3
-
4
- const fs = require("fs");
5
- const path = require("path");
6
- const dotenv = require("dotenv");
7
-
8
- // Load .env using dotenv from process.cwd()
9
- const envPath = path.resolve(process.cwd(), ".env");
10
- if (fs.existsSync(envPath)) dotenv.config({ path: envPath });
11
-
12
- const { getArgs } = require("./utils.js");
13
- const args = getArgs();
14
- const positional = args._ || [];
15
-
16
- let ROOT = runGit(["rev-parse", "--show-toplevel"]).trim();
17
- let REPO_PATH = ROOT;
18
-
19
- if (args.cwd) {
20
- ROOT = path.resolve(args.cwd);
21
- } else if (positional.length > 0) {
22
- ROOT = path.resolve(positional[0]);
23
- }
24
-
25
- console.log(`Installing submodules at ${ROOT}`);
26
-
27
- // Get submodule paths
28
- const submoduleList = runGit([
29
- "-C",
30
- REPO_PATH,
31
- "config",
32
- "-f",
33
- ".gitmodules",
34
- "--get-regexp",
35
- "^submodule\\..*\\.path$"
36
- ])
37
- .split("\n")
38
- .filter(Boolean);
39
-
40
- for (const line of submoduleList) {
41
- const [KEY, MODULE_PATH] = line.trim().split(/\s+/);
42
- const RELATIVE_MODULE_PATH = path.join(ROOT, MODULE_PATH);
43
-
44
- if (fs.existsSync(RELATIVE_MODULE_PATH)) {
45
- console.log(`Deleting ${RELATIVE_MODULE_PATH}`);
46
- fs.rmSync(RELATIVE_MODULE_PATH, { recursive: true, force: true });
47
- }
48
-
49
- const NAME = KEY.match(/^submodule\.(.*)\.path$/)[1];
50
- const URL = runGit(["config", "-f", ".gitmodules", "--get", `submodule.${NAME}.url`]).trim();
51
-
52
- let BRANCH = "master";
53
- try {
54
- BRANCH = runGit(["config", "-f", ".gitmodules", "--get", `submodule.${NAME}.branch`]).trim();
55
- } catch {
56
- // silently ignore if branch is not set
57
- }
58
-
59
- const addResult = runGit(
60
- ["-C", REPO_PATH, "submodule", "add", "--force", "-b", BRANCH, "--name", NAME, URL, MODULE_PATH],
61
- true
62
- );
63
-
64
- if (addResult.status !== 0) {
65
- console.warn(`Cannot add submodule ${MODULE_PATH}`);
66
- continue;
67
- }
68
-
69
- const GIT_MODULES = path.join(RELATIVE_MODULE_PATH, ".gitmodules");
70
-
71
- if (process.env.ACCESS_TOKEN) {
72
- let URL_WITH_TOKEN = "";
73
- let repoInfo;
74
-
75
- if (URL.includes("github.com")) {
76
- repoInfo = URL.replace("https://github.com/", "");
77
- URL_WITH_TOKEN = `https://${process.env.ACCESS_TOKEN}@github.com/${repoInfo}`;
78
- } else if (URL.includes("gitlab.com") && typeof process.env.GITLAB_TOKEN === "string") {
79
- repoInfo = URL.replace("https://gitlab.com/", "");
80
- URL_WITH_TOKEN = `https://oauth2:${process.env.ACCESS_TOKEN}@gitlab.com/${repoInfo}`;
81
- } else {
82
- // For other Git providers, try a generic approach
83
- const urlObj = new URL(URL);
84
- repoInfo = urlObj.pathname.substring(1); // Remove leading slash
85
- URL_WITH_TOKEN = `${urlObj.protocol}//${process.env.ACCESS_TOKEN}@${urlObj.host}${urlObj.pathname}`;
86
- }
87
-
88
- if (URL_WITH_TOKEN && URL_WITH_TOKEN.length > 0) {
89
- console.log(`Apply token for ${repoInfo} at ${MODULE_PATH} branch ${BRANCH}`);
90
- runGit(["-C", RELATIVE_MODULE_PATH, "remote", "set-url", "origin", URL_WITH_TOKEN]);
91
- }
92
- }
93
-
94
- runGit(["-C", RELATIVE_MODULE_PATH, "fetch", "--all"]);
95
- runGit(["-C", RELATIVE_MODULE_PATH, "pull", "origin", BRANCH, "-X", "theirs"]);
96
-
97
- if (fs.existsSync(GIT_MODULES)) {
98
- console.log(`${MODULE_PATH} has submodules`);
99
- const result = spawnSync("node", [__filename, "-cwd", RELATIVE_MODULE_PATH], { stdio: "inherit" });
100
- if (result.status !== 0) {
101
- console.error(`Recursive submodule failed for ${RELATIVE_MODULE_PATH}`);
102
- process.exit(result.status);
103
- }
104
- }
105
- }
106
-
107
- runGit(["-C", REPO_PATH, "submodule", "update", "--init", "--recursive"]);
108
-
109
- // ----------- Helper Functions -----------
110
-
111
- function runGit(args, returnResult = false) {
112
- const result = spawnSync("git", args, { encoding: "utf-8" });
113
-
114
- if (returnResult) return result;
115
-
116
- if (result.status !== 0) {
117
- throw new Error(result.stderr || `git ${args.join(" ")} failed`);
118
- }
119
-
120
- return result.stdout || "";
121
- }
package/lib/utils.d.mts DELETED
@@ -1,40 +0,0 @@
1
- import * as minimist from 'minimist';
2
-
3
- declare function parseGitRemotes(): Promise<{}>;
4
- /**
5
- * Joins all given path segments together and normalizes the resulting path.
6
- * Preserves the case of the drive letter on Windows.
7
- *
8
- * @param {...string} segments Path segments to join.
9
- * @returns {string} Normalized path with drive letter case preserved.
10
- */
11
- declare function joinPathPreserveDriveLetter(...segments: string[]): string;
12
- /**
13
- * Returns parsed command line arguments using minimist.
14
- * @returns {import('minimist').ParsedArgs} Parsed command line arguments
15
- */
16
- declare function getArgs(): minimist.ParsedArgs;
17
- /**
18
- * Recursively deletes a file or directory at the given path.
19
- * @param {string} fullPath Absolute path to the file or directory to delete.
20
- */
21
- declare function del(fullPath: string): void;
22
- /**
23
- * Handles a glob stream to delete matched files and directories recursively.
24
- * @param {glob.Glob} globStream Glob stream object.
25
- */
26
- declare function delStream(globStream: glob.Glob): void;
27
- /**
28
- * Creates a directory/file tree string from an array of file paths and hashes.
29
- * @param {string[]} hashArray Array of strings in the format 'relative/path/to/file hash'.
30
- * @returns {string} Directory/file tree as a string, with file hashes.
31
- */
32
- declare function getFileTreeString(hashArray: string[]): string;
33
- /**
34
- * Creates an async delay for the specified number of milliseconds.
35
- * @param {number} ms Number of milliseconds to delay.
36
- * @returns {Promise<void>} Promise that resolves after the specified delay.
37
- */
38
- declare function delay(ms: number): Promise<void>;
39
-
40
- export { del, delStream, delay, getArgs, getFileTreeString, joinPathPreserveDriveLetter, parseGitRemotes };