binary-collections 2.0.10 → 2.0.11
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/.puppeterrc.cjs +25 -0
- package/binaries/binary-executor.cjs +138 -3
- package/binaries/clean-nodemodule.cjs +138 -3
- package/binaries/clean-nodemodules.cjs +138 -3
- package/binaries/dev.cjs +138 -3
- package/binaries/empty.cjs +138 -3
- package/binaries/git-reduce-size.cjs +138 -3
- package/binaries/javakill.cjs +138 -3
- package/binaries/kill-night-crows.bat +7 -0
- package/binaries/kill-night-crows.ps1 +172 -0
- package/binaries/kill-process.cjs +138 -3
- package/binaries/nodekill.cjs +138 -3
- package/binaries/prod.cjs +138 -3
- package/binaries/py +111 -0
- package/binaries/py.cjs +178 -0
- package/binaries/py.cmd +49 -0
- package/binaries/rmfind.cjs +138 -3
- package/binaries/rmx.cjs +138 -3
- package/binaries/submodule-token.cjs +138 -3
- package/binaries/test-cjs +10 -0
- package/binaries/test-cjs.cjs +178 -0
- package/binaries/test-cjs.cmd +11 -0
- package/binaries/yarn-clean +32 -0
- package/binaries/yarn-clean.cjs +178 -0
- package/binaries/yarn-clean.cmd +30 -0
- package/binaries/yarn-clean.py +148 -0
- package/lib/binary-collections-config.cjs +1 -1
- package/lib/binary-collections-config.mjs +1 -1
- package/lib/binary-collections.cjs +167 -106
- package/lib/binary-collections.mjs +108 -94
- package/lib/changelog.cjs +61 -13
- package/lib/changelog.mjs +1 -1
- package/lib/{chunk-AI4CVPJ7.mjs → chunk-2CBJCW7E.mjs} +4 -4
- package/lib/chunk-34IQDTLZ.mjs +27 -0
- package/lib/chunk-3HFFECCI.mjs +27 -0
- package/lib/{chunk-SBNDSKG5.mjs → chunk-4UHL4WVN.mjs} +1 -1
- package/lib/chunk-7XTEJHOE.mjs +193 -0
- package/lib/chunk-AJDD5DZM.mjs +109 -0
- package/lib/chunk-BZWVHODJ.mjs +62 -0
- package/lib/{chunk-BEZKJ25G.mjs → chunk-FCDQGYBF.mjs} +5 -9
- package/lib/chunk-GEYA2USY.mjs +207 -0
- package/lib/chunk-ID2WBTE2.mjs +80 -0
- package/lib/chunk-JXFOHKDM.mjs +239 -0
- package/lib/{chunk-DI5MDPSN.mjs → chunk-N436BNBK.mjs} +192 -64
- package/lib/chunk-NCXAP7AA.mjs +31 -0
- package/lib/chunk-PDN26I7O.mjs +188 -0
- package/lib/{chunk-E6FDDAOO.mjs → chunk-RWLXRTYP.mjs} +1 -1
- package/lib/{chunk-BDCHCWHD.mjs → chunk-TOIVAQF7.mjs} +4 -4
- package/lib/chunk-V5SKYJUB.mjs +136 -0
- package/lib/{chunk-HMRMTYZM.mjs → chunk-WSRETQCA.mjs} +21 -2
- package/lib/chunk-XA3SNBPA.mjs +184 -0
- package/lib/chunk-YYLIQQKF.mjs +31 -0
- package/lib/{chunk-V3N3JEUF.mjs → chunk-Z6JLYU2J.mjs} +60 -13
- package/lib/{chunk-O6SWBEOQ.mjs → chunk-ZDMWBSYF.mjs} +2 -2
- package/lib/clean-github-actions-caches.cjs +63 -15
- package/lib/clean-github-actions-caches.mjs +3 -3
- package/lib/del-gradle.cjs +61 -13
- package/lib/del-gradle.js +1 -0
- package/lib/del-gradle.mjs +1 -1
- package/lib/del-node-modules.cjs +143 -148
- package/lib/del-node-modules.js +210 -14
- package/lib/del-node-modules.mjs +148 -17
- package/lib/del-ps.cjs +61 -13
- package/lib/del-ps.js +1 -0
- package/lib/del-ps.mjs +1 -1
- package/lib/del-yarn-caches.cjs +61 -13
- package/lib/del-yarn-caches.mjs +1 -1
- package/lib/find-node-modules-cli.js +1 -0
- package/lib/free-chatgpt.cjs +253 -47
- package/lib/free-chatgpt.mjs +2 -2
- package/lib/git/gitattributes.cjs +1 -0
- package/lib/git/gitattributes.d.cts +7 -2
- package/lib/git/gitattributes.mjs +1 -1
- package/lib/git/line-endings.cjs +2 -1
- package/lib/git/line-endings.mjs +2 -2
- package/lib/git/undo-commit-cli.cjs +110 -0
- package/lib/git/undo-commit-cli.d.ts +1 -0
- package/lib/git/undo-commit-cli.js +4 -0
- package/lib/git/undo-commit-cli.mjs +14 -0
- package/lib/git/undo-commit.cjs +81 -0
- package/lib/git/undo-commit.d.cts +1 -0
- package/lib/git/undo-commit.mjs +7 -0
- package/lib/git/undo-staged-cli.cjs +110 -0
- package/lib/git/undo-staged-cli.d.ts +1 -0
- package/lib/git/undo-staged-cli.js +4 -0
- package/lib/git/undo-staged-cli.mjs +14 -0
- package/lib/git/undo-staged.cjs +81 -0
- package/lib/git/undo-staged.d.cts +1 -0
- package/lib/git/undo-staged.mjs +7 -0
- package/lib/git/user-config.cjs +61 -14
- package/lib/git/user-config.mjs +2 -2
- package/lib/git-diff-cli.cjs +255 -49
- package/lib/git-diff-cli.d.ts +1 -0
- package/lib/git-diff-cli.js +1 -0
- package/lib/git-diff-cli.mjs +5 -4
- package/lib/git-diff.cjs +254 -49
- package/lib/git-diff.mjs +4 -4
- package/lib/git-fix.cjs +64 -16
- package/lib/git-fix.mjs +10 -10
- package/lib/git-purge.cjs +61 -13
- package/lib/git-purge.mjs +1 -1
- package/lib/kill-night-crows.cjs +87 -0
- package/lib/kill-night-crows.d.mts +1 -0
- package/lib/kill-night-crows.mjs +65 -0
- package/lib/npm-run-series.cjs +60 -13
- package/lib/npm-run-series.mjs +1 -1
- package/lib/package-resolutions-updater-cli.cjs +560 -0
- package/lib/package-resolutions-updater-cli.d.mts +1 -0
- package/lib/package-resolutions-updater-cli.mjs +124 -0
- package/lib/package-resolutions-updater.cjs +174 -154
- package/lib/package-resolutions-updater.d.mts +32 -1
- package/lib/package-resolutions-updater.mjs +16 -294
- package/lib/php-cs-fixer-staged.cjs +105 -0
- package/lib/php-cs-fixer-staged.d.cts +2 -0
- package/lib/php-cs-fixer-staged.mjs +117 -0
- package/lib/print-directory-tree.cjs +62 -14
- package/lib/print-directory-tree.mjs +2 -2
- package/lib/ps/connected-domain.d.ts +1 -1
- package/lib/ps/index.js +1 -0
- package/lib/remove-module.cjs +61 -13
- package/lib/remove-module.mjs +1 -1
- package/lib/rmpath.cjs +63 -15
- package/lib/rmpath.mjs +2 -2
- package/lib/submodule-install.cjs +62 -15
- package/lib/submodule-install.mjs +3 -3
- package/lib/submodule-remove-cli.cjs +5 -1
- package/lib/submodule-remove-cli.mjs +1 -1
- package/lib/submodule-remove.cjs +4 -1
- package/lib/submodule-remove.mjs +1 -1
- package/lib/utils/chatgpt.cjs +192 -34
- package/lib/utils/chatgpt.js +210 -43
- package/lib/utils/chatgpt.mjs +1 -1
- package/lib/utils/findEnvFiles.cjs +107 -0
- package/lib/utils/findEnvFiles.d.ts +8 -0
- package/lib/utils/findEnvFiles.js +121 -0
- package/lib/utils/findEnvFiles.mjs +8 -0
- package/lib/utils/findWorkspaceRoot.cjs +70 -0
- package/lib/utils/findWorkspaceRoot.d.ts +9 -0
- package/lib/utils/findWorkspaceRoot.js +57 -0
- package/lib/utils/findWorkspaceRoot.mjs +40 -0
- package/lib/utils/index.cjs +60 -13
- package/lib/utils/index.mjs +1 -1
- package/lib/utils/isGithubTokenValid.cjs +64 -0
- package/lib/utils/isGithubTokenValid.d.ts +7 -0
- package/lib/utils/isGithubTokenValid.js +48 -0
- package/lib/utils/isGithubTokenValid.mjs +36 -0
- package/lib/yarn-reinstall.cjs +61 -13
- package/lib/yarn-reinstall.mjs +1 -1
- package/package.json +107 -93
- package/readme.md +33 -34
- package/releases/readme.md +1 -1
- package/requirements.txt +1 -0
- package/lib/chunk-4EWQC6GZ.mjs +0 -382
- package/lib/chunk-4ZI7BQKQ.mjs +0 -381
- package/lib/chunk-5J2BEPY5.mjs +0 -83
- package/lib/chunk-AGZYRDC2.mjs +0 -323
- package/lib/chunk-HN52G2YL.mjs +0 -305
- package/lib/chunk-HO6GHCOB.mjs +0 -385
- package/lib/chunk-LEM5OMRP.mjs +0 -384
- package/lib/chunk-RCP7DHVY.mjs +0 -190
- package/lib/chunk-U6SO4QEV.mjs +0 -320
- package/lib/chunk-XD6BJK6Q.mjs +0 -351
- package/lib/chunk-YXSFGA2D.mjs +0 -383
- package/lib/git/gitattributes.d.ts +0 -33
- package/lib/git/gitattributes.js +0 -223
|
@@ -10,6 +10,10 @@ var __esm = (fn, res) => function __init() {
|
|
|
10
10
|
var __commonJS = (cb, mod) => function __require() {
|
|
11
11
|
return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
|
|
12
12
|
};
|
|
13
|
+
var __export = (target, all) => {
|
|
14
|
+
for (var name in all)
|
|
15
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
16
|
+
};
|
|
13
17
|
var __copyProps = (to, from, except, desc) => {
|
|
14
18
|
if (from && typeof from === "object" || typeof from === "function") {
|
|
15
19
|
for (let key of __getOwnPropNames(from))
|
|
@@ -26,6 +30,7 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
|
26
30
|
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
27
31
|
mod
|
|
28
32
|
));
|
|
33
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
34
|
|
|
30
35
|
// node_modules/tsup/assets/cjs_shims.js
|
|
31
36
|
var init_cjs_shims = __esm({
|
|
@@ -37,8 +42,8 @@ var init_cjs_shims = __esm({
|
|
|
37
42
|
var require_utils = __commonJS({
|
|
38
43
|
"src/utils/index.cjs"(exports2, module2) {
|
|
39
44
|
init_cjs_shims();
|
|
40
|
-
var
|
|
41
|
-
var
|
|
45
|
+
var fs3 = require("fs");
|
|
46
|
+
var path3 = require("upath");
|
|
42
47
|
var argv = require("minimist")(process.argv.slice(2));
|
|
43
48
|
var { exec } = require("child_process");
|
|
44
49
|
var { URL: URL2 } = require("url");
|
|
@@ -88,31 +93,78 @@ var require_utils = __commonJS({
|
|
|
88
93
|
}
|
|
89
94
|
module2.exports.getArgs = getArgs2;
|
|
90
95
|
function del(fullPath) {
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
96
|
+
try {
|
|
97
|
+
if (!fs3.existsSync(fullPath)) return;
|
|
98
|
+
const stat = fs3.lstatSync(fullPath);
|
|
99
|
+
if (stat.isSymbolicLink()) {
|
|
100
|
+
try {
|
|
101
|
+
fs3.unlinkSync(fullPath);
|
|
102
|
+
console.log("deleted symlink", fullPath);
|
|
103
|
+
} catch (e) {
|
|
104
|
+
console.log("failed delete symlink", fullPath, e && e.message);
|
|
105
|
+
}
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
if (stat.isDirectory()) {
|
|
109
|
+
const subdir = fs3.readdirSync(fullPath).map((dirPath) => path3.resolve(fullPath, dirPath));
|
|
110
|
+
for (let i = 0; i < subdir.length; i++) {
|
|
111
|
+
del(subdir[i]);
|
|
112
|
+
}
|
|
113
|
+
try {
|
|
114
|
+
fs3.rmdirSync(fullPath);
|
|
115
|
+
console.log("deleted", fullPath);
|
|
116
|
+
} catch (e) {
|
|
117
|
+
try {
|
|
118
|
+
fs3.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7e3 });
|
|
119
|
+
console.log("deleted", fullPath);
|
|
120
|
+
} catch (ee) {
|
|
121
|
+
console.log("failed delete", fullPath, ee && ee.message);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
return;
|
|
95
125
|
}
|
|
96
|
-
} else {
|
|
97
126
|
try {
|
|
98
|
-
|
|
127
|
+
fs3.unlinkSync(fullPath);
|
|
99
128
|
console.log("deleted", fullPath);
|
|
100
|
-
} catch (
|
|
101
|
-
|
|
129
|
+
} catch (e) {
|
|
130
|
+
try {
|
|
131
|
+
fs3.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7e3 });
|
|
132
|
+
console.log("deleted", fullPath);
|
|
133
|
+
} catch (ee) {
|
|
134
|
+
console.log("failed delete", fullPath, ee && ee.message);
|
|
135
|
+
}
|
|
102
136
|
}
|
|
137
|
+
} catch (err) {
|
|
138
|
+
console.log("failed delete", fullPath, err && err.message);
|
|
103
139
|
}
|
|
104
140
|
}
|
|
105
141
|
module2.exports.del = del;
|
|
106
142
|
function delStream(globStream) {
|
|
107
143
|
globStream.stream().on("data", (result) => {
|
|
108
|
-
const fullPath =
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
144
|
+
const fullPath = path3.resolve(process.cwd(), result);
|
|
145
|
+
try {
|
|
146
|
+
if (fs3.existsSync(fullPath)) {
|
|
147
|
+
const stat = fs3.lstatSync(fullPath);
|
|
148
|
+
if (stat.isSymbolicLink()) {
|
|
149
|
+
try {
|
|
150
|
+
fs3.unlinkSync(fullPath);
|
|
151
|
+
console.log("deleted symlink", fullPath);
|
|
152
|
+
} catch (e) {
|
|
153
|
+
console.log("failed delete symlink", fullPath, e && e.message);
|
|
154
|
+
}
|
|
155
|
+
return;
|
|
156
|
+
}
|
|
157
|
+
if (stat.isDirectory()) {
|
|
158
|
+
const subdir = fs3.readdirSync(fullPath).map((dirPath) => path3.resolve(fullPath, dirPath));
|
|
159
|
+
for (let i = 0; i < subdir.length; i++) {
|
|
160
|
+
del(subdir[i]);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
113
163
|
}
|
|
164
|
+
del(fullPath);
|
|
165
|
+
} catch (err) {
|
|
166
|
+
console.log("failed processing", fullPath, err && err.message);
|
|
114
167
|
}
|
|
115
|
-
del(fullPath);
|
|
116
168
|
});
|
|
117
169
|
}
|
|
118
170
|
module2.exports.delStream = delStream;
|
|
@@ -159,18 +211,112 @@ var require_utils = __commonJS({
|
|
|
159
211
|
});
|
|
160
212
|
|
|
161
213
|
// src/package-resolutions-updater.mjs
|
|
214
|
+
var package_resolutions_updater_exports = {};
|
|
215
|
+
__export(package_resolutions_updater_exports, {
|
|
216
|
+
fetchJson: () => fetchJson,
|
|
217
|
+
getLatestCommit: () => getLatestCommit,
|
|
218
|
+
getLatestCommitAcrossBranches: () => getLatestCommitAcrossBranches,
|
|
219
|
+
parseGitHubUrl: () => import_git_command_helper.parseGitHubUrl,
|
|
220
|
+
replaceRawWithLatestHash: () => replaceRawWithLatestHash
|
|
221
|
+
});
|
|
222
|
+
module.exports = __toCommonJS(package_resolutions_updater_exports);
|
|
162
223
|
init_cjs_shims();
|
|
163
|
-
var import_ansi_colors = __toESM(require("ansi-colors"), 1);
|
|
164
224
|
var dotenv = __toESM(require("dotenv"), 1);
|
|
165
225
|
var import_fs = __toESM(require("fs"), 1);
|
|
166
226
|
var import_https = __toESM(require("https"), 1);
|
|
167
227
|
var import_os = __toESM(require("os"), 1);
|
|
168
228
|
var import_path = __toESM(require("path"), 1);
|
|
169
229
|
var utils = __toESM(require_utils(), 1);
|
|
230
|
+
|
|
231
|
+
// src/utils/findEnvFiles.js
|
|
232
|
+
init_cjs_shims();
|
|
233
|
+
var import_node_fs = __toESM(require("fs"), 1);
|
|
234
|
+
var import_node_path = __toESM(require("path"), 1);
|
|
235
|
+
var glob = __toESM(require("glob"), 1);
|
|
236
|
+
var DEFAULT_IGNORES = [
|
|
237
|
+
"**/node_modules/**",
|
|
238
|
+
"**/.git/**",
|
|
239
|
+
"**/.yarn/**",
|
|
240
|
+
"**/.pnpm/**",
|
|
241
|
+
"**/dist/**",
|
|
242
|
+
"**/build/**",
|
|
243
|
+
"**/coverage/**",
|
|
244
|
+
"**/vendor/**",
|
|
245
|
+
"**/tmp/**",
|
|
246
|
+
"**/.cache/**",
|
|
247
|
+
"**/assets/**",
|
|
248
|
+
"**/logs/**",
|
|
249
|
+
"**/output/**",
|
|
250
|
+
"**/public/**",
|
|
251
|
+
"**/static/**",
|
|
252
|
+
"**/temp/**",
|
|
253
|
+
"**/backup/**",
|
|
254
|
+
"**/backups/**",
|
|
255
|
+
"**/examples/**",
|
|
256
|
+
"**/docs/**",
|
|
257
|
+
"**/tests/**",
|
|
258
|
+
"**/__tests__/**",
|
|
259
|
+
"**/spec/**",
|
|
260
|
+
"**/__specs__/**",
|
|
261
|
+
"**/scripts/**",
|
|
262
|
+
"**/bin/**",
|
|
263
|
+
"**/hooks/**",
|
|
264
|
+
"**/config/**",
|
|
265
|
+
"**/configs/**",
|
|
266
|
+
"**/settings/**",
|
|
267
|
+
"**/.vscode/**",
|
|
268
|
+
"**/.idea/**"
|
|
269
|
+
];
|
|
270
|
+
function findEnvFiles(startDir = process.cwd(), filter) {
|
|
271
|
+
const found = /* @__PURE__ */ new Set();
|
|
272
|
+
function addFile(file) {
|
|
273
|
+
const normalized = import_node_path.default.normalize(file);
|
|
274
|
+
if (typeof filter === "function" && !filter(normalized)) {
|
|
275
|
+
return;
|
|
276
|
+
}
|
|
277
|
+
found.add(normalized);
|
|
278
|
+
}
|
|
279
|
+
let current = import_node_path.default.resolve(startDir);
|
|
280
|
+
while (true) {
|
|
281
|
+
const envPath2 = import_node_path.default.join(current, ".env");
|
|
282
|
+
if (import_node_fs.default.existsSync(envPath2)) {
|
|
283
|
+
addFile(envPath2);
|
|
284
|
+
}
|
|
285
|
+
const parent = import_node_path.default.dirname(current);
|
|
286
|
+
if (parent === current) {
|
|
287
|
+
break;
|
|
288
|
+
}
|
|
289
|
+
current = parent;
|
|
290
|
+
}
|
|
291
|
+
const files = glob.globSync("**/.env*", {
|
|
292
|
+
cwd: startDir,
|
|
293
|
+
absolute: true,
|
|
294
|
+
nodir: true,
|
|
295
|
+
ignore: DEFAULT_IGNORES
|
|
296
|
+
});
|
|
297
|
+
for (const file of files) {
|
|
298
|
+
addFile(file);
|
|
299
|
+
}
|
|
300
|
+
return [...found];
|
|
301
|
+
}
|
|
302
|
+
|
|
303
|
+
// src/package-resolutions-updater.mjs
|
|
304
|
+
var import_git_command_helper = require("git-command-helper");
|
|
170
305
|
var projectDir = process.cwd();
|
|
171
306
|
var envPath = import_path.default.join(projectDir, ".env");
|
|
172
307
|
var args = utils.getArgs();
|
|
173
|
-
if (import_fs.default.existsSync(envPath))
|
|
308
|
+
if (!import_fs.default.existsSync(envPath)) {
|
|
309
|
+
const envFiles = findEnvFiles(projectDir, (file) => {
|
|
310
|
+
const content = import_fs.default.readFileSync(file, "utf-8");
|
|
311
|
+
return /GITHUB_TOKEN|ACCESS_TOKEN/.test(content);
|
|
312
|
+
});
|
|
313
|
+
if (envFiles.length > 0) {
|
|
314
|
+
envPath = envFiles[0];
|
|
315
|
+
}
|
|
316
|
+
}
|
|
317
|
+
if (import_fs.default.existsSync(envPath)) {
|
|
318
|
+
dotenv.config({ path: envPath, quiet: true, override: true });
|
|
319
|
+
}
|
|
174
320
|
var ACCESS_TOKEN = process.env.GITHUB_TOKEN || process.env.ACCESS_TOKEN;
|
|
175
321
|
if (args.help || args.h) {
|
|
176
322
|
showHelp();
|
|
@@ -204,51 +350,6 @@ Examples:
|
|
|
204
350
|
console.log(helpText);
|
|
205
351
|
process.exit(0);
|
|
206
352
|
}
|
|
207
|
-
var specialPackageOverrides = [
|
|
208
|
-
// SBG packages
|
|
209
|
-
{ pkg: "sbg-utility", branch: "sbg-utility", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
210
|
-
{ pkg: "sbg-api", branch: "sbg-api", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
211
|
-
{ pkg: "instant-indexing", branch: "instant-indexing", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
212
|
-
{ pkg: "sbg-server", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
213
|
-
{ pkg: "sbg-cli", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
214
|
-
{ pkg: "static-blog-generator", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
215
|
-
// Hexo family
|
|
216
|
-
{ pkg: "hexo", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
217
|
-
{ pkg: "hexo-util", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
218
|
-
{ pkg: "warehouse", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
219
|
-
{ pkg: "hexo-server", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
220
|
-
{ pkg: "hexo-log", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
221
|
-
{ pkg: "hexo-front-matter", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
222
|
-
{ pkg: "hexo-cli", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
223
|
-
{ pkg: "hexo-asset-link", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
224
|
-
{ pkg: "hexo-post-parser", branch: "pre-release", repo: "hexo-post-parser", owner: "dimaslanjaka" },
|
|
225
|
-
{ pkg: "hexo-seo", branch: "pre-release", repo: "hexo-seo", owner: "dimaslanjaka" },
|
|
226
|
-
{ pkg: "hexo-is", branch: "master", repo: "hexo-is", owner: "dimaslanjaka" },
|
|
227
|
-
{ pkg: "markdown-it", branch: "master", repo: "markdown-it", owner: "dimaslanjaka" },
|
|
228
|
-
{ pkg: "hexo-renderers", branch: "pre-release", repo: "hexo-renderers", owner: "dimaslanjaka" },
|
|
229
|
-
{ pkg: "hexo-shortcodes", branch: "pre-release", repo: "hexo-shortcodes", owner: "dimaslanjaka" },
|
|
230
|
-
{ pkg: "google-news-sitemap", branch: "master", repo: "google-news-sitemap", owner: "dimaslanjaka" },
|
|
231
|
-
{ pkg: "git-command-helper", branch: "pre-release", repo: "git-command-helper", owner: "dimaslanjaka" },
|
|
232
|
-
{
|
|
233
|
-
pkg: "nodejs-package-types",
|
|
234
|
-
branch: "main",
|
|
235
|
-
repo: "nodejs-package-types",
|
|
236
|
-
owner: "dimaslanjaka"
|
|
237
|
-
},
|
|
238
|
-
{ pkg: "cross-spawn", branch: "private", repo: "node-cross-spawn", owner: "dimaslanjaka" },
|
|
239
|
-
{ pkg: "hexo-generator-redirect", branch: "master", repo: "hexo-generator-redirect", owner: "dimaslanjaka" },
|
|
240
|
-
{ pkg: "binary-collections", branch: "master", repo: "bin", owner: "dimaslanjaka" },
|
|
241
|
-
{ pkg: "@types/hexo", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
242
|
-
{ pkg: "@types/git-command-helper", branch: "pre-release", repo: "git-command-helper", owner: "dimaslanjaka" }
|
|
243
|
-
];
|
|
244
|
-
var pkgPath = import_path.default.join(process.cwd(), "package.json");
|
|
245
|
-
var pkg;
|
|
246
|
-
try {
|
|
247
|
-
pkg = JSON.parse(import_fs.default.readFileSync(pkgPath, "utf-8"));
|
|
248
|
-
} catch (e) {
|
|
249
|
-
console.error(import_ansi_colors.default.red(`Failed to read package.json: ${e.message}`));
|
|
250
|
-
process.exit(1);
|
|
251
|
-
}
|
|
252
353
|
var GITHUB_USER_AGENTS = [
|
|
253
354
|
"octokit-rest.js/19.0.7",
|
|
254
355
|
"GitHub CLI/2.40.0",
|
|
@@ -353,95 +454,14 @@ async function getLatestCommitAcrossBranches(owner, repo) {
|
|
|
353
454
|
function replaceRawWithLatestHash(url, latestHash) {
|
|
354
455
|
const match = url.match(/^https:\/\/github\.com\/([^/]+)\/([^/]+)\/raw\/([^/]+)\/(.+)$/);
|
|
355
456
|
if (!match) throw new Error("Invalid GitHub raw URL");
|
|
356
|
-
const [, owner, repo, _oldHash,
|
|
357
|
-
return `https://github.com/${owner}/${repo}/raw/${latestHash}/${
|
|
457
|
+
const [, owner, repo, _oldHash, path3] = match;
|
|
458
|
+
return `https://github.com/${owner}/${repo}/raw/${latestHash}/${path3}`;
|
|
358
459
|
}
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
return { owner, repo, branch, url };
|
|
368
|
-
}
|
|
369
|
-
if (match = url.match(ghDotComRaw)) {
|
|
370
|
-
const [, owner, repo, branch] = match;
|
|
371
|
-
return { owner, repo, branch, url };
|
|
372
|
-
}
|
|
373
|
-
if (match = url.match(ghTreeOrBlob)) {
|
|
374
|
-
const [, owner, repo, , branchPath] = match;
|
|
375
|
-
return { owner, repo, branch: branchPath, url };
|
|
376
|
-
}
|
|
377
|
-
if (match = url.match(ghRepoRoot)) {
|
|
378
|
-
const [, owner, repo] = match;
|
|
379
|
-
return { owner, repo, url };
|
|
380
|
-
}
|
|
381
|
-
throw new Error(`Unsupported GitHub URL: ${url}`);
|
|
382
|
-
}
|
|
383
|
-
(async () => {
|
|
384
|
-
const entries = Object.entries(pkg.resolutions || {});
|
|
385
|
-
if (entries.length === 0) {
|
|
386
|
-
console.log(import_ansi_colors.default.yellow("No resolutions found in package.json"));
|
|
387
|
-
return;
|
|
388
|
-
}
|
|
389
|
-
console.log(`Processing ${entries.length} resolution(s)...`);
|
|
390
|
-
const updates = [];
|
|
391
|
-
for (const [currentPkgName, url] of entries) {
|
|
392
|
-
let repo;
|
|
393
|
-
try {
|
|
394
|
-
repo = parseGitHubUrl(url);
|
|
395
|
-
console.log(`\u2705 Valid GitHub URL for ${import_ansi_colors.default.cyan(currentPkgName)}: ${url}`);
|
|
396
|
-
} catch (error) {
|
|
397
|
-
console.log(`\u23ED\uFE0F Skipping ${import_ansi_colors.default.yellow(currentPkgName)}: ${error.message}`);
|
|
398
|
-
continue;
|
|
399
|
-
}
|
|
400
|
-
try {
|
|
401
|
-
const override = specialPackageOverrides.find((p) => p.pkg === currentPkgName);
|
|
402
|
-
const latest = override ? await getLatestCommit(override.owner, override.repo, override.branch) : await getLatestCommitAcrossBranches(repo.owner, repo.repo);
|
|
403
|
-
const new_url = replaceRawWithLatestHash(url, latest.sha);
|
|
404
|
-
updates.push({
|
|
405
|
-
currentPkgName,
|
|
406
|
-
url,
|
|
407
|
-
new_url,
|
|
408
|
-
repo,
|
|
409
|
-
latest
|
|
410
|
-
});
|
|
411
|
-
} catch (error) {
|
|
412
|
-
console.log(`\u274C Failed to process ${import_ansi_colors.default.red(currentPkgName)}: ${error.message}`);
|
|
413
|
-
}
|
|
414
|
-
}
|
|
415
|
-
if (updates.length === 0) {
|
|
416
|
-
console.log(import_ansi_colors.default.yellow("No GitHub URLs were processed"));
|
|
417
|
-
return;
|
|
418
|
-
}
|
|
419
|
-
console.log(`
|
|
420
|
-
\u{1F4DD} Applying updates to ${updates.length} GitHub URL(s)...`);
|
|
421
|
-
let changed = false;
|
|
422
|
-
for (const { currentPkgName, url, new_url, repo, latest } of updates) {
|
|
423
|
-
if (url !== new_url) {
|
|
424
|
-
console.log(`
|
|
425
|
-
${import_ansi_colors.default.cyan(currentPkgName)}:`);
|
|
426
|
-
console.log(" from:", url.replace(repo.branch, import_ansi_colors.default.red(repo.branch)));
|
|
427
|
-
console.log(" to:", new_url.replace(latest.sha, import_ansi_colors.default.green(latest.sha)));
|
|
428
|
-
pkg.resolutions[currentPkgName] = new_url;
|
|
429
|
-
changed = true;
|
|
430
|
-
} else {
|
|
431
|
-
console.log(`
|
|
432
|
-
${import_ansi_colors.default.cyan(currentPkgName)}: ${import_ansi_colors.default.gray("already up-to-date")}`);
|
|
433
|
-
}
|
|
434
|
-
}
|
|
435
|
-
if (changed) {
|
|
436
|
-
try {
|
|
437
|
-
import_fs.default.writeFileSync(pkgPath, JSON.stringify(pkg, null, 2) + "\n");
|
|
438
|
-
console.log(`
|
|
439
|
-
\u2705 package.json updated successfully`);
|
|
440
|
-
} catch (e) {
|
|
441
|
-
console.error(import_ansi_colors.default.red(`Failed to write package.json: ${e.message}`));
|
|
442
|
-
process.exit(1);
|
|
443
|
-
}
|
|
444
|
-
} else {
|
|
445
|
-
console.log(import_ansi_colors.default.green("No changes to package.json were necessary."));
|
|
446
|
-
}
|
|
447
|
-
})();
|
|
460
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
461
|
+
0 && (module.exports = {
|
|
462
|
+
fetchJson,
|
|
463
|
+
getLatestCommit,
|
|
464
|
+
getLatestCommitAcrossBranches,
|
|
465
|
+
parseGitHubUrl,
|
|
466
|
+
replaceRawWithLatestHash
|
|
467
|
+
});
|
|
@@ -1 +1,32 @@
|
|
|
1
|
-
|
|
1
|
+
/**
|
|
2
|
+
* Fetch JSON from a URL with GitHub headers.
|
|
3
|
+
* @param {string} url
|
|
4
|
+
* @returns {Promise<any>}
|
|
5
|
+
*/
|
|
6
|
+
export function fetchJson(url: string): Promise<any>;
|
|
7
|
+
/**
|
|
8
|
+
* Get latest commit SHA from a specific branch.
|
|
9
|
+
*/
|
|
10
|
+
export function getLatestCommit(owner: any, repo: any, branch?: string): Promise<{
|
|
11
|
+
owner: any;
|
|
12
|
+
repo: any;
|
|
13
|
+
branch: string;
|
|
14
|
+
sha: any;
|
|
15
|
+
date: string;
|
|
16
|
+
}>;
|
|
17
|
+
/**
|
|
18
|
+
* Get latest commit SHA from all branches and pick the latest.
|
|
19
|
+
*/
|
|
20
|
+
export function getLatestCommitAcrossBranches(owner: any, repo: any): Promise<{
|
|
21
|
+
owner: any;
|
|
22
|
+
repo: any;
|
|
23
|
+
branch: any;
|
|
24
|
+
sha: any;
|
|
25
|
+
date: any;
|
|
26
|
+
}>;
|
|
27
|
+
/**
|
|
28
|
+
* Replace the branch or commit in a GitHub raw URL with the latest hash.
|
|
29
|
+
*/
|
|
30
|
+
export function replaceRawWithLatestHash(url: any, latestHash: any): string;
|
|
31
|
+
export { parseGitHubUrl };
|
|
32
|
+
import { parseGitHubUrl } from "git-command-helper";
|