@kevinrabun/judges 3.90.0 → 3.91.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.
Files changed (42) hide show
  1. package/CHANGELOG.md +13 -0
  2. package/dist/cli.d.ts.map +1 -1
  3. package/dist/cli.js +63 -0
  4. package/dist/cli.js.map +1 -1
  5. package/dist/commands/finding-blast-radius.d.ts +5 -0
  6. package/dist/commands/finding-blast-radius.d.ts.map +1 -0
  7. package/dist/commands/finding-blast-radius.js +92 -0
  8. package/dist/commands/finding-blast-radius.js.map +1 -0
  9. package/dist/commands/finding-hotspot-map.d.ts +5 -0
  10. package/dist/commands/finding-hotspot-map.d.ts.map +1 -0
  11. package/dist/commands/finding-hotspot-map.js +107 -0
  12. package/dist/commands/finding-hotspot-map.js.map +1 -0
  13. package/dist/commands/finding-metadata-enrich.d.ts +5 -0
  14. package/dist/commands/finding-metadata-enrich.d.ts.map +1 -0
  15. package/dist/commands/finding-metadata-enrich.js +93 -0
  16. package/dist/commands/finding-metadata-enrich.js.map +1 -0
  17. package/dist/commands/review-annotation-export.d.ts +5 -0
  18. package/dist/commands/review-annotation-export.d.ts.map +1 -0
  19. package/dist/commands/review-annotation-export.js +106 -0
  20. package/dist/commands/review-annotation-export.js.map +1 -0
  21. package/dist/commands/review-cache-warm.d.ts +5 -0
  22. package/dist/commands/review-cache-warm.d.ts.map +1 -0
  23. package/dist/commands/review-cache-warm.js +71 -0
  24. package/dist/commands/review-cache-warm.js.map +1 -0
  25. package/dist/commands/review-merge-config.d.ts +5 -0
  26. package/dist/commands/review-merge-config.d.ts.map +1 -0
  27. package/dist/commands/review-merge-config.js +120 -0
  28. package/dist/commands/review-merge-config.js.map +1 -0
  29. package/dist/commands/review-onboard-wizard.d.ts +5 -0
  30. package/dist/commands/review-onboard-wizard.d.ts.map +1 -0
  31. package/dist/commands/review-onboard-wizard.js +93 -0
  32. package/dist/commands/review-onboard-wizard.js.map +1 -0
  33. package/dist/commands/review-parallel-run.d.ts +5 -0
  34. package/dist/commands/review-parallel-run.d.ts.map +1 -0
  35. package/dist/commands/review-parallel-run.js +117 -0
  36. package/dist/commands/review-parallel-run.js.map +1 -0
  37. package/dist/commands/review-quality-score.d.ts +5 -0
  38. package/dist/commands/review-quality-score.d.ts.map +1 -0
  39. package/dist/commands/review-quality-score.js +128 -0
  40. package/dist/commands/review-quality-score.js.map +1 -0
  41. package/package.json +1 -1
  42. package/server.json +2 -2
