okit-cli 2.1.0
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/README.md +222 -0
- package/dist/commands/check.d.ts +13 -0
- package/dist/commands/check.d.ts.map +1 -0
- package/dist/commands/check.js +259 -0
- package/dist/commands/check.js.map +1 -0
- package/dist/commands/claude.d.ts +10 -0
- package/dist/commands/claude.d.ts.map +1 -0
- package/dist/commands/claude.js +504 -0
- package/dist/commands/claude.js.map +1 -0
- package/dist/commands/menu.d.ts +3 -0
- package/dist/commands/menu.d.ts.map +1 -0
- package/dist/commands/menu.js +152 -0
- package/dist/commands/menu.js.map +1 -0
- package/dist/commands/repo.d.ts +3 -0
- package/dist/commands/repo.d.ts.map +1 -0
- package/dist/commands/repo.js +266 -0
- package/dist/commands/repo.js.map +1 -0
- package/dist/commands/uninstall.d.ts +2 -0
- package/dist/commands/uninstall.d.ts.map +1 -0
- package/dist/commands/uninstall.js +125 -0
- package/dist/commands/uninstall.js.map +1 -0
- package/dist/commands/upgrade.d.ts +6 -0
- package/dist/commands/upgrade.d.ts.map +1 -0
- package/dist/commands/upgrade.js +204 -0
- package/dist/commands/upgrade.js.map +1 -0
- package/dist/config/i18n.d.ts +141 -0
- package/dist/config/i18n.d.ts.map +1 -0
- package/dist/config/i18n.js +316 -0
- package/dist/config/i18n.js.map +1 -0
- package/dist/config/registry.d.ts +24 -0
- package/dist/config/registry.d.ts.map +1 -0
- package/dist/config/registry.js +388 -0
- package/dist/config/registry.js.map +1 -0
- package/dist/config/user.d.ts +32 -0
- package/dist/config/user.d.ts.map +1 -0
- package/dist/config/user.js +72 -0
- package/dist/config/user.js.map +1 -0
- package/dist/executor/deps/BrewDependencyProvider.d.ts +8 -0
- package/dist/executor/deps/BrewDependencyProvider.d.ts.map +1 -0
- package/dist/executor/deps/BrewDependencyProvider.js +52 -0
- package/dist/executor/deps/BrewDependencyProvider.js.map +1 -0
- package/dist/executor/deps/DependencyProvider.d.ts +11 -0
- package/dist/executor/deps/DependencyProvider.d.ts.map +1 -0
- package/dist/executor/deps/DependencyProvider.js +3 -0
- package/dist/executor/deps/DependencyProvider.js.map +1 -0
- package/dist/executor/deps/NpmDependencyProvider.d.ts +12 -0
- package/dist/executor/deps/NpmDependencyProvider.d.ts.map +1 -0
- package/dist/executor/deps/NpmDependencyProvider.js +78 -0
- package/dist/executor/deps/NpmDependencyProvider.js.map +1 -0
- package/dist/executor/deps/PipxDependencyProvider.d.ts +8 -0
- package/dist/executor/deps/PipxDependencyProvider.d.ts.map +1 -0
- package/dist/executor/deps/PipxDependencyProvider.js +32 -0
- package/dist/executor/deps/PipxDependencyProvider.js.map +1 -0
- package/dist/executor/deps/UvToolDependencyProvider.d.ts +8 -0
- package/dist/executor/deps/UvToolDependencyProvider.d.ts.map +1 -0
- package/dist/executor/deps/UvToolDependencyProvider.js +35 -0
- package/dist/executor/deps/UvToolDependencyProvider.js.map +1 -0
- package/dist/executor/plan/ExecutionPlanner.d.ts +13 -0
- package/dist/executor/plan/ExecutionPlanner.d.ts.map +1 -0
- package/dist/executor/plan/ExecutionPlanner.js +109 -0
- package/dist/executor/plan/ExecutionPlanner.js.map +1 -0
- package/dist/executor/plan/TopologicalSorter.d.ts +3 -0
- package/dist/executor/plan/TopologicalSorter.d.ts.map +1 -0
- package/dist/executor/plan/TopologicalSorter.js +49 -0
- package/dist/executor/plan/TopologicalSorter.js.map +1 -0
- package/dist/executor/plan/registryDeps.d.ts +3 -0
- package/dist/executor/plan/registryDeps.d.ts.map +1 -0
- package/dist/executor/plan/registryDeps.js +22 -0
- package/dist/executor/plan/registryDeps.js.map +1 -0
- package/dist/executor/runner.d.ts +13 -0
- package/dist/executor/runner.d.ts.map +1 -0
- package/dist/executor/runner.js +430 -0
- package/dist/executor/runner.js.map +1 -0
- package/dist/main.d.ts +3 -0
- package/dist/main.d.ts.map +1 -0
- package/dist/main.js +244 -0
- package/dist/main.js.map +1 -0
- package/dist/utils/sound.d.ts +10 -0
- package/dist/utils/sound.d.ts.map +1 -0
- package/dist/utils/sound.js +36 -0
- package/dist/utils/sound.js.map +1 -0
- package/dist/web/api/config.js +73 -0
- package/dist/web/api/stats.js +130 -0
- package/dist/web/public/app.js +284 -0
- package/dist/web/public/index.html +367 -0
- package/dist/web/public/styles.css +1004 -0
- package/dist/web/server.js +41 -0
- package/package.json +61 -0
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.NpmDependencyProvider = void 0;
|
|
7
|
+
const execa_1 = __importDefault(require("execa"));
|
|
8
|
+
class NpmDependencyProvider {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.id = "npm";
|
|
11
|
+
this.dependentsCache = null;
|
|
12
|
+
this.loadError = false;
|
|
13
|
+
}
|
|
14
|
+
getPackageInfo(step) {
|
|
15
|
+
if (!step.uninstall)
|
|
16
|
+
return null;
|
|
17
|
+
const segment = step.uninstall.split("&&")[0]?.trim() ?? "";
|
|
18
|
+
const tokens = segment.split(/\s+/).filter(Boolean);
|
|
19
|
+
const npmIndex = tokens.indexOf("npm");
|
|
20
|
+
if (npmIndex < 0)
|
|
21
|
+
return null;
|
|
22
|
+
const uninstallIndex = tokens.findIndex((token, index) => index > npmIndex && (token === "uninstall" || token === "remove"));
|
|
23
|
+
if (uninstallIndex < 0)
|
|
24
|
+
return null;
|
|
25
|
+
for (let i = uninstallIndex + 1; i < tokens.length; i++) {
|
|
26
|
+
const token = tokens[i];
|
|
27
|
+
if (token.startsWith("-"))
|
|
28
|
+
continue;
|
|
29
|
+
return { name: token };
|
|
30
|
+
}
|
|
31
|
+
return null;
|
|
32
|
+
}
|
|
33
|
+
async getDependents(info) {
|
|
34
|
+
if (this.loadError)
|
|
35
|
+
return [];
|
|
36
|
+
if (!this.dependentsCache) {
|
|
37
|
+
this.dependentsCache = await this.buildDependentsCache();
|
|
38
|
+
}
|
|
39
|
+
return this.dependentsCache.get(info.name) || [];
|
|
40
|
+
}
|
|
41
|
+
async buildDependentsCache() {
|
|
42
|
+
try {
|
|
43
|
+
const { stdout } = await execa_1.default.command("npm ls -g --json --all", {
|
|
44
|
+
shell: true,
|
|
45
|
+
});
|
|
46
|
+
const tree = JSON.parse(stdout);
|
|
47
|
+
return this.buildReverseDependencies(tree);
|
|
48
|
+
}
|
|
49
|
+
catch {
|
|
50
|
+
this.loadError = true;
|
|
51
|
+
return new Map();
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
buildReverseDependencies(tree) {
|
|
55
|
+
const rootName = tree.name;
|
|
56
|
+
const reverse = new Map();
|
|
57
|
+
const walk = (node, parentName) => {
|
|
58
|
+
if (!node.dependencies)
|
|
59
|
+
return;
|
|
60
|
+
for (const [depName, depNode] of Object.entries(node.dependencies)) {
|
|
61
|
+
if (parentName && parentName !== rootName) {
|
|
62
|
+
if (!reverse.has(depName))
|
|
63
|
+
reverse.set(depName, new Set());
|
|
64
|
+
reverse.get(depName).add(parentName);
|
|
65
|
+
}
|
|
66
|
+
walk(depNode, depName);
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
walk(tree, tree.name);
|
|
70
|
+
const result = new Map();
|
|
71
|
+
for (const [name, deps] of reverse.entries()) {
|
|
72
|
+
result.set(name, Array.from(deps));
|
|
73
|
+
}
|
|
74
|
+
return result;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
exports.NpmDependencyProvider = NpmDependencyProvider;
|
|
78
|
+
//# sourceMappingURL=NpmDependencyProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NpmDependencyProvider.js","sourceRoot":"","sources":["../../../src/executor/deps/NpmDependencyProvider.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Step } from "../../config/registry";
|
|
2
|
+
import { DependencyProvider, PackageInfo } from "./DependencyProvider";
|
|
3
|
+
export declare class PipxDependencyProvider implements DependencyProvider {
|
|
4
|
+
id: string;
|
|
5
|
+
getPackageInfo(step: Step): PackageInfo | null;
|
|
6
|
+
getDependents(_info: PackageInfo): Promise<string[]>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=PipxDependencyProvider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PipxDependencyProvider.d.ts","sourceRoot":"","sources":["../../../src/executor/deps/PipxDependencyProvider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,uBAAuB,CAAC;AAC7C,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAEvE,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,EAAE,SAAU;IAEZ,cAAc,CAAC,IAAI,EAAE,IAAI,GAAG,WAAW,GAAG,IAAI;IAmBxC,aAAa,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;CAG3D"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PipxDependencyProvider = void 0;
|
|
4
|
+
class PipxDependencyProvider {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.id = "pipx";
|
|
7
|
+
}
|
|
8
|
+
getPackageInfo(step) {
|
|
9
|
+
if (!step.uninstall)
|
|
10
|
+
return null;
|
|
11
|
+
const segment = step.uninstall.split("&&")[0]?.trim() ?? "";
|
|
12
|
+
const tokens = segment.split(/\s+/).filter(Boolean);
|
|
13
|
+
const pipxIndex = tokens.indexOf("pipx");
|
|
14
|
+
if (pipxIndex < 0)
|
|
15
|
+
return null;
|
|
16
|
+
const uninstallIndex = tokens.findIndex((token, index) => index > pipxIndex && token === "uninstall");
|
|
17
|
+
if (uninstallIndex < 0)
|
|
18
|
+
return null;
|
|
19
|
+
for (let i = uninstallIndex + 1; i < tokens.length; i++) {
|
|
20
|
+
const token = tokens[i];
|
|
21
|
+
if (token.startsWith("-"))
|
|
22
|
+
continue;
|
|
23
|
+
return { name: token };
|
|
24
|
+
}
|
|
25
|
+
return null;
|
|
26
|
+
}
|
|
27
|
+
async getDependents(_info) {
|
|
28
|
+
return [];
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
exports.PipxDependencyProvider = PipxDependencyProvider;
|
|
32
|
+
//# sourceMappingURL=PipxDependencyProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PipxDependencyProvider.js","sourceRoot":"","sources":["../../../src/executor/deps/PipxDependencyProvider.ts"],"names":[],"mappings":";;;AAGA,MAAa,sBAAsB;IAAnC;QACE,OAAE,GAAG,MAAM,CAAC;IAwBd,CAAC;IAtBC,cAAc,CAAC,IAAU;QACvB,IAAI,CAAC,IAAI,CAAC,SAAS;YAAE,OAAO,IAAI,CAAC;QACjC,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;QAC5D,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QACpD,MAAM,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QACzC,IAAI,SAAS,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC;QAC/B,MAAM,cAAc,GAAG,MAAM,CAAC,SAAS,CACrC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,GAAG,SAAS,IAAI,KAAK,KAAK,WAAW,CAC7D,CAAC;QACF,IAAI,cAAc,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC;QAEpC,KAAK,IAAI,CAAC,GAAG,cAAc,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACxD,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;YACxB,IAAI,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC;gBAAE,SAAS;YACpC,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;QACzB,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,KAAkB;QACpC,OAAO,EAAE,CAAC;IACZ,CAAC;CACF;AAzBD,wDAyBC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Step } from "../../config/registry";
|
|
2
|
+
import { DependencyProvider, PackageInfo } from "./DependencyProvider";
|
|
3
|
+
export declare class UvToolDependencyProvider implements DependencyProvider {
|
|
4
|
+
id: string;
|
|
5
|
+
getPackageInfo(step: Step): PackageInfo | null;
|
|
6
|
+
getDependents(_info: PackageInfo): Promise<string[]>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=UvToolDependencyProvider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UvToolDependencyProvider.d.ts","sourceRoot":"","sources":["../../../src/executor/deps/UvToolDependencyProvider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,uBAAuB,CAAC;AAC7C,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAEvE,qBAAa,wBAAyB,YAAW,kBAAkB;IACjE,EAAE,SAAQ;IAEV,cAAc,CAAC,IAAI,EAAE,IAAI,GAAG,WAAW,GAAG,IAAI;IAqBxC,aAAa,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;CAG3D"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UvToolDependencyProvider = void 0;
|
|
4
|
+
class UvToolDependencyProvider {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.id = "uv";
|
|
7
|
+
}
|
|
8
|
+
getPackageInfo(step) {
|
|
9
|
+
if (!step.uninstall)
|
|
10
|
+
return null;
|
|
11
|
+
const segment = step.uninstall.split("&&")[0]?.trim() ?? "";
|
|
12
|
+
const tokens = segment.split(/\s+/).filter(Boolean);
|
|
13
|
+
const uvIndex = tokens.indexOf("uv");
|
|
14
|
+
if (uvIndex < 0)
|
|
15
|
+
return null;
|
|
16
|
+
const toolIndex = tokens.findIndex((token, index) => index > uvIndex && token === "tool");
|
|
17
|
+
if (toolIndex < 0)
|
|
18
|
+
return null;
|
|
19
|
+
const uninstallIndex = tokens.findIndex((token, index) => index > toolIndex && token === "uninstall");
|
|
20
|
+
if (uninstallIndex < 0)
|
|
21
|
+
return null;
|
|
22
|
+
for (let i = uninstallIndex + 1; i < tokens.length; i++) {
|
|
23
|
+
const token = tokens[i];
|
|
24
|
+
if (token.startsWith("-"))
|
|
25
|
+
continue;
|
|
26
|
+
return { name: token };
|
|
27
|
+
}
|
|
28
|
+
return null;
|
|
29
|
+
}
|
|
30
|
+
async getDependents(_info) {
|
|
31
|
+
return [];
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
exports.UvToolDependencyProvider = UvToolDependencyProvider;
|
|
35
|
+
//# sourceMappingURL=UvToolDependencyProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UvToolDependencyProvider.js","sourceRoot":"","sources":["../../../src/executor/deps/UvToolDependencyProvider.ts"],"names":[],"mappings":";;;AAGA,MAAa,wBAAwB;IAArC;QACE,OAAE,GAAG,IAAI,CAAC;IA0BZ,CAAC;IAxBC,cAAc,CAAC,IAAU;QACvB,IAAI,CAAC,IAAI,CAAC,SAAS;YAAE,OAAO,IAAI,CAAC;QACjC,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;QAC5D,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QACpD,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACrC,IAAI,OAAO,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC;QAC7B,MAAM,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,GAAG,OAAO,IAAI,KAAK,KAAK,MAAM,CAAC,CAAC;QAC1F,IAAI,SAAS,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC;QAC/B,MAAM,cAAc,GAAG,MAAM,CAAC,SAAS,CACrC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,GAAG,SAAS,IAAI,KAAK,KAAK,WAAW,CAC7D,CAAC;QACF,IAAI,cAAc,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC;QAEpC,KAAK,IAAI,CAAC,GAAG,cAAc,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACxD,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;YACxB,IAAI,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC;gBAAE,SAAS;YACpC,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;QACzB,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,KAAkB;QACpC,OAAO,EAAE,CAAC;IACZ,CAAC;CACF;AA3BD,4DA2BC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Step, Registry } from "../../config/registry";
|
|
2
|
+
export type ExecutionPlan = {
|
|
3
|
+
ordered: Step[];
|
|
4
|
+
addedDeps: Set<string>;
|
|
5
|
+
externalDependents: Map<string, string[]>;
|
|
6
|
+
missingDeps: Map<string, string[]>;
|
|
7
|
+
};
|
|
8
|
+
export declare class ExecutionPlanner {
|
|
9
|
+
static build(steps: Step[], action: "install" | "upgrade" | "uninstall", registry: Registry): Promise<ExecutionPlan>;
|
|
10
|
+
private static expandStepsForInstall;
|
|
11
|
+
private static applyProviderEdges;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=ExecutionPlanner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ExecutionPlanner.d.ts","sourceRoot":"","sources":["../../../src/executor/plan/ExecutionPlanner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AASvD,MAAM,MAAM,aAAa,GAAG;IAC1B,OAAO,EAAE,IAAI,EAAE,CAAC;IAChB,SAAS,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IACvB,kBAAkB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;IAC1C,WAAW,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;CACpC,CAAC;AAEF,qBAAa,gBAAgB;WACd,KAAK,CAChB,KAAK,EAAE,IAAI,EAAE,EACb,MAAM,EAAE,SAAS,GAAG,SAAS,GAAG,WAAW,EAC3C,QAAQ,EAAE,QAAQ,GACjB,OAAO,CAAC,aAAa,CAAC;IAkDzB,OAAO,CAAC,MAAM,CAAC,qBAAqB;mBAsBf,kBAAkB;CAwCxC"}
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ExecutionPlanner = void 0;
|
|
4
|
+
const BrewDependencyProvider_1 = require("../deps/BrewDependencyProvider");
|
|
5
|
+
const NpmDependencyProvider_1 = require("../deps/NpmDependencyProvider");
|
|
6
|
+
const PipxDependencyProvider_1 = require("../deps/PipxDependencyProvider");
|
|
7
|
+
const UvToolDependencyProvider_1 = require("../deps/UvToolDependencyProvider");
|
|
8
|
+
const registryDeps_1 = require("./registryDeps");
|
|
9
|
+
const TopologicalSorter_1 = require("./TopologicalSorter");
|
|
10
|
+
class ExecutionPlanner {
|
|
11
|
+
static async build(steps, action, registry) {
|
|
12
|
+
const providers = [
|
|
13
|
+
new BrewDependencyProvider_1.BrewDependencyProvider(),
|
|
14
|
+
new NpmDependencyProvider_1.NpmDependencyProvider(),
|
|
15
|
+
new PipxDependencyProvider_1.PipxDependencyProvider(),
|
|
16
|
+
new UvToolDependencyProvider_1.UvToolDependencyProvider(),
|
|
17
|
+
];
|
|
18
|
+
let planSteps = steps;
|
|
19
|
+
let addedDeps = new Set();
|
|
20
|
+
if (action === "install") {
|
|
21
|
+
const expanded = this.expandStepsForInstall(steps, registry);
|
|
22
|
+
planSteps = expanded.expanded;
|
|
23
|
+
addedDeps = expanded.addedDeps;
|
|
24
|
+
}
|
|
25
|
+
const stepsByName = new Map(planSteps.map((s) => [s.name, s]));
|
|
26
|
+
const edges = new Map();
|
|
27
|
+
const ensureEdgeSet = (name) => {
|
|
28
|
+
if (!edges.has(name))
|
|
29
|
+
edges.set(name, new Set());
|
|
30
|
+
return edges.get(name);
|
|
31
|
+
};
|
|
32
|
+
const missingDeps = new Map();
|
|
33
|
+
for (const step of planSteps) {
|
|
34
|
+
const deps = step.dependencies || [];
|
|
35
|
+
for (const depName of deps) {
|
|
36
|
+
if (!stepsByName.has(depName)) {
|
|
37
|
+
if (!missingDeps.has(step.name))
|
|
38
|
+
missingDeps.set(step.name, []);
|
|
39
|
+
missingDeps.get(step.name).push(depName);
|
|
40
|
+
continue;
|
|
41
|
+
}
|
|
42
|
+
if (action === "uninstall") {
|
|
43
|
+
ensureEdgeSet(step.name).add(depName);
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
ensureEdgeSet(depName).add(step.name);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
const externalDependents = new Map();
|
|
51
|
+
if (action === "uninstall") {
|
|
52
|
+
await this.applyProviderEdges(planSteps, providers, ensureEdgeSet, externalDependents);
|
|
53
|
+
}
|
|
54
|
+
const ordered = (0, TopologicalSorter_1.topologicalSortSteps)(planSteps, edges) || planSteps;
|
|
55
|
+
return { ordered, addedDeps, externalDependents, missingDeps };
|
|
56
|
+
}
|
|
57
|
+
static expandStepsForInstall(steps, registry) {
|
|
58
|
+
const selectedNames = new Set(steps.map((s) => s.name));
|
|
59
|
+
const addedDeps = new Set();
|
|
60
|
+
const allNames = new Set(selectedNames);
|
|
61
|
+
for (const step of steps) {
|
|
62
|
+
const deps = (0, registryDeps_1.getAllDependencies)(step, registry);
|
|
63
|
+
for (const dep of deps) {
|
|
64
|
+
if (!allNames.has(dep.name)) {
|
|
65
|
+
addedDeps.add(dep.name);
|
|
66
|
+
allNames.add(dep.name);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
const expanded = registry.steps.filter((s) => allNames.has(s.name));
|
|
71
|
+
return { expanded, addedDeps };
|
|
72
|
+
}
|
|
73
|
+
static async applyProviderEdges(steps, providers, ensureEdgeSet, externalDependents) {
|
|
74
|
+
for (const provider of providers) {
|
|
75
|
+
const infoByStep = new Map();
|
|
76
|
+
const nameToStep = new Map();
|
|
77
|
+
for (const step of steps) {
|
|
78
|
+
const info = provider.getPackageInfo(step);
|
|
79
|
+
if (!info)
|
|
80
|
+
continue;
|
|
81
|
+
infoByStep.set(step.name, info);
|
|
82
|
+
nameToStep.set(info.name, step);
|
|
83
|
+
}
|
|
84
|
+
for (const [stepName, info] of infoByStep.entries()) {
|
|
85
|
+
const dependents = await provider.getDependents(info);
|
|
86
|
+
const internal = [];
|
|
87
|
+
const external = [];
|
|
88
|
+
for (const depName of dependents) {
|
|
89
|
+
if (nameToStep.has(depName))
|
|
90
|
+
internal.push(depName);
|
|
91
|
+
else
|
|
92
|
+
external.push(depName);
|
|
93
|
+
}
|
|
94
|
+
if (external.length > 0 && provider.id === "brew") {
|
|
95
|
+
const existing = externalDependents.get(stepName) || [];
|
|
96
|
+
externalDependents.set(stepName, existing.concat(external));
|
|
97
|
+
}
|
|
98
|
+
for (const internalName of internal) {
|
|
99
|
+
const internalStep = nameToStep.get(internalName);
|
|
100
|
+
if (!internalStep)
|
|
101
|
+
continue;
|
|
102
|
+
ensureEdgeSet(internalStep.name).add(stepName);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
exports.ExecutionPlanner = ExecutionPlanner;
|
|
109
|
+
//# sourceMappingURL=ExecutionPlanner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ExecutionPlanner.js","sourceRoot":"","sources":["../../../src/executor/plan/ExecutionPlanner.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TopologicalSorter.d.ts","sourceRoot":"","sources":["../../../src/executor/plan/TopologicalSorter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,uBAAuB,CAAC;AAE7C,wBAAgB,oBAAoB,CAClC,KAAK,EAAE,IAAI,EAAE,EACb,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC,GAC9B,IAAI,EAAE,GAAG,IAAI,CA2Cf"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.topologicalSortSteps = topologicalSortSteps;
|
|
4
|
+
function topologicalSortSteps(steps, edges) {
|
|
5
|
+
const stepsByName = new Map(steps.map((s) => [s.name, s]));
|
|
6
|
+
const inDegree = new Map();
|
|
7
|
+
for (const step of steps) {
|
|
8
|
+
inDegree.set(step.name, 0);
|
|
9
|
+
}
|
|
10
|
+
for (const [from, tos] of edges.entries()) {
|
|
11
|
+
if (!stepsByName.has(from))
|
|
12
|
+
continue;
|
|
13
|
+
for (const to of tos) {
|
|
14
|
+
if (!stepsByName.has(to))
|
|
15
|
+
continue;
|
|
16
|
+
inDegree.set(to, (inDegree.get(to) || 0) + 1);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
const queue = [];
|
|
20
|
+
for (const step of steps) {
|
|
21
|
+
if ((inDegree.get(step.name) || 0) === 0) {
|
|
22
|
+
queue.push(step);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
const ordered = [];
|
|
26
|
+
while (queue.length > 0) {
|
|
27
|
+
const current = queue.shift();
|
|
28
|
+
if (!current)
|
|
29
|
+
break;
|
|
30
|
+
ordered.push(current);
|
|
31
|
+
const neighbors = edges.get(current.name);
|
|
32
|
+
if (!neighbors)
|
|
33
|
+
continue;
|
|
34
|
+
for (const next of neighbors) {
|
|
35
|
+
const degree = (inDegree.get(next) || 0) - 1;
|
|
36
|
+
inDegree.set(next, degree);
|
|
37
|
+
if (degree === 0) {
|
|
38
|
+
const step = stepsByName.get(next);
|
|
39
|
+
if (step)
|
|
40
|
+
queue.push(step);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
if (ordered.length !== steps.length) {
|
|
45
|
+
return null;
|
|
46
|
+
}
|
|
47
|
+
return ordered;
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=TopologicalSorter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TopologicalSorter.js","sourceRoot":"","sources":["../../../src/executor/plan/TopologicalSorter.ts"],"names":[],"mappings":";;AAEA,oDA8CC;AA9CD,SAAgB,oBAAoB,CAClC,KAAa,EACb,KAA+B;IAE/B,MAAM,WAAW,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3D,MAAM,QAAQ,GAAG,IAAI,GAAG,EAAkB,CAAC;IAE3C,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAC7B,CAAC;IACD,KAAK,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,IAAI,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC;QAC1C,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC;YAAE,SAAS;QACrC,KAAK,MAAM,EAAE,IAAI,GAAG,EAAE,CAAC;YACrB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC;gBAAE,SAAS;YACnC,QAAQ,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAChD,CAAC;IACH,CAAC;IAED,MAAM,KAAK,GAAW,EAAE,CAAC;IACzB,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC;YACzC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnB,CAAC;IACH,CAAC;IAED,MAAM,OAAO,GAAW,EAAE,CAAC;IAC3B,OAAO,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACxB,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,EAAE,CAAC;QAC9B,IAAI,CAAC,OAAO;YAAE,MAAM;QACpB,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACtB,MAAM,SAAS,GAAG,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC1C,IAAI,CAAC,SAAS;YAAE,SAAS;QACzB,KAAK,MAAM,IAAI,IAAI,SAAS,EAAE,CAAC;YAC7B,MAAM,MAAM,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;YAC7C,QAAQ,CAAC,GAAG,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;YAC3B,IAAI,MAAM,KAAK,CAAC,EAAE,CAAC;gBACjB,MAAM,IAAI,GAAG,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;gBACnC,IAAI,IAAI;oBAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC7B,CAAC;QACH,CAAC;IACH,CAAC;IAED,IAAI,OAAO,CAAC,MAAM,KAAK,KAAK,CAAC,MAAM,EAAE,CAAC;QACpC,OAAO,IAAI,CAAC;IACd,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registryDeps.d.ts","sourceRoot":"","sources":["../../../src/executor/plan/registryDeps.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAEvD,wBAAgB,kBAAkB,CAChC,IAAI,EAAE,IAAI,EACV,QAAQ,EAAE,QAAQ,EAClB,OAAO,GAAE,GAAG,CAAC,MAAM,CAAa,GAC/B,IAAI,EAAE,CAkBR"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getAllDependencies = getAllDependencies;
|
|
4
|
+
function getAllDependencies(step, registry, visited = new Set()) {
|
|
5
|
+
if (!step.dependencies || step.dependencies.length === 0) {
|
|
6
|
+
return [];
|
|
7
|
+
}
|
|
8
|
+
const deps = [];
|
|
9
|
+
for (const depName of step.dependencies) {
|
|
10
|
+
if (visited.has(depName))
|
|
11
|
+
continue;
|
|
12
|
+
visited.add(depName);
|
|
13
|
+
const depStep = registry.steps.find((s) => s.name === depName);
|
|
14
|
+
if (depStep) {
|
|
15
|
+
const nestedDeps = getAllDependencies(depStep, registry, visited);
|
|
16
|
+
deps.push(...nestedDeps);
|
|
17
|
+
deps.push(depStep);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
return deps;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=registryDeps.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registryDeps.js","sourceRoot":"","sources":["../../../src/executor/plan/registryDeps.ts"],"names":[],"mappings":";;AAEA,gDAsBC;AAtBD,SAAgB,kBAAkB,CAChC,IAAU,EACV,QAAkB,EAClB,UAAuB,IAAI,GAAG,EAAE;IAEhC,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,MAAM,IAAI,GAAW,EAAE,CAAC;IACxB,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;QACxC,IAAI,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC;YAAE,SAAS;QACnC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QAErB,MAAM,OAAO,GAAG,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC;QAC/D,IAAI,OAAO,EAAE,CAAC;YACZ,MAAM,UAAU,GAAG,kBAAkB,CAAC,OAAO,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;YAClE,IAAI,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,CAAC;YACzB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACrB,CAAC;IACH,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Step, Registry } from "../config/registry";
|
|
2
|
+
export interface ExecuteResult {
|
|
3
|
+
step: Step;
|
|
4
|
+
action: "install" | "upgrade" | "uninstall" | "skip";
|
|
5
|
+
success: boolean;
|
|
6
|
+
message?: string;
|
|
7
|
+
duration?: number;
|
|
8
|
+
}
|
|
9
|
+
export declare function checkStep(step: Step): Promise<boolean>;
|
|
10
|
+
export declare function executeStep(step: Step, action: "install" | "upgrade" | "uninstall", registry?: Registry, installedSteps?: Set<string>, allResults?: ExecuteResult[], isDependency?: boolean): Promise<ExecuteResult>;
|
|
11
|
+
export declare function executeSteps(steps: Step[], action: "install" | "upgrade" | "uninstall", registry?: Registry): Promise<ExecuteResult[]>;
|
|
12
|
+
export declare function printResults(results: ExecuteResult[]): void;
|
|
13
|
+
//# sourceMappingURL=runner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runner.d.ts","sourceRoot":"","sources":["../../src/executor/runner.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AASpD,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,IAAI,CAAC;IACX,MAAM,EAAE,SAAS,GAAG,SAAS,GAAG,WAAW,GAAG,MAAM,CAAC;IACrD,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,wBAAsB,SAAS,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,OAAO,CAAC,CAS5D;AA2DD,wBAAsB,WAAW,CAC/B,IAAI,EAAE,IAAI,EACV,MAAM,EAAE,SAAS,GAAG,SAAS,GAAG,WAAW,EAC3C,QAAQ,CAAC,EAAE,QAAQ,EACnB,cAAc,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,EAC5B,UAAU,CAAC,EAAE,aAAa,EAAE,EAC5B,YAAY,GAAE,OAAe,GAC5B,OAAO,CAAC,aAAa,CAAC,CA+GxB;AAiID,wBAAsB,YAAY,CAChC,KAAK,EAAE,IAAI,EAAE,EACb,MAAM,EAAE,SAAS,GAAG,SAAS,GAAG,WAAW,EAC3C,QAAQ,CAAC,EAAE,QAAQ,GAClB,OAAO,CAAC,aAAa,EAAE,CAAC,CAuD1B;AAaD,wBAAgB,YAAY,CAAC,OAAO,EAAE,aAAa,EAAE,QAwDpD"}
|