binary-collections 2.0.9 → 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 +178 -0
- package/{bin → binaries}/clean-nodemodule +0 -0
- package/binaries/clean-nodemodule.cjs +178 -0
- package/binaries/clean-nodemodule.cmd +4 -0
- package/{bin → binaries}/clean-nodemodules +0 -0
- package/binaries/clean-nodemodules.cjs +178 -0
- package/binaries/clean-nodemodules.cmd +5 -0
- package/{bin → binaries}/dev +0 -0
- package/binaries/dev.cjs +178 -0
- package/{bin → binaries}/empty +0 -0
- package/binaries/empty.cjs +178 -0
- package/{bin → binaries}/git-reduce-size +0 -0
- package/binaries/git-reduce-size.cjs +178 -0
- package/binaries/javakill.cjs +178 -0
- package/{bin → binaries}/javakill.cmd +0 -0
- package/binaries/kill-night-crows.bat +7 -0
- package/binaries/kill-night-crows.ps1 +172 -0
- package/{bin → binaries}/kill-process +0 -0
- package/binaries/kill-process.cjs +178 -0
- package/binaries/nodekill.cjs +178 -0
- package/{bin → binaries}/nodekill.ps1 +0 -0
- package/{bin → binaries}/prod +0 -0
- package/binaries/prod.cjs +178 -0
- package/binaries/py +111 -0
- package/binaries/py.cjs +178 -0
- package/binaries/py.cmd +49 -0
- package/{bin → binaries}/rmfind +0 -0
- package/binaries/rmfind.cjs +178 -0
- package/{bin → binaries}/rmx +0 -0
- package/binaries/rmx.cjs +178 -0
- package/{bin → binaries}/submodule-token +0 -0
- package/binaries/submodule-token.cjs +178 -0
- 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/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 +513 -105
- package/lib/binary-collections.mjs +178 -117
- package/lib/changelog.cjs +64 -16
- package/lib/changelog.mjs +177 -171
- package/lib/{chunk-VVEZVNIV.mjs → chunk-2CBJCW7E.mjs} +3 -3
- package/lib/chunk-34IQDTLZ.mjs +27 -0
- package/lib/chunk-3HFFECCI.mjs +27 -0
- package/lib/chunk-4UHL4WVN.mjs +136 -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-7XTEJHOE.mjs +193 -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-AJDD5DZM.mjs +109 -0
- package/lib/chunk-BZWVHODJ.mjs +62 -0
- package/lib/chunk-FCDQGYBF.mjs +136 -0
- package/lib/chunk-FKI7IEB5.mjs +172 -0
- package/lib/chunk-GEYA2USY.mjs +207 -0
- package/lib/chunk-GJTGHXRA.mjs +356 -0
- package/lib/{chunk-YV7DO3YV.mjs → chunk-HLGOWBEO.mjs} +1 -1
- package/lib/chunk-ID2WBTE2.mjs +80 -0
- package/lib/chunk-JXFOHKDM.mjs +239 -0
- package/lib/{chunk-YX5U7XDR.mjs → chunk-M3YIYRHT.mjs} +6 -5
- package/lib/chunk-N436BNBK.mjs +514 -0
- package/lib/chunk-NCXAP7AA.mjs +31 -0
- package/lib/chunk-PDN26I7O.mjs +188 -0
- package/lib/{chunk-JGR2NW6D.mjs → chunk-PDSXF5HY.mjs} +3 -3
- package/lib/{chunk-AASHBCRW.mjs → chunk-QQ4A6DLD.mjs} +8 -0
- package/lib/{chunk-ONIBBBQ3.mjs → chunk-RWLXRTYP.mjs} +4 -3
- package/lib/chunk-TOIVAQF7.mjs +136 -0
- package/lib/chunk-V5SKYJUB.mjs +136 -0
- package/lib/chunk-WSRETQCA.mjs +59 -0
- package/lib/chunk-XA3SNBPA.mjs +184 -0
- package/lib/chunk-XVBFFVCJ.mjs +209 -0
- package/lib/chunk-YYLIQQKF.mjs +31 -0
- package/lib/{chunk-APBWENF6.mjs → chunk-Z6JLYU2J.mjs} +63 -16
- package/lib/chunk-ZDMWBSYF.mjs +81 -0
- package/lib/clean-github-actions-caches.cjs +291 -148
- package/lib/clean-github-actions-caches.mjs +4 -3
- package/lib/del-gradle.cjs +63 -15
- package/lib/del-gradle.js +2 -1
- package/lib/del-gradle.mjs +2 -2
- package/lib/del-node-modules.cjs +143 -148
- package/lib/del-node-modules.js +210 -14
- package/lib/del-node-modules.mjs +149 -18
- package/lib/del-ps.cjs +90 -21
- package/lib/del-ps.js +3 -2
- package/lib/del-ps.mjs +7 -5
- package/lib/del-yarn-caches.cjs +87 -18
- 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 +2 -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 +754 -0
- package/lib/free-chatgpt.js +51 -0
- package/lib/free-chatgpt.mjs +50 -0
- package/lib/git/gitattributes.cjs +2 -1
- package/lib/git/{gitattributes.d.ts → gitattributes.d.cts} +7 -2
- package/lib/git/gitattributes.mjs +2 -2
- package/lib/git/line-endings.cjs +298 -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/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 +313 -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 +857 -0
- package/lib/git-diff-cli.js +16 -0
- package/lib/git-diff-cli.mjs +17 -0
- package/lib/git-diff.cjs +862 -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 +733 -97
- package/lib/git-fix.mjs +10 -9
- package/lib/git-purge.cjs +64 -16
- 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/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 +63 -16
- package/lib/npm-run-series.mjs +42 -36
- 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 +178 -158
- package/lib/package-resolutions-updater.d.mts +32 -1
- package/lib/package-resolutions-updater.mjs +17 -338
- 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 +320 -207
- package/lib/print-directory-tree.mjs +3 -3
- 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 +2 -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 +310 -0
- package/lib/remove-module.d.mts +1 -0
- package/lib/remove-module.mjs +111 -0
- package/lib/rmpath.cjs +322 -0
- package/lib/rmpath.d.mts +3 -0
- package/lib/rmpath.mjs +108 -0
- package/lib/submodule-install.cjs +311 -86
- package/lib/submodule-install.mjs +53 -5
- package/lib/submodule-remove-cli.cjs +107 -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 +46 -0
- package/lib/submodule-remove.d.cts +2 -0
- package/lib/submodule-remove.mjs +6 -0
- package/lib/utils/chatgpt.cjs +541 -0
- package/lib/utils/chatgpt.d.ts +31 -0
- package/lib/utils/chatgpt.js +708 -0
- package/lib/utils/chatgpt.mjs +8 -0
- 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.cjs → utils/index.cjs} +61 -14
- package/lib/{utils.mjs → utils/index.mjs} +2 -2
- 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 +220 -38
- package/lib/yarn-reinstall.mjs +2 -2
- package/package.json +138 -104
- package/readme.md +48 -75
- package/releases/readme.md +36 -0
- package/requirements.txt +1 -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/gitattributes.d.mts +0 -35
- package/lib/git/gitattributes.js +0 -223
- 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.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 → git-diff-cli.d.ts} +0 -0
- /package/lib/{npm-run-series.d.ts → npm-run-series.d.cts} +0 -0
- /package/lib/{utils.d.ts → utils/index.d.cts} +0 -0
|
@@ -1,339 +1,18 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
*
|
|
19
|
-
* 🧩 Dependencies:
|
|
20
|
-
* - `ansi-colors` – for styled terminal output
|
|
21
|
-
* - `dotenv` – to load GitHub token from `.env`
|
|
22
|
-
*
|
|
23
|
-
* ✅ Use case:
|
|
24
|
-
* - Ensures package resolutions always use immutable SHAs instead of mutable branch names.
|
|
25
|
-
* - Helps achieve deterministic builds in monorepos or projects with internal GitHub packages.
|
|
26
|
-
*/
|
|
27
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
28
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
29
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
30
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
31
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
32
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
33
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
34
|
-
});
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
fetchJson,
|
|
4
|
+
getLatestCommit,
|
|
5
|
+
getLatestCommitAcrossBranches,
|
|
6
|
+
parseGitHubUrl,
|
|
7
|
+
replaceRawWithLatestHash
|
|
8
|
+
} from "./chunk-XA3SNBPA.mjs";
|
|
9
|
+
import "./chunk-ID2WBTE2.mjs";
|
|
10
|
+
import "./chunk-Z6JLYU2J.mjs";
|
|
11
|
+
import "./chunk-QQ4A6DLD.mjs";
|
|
12
|
+
export {
|
|
13
|
+
fetchJson,
|
|
14
|
+
getLatestCommit,
|
|
15
|
+
getLatestCommitAcrossBranches,
|
|
16
|
+
parseGitHubUrl,
|
|
17
|
+
replaceRawWithLatestHash
|
|
35
18
|
};
|
|
36
|
-
import ansiColors from "ansi-colors";
|
|
37
|
-
import * as dotenv from "dotenv";
|
|
38
|
-
import fs from "fs";
|
|
39
|
-
import https from "https";
|
|
40
|
-
import os from "os";
|
|
41
|
-
import path from "path";
|
|
42
|
-
import { getArgs } from "./utils.js";
|
|
43
|
-
const projectDir = process.cwd();
|
|
44
|
-
const envPath = path.join(projectDir, ".env");
|
|
45
|
-
const args = getArgs();
|
|
46
|
-
const ACCESS_TOKEN = process.env.GITHUB_TOKEN || process.env.ACCESS_TOKEN;
|
|
47
|
-
// Show help if --help/-h is passed
|
|
48
|
-
if (args.help || args.h) {
|
|
49
|
-
showHelp();
|
|
50
|
-
}
|
|
51
|
-
/**
|
|
52
|
-
* Display help information for the package-resolutions-updater script.
|
|
53
|
-
*/
|
|
54
|
-
function showHelp() {
|
|
55
|
-
const helpText = `\n\
|
|
56
|
-
GitHub Package Resolutions Updater\n\
|
|
57
|
-
Usage:\n node src/package-resolutions-updater.mjs [options]\n\
|
|
58
|
-
Options:\n --help, -h Show this help message\n\
|
|
59
|
-
Description:\n 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.\n\
|
|
60
|
-
Features:\n - Parses GitHub URLs to extract repository owner, name, and branch.\n - Fetches the latest commit SHA across all branches using GitHub's API.\n - Replaces the old branch or commit in the URL with the latest SHA.\n - Overwrites package.json with the updated URLs.\n\
|
|
61
|
-
Requirements:\n - GitHub Personal Access Token (GITHUB_TOKEN) via .env\n - ESM support (type: "module" in package.json)\n - Node.js v18+ recommended\n\
|
|
62
|
-
Dependencies:\n - ansi-colors – for styled terminal output\n - dotenv – to load GitHub token from .env\n\
|
|
63
|
-
Examples:\n node src/package-resolutions-updater.mjs\n node src/package-resolutions-updater.mjs --help\n\n`;
|
|
64
|
-
console.log(helpText);
|
|
65
|
-
process.exit(0);
|
|
66
|
-
}
|
|
67
|
-
// Load the .env file using dotenv (ESM import)
|
|
68
|
-
if (fs.existsSync(envPath))
|
|
69
|
-
dotenv.config({ path: envPath });
|
|
70
|
-
// 📌 Static override rules
|
|
71
|
-
const specialPackageOverrides = [
|
|
72
|
-
// SBG packages
|
|
73
|
-
{ pkg: "sbg-utility", branch: "sbg-utility", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
74
|
-
{ pkg: "sbg-api", branch: "sbg-api", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
75
|
-
{ pkg: "instant-indexing", branch: "instant-indexing", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
76
|
-
{ pkg: "sbg-server", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
77
|
-
{ pkg: "sbg-cli", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
78
|
-
{ pkg: "static-blog-generator", branch: "master", repo: "static-blog-generator", owner: "dimaslanjaka" },
|
|
79
|
-
// Hexo family
|
|
80
|
-
{ pkg: "hexo", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
81
|
-
{ pkg: "hexo-util", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
82
|
-
{ pkg: "warehouse", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
83
|
-
{ pkg: "hexo-server", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
84
|
-
{ pkg: "hexo-log", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
85
|
-
{ pkg: "hexo-front-matter", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
86
|
-
{ pkg: "hexo-cli", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
87
|
-
{ pkg: "hexo-asset-link", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
88
|
-
{ pkg: "hexo-post-parser", branch: "pre-release", repo: "hexo-post-parser", owner: "dimaslanjaka" },
|
|
89
|
-
{ pkg: "hexo-seo", branch: "pre-release", repo: "hexo-seo", owner: "dimaslanjaka" },
|
|
90
|
-
{ pkg: "hexo-is", branch: "master", repo: "hexo-is", owner: "dimaslanjaka" },
|
|
91
|
-
{ pkg: "markdown-it", branch: "master", repo: "markdown-it", owner: "dimaslanjaka" },
|
|
92
|
-
{ pkg: "hexo-renderers", branch: "pre-release", repo: "hexo-renderers", owner: "dimaslanjaka" },
|
|
93
|
-
{ pkg: "hexo-shortcodes", branch: "pre-release", repo: "hexo-shortcodes", owner: "dimaslanjaka" },
|
|
94
|
-
{ pkg: "google-news-sitemap", branch: "master", repo: "google-news-sitemap", owner: "dimaslanjaka" },
|
|
95
|
-
{ pkg: "git-command-helper", branch: "pre-release", repo: "git-command-helper", owner: "dimaslanjaka" },
|
|
96
|
-
{
|
|
97
|
-
pkg: "nodejs-package-types",
|
|
98
|
-
branch: "main",
|
|
99
|
-
repo: "nodejs-package-types",
|
|
100
|
-
owner: "dimaslanjaka"
|
|
101
|
-
},
|
|
102
|
-
{ pkg: "cross-spawn", branch: "private", repo: "node-cross-spawn", owner: "dimaslanjaka" },
|
|
103
|
-
{ pkg: "hexo-generator-redirect", branch: "master", repo: "hexo-generator-redirect", owner: "dimaslanjaka" },
|
|
104
|
-
{ pkg: "binary-collections", branch: "master", repo: "bin", owner: "dimaslanjaka" },
|
|
105
|
-
{ pkg: "@types/hexo", branch: "monorepo-v7", repo: "hexo", owner: "dimaslanjaka" },
|
|
106
|
-
{ pkg: "@types/git-command-helper", branch: "pre-release", repo: "git-command-helper", owner: "dimaslanjaka" }
|
|
107
|
-
];
|
|
108
|
-
// --- Optimized: Load package.json once at the top ---
|
|
109
|
-
const pkgPath = path.join(process.cwd(), "package.json");
|
|
110
|
-
let pkg;
|
|
111
|
-
try {
|
|
112
|
-
pkg = JSON.parse(fs.readFileSync(pkgPath, "utf-8"));
|
|
113
|
-
}
|
|
114
|
-
catch (e) {
|
|
115
|
-
console.error(ansiColors.red(`Failed to read package.json: ${e.message}`));
|
|
116
|
-
process.exit(1);
|
|
117
|
-
}
|
|
118
|
-
// --- Use a random User-Agent for GitHub API requests ---
|
|
119
|
-
const GITHUB_USER_AGENTS = [
|
|
120
|
-
"octokit-rest.js/19.0.7",
|
|
121
|
-
"GitHub CLI/2.40.0",
|
|
122
|
-
"Mozilla/5.0 (compatible; GitHubCopilot/1.0)",
|
|
123
|
-
"PostmanRuntime/7.32.3",
|
|
124
|
-
"binary-collections-resolver/1.0 (+https://github.com/dimaslanjaka/bin)"
|
|
125
|
-
];
|
|
126
|
-
// --- User-Agent persistence in system temp folder ---
|
|
127
|
-
const userAgentDir = path.join(os.tmpdir(), "nodejs");
|
|
128
|
-
const userAgentFile = path.join(userAgentDir, "useragent.txt");
|
|
129
|
-
let selectedUserAgent;
|
|
130
|
-
try {
|
|
131
|
-
if (!fs.existsSync(userAgentDir))
|
|
132
|
-
fs.mkdirSync(userAgentDir, { recursive: true });
|
|
133
|
-
if (fs.existsSync(userAgentFile)) {
|
|
134
|
-
const fileAgent = fs.readFileSync(userAgentFile, "utf-8").trim();
|
|
135
|
-
if (GITHUB_USER_AGENTS.includes(fileAgent)) {
|
|
136
|
-
selectedUserAgent = fileAgent;
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
if (!selectedUserAgent) {
|
|
140
|
-
selectedUserAgent = GITHUB_USER_AGENTS[Math.floor(Math.random() * GITHUB_USER_AGENTS.length)];
|
|
141
|
-
fs.writeFileSync(userAgentFile, selectedUserAgent, "utf-8");
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
catch (_e) {
|
|
145
|
-
// fallback to random if any error
|
|
146
|
-
selectedUserAgent = GITHUB_USER_AGENTS[Math.floor(Math.random() * GITHUB_USER_AGENTS.length)];
|
|
147
|
-
}
|
|
148
|
-
/**
|
|
149
|
-
* Fetch JSON from a URL with GitHub headers.
|
|
150
|
-
* @param {string} url
|
|
151
|
-
* @returns {Promise<any>}
|
|
152
|
-
*/
|
|
153
|
-
function fetchJson(url) {
|
|
154
|
-
const headers = Object.assign({ "User-Agent": selectedUserAgent, Accept: "application/vnd.github.v3+json", "X-GitHub-Api-Version": "2022-11-28" }, (ACCESS_TOKEN ? { Authorization: `token ${ACCESS_TOKEN}` } : {}));
|
|
155
|
-
return new Promise((resolve, reject) => {
|
|
156
|
-
https
|
|
157
|
-
.get(url, { headers }, (res) => {
|
|
158
|
-
let data = "";
|
|
159
|
-
res.on("data", (chunk) => (data += chunk));
|
|
160
|
-
res.on("end", () => {
|
|
161
|
-
try {
|
|
162
|
-
const json = JSON.parse(data);
|
|
163
|
-
if (res.statusCode < 200 || res.statusCode >= 300) {
|
|
164
|
-
return reject(new Error(`GitHub API Error ${res.statusCode}: ${json.message || "Unknown error"}\nURL: ${url}`));
|
|
165
|
-
}
|
|
166
|
-
resolve(json);
|
|
167
|
-
}
|
|
168
|
-
catch (_a) {
|
|
169
|
-
reject(new Error(`Invalid JSON from: ${url}`));
|
|
170
|
-
}
|
|
171
|
-
});
|
|
172
|
-
})
|
|
173
|
-
.on("error", reject);
|
|
174
|
-
});
|
|
175
|
-
}
|
|
176
|
-
/**
|
|
177
|
-
* Get latest commit SHA from a specific branch.
|
|
178
|
-
*/
|
|
179
|
-
function getLatestCommit(owner_1, repo_1) {
|
|
180
|
-
return __awaiter(this, arguments, void 0, function* (owner, repo, branch = "main") {
|
|
181
|
-
var _a, _b, _c, _d;
|
|
182
|
-
const url = `https://api.github.com/repos/${owner}/${repo}/commits/${branch}`;
|
|
183
|
-
const json = yield fetchJson(url);
|
|
184
|
-
const sha = json.sha;
|
|
185
|
-
const dateStr = ((_b = (_a = json.commit) === null || _a === void 0 ? void 0 : _a.committer) === null || _b === void 0 ? void 0 : _b.date) || ((_d = (_c = json.commit) === null || _c === void 0 ? void 0 : _c.author) === null || _d === void 0 ? void 0 : _d.date);
|
|
186
|
-
if (!sha || !dateStr) {
|
|
187
|
-
console.log(json);
|
|
188
|
-
throw new Error(`Missing SHA or date for ${owner}/${repo}@${branch}`);
|
|
189
|
-
}
|
|
190
|
-
return {
|
|
191
|
-
owner,
|
|
192
|
-
repo,
|
|
193
|
-
branch,
|
|
194
|
-
sha,
|
|
195
|
-
date: new Date(dateStr).toISOString()
|
|
196
|
-
};
|
|
197
|
-
});
|
|
198
|
-
}
|
|
199
|
-
/**
|
|
200
|
-
* Get latest commit SHA from all branches and pick the latest.
|
|
201
|
-
*/
|
|
202
|
-
function getLatestCommitAcrossBranches(owner, repo) {
|
|
203
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
204
|
-
const branches = yield fetchJson(`https://api.github.com/repos/${owner}/${repo}/branches`);
|
|
205
|
-
const commits = yield Promise.all(branches.map((_a) => __awaiter(this, [_a], void 0, function* ({ name, commit }) {
|
|
206
|
-
var _b, _c, _d, _f;
|
|
207
|
-
const commitSha = commit === null || commit === void 0 ? void 0 : commit.sha;
|
|
208
|
-
if (!commitSha) {
|
|
209
|
-
console.warn(`No commit SHA for '${owner}/${repo}' branch: ${name}`);
|
|
210
|
-
return { branch: name, sha: "", date: new Date(0) };
|
|
211
|
-
}
|
|
212
|
-
try {
|
|
213
|
-
const commitData = yield fetchJson(`https://api.github.com/repos/${owner}/${repo}/commits/${commitSha}`);
|
|
214
|
-
const dateStr = ((_c = (_b = commitData.commit) === null || _b === void 0 ? void 0 : _b.committer) === null || _c === void 0 ? void 0 : _c.date) || ((_f = (_d = commitData.commit) === null || _d === void 0 ? void 0 : _d.author) === null || _f === void 0 ? void 0 : _f.date);
|
|
215
|
-
const date = dateStr ? new Date(dateStr) : new Date(0);
|
|
216
|
-
return { branch: name, sha: commitData.sha, date };
|
|
217
|
-
}
|
|
218
|
-
catch (e) {
|
|
219
|
-
console.warn(`Failed to fetch commit for ${name}: ${e.message}`);
|
|
220
|
-
return { branch: name, sha: commitSha, date: new Date(0) };
|
|
221
|
-
}
|
|
222
|
-
})));
|
|
223
|
-
const latest = commits.reduce((a, b) => (a.date > b.date ? a : b), { date: new Date(0) });
|
|
224
|
-
return {
|
|
225
|
-
owner,
|
|
226
|
-
repo,
|
|
227
|
-
branch: latest.branch,
|
|
228
|
-
sha: latest.sha,
|
|
229
|
-
date: latest.date.toISOString()
|
|
230
|
-
};
|
|
231
|
-
});
|
|
232
|
-
}
|
|
233
|
-
/**
|
|
234
|
-
* Replace the branch or commit in a GitHub raw URL with the latest hash.
|
|
235
|
-
*/
|
|
236
|
-
function replaceRawWithLatestHash(url, latestHash) {
|
|
237
|
-
const match = url.match(/^https:\/\/github\.com\/([^/]+)\/([^/]+)\/raw\/([^/]+)\/(.+)$/);
|
|
238
|
-
if (!match)
|
|
239
|
-
throw new Error("Invalid GitHub raw URL");
|
|
240
|
-
const [, owner, repo, _oldHash, path] = match;
|
|
241
|
-
return `https://github.com/${owner}/${repo}/raw/${latestHash}/${path}`;
|
|
242
|
-
}
|
|
243
|
-
/**
|
|
244
|
-
* Parse GitHub URLs and extract owner, repo, branch, and original URL.
|
|
245
|
-
*/
|
|
246
|
-
function parseGitHubUrl(url) {
|
|
247
|
-
const ghRepoRoot = /^https:\/\/github\.com\/([^/]+)\/([^/]+)\/?$/;
|
|
248
|
-
const ghTreeOrBlob = /^https:\/\/github\.com\/([^/]+)\/([^/]+)\/(tree|blob)\/([^/]+(?:\/[^/]+)*)/;
|
|
249
|
-
const ghRaw = /^https:\/\/raw\.githubusercontent\.com\/([^/]+)\/([^/]+)\/([^/]+)(\/.+)?$/;
|
|
250
|
-
const ghDotComRaw = /^https:\/\/github\.com\/([^/]+)\/([^/]+)\/raw\/([^/]+)\/.+/;
|
|
251
|
-
let match;
|
|
252
|
-
if ((match = url.match(ghRaw))) {
|
|
253
|
-
const [, owner, repo, branch] = match;
|
|
254
|
-
return { owner, repo, branch, url };
|
|
255
|
-
}
|
|
256
|
-
if ((match = url.match(ghDotComRaw))) {
|
|
257
|
-
const [, owner, repo, branch] = match;
|
|
258
|
-
return { owner, repo, branch, url };
|
|
259
|
-
}
|
|
260
|
-
if ((match = url.match(ghTreeOrBlob))) {
|
|
261
|
-
const [, owner, repo, , branchPath] = match;
|
|
262
|
-
return { owner, repo, branch: branchPath, url };
|
|
263
|
-
}
|
|
264
|
-
if ((match = url.match(ghRepoRoot))) {
|
|
265
|
-
const [, owner, repo] = match;
|
|
266
|
-
return { owner, repo, url };
|
|
267
|
-
}
|
|
268
|
-
throw new Error(`Unsupported GitHub URL: ${url}`);
|
|
269
|
-
}
|
|
270
|
-
// --- Main logic ---
|
|
271
|
-
(() => __awaiter(void 0, void 0, void 0, function* () {
|
|
272
|
-
const entries = Object.entries(pkg.resolutions || {});
|
|
273
|
-
if (entries.length === 0) {
|
|
274
|
-
console.log(ansiColors.yellow("No resolutions found in package.json"));
|
|
275
|
-
return;
|
|
276
|
-
}
|
|
277
|
-
console.log(`Processing ${entries.length} resolution(s)...`);
|
|
278
|
-
const updates = [];
|
|
279
|
-
for (const [currentPkgName, url] of entries) {
|
|
280
|
-
// Validate if URL is a GitHub URL
|
|
281
|
-
let repo;
|
|
282
|
-
try {
|
|
283
|
-
repo = parseGitHubUrl(url);
|
|
284
|
-
console.log(`✅ Valid GitHub URL for ${ansiColors.cyan(currentPkgName)}: ${url}`);
|
|
285
|
-
}
|
|
286
|
-
catch (error) {
|
|
287
|
-
console.log(`⏭️ Skipping ${ansiColors.yellow(currentPkgName)}: ${error.message}`);
|
|
288
|
-
continue;
|
|
289
|
-
}
|
|
290
|
-
try {
|
|
291
|
-
const override = specialPackageOverrides.find((p) => p.pkg === currentPkgName);
|
|
292
|
-
const latest = override
|
|
293
|
-
? yield getLatestCommit(override.owner, override.repo, override.branch)
|
|
294
|
-
: yield getLatestCommitAcrossBranches(repo.owner, repo.repo);
|
|
295
|
-
const new_url = replaceRawWithLatestHash(url, latest.sha);
|
|
296
|
-
updates.push({
|
|
297
|
-
currentPkgName,
|
|
298
|
-
url,
|
|
299
|
-
new_url,
|
|
300
|
-
repo,
|
|
301
|
-
latest
|
|
302
|
-
});
|
|
303
|
-
}
|
|
304
|
-
catch (error) {
|
|
305
|
-
console.log(`❌ Failed to process ${ansiColors.red(currentPkgName)}: ${error.message}`);
|
|
306
|
-
}
|
|
307
|
-
}
|
|
308
|
-
if (updates.length === 0) {
|
|
309
|
-
console.log(ansiColors.yellow("No GitHub URLs were processed"));
|
|
310
|
-
return;
|
|
311
|
-
}
|
|
312
|
-
console.log(`\n📝 Applying updates to ${updates.length} GitHub URL(s)...`);
|
|
313
|
-
let changed = false;
|
|
314
|
-
for (const { currentPkgName, url, new_url, repo, latest } of updates) {
|
|
315
|
-
if (url !== new_url) {
|
|
316
|
-
console.log(`\n${ansiColors.cyan(currentPkgName)}:`);
|
|
317
|
-
console.log(" from:", url.replace(repo.branch, ansiColors.red(repo.branch)));
|
|
318
|
-
console.log(" to:", new_url.replace(latest.sha, ansiColors.green(latest.sha)));
|
|
319
|
-
pkg.resolutions[currentPkgName] = new_url;
|
|
320
|
-
changed = true;
|
|
321
|
-
}
|
|
322
|
-
else {
|
|
323
|
-
console.log(`\n${ansiColors.cyan(currentPkgName)}: ${ansiColors.gray("already up-to-date")}`);
|
|
324
|
-
}
|
|
325
|
-
}
|
|
326
|
-
if (changed) {
|
|
327
|
-
try {
|
|
328
|
-
fs.writeFileSync(pkgPath, JSON.stringify(pkg, null, 2) + "\n");
|
|
329
|
-
console.log(`\n✅ package.json updated successfully`);
|
|
330
|
-
}
|
|
331
|
-
catch (e) {
|
|
332
|
-
console.error(ansiColors.red(`Failed to write package.json: ${e.message}`));
|
|
333
|
-
process.exit(1);
|
|
334
|
-
}
|
|
335
|
-
}
|
|
336
|
-
else {
|
|
337
|
-
console.log(ansiColors.green("No changes to package.json were necessary."));
|
|
338
|
-
}
|
|
339
|
-
}))();
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
// src/php-cs-fixer-staged.cjs
|
|
3
|
+
var { exec } = require("child_process");
|
|
4
|
+
var { spawn, spawnSync } = require("child_process");
|
|
5
|
+
var util = require("util");
|
|
6
|
+
var fs = require("fs");
|
|
7
|
+
var path = require("path");
|
|
8
|
+
var execP = util.promisify(exec);
|
|
9
|
+
function log(...args) {
|
|
10
|
+
console.log("[php-cs-fixer-staged]", ...args);
|
|
11
|
+
}
|
|
12
|
+
function isPathLike(p) {
|
|
13
|
+
return p.includes("/") || p.includes("\\\\") || p.includes(path.sep);
|
|
14
|
+
}
|
|
15
|
+
async function findPhpCsFixer() {
|
|
16
|
+
const candidates = ["php-cs-fixer", "vendor/bin/php-cs-fixer", "bin/php-cs-fixer", "tools/php-cs-fixer"];
|
|
17
|
+
for (const c of candidates) {
|
|
18
|
+
try {
|
|
19
|
+
let cmd;
|
|
20
|
+
let args;
|
|
21
|
+
if (isPathLike(c)) {
|
|
22
|
+
const resolved = path.resolve(process.cwd(), c);
|
|
23
|
+
if (!fs.existsSync(resolved)) continue;
|
|
24
|
+
if (process.platform === "win32") {
|
|
25
|
+
cmd = "php";
|
|
26
|
+
args = [resolved, "--version"];
|
|
27
|
+
} else {
|
|
28
|
+
cmd = resolved;
|
|
29
|
+
args = ["--version"];
|
|
30
|
+
}
|
|
31
|
+
} else {
|
|
32
|
+
cmd = c;
|
|
33
|
+
args = ["--version"];
|
|
34
|
+
}
|
|
35
|
+
const res = spawnSync(cmd, args, { encoding: "utf8" });
|
|
36
|
+
if (res && res.status === 0) return c;
|
|
37
|
+
} catch (_e) {
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
try {
|
|
41
|
+
const phar = path.resolve(process.cwd(), "php-cs-fixer.phar");
|
|
42
|
+
if (fs.existsSync(phar)) return phar;
|
|
43
|
+
} catch (_e) {
|
|
44
|
+
}
|
|
45
|
+
return null;
|
|
46
|
+
}
|
|
47
|
+
async function getStagedPhpFiles() {
|
|
48
|
+
try {
|
|
49
|
+
const { stdout } = await execP("git diff --name-only --cached --diff-filter=ACM");
|
|
50
|
+
return stdout.split(/\r?\n/).map((s) => s.trim()).filter(Boolean).filter((f) => f.toLowerCase().endsWith(".php"));
|
|
51
|
+
} catch (err) {
|
|
52
|
+
throw new Error("Failed to get staged files: " + err.message);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
async function run() {
|
|
56
|
+
const files = await getStagedPhpFiles();
|
|
57
|
+
if (!files.length) {
|
|
58
|
+
log("No staged PHP files found. Nothing to do.");
|
|
59
|
+
return 0;
|
|
60
|
+
}
|
|
61
|
+
const bin = await findPhpCsFixer();
|
|
62
|
+
if (!bin) {
|
|
63
|
+
console.error("php-cs-fixer binary not found in PATH or common locations.");
|
|
64
|
+
console.error("Install php-cs-fixer or add it to PATH, or place it in vendor/bin/.");
|
|
65
|
+
return 2;
|
|
66
|
+
}
|
|
67
|
+
log("Running", bin, "on", files.length, "file(s)");
|
|
68
|
+
return new Promise((resolve) => {
|
|
69
|
+
let cmd;
|
|
70
|
+
let args;
|
|
71
|
+
if (isPathLike(bin)) {
|
|
72
|
+
const resolved = path.resolve(process.cwd(), bin);
|
|
73
|
+
if (process.platform === "win32") {
|
|
74
|
+
cmd = "php";
|
|
75
|
+
args = [resolved, "fix", ...files];
|
|
76
|
+
} else {
|
|
77
|
+
cmd = resolved;
|
|
78
|
+
args = ["fix", ...files];
|
|
79
|
+
}
|
|
80
|
+
} else {
|
|
81
|
+
cmd = bin;
|
|
82
|
+
args = ["fix", ...files];
|
|
83
|
+
}
|
|
84
|
+
const child = spawn(cmd, args, { stdio: "inherit", shell: false });
|
|
85
|
+
child.on("close", (code) => {
|
|
86
|
+
if (code === 0) {
|
|
87
|
+
log("php-cs-fixer completed successfully.");
|
|
88
|
+
} else {
|
|
89
|
+
console.error("php-cs-fixer exited with code", code);
|
|
90
|
+
}
|
|
91
|
+
resolve(code);
|
|
92
|
+
});
|
|
93
|
+
child.on("error", (err) => {
|
|
94
|
+
console.error("Failed to run php-cs-fixer:", err.message);
|
|
95
|
+
resolve(3);
|
|
96
|
+
});
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
if (require.main === module) {
|
|
100
|
+
run().then((code) => process.exit(code)).catch((err) => {
|
|
101
|
+
console.error(err);
|
|
102
|
+
process.exit(4);
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
module.exports = { run, getStagedPhpFiles };
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
__commonJS,
|
|
4
|
+
__require,
|
|
5
|
+
init_esm_shims
|
|
6
|
+
} from "./chunk-QQ4A6DLD.mjs";
|
|
7
|
+
|
|
8
|
+
// src/php-cs-fixer-staged.cjs
|
|
9
|
+
var require_php_cs_fixer_staged = __commonJS({
|
|
10
|
+
"src/php-cs-fixer-staged.cjs"(exports, module) {
|
|
11
|
+
init_esm_shims();
|
|
12
|
+
var { exec } = __require("child_process");
|
|
13
|
+
var { spawn, spawnSync } = __require("child_process");
|
|
14
|
+
var util = __require("util");
|
|
15
|
+
var fs = __require("fs");
|
|
16
|
+
var path = __require("path");
|
|
17
|
+
var execP = util.promisify(exec);
|
|
18
|
+
function log(...args) {
|
|
19
|
+
console.log("[php-cs-fixer-staged]", ...args);
|
|
20
|
+
}
|
|
21
|
+
function isPathLike(p) {
|
|
22
|
+
return p.includes("/") || p.includes("\\\\") || p.includes(path.sep);
|
|
23
|
+
}
|
|
24
|
+
async function findPhpCsFixer() {
|
|
25
|
+
const candidates = ["php-cs-fixer", "vendor/bin/php-cs-fixer", "bin/php-cs-fixer", "tools/php-cs-fixer"];
|
|
26
|
+
for (const c of candidates) {
|
|
27
|
+
try {
|
|
28
|
+
let cmd;
|
|
29
|
+
let args;
|
|
30
|
+
if (isPathLike(c)) {
|
|
31
|
+
const resolved = path.resolve(process.cwd(), c);
|
|
32
|
+
if (!fs.existsSync(resolved)) continue;
|
|
33
|
+
if (process.platform === "win32") {
|
|
34
|
+
cmd = "php";
|
|
35
|
+
args = [resolved, "--version"];
|
|
36
|
+
} else {
|
|
37
|
+
cmd = resolved;
|
|
38
|
+
args = ["--version"];
|
|
39
|
+
}
|
|
40
|
+
} else {
|
|
41
|
+
cmd = c;
|
|
42
|
+
args = ["--version"];
|
|
43
|
+
}
|
|
44
|
+
const res = spawnSync(cmd, args, { encoding: "utf8" });
|
|
45
|
+
if (res && res.status === 0) return c;
|
|
46
|
+
} catch (_e) {
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
try {
|
|
50
|
+
const phar = path.resolve(process.cwd(), "php-cs-fixer.phar");
|
|
51
|
+
if (fs.existsSync(phar)) return phar;
|
|
52
|
+
} catch (_e) {
|
|
53
|
+
}
|
|
54
|
+
return null;
|
|
55
|
+
}
|
|
56
|
+
async function getStagedPhpFiles() {
|
|
57
|
+
try {
|
|
58
|
+
const { stdout } = await execP("git diff --name-only --cached --diff-filter=ACM");
|
|
59
|
+
return stdout.split(/\r?\n/).map((s) => s.trim()).filter(Boolean).filter((f) => f.toLowerCase().endsWith(".php"));
|
|
60
|
+
} catch (err) {
|
|
61
|
+
throw new Error("Failed to get staged files: " + err.message);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
async function run() {
|
|
65
|
+
const files = await getStagedPhpFiles();
|
|
66
|
+
if (!files.length) {
|
|
67
|
+
log("No staged PHP files found. Nothing to do.");
|
|
68
|
+
return 0;
|
|
69
|
+
}
|
|
70
|
+
const bin = await findPhpCsFixer();
|
|
71
|
+
if (!bin) {
|
|
72
|
+
console.error("php-cs-fixer binary not found in PATH or common locations.");
|
|
73
|
+
console.error("Install php-cs-fixer or add it to PATH, or place it in vendor/bin/.");
|
|
74
|
+
return 2;
|
|
75
|
+
}
|
|
76
|
+
log("Running", bin, "on", files.length, "file(s)");
|
|
77
|
+
return new Promise((resolve) => {
|
|
78
|
+
let cmd;
|
|
79
|
+
let args;
|
|
80
|
+
if (isPathLike(bin)) {
|
|
81
|
+
const resolved = path.resolve(process.cwd(), bin);
|
|
82
|
+
if (process.platform === "win32") {
|
|
83
|
+
cmd = "php";
|
|
84
|
+
args = [resolved, "fix", ...files];
|
|
85
|
+
} else {
|
|
86
|
+
cmd = resolved;
|
|
87
|
+
args = ["fix", ...files];
|
|
88
|
+
}
|
|
89
|
+
} else {
|
|
90
|
+
cmd = bin;
|
|
91
|
+
args = ["fix", ...files];
|
|
92
|
+
}
|
|
93
|
+
const child = spawn(cmd, args, { stdio: "inherit", shell: false });
|
|
94
|
+
child.on("close", (code) => {
|
|
95
|
+
if (code === 0) {
|
|
96
|
+
log("php-cs-fixer completed successfully.");
|
|
97
|
+
} else {
|
|
98
|
+
console.error("php-cs-fixer exited with code", code);
|
|
99
|
+
}
|
|
100
|
+
resolve(code);
|
|
101
|
+
});
|
|
102
|
+
child.on("error", (err) => {
|
|
103
|
+
console.error("Failed to run php-cs-fixer:", err.message);
|
|
104
|
+
resolve(3);
|
|
105
|
+
});
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
if (__require.main === module) {
|
|
109
|
+
run().then((code) => process.exit(code)).catch((err) => {
|
|
110
|
+
console.error(err);
|
|
111
|
+
process.exit(4);
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
module.exports = { run, getStagedPhpFiles };
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
export default require_php_cs_fixer_staged();
|