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.
- package/binaries/binary-executor.cjs +43 -0
- package/{bin → binaries}/clean-nodemodule +0 -0
- package/binaries/clean-nodemodule.cjs +43 -0
- package/binaries/clean-nodemodule.cmd +4 -0
- package/{bin → binaries}/clean-nodemodules +0 -0
- package/binaries/clean-nodemodules.cjs +43 -0
- package/binaries/clean-nodemodules.cmd +5 -0
- package/{bin → binaries}/dev +0 -0
- package/binaries/dev.cjs +43 -0
- package/{bin → binaries}/empty +0 -0
- package/binaries/empty.cjs +43 -0
- package/{bin → binaries}/git-reduce-size +0 -0
- package/binaries/git-reduce-size.cjs +43 -0
- package/binaries/javakill.cjs +43 -0
- package/{bin → binaries}/javakill.cmd +0 -0
- package/{bin → binaries}/kill-process +0 -0
- package/binaries/kill-process.cjs +43 -0
- package/binaries/nodekill.cjs +43 -0
- package/{bin → binaries}/nodekill.ps1 +0 -0
- package/{bin → binaries}/prod +0 -0
- package/binaries/prod.cjs +43 -0
- package/{bin → binaries}/rmfind +0 -0
- package/binaries/rmfind.cjs +43 -0
- package/{bin → binaries}/rmx +0 -0
- package/binaries/rmx.cjs +43 -0
- package/{bin → binaries}/submodule-token +0 -0
- package/binaries/submodule-token.cjs +43 -0
- package/docs-src/clean-github-actions-caches.md +26 -0
- package/docs-src/free-chatgpt.md +26 -0
- package/lib/binary-collections-config.cjs +3 -2
- package/lib/binary-collections-config.mjs +2 -2
- package/lib/binary-collections.cjs +452 -105
- package/lib/binary-collections.mjs +131 -84
- package/lib/changelog.cjs +3 -3
- package/lib/changelog.mjs +177 -171
- package/lib/chunk-4EWQC6GZ.mjs +382 -0
- package/lib/chunk-4ZI7BQKQ.mjs +381 -0
- package/lib/chunk-5J2BEPY5.mjs +83 -0
- package/lib/{chunk-4BYBVEYC.mjs → chunk-66PAU5PS.mjs} +5 -4
- package/lib/chunk-6HHJRKFB.mjs +59 -0
- package/lib/chunk-6S4NXESK.mjs +26 -0
- package/lib/{chunk-ZYAQRPUL.mjs → chunk-7YD7IPFF.mjs} +2 -2
- package/lib/{chunk-SH3L6HHV.mjs → chunk-A2JQXI5Z.mjs} +2 -2
- package/lib/{chunk-EGSSKVDH.mjs → chunk-A3VUZEJK.mjs} +1 -1
- package/lib/chunk-AGZYRDC2.mjs +323 -0
- package/lib/{chunk-VVEZVNIV.mjs → chunk-AI4CVPJ7.mjs} +6 -6
- package/lib/chunk-BDCHCWHD.mjs +136 -0
- package/lib/chunk-BEZKJ25G.mjs +140 -0
- package/lib/chunk-DI5MDPSN.mjs +386 -0
- package/lib/{chunk-ONIBBBQ3.mjs → chunk-E6FDDAOO.mjs} +4 -3
- package/lib/chunk-FKI7IEB5.mjs +172 -0
- package/lib/chunk-GJTGHXRA.mjs +356 -0
- package/lib/{chunk-YV7DO3YV.mjs → chunk-HLGOWBEO.mjs} +1 -1
- package/lib/chunk-HMRMTYZM.mjs +40 -0
- package/lib/chunk-HN52G2YL.mjs +305 -0
- package/lib/chunk-HO6GHCOB.mjs +385 -0
- package/lib/chunk-LEM5OMRP.mjs +384 -0
- package/lib/{chunk-YX5U7XDR.mjs → chunk-M3YIYRHT.mjs} +6 -5
- package/lib/chunk-O6SWBEOQ.mjs +81 -0
- package/lib/{chunk-JGR2NW6D.mjs → chunk-PDSXF5HY.mjs} +3 -3
- package/lib/{chunk-AASHBCRW.mjs → chunk-QQ4A6DLD.mjs} +8 -0
- package/lib/chunk-RCP7DHVY.mjs +190 -0
- package/lib/chunk-SBNDSKG5.mjs +136 -0
- package/lib/chunk-U6SO4QEV.mjs +320 -0
- package/lib/{chunk-APBWENF6.mjs → chunk-V3N3JEUF.mjs} +3 -3
- package/lib/chunk-XD6BJK6Q.mjs +351 -0
- package/lib/chunk-XVBFFVCJ.mjs +209 -0
- package/lib/chunk-YXSFGA2D.mjs +383 -0
- package/lib/clean-github-actions-caches.cjs +243 -148
- package/lib/clean-github-actions-caches.mjs +3 -2
- package/lib/del-gradle.cjs +2 -2
- package/lib/del-gradle.js +1 -1
- package/lib/del-gradle.mjs +2 -2
- package/lib/del-node-modules.cjs +2 -2
- package/lib/del-node-modules.js +1 -1
- package/lib/del-node-modules.mjs +2 -2
- package/lib/del-ps.cjs +29 -8
- package/lib/del-ps.js +2 -2
- package/lib/del-ps.mjs +7 -5
- package/lib/del-yarn-caches.cjs +26 -5
- package/lib/del-yarn-caches.js +38 -3
- package/lib/del-yarn-caches.mjs +6 -6
- package/lib/find-node-modules-cli.cjs +5 -4
- package/lib/find-node-modules-cli.js +1 -1
- package/lib/find-node-modules-cli.mjs +2 -2
- package/lib/find-node-modules.cjs +4 -3
- package/lib/{find-node-modules.d.ts → find-node-modules.d.cts} +1 -1
- package/lib/find-node-modules.mjs +2 -2
- package/lib/free-chatgpt.cjs +548 -0
- package/lib/free-chatgpt.js +51 -0
- package/lib/free-chatgpt.mjs +50 -0
- package/lib/git/gitattributes.cjs +1 -1
- package/lib/git/{gitattributes.d.mts → gitattributes.d.cts} +5 -7
- package/lib/git/gitattributes.mjs +2 -2
- package/lib/git/line-endings.cjs +297 -64
- package/lib/git/line-endings.mjs +4 -4
- package/lib/git/normalize.cjs +26 -36
- package/lib/git/normalize.mjs +2 -2
- package/lib/git/permissions.cjs +77 -11
- package/lib/git/permissions.mjs +3 -3
- package/lib/git/pull-strategy.cjs +76 -9
- package/lib/git/pull-strategy.mjs +3 -3
- package/lib/git/user-config.cjs +266 -83
- package/lib/git/user-config.mjs +4 -4
- package/lib/git/utils.cjs +40 -60
- package/lib/git/utils.mjs +2 -2
- package/lib/git-diff-cli.cjs +651 -0
- package/lib/git-diff-cli.d.ts +1 -0
- package/lib/git-diff-cli.js +15 -0
- package/lib/git-diff-cli.mjs +16 -0
- package/lib/git-diff.cjs +657 -58
- package/lib/git-diff.d.ts +38 -83
- package/lib/git-diff.js +152 -0
- package/lib/git-diff.mjs +23 -85
- package/lib/git-fix.cjs +685 -97
- package/lib/git-fix.mjs +14 -13
- package/lib/git-purge.cjs +3 -3
- package/lib/git-purge.d.cts +1 -0
- package/lib/git-purge.mjs +43 -37
- package/lib/index.cjs +7 -6
- package/lib/index.d.ts +1 -1
- package/lib/index.js +2 -5
- package/lib/index.mjs +4 -4
- package/lib/npm-run-series.cjs +3 -3
- package/lib/npm-run-series.mjs +42 -36
- package/lib/package-resolutions-updater.cjs +5 -5
- package/lib/package-resolutions-updater.mjs +266 -309
- package/lib/print-directory-tree.cjs +275 -210
- package/lib/print-directory-tree.mjs +2 -2
- package/lib/ps/connected-domain.cjs +25 -2
- package/lib/ps/connected-domain.d.ts +10 -2
- package/lib/ps/connected-domain.js +5 -2
- package/lib/ps/connected-domain.mjs +8 -4
- package/lib/ps/index.cjs +345 -322
- package/lib/ps/index.d.mjs +1 -1
- package/lib/ps/index.js +1 -1
- package/lib/ps/index.mjs +179 -182
- package/lib/ps/isWin.cjs +24 -1
- package/lib/ps/isWin.d.ts +1 -1
- package/lib/ps/isWin.js +3 -1
- package/lib/ps/isWin.mjs +8 -4
- package/lib/ps/table-parser.cjs +167 -159
- package/lib/ps/table-parser.d.ts +5 -0
- package/lib/ps/table-parser.js +10 -4
- package/lib/ps/table-parser.mjs +9 -5
- package/lib/remove-module.cjs +262 -0
- package/lib/remove-module.d.mts +1 -0
- package/lib/remove-module.mjs +111 -0
- package/lib/rmpath.cjs +274 -0
- package/lib/rmpath.d.mts +3 -0
- package/lib/rmpath.mjs +108 -0
- package/lib/submodule-install.cjs +264 -86
- package/lib/submodule-install.mjs +51 -3
- package/lib/submodule-remove-cli.cjs +103 -0
- package/lib/submodule-remove-cli.d.ts +1 -0
- package/lib/submodule-remove-cli.js +31 -0
- package/lib/submodule-remove-cli.mjs +28 -0
- package/lib/submodule-remove.cjs +43 -0
- package/lib/submodule-remove.d.cts +2 -0
- package/lib/submodule-remove.mjs +6 -0
- package/lib/utils/chatgpt.cjs +383 -0
- package/lib/utils/chatgpt.d.ts +31 -0
- package/lib/utils/chatgpt.js +541 -0
- package/lib/utils/chatgpt.mjs +8 -0
- package/lib/{utils.cjs → utils/index.cjs} +1 -1
- package/lib/{utils.mjs → utils/index.mjs} +2 -2
- package/lib/yarn-reinstall.cjs +172 -38
- package/lib/yarn-reinstall.mjs +2 -2
- package/package.json +91 -71
- package/readme.md +43 -69
- package/releases/readme.md +36 -0
- package/test/README.md +101 -0
- package/test/package.json +2 -1
- package/test-project/readme.md +26 -0
- package/tmp/test-repo/README.md +35 -0
- package/tmp/test-repo/package.json +1 -1
- package/tmp/typedoc/readme.md +320 -0
- package/bin/bash-dummy +0 -56
- package/bin/bash-dummy.cmd +0 -25
- package/bin/dir-tree.cmd +0 -7
- package/bin/git-diff +0 -4
- package/bin/git-diff.cmd +0 -7
- package/bin/git-fix +0 -36
- package/bin/git-fix.cmd +0 -7
- package/bin/rmpath +0 -70
- package/bin/submodule-install.txt +0 -118
- package/bin/submodule-remove +0 -46
- package/bin/submodule.txt +0 -172
- package/lib/binary-collections-config.d.mts +0 -18
- package/lib/binary-collections-config.js +0 -39
- package/lib/binary-collections.d.mts +0 -137
- package/lib/binary-collections.d.ts +0 -137
- package/lib/changelog.d.mts +0 -2
- package/lib/changelog.js +0 -226
- package/lib/chunk-DPKAJKFO.mjs +0 -171
- package/lib/chunk-G3THLIDT.mjs +0 -200
- package/lib/chunk-W3ENOM53.mjs +0 -18
- package/lib/clean-github-actions-caches.d.mts +0 -169
- package/lib/clean-github-actions-caches.d.ts +0 -169
- package/lib/del-gradle.d.mts +0 -2
- package/lib/del-node-modules.d.mts +0 -2
- package/lib/del-ps.d.mts +0 -2
- package/lib/del-yarn-caches.d.mts +0 -2
- package/lib/find-node-modules-cli.d.mts +0 -1
- package/lib/find-node-modules.d.mts +0 -13
- package/lib/find-node-modules.js +0 -53
- package/lib/git/line-endings.d.mts +0 -83
- package/lib/git/line-endings.d.ts +0 -83
- package/lib/git/normalize.d.mts +0 -43
- package/lib/git/normalize.d.ts +0 -43
- package/lib/git/permissions.d.mts +0 -17
- package/lib/git/permissions.d.ts +0 -17
- package/lib/git/pull-strategy.d.mts +0 -15
- package/lib/git/pull-strategy.d.ts +0 -15
- package/lib/git/user-config.d.mts +0 -105
- package/lib/git/user-config.d.ts +0 -105
- package/lib/git/utils.d.mts +0 -69
- package/lib/git/utils.d.ts +0 -69
- package/lib/git-diff.d.mts +0 -84
- package/lib/git-fix.d.mts +0 -141
- package/lib/git-fix.d.ts +0 -141
- package/lib/git-purge.d.mts +0 -2
- package/lib/git-purge.js +0 -59
- package/lib/index.d.mts +0 -1
- package/lib/npm-run-series.d.mts +0 -1
- package/lib/npm-run-series.d.ts +0 -2
- package/lib/npm-run-series.js +0 -86
- package/lib/package-resolutions-updater.d.ts +0 -352
- package/lib/print-directory-tree.d.mts +0 -234
- package/lib/print-directory-tree.d.ts +0 -234
- package/lib/ps/connected-domain.d.mts +0 -3
- package/lib/ps/index.d.d.mts +0 -26
- package/lib/ps/index.d.d.ts +0 -26
- package/lib/ps/index.d.mts +0 -26
- package/lib/ps/isWin.d.mts +0 -3
- package/lib/ps/table-parser.d.mts +0 -3
- package/lib/submodule-install.d.mts +0 -121
- package/lib/submodule-install.d.ts +0 -121
- package/lib/utils.d.mts +0 -40
- package/lib/utils.js +0 -181
- package/lib/yarn-reinstall.d.mts +0 -49
- package/lib/yarn-reinstall.d.ts +0 -49
- package/src/package-resolutions-updater.mjs +0 -350
- package/src/print-directory-tree.cjs +0 -234
- package/src/ps/index.js +0 -286
- package/src/yarn-reinstall.cjs +0 -49
- /package/{bin → binaries}/nodekill +0 -0
- /package/{bin → binaries}/nodekill.cmd +0 -0
- /package/lib/{binary-collections-config.d.ts → binary-collections-config.d.cts} +0 -0
- /package/lib/{changelog.d.ts → changelog.d.cts} +0 -0
- /package/lib/{git-purge.d.ts → free-chatgpt.d.ts} +0 -0
- /package/lib/{git-diff.d.cts → npm-run-series.d.cts} +0 -0
- /package/lib/{utils.d.ts → utils/index.d.cts} +0 -0
|
@@ -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
|
-
const ACCESS_TOKEN = process.env.GITHUB_TOKEN || process.env.ACCESS_TOKEN;
|
|
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 (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://${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:${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}//${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 };
|
package/lib/utils.js
DELETED
|
@@ -1,181 +0,0 @@
|
|
|
1
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
-
});
|
|
9
|
-
};
|
|
10
|
-
const fs = require("fs");
|
|
11
|
-
const path = require("upath");
|
|
12
|
-
const argv = require("minimist")(process.argv.slice(2));
|
|
13
|
-
const { exec } = require("child_process");
|
|
14
|
-
const { URL } = require("url");
|
|
15
|
-
const { promisify } = require("util");
|
|
16
|
-
/**
|
|
17
|
-
* Promisified version of Node.js exec function for async shell command execution.
|
|
18
|
-
* @type {(command: string) => Promise<{ stdout: string, stderr: string }>}
|
|
19
|
-
*/
|
|
20
|
-
const execAsync = promisify(exec);
|
|
21
|
-
function parseGitRemotes() {
|
|
22
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
23
|
-
try {
|
|
24
|
-
// Run the `git remote -v` command
|
|
25
|
-
const { stdout } = yield execAsync("git remote -v");
|
|
26
|
-
// Split the output into lines
|
|
27
|
-
const lines = stdout.split("\n");
|
|
28
|
-
// Object to hold the remotes
|
|
29
|
-
const remotes = {};
|
|
30
|
-
// Process each line
|
|
31
|
-
lines.forEach((line) => {
|
|
32
|
-
const [name, url] = line.split("\t");
|
|
33
|
-
if (name && url) {
|
|
34
|
-
const [repoUrl] = url.split(" ");
|
|
35
|
-
try {
|
|
36
|
-
// Parse the URL
|
|
37
|
-
const parsedUrl = new URL(repoUrl);
|
|
38
|
-
// Extract the path from the URL
|
|
39
|
-
const pathParts = parsedUrl.pathname.split("/").filter(Boolean);
|
|
40
|
-
// Check if the URL is from GitHub and has the username/repo format
|
|
41
|
-
if (parsedUrl.hostname === "github.com" && pathParts.length === 2) {
|
|
42
|
-
// Remove the `.git` suffix if present
|
|
43
|
-
let repoPath = pathParts.join("/");
|
|
44
|
-
if (repoPath.endsWith(".git")) {
|
|
45
|
-
repoPath = repoPath.slice(0, -4); // Remove the `.git` suffix
|
|
46
|
-
}
|
|
47
|
-
remotes[name] = repoPath;
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
catch (e) {
|
|
51
|
-
console.error("URL Parsing Error:", e.message);
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
});
|
|
55
|
-
return remotes;
|
|
56
|
-
}
|
|
57
|
-
catch (error) {
|
|
58
|
-
console.error("Error:", error.message);
|
|
59
|
-
return {};
|
|
60
|
-
}
|
|
61
|
-
});
|
|
62
|
-
}
|
|
63
|
-
module.exports.parseGitRemotes = parseGitRemotes;
|
|
64
|
-
/**
|
|
65
|
-
* Joins all given path segments together and normalizes the resulting path.
|
|
66
|
-
* Preserves the case of the drive letter on Windows.
|
|
67
|
-
*
|
|
68
|
-
* @param {...string} segments Path segments to join.
|
|
69
|
-
* @returns {string} Normalized path with drive letter case preserved.
|
|
70
|
-
*/
|
|
71
|
-
function joinPathPreserveDriveLetter(...segments) {
|
|
72
|
-
let fullPath = require("path").join(...segments);
|
|
73
|
-
// Check if the path starts with a drive letter (e.g., C:\)
|
|
74
|
-
if (/^[a-z]:\\/.test(fullPath)) {
|
|
75
|
-
// Convert the drive letter to uppercase
|
|
76
|
-
fullPath = fullPath.charAt(0).toUpperCase() + fullPath.slice(1);
|
|
77
|
-
}
|
|
78
|
-
return fullPath;
|
|
79
|
-
}
|
|
80
|
-
module.exports.joinPathPreserveDriveLetter = joinPathPreserveDriveLetter;
|
|
81
|
-
/**
|
|
82
|
-
* Returns parsed command line arguments using minimist.
|
|
83
|
-
* @returns {import('minimist').ParsedArgs} Parsed command line arguments
|
|
84
|
-
*/
|
|
85
|
-
function getArgs() {
|
|
86
|
-
return argv;
|
|
87
|
-
}
|
|
88
|
-
module.exports.getArgs = getArgs;
|
|
89
|
-
/**
|
|
90
|
-
* Recursively deletes a file or directory at the given path.
|
|
91
|
-
* @param {string} fullPath Absolute path to the file or directory to delete.
|
|
92
|
-
*/
|
|
93
|
-
function del(fullPath) {
|
|
94
|
-
if (fs.statSync(fullPath).isDirectory()) {
|
|
95
|
-
// delete all files each package directory
|
|
96
|
-
const subdir = fs.readdirSync(fullPath).map((dirPath) => path.resolve(fullPath, dirPath));
|
|
97
|
-
for (let i = 0; i < subdir.length; i++) {
|
|
98
|
-
del(subdir[i]);
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
else {
|
|
102
|
-
try {
|
|
103
|
-
fs.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7000 });
|
|
104
|
-
console.log("deleted", fullPath);
|
|
105
|
-
}
|
|
106
|
-
catch (_) {
|
|
107
|
-
console.log("failed delete", fullPath);
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
module.exports.del = del;
|
|
112
|
-
/**
|
|
113
|
-
* Handles a glob stream to delete matched files and directories recursively.
|
|
114
|
-
* @param {glob.Glob} globStream Glob stream object.
|
|
115
|
-
*/
|
|
116
|
-
function delStream(globStream) {
|
|
117
|
-
globStream.stream().on("data", (result) => {
|
|
118
|
-
const fullPath = path.resolve(process.cwd(), result);
|
|
119
|
-
if (fs.statSync(fullPath).isDirectory()) {
|
|
120
|
-
// delete all files each package directory
|
|
121
|
-
const subdir = fs.readdirSync(fullPath).map((dirPath) => path.resolve(fullPath, dirPath));
|
|
122
|
-
for (let i = 0; i < subdir.length; i++) {
|
|
123
|
-
del(subdir[i]);
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
del(fullPath);
|
|
127
|
-
});
|
|
128
|
-
}
|
|
129
|
-
module.exports.delStream = delStream;
|
|
130
|
-
/**
|
|
131
|
-
* Creates a directory/file tree string from an array of file paths and hashes.
|
|
132
|
-
* @param {string[]} hashArray Array of strings in the format 'relative/path/to/file hash'.
|
|
133
|
-
* @returns {string} Directory/file tree as a string, with file hashes.
|
|
134
|
-
*/
|
|
135
|
-
function getFileTreeString(hashArray) {
|
|
136
|
-
const tree = {};
|
|
137
|
-
// Map file paths to hashes for quick lookup
|
|
138
|
-
const hashMap = {};
|
|
139
|
-
for (const entry of hashArray) {
|
|
140
|
-
const [filePath, hash] = entry.split(" ");
|
|
141
|
-
hashMap[filePath] = hash;
|
|
142
|
-
const parts = filePath.split("/");
|
|
143
|
-
let current = tree;
|
|
144
|
-
for (let i = 0; i < parts.length; i++) {
|
|
145
|
-
const part = parts[i];
|
|
146
|
-
if (i === parts.length - 1) {
|
|
147
|
-
current[part] = null; // file
|
|
148
|
-
}
|
|
149
|
-
else {
|
|
150
|
-
current[part] = current[part] || {};
|
|
151
|
-
current = current[part];
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
function printNode(node, prefix = "", parentPath = "") {
|
|
156
|
-
const keys = Object.keys(node).sort();
|
|
157
|
-
let lines = [];
|
|
158
|
-
keys.forEach((key, idx) => {
|
|
159
|
-
const isLast = idx === keys.length - 1;
|
|
160
|
-
const branch = isLast ? "└── " : "├── ";
|
|
161
|
-
const currentPath = parentPath ? parentPath + "/" + key : key;
|
|
162
|
-
if (node[key] === null) {
|
|
163
|
-
lines.push(prefix + branch + key + " [" + (hashMap[currentPath] || "") + "]");
|
|
164
|
-
}
|
|
165
|
-
else {
|
|
166
|
-
lines.push(prefix + branch + key + "/");
|
|
167
|
-
lines = lines.concat(printNode(node[key], prefix + (isLast ? " " : "│ "), currentPath));
|
|
168
|
-
}
|
|
169
|
-
});
|
|
170
|
-
return lines;
|
|
171
|
-
}
|
|
172
|
-
return printNode(tree, "", "").join("\n");
|
|
173
|
-
}
|
|
174
|
-
module.exports.getFileTreeString = getFileTreeString;
|
|
175
|
-
/**
|
|
176
|
-
* Creates an async delay for the specified number of milliseconds.
|
|
177
|
-
* @param {number} ms Number of milliseconds to delay.
|
|
178
|
-
* @returns {Promise<void>} Promise that resolves after the specified delay.
|
|
179
|
-
*/
|
|
180
|
-
const delay = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
181
|
-
module.exports.delay = delay;
|
package/lib/yarn-reinstall.d.mts
DELETED
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
const { execSync } = require("child_process");
|
|
2
|
-
const { getArgs } = require("./utils.js");
|
|
3
|
-
const args = getArgs();
|
|
4
|
-
const positional = args._ || [];
|
|
5
|
-
|
|
6
|
-
if (positional.length === 0) {
|
|
7
|
-
console.error("Usage: yarn-reinstall <packageName> [--dev|-D|--peer|-P|--optional|-O]");
|
|
8
|
-
process.exit(1);
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
const packageName = positional[0];
|
|
12
|
-
const flags = positional.slice(1).concat(
|
|
13
|
-
Object.keys(args)
|
|
14
|
-
.filter((k) => k !== "_" && args[k] === true)
|
|
15
|
-
.map((k) => `--${k}`)
|
|
16
|
-
);
|
|
17
|
-
|
|
18
|
-
if (!packageName) {
|
|
19
|
-
console.error("Please provide a package name.");
|
|
20
|
-
process.exit(1);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
// Remove and add commands
|
|
24
|
-
const removeCmd = `yarn remove ${packageName}`;
|
|
25
|
-
const addCmd = `yarn add ${packageName} ${flags.join(" ")}`.trim();
|
|
26
|
-
|
|
27
|
-
try {
|
|
28
|
-
// Check if the package is installed before removing
|
|
29
|
-
let isInstalled = false;
|
|
30
|
-
try {
|
|
31
|
-
const listOutput = execSync(`yarn list --pattern "${packageName}" --depth=0`, { encoding: "utf8" });
|
|
32
|
-
isInstalled = listOutput.includes(packageName + "@");
|
|
33
|
-
} catch (_e) {
|
|
34
|
-
// If yarn list fails, assume not installed
|
|
35
|
-
isInstalled = false;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
if (isInstalled) {
|
|
39
|
-
console.log(`Running: ${removeCmd}`);
|
|
40
|
-
execSync(removeCmd, { stdio: "inherit" });
|
|
41
|
-
} else {
|
|
42
|
-
console.warn(`Package "${packageName}" was not installed or not referenced, skipping remove.`);
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
console.log(`Running: ${addCmd}`);
|
|
46
|
-
execSync(addCmd, { stdio: "inherit" });
|
|
47
|
-
} catch (err) {
|
|
48
|
-
process.exit(err.status || 1);
|
|
49
|
-
}
|
package/lib/yarn-reinstall.d.ts
DELETED
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
const { execSync } = require("child_process");
|
|
2
|
-
const { getArgs } = require("./utils.js");
|
|
3
|
-
const args = getArgs();
|
|
4
|
-
const positional = args._ || [];
|
|
5
|
-
|
|
6
|
-
if (positional.length === 0) {
|
|
7
|
-
console.error("Usage: yarn-reinstall <packageName> [--dev|-D|--peer|-P|--optional|-O]");
|
|
8
|
-
process.exit(1);
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
const packageName = positional[0];
|
|
12
|
-
const flags = positional.slice(1).concat(
|
|
13
|
-
Object.keys(args)
|
|
14
|
-
.filter((k) => k !== "_" && args[k] === true)
|
|
15
|
-
.map((k) => `--${k}`)
|
|
16
|
-
);
|
|
17
|
-
|
|
18
|
-
if (!packageName) {
|
|
19
|
-
console.error("Please provide a package name.");
|
|
20
|
-
process.exit(1);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
// Remove and add commands
|
|
24
|
-
const removeCmd = `yarn remove ${packageName}`;
|
|
25
|
-
const addCmd = `yarn add ${packageName} ${flags.join(" ")}`.trim();
|
|
26
|
-
|
|
27
|
-
try {
|
|
28
|
-
// Check if the package is installed before removing
|
|
29
|
-
let isInstalled = false;
|
|
30
|
-
try {
|
|
31
|
-
const listOutput = execSync(`yarn list --pattern "${packageName}" --depth=0`, { encoding: "utf8" });
|
|
32
|
-
isInstalled = listOutput.includes(packageName + "@");
|
|
33
|
-
} catch (_e) {
|
|
34
|
-
// If yarn list fails, assume not installed
|
|
35
|
-
isInstalled = false;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
if (isInstalled) {
|
|
39
|
-
console.log(`Running: ${removeCmd}`);
|
|
40
|
-
execSync(removeCmd, { stdio: "inherit" });
|
|
41
|
-
} else {
|
|
42
|
-
console.warn(`Package "${packageName}" was not installed or not referenced, skipping remove.`);
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
console.log(`Running: ${addCmd}`);
|
|
46
|
-
execSync(addCmd, { stdio: "inherit" });
|
|
47
|
-
} catch (err) {
|
|
48
|
-
process.exit(err.status || 1);
|
|
49
|
-
}
|