@@ -0,0 +1,120 @@
1
+ /**
2
+ * Review-merge-config — Merge multiple Judges configuration files.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync } from "fs";
5
+ // ─── Analysis ───────────────────────────────────────────────────────────────
6
+ function mergeConfigs(configs) {
7
+ const merged = {};
8
+ const conflicts = [];
9
+ const sources = configs.map((c) => c.path);
10
+ // merge presets — last wins, track conflicts
11
+ const presets = configs.filter((c) => c.config.preset).map((c) => c.config.preset);
12
+ if (presets.length > 1 && new Set(presets).size > 1) {
13
+ conflicts.push({ key: "preset", values: presets });
14
+ }
15
+ if (presets.length > 0) {
16
+ merged.preset = presets[presets.length - 1];
17
+ }
18
+ // merge disabled judges — union
19
+ const allDisabled = new Set();
20
+ for (const c of configs) {
21
+ if (c.config.disabledJudges) {
22
+ for (const j of c.config.disabledJudges) {
23
+ allDisabled.add(j);
24
+ }
25
+ }
26
+ }
27
+ if (allDisabled.size > 0) {
28
+ merged.disabledJudges = [...allDisabled];
29
+ }
30
+ // merge disabled rules — union
31
+ const allDisabledRules = new Set();
32
+ for (const c of configs) {
33
+ if (c.config.disabledRules) {
34
+ for (const r of c.config.disabledRules) {
35
+ allDisabledRules.add(r);
36
+ }
37
+ }
38
+ }
39
+ if (allDisabledRules.size > 0) {
40
+ merged.disabledRules = [...allDisabledRules];
41
+ }
42
+ // merge minSeverity — most restrictive (highest)
43
+ const severityOrder = ["low", "medium", "high", "critical"];
44
+ const severities = configs.filter((c) => c.config.minSeverity).map((c) => c.config.minSeverity);
45
+ if (severities.length > 0) {
46
+ const maxSev = severities.reduce((a, b) => (severityOrder.indexOf(a) > severityOrder.indexOf(b) ? a : b));
47
+ merged.minSeverity = maxSev;
48
+ }
49
+ return { merged, sources, conflicts };
50
+ }
51
+ // ─── CLI ────────────────────────────────────────────────────────────────────
52
+ export function runReviewMergeConfig(argv) {
53
+ const filesIdx = argv.indexOf("--files");
54
+ const outputIdx = argv.indexOf("--output");
55
+ const formatIdx = argv.indexOf("--format");
56
+ const outputPath = outputIdx >= 0 ? argv[outputIdx + 1] : undefined;
57
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
58
+ if (argv.includes("--help") || argv.includes("-h")) {
59
+ console.log(`
60
+ judges review-merge-config — Merge configuration files
61
+
62
+ Usage:
63
+ judges review-merge-config --files <a.json,b.json,...> [--output <out.json>]
64
+ [--format table|json]
65
+
66
+ Options:
67
+ --files <paths> Comma-separated config file paths (required)
68
+ --output <path> Write merged config to file
69
+ --format <fmt> Output format: table (default), json
70
+ --help, -h Show this help
71
+ `);
72
+ return;
73
+ }
74
+ const filesArg = filesIdx >= 0 ? argv[filesIdx + 1] : undefined;
75
+ if (!filesArg) {
76
+ console.error("Error: --files required");
77
+ process.exitCode = 1;
78
+ return;
79
+ }
80
+ const filePaths = filesArg.split(",").map((f) => f.trim());
81
+ const configs = [];
82
+ for (const fp of filePaths) {
83
+ if (!existsSync(fp)) {
84
+ console.error(`Error: not found: ${fp}`);
85
+ process.exitCode = 1;
86
+ return;
87
+ }
88
+ try {
89
+ configs.push({ path: fp, config: JSON.parse(readFileSync(fp, "utf-8")) });
90
+ }
91
+ catch {
92
+ console.error(`Error: invalid JSON: ${fp}`);
93
+ process.exitCode = 1;
94
+ return;
95
+ }
96
+ }
97
+ const result = mergeConfigs(configs);
98
+ if (outputPath) {
99
+ writeFileSync(outputPath, JSON.stringify(result.merged, null, 2));
100
+ console.log(`Merged config written to ${outputPath}`);
101
+ return;
102
+ }
103
+ if (format === "json") {
104
+ console.log(JSON.stringify(result, null, 2));
105
+ return;
106
+ }
107
+ console.log(`\nMerged Configuration (${result.sources.length} sources)`);
108
+ console.log("═".repeat(60));
109
+ console.log(` Sources: ${result.sources.join(", ")}`);
110
+ console.log(` Merged config:`);
111
+ console.log(` ${JSON.stringify(result.merged, null, 2).replace(/\n/g, "\n ")}`);
112
+ if (result.conflicts.length > 0) {
113
+ console.log(`\n Conflicts (${result.conflicts.length}):`);
114
+ for (const c of result.conflicts) {
115
+ console.log(` ${c.key}: ${c.values.join(" vs ")}`);
116
+ }
117
+ }
118
+ console.log("═".repeat(60));
119
+ }
120
+ //# sourceMappingURL=review-merge-config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-merge-config.js","sourceRoot":"","sources":["../../src/commands/review-merge-config.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-onboard-wizard — Interactive onboarding wizard for new users.
3
+ */
4
+ export declare function runReviewOnboardWizard(argv: string[]): void;
5
+ //# sourceMappingURL=review-onboard-wizard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-onboard-wizard.d.ts","sourceRoot":"","sources":["../../src/commands/review-onboard-wizard.ts"],"names":[],"mappings":"AAAA;;GAEG;AAgDH,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAgE3D"}
@@ -0,0 +1,93 @@
1
+ /**
2
+ * Review-onboard-wizard — Interactive onboarding wizard for new users.
3
+ */
4
+ import { writeFileSync, existsSync, mkdirSync } from "fs";
5
+ import { dirname } from "path";
6
+ import { defaultRegistry } from "../judge-registry.js";
7
+ // ─── Wizard Logic ───────────────────────────────────────────────────────────
8
+ function generateProfile(team, language, focus) {
9
+ const judges = defaultRegistry.getJudges();
10
+ // suggest judges based on focus areas
11
+ const suggested = judges.filter((j) => {
12
+ const jName = `${j.id} ${j.domain}`.toLowerCase();
13
+ return focus.some((f) => jName.includes(f.toLowerCase()));
14
+ });
15
+ // pick preset based on focus
16
+ let preset = "default";
17
+ if (focus.includes("security"))
18
+ preset = "security-focused";
19
+ else if (focus.includes("performance"))
20
+ preset = "performance";
21
+ else if (focus.includes("quality"))
22
+ preset = "strict";
23
+ return {
24
+ version: 1,
25
+ team,
26
+ language,
27
+ focus,
28
+ preset,
29
+ suggestedJudges: suggested.map((j) => j.id).slice(0, 10),
30
+ configPath: ".judgesrc.json",
31
+ };
32
+ }
33
+ // ─── CLI ────────────────────────────────────────────────────────────────────
34
+ export function runReviewOnboardWizard(argv) {
35
+ const teamIdx = argv.indexOf("--team");
36
+ const langIdx = argv.indexOf("--language");
37
+ const focusIdx = argv.indexOf("--focus");
38
+ const outputIdx = argv.indexOf("--output");
39
+ const formatIdx = argv.indexOf("--format");
40
+ const team = teamIdx >= 0 ? argv[teamIdx + 1] : "default";
41
+ const language = langIdx >= 0 ? argv[langIdx + 1] : "typescript";
42
+ const focusArg = focusIdx >= 0 ? argv[focusIdx + 1] : "security,quality";
43
+ const outputPath = outputIdx >= 0 ? argv[outputIdx + 1] : undefined;
44
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
45
+ if (argv.includes("--help") || argv.includes("-h")) {
46
+ console.log(`
47
+ judges review-onboard-wizard — Onboarding wizard
48
+
49
+ Usage:
50
+ judges review-onboard-wizard [--team <name>] [--language <lang>]
51
+ [--focus <areas>] [--output <file>]
52
+ [--format table|json]
53
+
54
+ Options:
55
+ --team <name> Team name (default: default)
56
+ --language <lang> Primary language (default: typescript)
57
+ --focus <areas> Comma-separated focus areas (e.g., security,quality)
58
+ --output <path> Write config to file
59
+ --format <fmt> Output format: table (default), json
60
+ --help, -h Show this help
61
+ `);
62
+ return;
63
+ }
64
+ const focus = focusArg.split(",").map((f) => f.trim());
65
+ const profile = generateProfile(team, language, focus);
66
+ if (outputPath) {
67
+ const dir = dirname(outputPath);
68
+ if (!existsSync(dir)) {
69
+ mkdirSync(dir, { recursive: true });
70
+ }
71
+ writeFileSync(outputPath, JSON.stringify(profile, null, 2));
72
+ console.log(`Onboard profile written to ${outputPath}`);
73
+ return;
74
+ }
75
+ if (format === "json") {
76
+ console.log(JSON.stringify(profile, null, 2));
77
+ return;
78
+ }
79
+ console.log(`\nOnboarding Wizard`);
80
+ console.log("═".repeat(55));
81
+ console.log(` Team: ${profile.team}`);
82
+ console.log(` Language: ${profile.language}`);
83
+ console.log(` Focus: ${profile.focus.join(", ")}`);
84
+ console.log(` Preset: ${profile.preset}`);
85
+ console.log(` Config: ${profile.configPath}`);
86
+ console.log(`\n Suggested Judges (${profile.suggestedJudges.length}):`);
87
+ for (const j of profile.suggestedJudges) {
88
+ console.log(` - ${j}`);
89
+ }
90
+ console.log("═".repeat(55));
91
+ console.log("\nTo get started, run: judges eval --file <your-file>");
92
+ }
93
+ //# sourceMappingURL=review-onboard-wizard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-onboard-wizard.js","sourceRoot":"","sources":["../../src/commands/review-onboard-wizard.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-parallel-run — Configure and summarize parallel review runs.
3
+ */
4
+ export declare function runReviewParallelRun(argv: string[]): void;
5
+ //# sourceMappingURL=review-parallel-run.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-parallel-run.d.ts","sourceRoot":"","sources":["../../src/commands/review-parallel-run.ts"],"names":[],"mappings":"AAAA;;GAEG;AAoEH,wBAAgB,oBAAoB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA2EzD"}
@@ -0,0 +1,117 @@
1
+ /**
2
+ * Review-parallel-run — Configure and summarize parallel review runs.
3
+ */
4
+ import { readFileSync, existsSync, readdirSync } from "fs";
5
+ // ─── Analysis ───────────────────────────────────────────────────────────────
6
+ function summarizeParallel(verdicts) {
7
+ const totalRuns = verdicts.length;
8
+ const scores = verdicts.map((v) => v.overallScore);
9
+ const avgScore = Math.round(scores.reduce((a, b) => a + b, 0) / totalRuns);
10
+ // variance
11
+ const variance = scores.reduce((sum, s) => sum + Math.pow(s - avgScore, 2), 0) / totalRuns;
12
+ const scoreVariance = Math.round(Math.sqrt(variance) * 10) / 10;
13
+ // verdict agreement
14
+ const verdictCounts = new Map();
15
+ for (const v of verdicts) {
16
+ verdictCounts.set(v.overallVerdict, (verdictCounts.get(v.overallVerdict) || 0) + 1);
17
+ }
18
+ const maxVerdictEntry = [...verdictCounts.entries()].sort((a, b) => b[1] - a[1])[0];
19
+ const consensusVerdict = maxVerdictEntry[0];
20
+ const verdictAgreement = Math.round((maxVerdictEntry[1] / totalRuns) * 100);
21
+ // finding consensus
22
+ const findingCounts = new Map();
23
+ for (const v of verdicts) {
24
+ const seen = new Set();
25
+ for (const f of v.findings) {
26
+ if (!seen.has(f.ruleId)) {
27
+ seen.add(f.ruleId);
28
+ const existing = findingCounts.get(f.ruleId);
29
+ if (existing) {
30
+ existing.count++;
31
+ }
32
+ else {
33
+ findingCounts.set(f.ruleId, { title: f.title, count: 1 });
34
+ }
35
+ }
36
+ }
37
+ }
38
+ const mergedFindings = [...findingCounts.entries()]
39
+ .map(([ruleId, data]) => ({
40
+ ruleId,
41
+ title: data.title,
42
+ agreedCount: data.count,
43
+ totalRuns,
44
+ }))
45
+ .sort((a, b) => b.agreedCount - a.agreedCount);
46
+ return { totalRuns, scores, avgScore, scoreVariance, consensusVerdict, verdictAgreement, mergedFindings };
47
+ }
48
+ // ─── CLI ────────────────────────────────────────────────────────────────────
49
+ export function runReviewParallelRun(argv) {
50
+ const dirIdx = argv.indexOf("--dir");
51
+ const formatIdx = argv.indexOf("--format");
52
+ const minAgreeIdx = argv.indexOf("--min-agree");
53
+ const dirPath = dirIdx >= 0 ? argv[dirIdx + 1] : undefined;
54
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
55
+ const minAgree = minAgreeIdx >= 0 ? parseInt(argv[minAgreeIdx + 1], 10) : 1;
56
+ if (argv.includes("--help") || argv.includes("-h")) {
57
+ console.log(`
58
+ judges review-parallel-run — Summarize parallel review runs
59
+
60
+ Usage:
61
+ judges review-parallel-run --dir <verdicts-dir> [--min-agree <n>]
62
+ [--format table|json]
63
+
64
+ Options:
65
+ --dir <path> Directory of verdict JSON files (required)
66
+ --min-agree <n> Minimum agreement count to include finding (default: 1)
67
+ --format <fmt> Output format: table (default), json
68
+ --help, -h Show this help
69
+ `);
70
+ return;
71
+ }
72
+ if (!dirPath) {
73
+ console.error("Error: --dir required");
74
+ process.exitCode = 1;
75
+ return;
76
+ }
77
+ if (!existsSync(dirPath)) {
78
+ console.error(`Error: not found: ${dirPath}`);
79
+ process.exitCode = 1;
80
+ return;
81
+ }
82
+ const files = readdirSync(dirPath).filter((f) => f.endsWith(".json"));
83
+ const verdicts = [];
84
+ for (const file of files) {
85
+ try {
86
+ verdicts.push(JSON.parse(readFileSync(`${dirPath}/${file}`, "utf-8")));
87
+ }
88
+ catch {
89
+ // skip
90
+ }
91
+ }
92
+ if (verdicts.length === 0) {
93
+ console.error("Error: no valid verdict files found");
94
+ process.exitCode = 1;
95
+ return;
96
+ }
97
+ const summary = summarizeParallel(verdicts);
98
+ const filtered = summary.mergedFindings.filter((f) => f.agreedCount >= minAgree);
99
+ if (format === "json") {
100
+ console.log(JSON.stringify({ ...summary, mergedFindings: filtered }, null, 2));
101
+ return;
102
+ }
103
+ console.log(`\nParallel Run Summary (${summary.totalRuns} runs)`);
104
+ console.log("═".repeat(70));
105
+ console.log(` Avg Score: ${summary.avgScore} | Variance: ${summary.scoreVariance}`);
106
+ console.log(` Consensus: ${summary.consensusVerdict} (${summary.verdictAgreement}% agreement)`);
107
+ console.log("─".repeat(70));
108
+ console.log(`${"Rule".padEnd(22)} ${"Agreement".padEnd(14)} Title`);
109
+ console.log("─".repeat(70));
110
+ for (const f of filtered.slice(0, 20)) {
111
+ const rule = f.ruleId.length > 20 ? f.ruleId.slice(0, 20) + "…" : f.ruleId;
112
+ const title = f.title.length > 30 ? f.title.slice(0, 30) + "…" : f.title;
113
+ console.log(`${rule.padEnd(22)} ${f.agreedCount}/${f.totalRuns}${" ".repeat(10)} ${title}`);
114
+ }
115
+ console.log("═".repeat(70));
116
+ }
117
+ //# sourceMappingURL=review-parallel-run.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-parallel-run.js","sourceRoot":"","sources":["../../src/commands/review-parallel-run.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-quality-score — Compute a quality score from multiple dimensions.
3
+ */
4
+ export declare function runReviewQualityScore(argv: string[]): void;
5
+ //# sourceMappingURL=review-quality-score.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-quality-score.d.ts","sourceRoot":"","sources":["../../src/commands/review-quality-score.ts"],"names":[],"mappings":"AAAA;;GAEG;AA0GH,wBAAgB,qBAAqB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAyD1D"}
@@ -0,0 +1,128 @@
1
+ /**
2
+ * Review-quality-score — Compute a quality score from multiple dimensions.
3
+ */
4
+ import { readFileSync, existsSync } from "fs";
5
+ // ─── Analysis ───────────────────────────────────────────────────────────────
6
+ function computeQuality(verdict) {
7
+ const dimensions = [];
8
+ // Security dimension
9
+ const secFindings = verdict.findings.filter((f) => {
10
+ const combined = `${f.ruleId} ${f.title}`.toLowerCase();
11
+ return (combined.includes("auth") ||
12
+ combined.includes("inject") ||
13
+ combined.includes("xss") ||
14
+ combined.includes("crypt") ||
15
+ combined.includes("vuln") ||
16
+ combined.includes("secret"));
17
+ });
18
+ const secScore = secFindings.length === 0 ? 100 : Math.max(0, 100 - secFindings.length * 15);
19
+ dimensions.push({
20
+ name: "Security",
21
+ score: secScore,
22
+ weight: 3,
23
+ detail: `${secFindings.length} security findings`,
24
+ });
25
+ // Reliability dimension
26
+ const relScore = Math.max(0, 100 - verdict.criticalCount * 25 - verdict.highCount * 10);
27
+ dimensions.push({
28
+ name: "Reliability",
29
+ score: relScore,
30
+ weight: 2,
31
+ detail: `${verdict.criticalCount} critical, ${verdict.highCount} high`,
32
+ });
33
+ // Maintainability dimension
34
+ const totalFindings = verdict.findings.length;
35
+ const maintScore = totalFindings === 0 ? 100 : Math.max(0, 100 - totalFindings * 3);
36
+ dimensions.push({
37
+ name: "Maintainability",
38
+ score: maintScore,
39
+ weight: 2,
40
+ detail: `${totalFindings} total findings`,
41
+ });
42
+ // Judge coverage dimension
43
+ const uniqueJudges = new Set(verdict.evaluations.map((e) => e.judgeId));
44
+ const coverageScore = Math.min(100, uniqueJudges.size * 15);
45
+ dimensions.push({
46
+ name: "Coverage",
47
+ score: coverageScore,
48
+ weight: 1,
49
+ detail: `${uniqueJudges.size} unique judges`,
50
+ });
51
+ // Verdict confidence dimension
52
+ const avgEvalScore = verdict.evaluations.length > 0
53
+ ? verdict.evaluations.reduce((s, e) => s + e.score, 0) / verdict.evaluations.length
54
+ : 50;
55
+ dimensions.push({
56
+ name: "Confidence",
57
+ score: Math.round(avgEvalScore),
58
+ weight: 1,
59
+ detail: `avg eval score: ${Math.round(avgEvalScore)}`,
60
+ });
61
+ // weighted average
62
+ const totalWeight = dimensions.reduce((s, d) => s + d.weight, 0);
63
+ const overallQuality = Math.round(dimensions.reduce((s, d) => s + d.score * d.weight, 0) / totalWeight);
64
+ const grade = overallQuality >= 90
65
+ ? "A"
66
+ : overallQuality >= 80
67
+ ? "B"
68
+ : overallQuality >= 70
69
+ ? "C"
70
+ : overallQuality >= 60
71
+ ? "D"
72
+ : "F";
73
+ return { overallQuality, grade, dimensions };
74
+ }
75
+ // ─── CLI ────────────────────────────────────────────────────────────────────
76
+ export function runReviewQualityScore(argv) {
77
+ const fileIdx = argv.indexOf("--file");
78
+ const formatIdx = argv.indexOf("--format");
79
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
80
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
81
+ if (argv.includes("--help") || argv.includes("-h")) {
82
+ console.log(`
83
+ judges review-quality-score — Compute multi-dimension quality score
84
+
85
+ Usage:
86
+ judges review-quality-score --file <verdict.json> [--format table|json]
87
+
88
+ Options:
89
+ --file <path> Path to verdict JSON file (required)
90
+ --format <fmt> Output format: table (default), json
91
+ --help, -h Show this help
92
+ `);
93
+ return;
94
+ }
95
+ if (!filePath) {
96
+ console.error("Error: --file required");
97
+ process.exitCode = 1;
98
+ return;
99
+ }
100
+ if (!existsSync(filePath)) {
101
+ console.error(`Error: not found: ${filePath}`);
102
+ process.exitCode = 1;
103
+ return;
104
+ }
105
+ let verdict;
106
+ try {
107
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
108
+ }
109
+ catch {
110
+ console.error("Error: invalid JSON");
111
+ process.exitCode = 1;
112
+ return;
113
+ }
114
+ const report = computeQuality(verdict);
115
+ if (format === "json") {
116
+ console.log(JSON.stringify(report, null, 2));
117
+ return;
118
+ }
119
+ console.log(`\nQuality Score: ${report.overallQuality}/100 (Grade: ${report.grade})`);
120
+ console.log("═".repeat(60));
121
+ console.log(`${"Dimension".padEnd(18)} ${"Score".padEnd(8)} ${"Weight".padEnd(8)} Detail`);
122
+ console.log("─".repeat(60));
123
+ for (const d of report.dimensions) {
124
+ console.log(`${d.name.padEnd(18)} ${String(d.score).padEnd(8)} ×${String(d.weight).padEnd(7)} ${d.detail}`);
125
+ }
126
+ console.log("═".repeat(60));
127
+ }
128
+ //# sourceMappingURL=review-quality-score.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-quality-score.js","sourceRoot":"","sources":["../../src/commands/review-quality-score.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kevinrabun/judges",
3
- "version": "3.90.0",
3
+ "version": "3.91.0",
4
4
  "description": "45 specialized judges that evaluate AI-generated code for security, cost, and quality.",
5
5
  "mcpName": "io.github.KevinRabun/judges",
6
6
  "type": "module",
package/server.json CHANGED
@@ -7,12 +7,12 @@
7
7
  "url": "https://github.com/kevinrabun/judges",
8
8
  "source": "github"
9
9
  },
10
- "version": "3.90.0",
10
+ "version": "3.91.0",
11
11
  "packages": [
12
12
  {
13
13
  "registryType": "npm",
14
14
  "identifier": "@kevinrabun/judges",
15
- "version": "3.90.0",
15
+ "version": "3.91.0",
16
16
  "transport": {
17
17
  "type": "stdio"
18
18
  }