@kevinrabun/judges 3.95.0 → 3.96.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-confidence-calibrate.d.ts +5 -0
  6. package/dist/commands/finding-confidence-calibrate.d.ts.map +1 -0
  7. package/dist/commands/finding-confidence-calibrate.js +112 -0
  8. package/dist/commands/finding-confidence-calibrate.js.map +1 -0
  9. package/dist/commands/finding-severity-heatmap.d.ts +5 -0
  10. package/dist/commands/finding-severity-heatmap.d.ts.map +1 -0
  11. package/dist/commands/finding-severity-heatmap.js +109 -0
  12. package/dist/commands/finding-severity-heatmap.js.map +1 -0
  13. package/dist/commands/review-adoption-metrics.d.ts +5 -0
  14. package/dist/commands/review-adoption-metrics.d.ts.map +1 -0
  15. package/dist/commands/review-adoption-metrics.js +96 -0
  16. package/dist/commands/review-adoption-metrics.js.map +1 -0
  17. package/dist/commands/review-bulk-apply.d.ts +5 -0
  18. package/dist/commands/review-bulk-apply.d.ts.map +1 -0
  19. package/dist/commands/review-bulk-apply.js +103 -0
  20. package/dist/commands/review-bulk-apply.js.map +1 -0
  21. package/dist/commands/review-config-migrate.d.ts +5 -0
  22. package/dist/commands/review-config-migrate.d.ts.map +1 -0
  23. package/dist/commands/review-config-migrate.js +124 -0
  24. package/dist/commands/review-config-migrate.js.map +1 -0
  25. package/dist/commands/review-history-compare.d.ts +5 -0
  26. package/dist/commands/review-history-compare.d.ts.map +1 -0
  27. package/dist/commands/review-history-compare.js +94 -0
  28. package/dist/commands/review-history-compare.js.map +1 -0
  29. package/dist/commands/review-output-transform.d.ts +5 -0
  30. package/dist/commands/review-output-transform.d.ts.map +1 -0
  31. package/dist/commands/review-output-transform.js +120 -0
  32. package/dist/commands/review-output-transform.js.map +1 -0
  33. package/dist/commands/review-team-dashboard.d.ts +5 -0
  34. package/dist/commands/review-team-dashboard.d.ts.map +1 -0
  35. package/dist/commands/review-team-dashboard.js +99 -0
  36. package/dist/commands/review-team-dashboard.js.map +1 -0
  37. package/dist/commands/review-workspace-init.d.ts +5 -0
  38. package/dist/commands/review-workspace-init.d.ts.map +1 -0
  39. package/dist/commands/review-workspace-init.js +105 -0
  40. package/dist/commands/review-workspace-init.js.map +1 -0
  41. package/package.json +1 -1
  42. package/server.json +2 -2
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-history-compare — Compare review results over time.
3
+ */
4
+ export declare function runReviewHistoryCompare(argv: string[]): void;
5
+ //# sourceMappingURL=review-history-compare.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-history-compare.d.ts","sourceRoot":"","sources":["../../src/commands/review-history-compare.ts"],"names":[],"mappings":"AAAA;;GAEG;AAmBH,wBAAgB,uBAAuB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAsG5D"}
@@ -0,0 +1,94 @@
1
+ /**
2
+ * Review-history-compare — Compare review results over time.
3
+ */
4
+ import { readFileSync, existsSync } from "fs";
5
+ // ─── CLI ────────────────────────────────────────────────────────────────────
6
+ export function runReviewHistoryCompare(argv) {
7
+ const beforeIdx = argv.indexOf("--before");
8
+ const afterIdx = argv.indexOf("--after");
9
+ const formatIdx = argv.indexOf("--format");
10
+ const beforeFile = beforeIdx >= 0 ? argv[beforeIdx + 1] : undefined;
11
+ const afterFile = afterIdx >= 0 ? argv[afterIdx + 1] : undefined;
12
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
13
+ if (argv.includes("--help") || argv.includes("-h")) {
14
+ console.log(`
15
+ judges review-history-compare — Compare review results over time
16
+
17
+ Usage:
18
+ judges review-history-compare --before <old.json> --after <new.json>
19
+ [--format table|json]
20
+
21
+ Options:
22
+ --before <path> Earlier review result JSON
23
+ --after <path> Later review result JSON
24
+ --format <fmt> Output format: table (default), json
25
+ --help, -h Show this help
26
+ `);
27
+ return;
28
+ }
29
+ if (!beforeFile || !afterFile) {
30
+ console.error("Error: --before and --after are required");
31
+ process.exitCode = 1;
32
+ return;
33
+ }
34
+ if (!existsSync(beforeFile)) {
35
+ console.error(`Error: file not found: ${beforeFile}`);
36
+ process.exitCode = 1;
37
+ return;
38
+ }
39
+ if (!existsSync(afterFile)) {
40
+ console.error(`Error: file not found: ${afterFile}`);
41
+ process.exitCode = 1;
42
+ return;
43
+ }
44
+ let before;
45
+ let after;
46
+ try {
47
+ before = JSON.parse(readFileSync(beforeFile, "utf-8"));
48
+ after = JSON.parse(readFileSync(afterFile, "utf-8"));
49
+ }
50
+ catch {
51
+ console.error("Error: failed to parse review files");
52
+ process.exitCode = 1;
53
+ return;
54
+ }
55
+ const beforeKeys = new Set(before.findings.map((f) => `${f.ruleId}|${f.title}`));
56
+ const afterKeys = new Set(after.findings.map((f) => `${f.ruleId}|${f.title}`));
57
+ const comparison = {
58
+ beforeFile,
59
+ afterFile,
60
+ scoreDelta: after.overallScore - before.overallScore,
61
+ findingDelta: after.findings.length - before.findings.length,
62
+ newFindings: after.findings
63
+ .filter((f) => !beforeKeys.has(`${f.ruleId}|${f.title}`))
64
+ .map((f) => ({ ruleId: f.ruleId, severity: f.severity, title: f.title })),
65
+ resolvedFindings: before.findings
66
+ .filter((f) => !afterKeys.has(`${f.ruleId}|${f.title}`))
67
+ .map((f) => ({ ruleId: f.ruleId, severity: f.severity, title: f.title })),
68
+ persistentFindings: after.findings.filter((f) => beforeKeys.has(`${f.ruleId}|${f.title}`)).length,
69
+ };
70
+ if (format === "json") {
71
+ console.log(JSON.stringify(comparison, null, 2));
72
+ return;
73
+ }
74
+ const scoreTrend = comparison.scoreDelta > 0 ? "↑" : comparison.scoreDelta < 0 ? "↓" : "→";
75
+ console.log(`\nReview History Comparison`);
76
+ console.log("═".repeat(55));
77
+ console.log(` Score: ${before.overallScore} → ${after.overallScore} (${scoreTrend}${Math.abs(comparison.scoreDelta).toFixed(1)})`);
78
+ console.log(` Findings: ${before.findings.length} → ${after.findings.length} (${comparison.findingDelta >= 0 ? "+" : ""}${comparison.findingDelta})`);
79
+ console.log(` Persistent: ${comparison.persistentFindings}`);
80
+ if (comparison.newFindings.length > 0) {
81
+ console.log(`\n New Findings (${comparison.newFindings.length}):`);
82
+ for (const f of comparison.newFindings) {
83
+ console.log(` + [${f.severity}] ${f.ruleId}: ${f.title}`);
84
+ }
85
+ }
86
+ if (comparison.resolvedFindings.length > 0) {
87
+ console.log(`\n Resolved Findings (${comparison.resolvedFindings.length}):`);
88
+ for (const f of comparison.resolvedFindings) {
89
+ console.log(` - [${f.severity}] ${f.ruleId}: ${f.title}`);
90
+ }
91
+ }
92
+ console.log("═".repeat(55));
93
+ }
94
+ //# sourceMappingURL=review-history-compare.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-history-compare.js","sourceRoot":"","sources":["../../src/commands/review-history-compare.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-output-transform — Transform review output between formats.
3
+ */
4
+ export declare function runReviewOutputTransform(argv: string[]): void;
5
+ //# sourceMappingURL=review-output-transform.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-output-transform.d.ts","sourceRoot":"","sources":["../../src/commands/review-output-transform.ts"],"names":[],"mappings":"AAAA;;GAEG;AA2DH,wBAAgB,wBAAwB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAyE7D"}
@@ -0,0 +1,120 @@
1
+ /**
2
+ * Review-output-transform — Transform review output between formats.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync } from "fs";
5
+ // ─── Transformers ───────────────────────────────────────────────────────────
6
+ function toMarkdown(verdict) {
7
+ const lines = [];
8
+ lines.push(`# Review Report`);
9
+ lines.push(``);
10
+ lines.push(`- **Verdict:** ${verdict.overallVerdict}`);
11
+ lines.push(`- **Score:** ${verdict.overallScore}`);
12
+ lines.push(`- **Findings:** ${verdict.findings.length}`);
13
+ lines.push(``);
14
+ if (verdict.findings.length > 0) {
15
+ lines.push(`## Findings`);
16
+ lines.push(``);
17
+ lines.push(`| Severity | Rule | Title | Recommendation |`);
18
+ lines.push(`|----------|------|-------|----------------|`);
19
+ for (const f of verdict.findings) {
20
+ lines.push(`| ${f.severity} | ${f.ruleId} | ${f.title} | ${f.recommendation} |`);
21
+ }
22
+ }
23
+ return lines.join("\n");
24
+ }
25
+ function toCsv(verdict) {
26
+ const lines = [];
27
+ lines.push("ruleId,severity,title,description,recommendation,lineNumbers,confidence");
28
+ for (const f of verdict.findings) {
29
+ const ln = f.lineNumbers !== undefined ? f.lineNumbers.join(";") : "";
30
+ const conf = f.confidence !== undefined ? String(f.confidence) : "";
31
+ const desc = f.description.replace(/"/g, '""');
32
+ const title = f.title.replace(/"/g, '""');
33
+ const rec = f.recommendation.replace(/"/g, '""');
34
+ lines.push(`"${f.ruleId}","${f.severity}","${title}","${desc}","${rec}","${ln}","${conf}"`);
35
+ }
36
+ return lines.join("\n");
37
+ }
38
+ function toSummaryText(verdict) {
39
+ const lines = [];
40
+ lines.push(`Review Summary`);
41
+ lines.push(`==============`);
42
+ lines.push(`Verdict: ${verdict.overallVerdict} Score: ${verdict.overallScore}`);
43
+ lines.push(`Findings: ${verdict.findings.length} (${verdict.criticalCount} critical, ${verdict.highCount} high)`);
44
+ lines.push(``);
45
+ for (const f of verdict.findings) {
46
+ lines.push(`[${f.severity.toUpperCase()}] ${f.ruleId}: ${f.title}`);
47
+ lines.push(` → ${f.recommendation}`);
48
+ }
49
+ return lines.join("\n");
50
+ }
51
+ // ─── CLI ────────────────────────────────────────────────────────────────────
52
+ export function runReviewOutputTransform(argv) {
53
+ const fileIdx = argv.indexOf("--file");
54
+ const toIdx = argv.indexOf("--to");
55
+ const outputIdx = argv.indexOf("--output");
56
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
57
+ const targetFormat = toIdx >= 0 ? argv[toIdx + 1] : "markdown";
58
+ const outputPath = outputIdx >= 0 ? argv[outputIdx + 1] : undefined;
59
+ if (argv.includes("--help") || argv.includes("-h")) {
60
+ console.log(`
61
+ judges review-output-transform — Transform output formats
62
+
63
+ Usage:
64
+ judges review-output-transform --file <review.json> --to <format>
65
+ [--output <file>]
66
+
67
+ Options:
68
+ --file <path> Review result JSON file
69
+ --to <format> Target: markdown, csv, text, json
70
+ --output <path> Write transformed output to file
71
+ --help, -h Show this help
72
+ `);
73
+ return;
74
+ }
75
+ if (!filePath) {
76
+ console.error("Error: --file is required");
77
+ process.exitCode = 1;
78
+ return;
79
+ }
80
+ if (!existsSync(filePath)) {
81
+ console.error(`Error: file not found: ${filePath}`);
82
+ process.exitCode = 1;
83
+ return;
84
+ }
85
+ let verdict;
86
+ try {
87
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
88
+ }
89
+ catch {
90
+ console.error(`Error: failed to parse review file: ${filePath}`);
91
+ process.exitCode = 1;
92
+ return;
93
+ }
94
+ let output;
95
+ switch (targetFormat) {
96
+ case "markdown":
97
+ output = toMarkdown(verdict);
98
+ break;
99
+ case "csv":
100
+ output = toCsv(verdict);
101
+ break;
102
+ case "text":
103
+ output = toSummaryText(verdict);
104
+ break;
105
+ case "json":
106
+ output = JSON.stringify(verdict, null, 2);
107
+ break;
108
+ default:
109
+ console.error(`Error: unknown format: ${targetFormat}. Use markdown, csv, text, or json.`);
110
+ process.exitCode = 1;
111
+ return;
112
+ }
113
+ if (outputPath) {
114
+ writeFileSync(outputPath, output);
115
+ console.log(`Transformed to ${targetFormat}, written to ${outputPath}`);
116
+ return;
117
+ }
118
+ console.log(output);
119
+ }
120
+ //# sourceMappingURL=review-output-transform.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-output-transform.js","sourceRoot":"","sources":["../../src/commands/review-output-transform.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-team-dashboard — Team-level review dashboard with aggregated metrics.
3
+ */
4
+ export declare function runReviewTeamDashboard(argv: string[]): void;
5
+ //# sourceMappingURL=review-team-dashboard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-team-dashboard.d.ts","sourceRoot":"","sources":["../../src/commands/review-team-dashboard.ts"],"names":[],"mappings":"AAAA;;GAEG;AAoBH,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA0G3D"}
@@ -0,0 +1,99 @@
1
+ /**
2
+ * Review-team-dashboard — Team-level review dashboard with aggregated metrics.
3
+ */
4
+ import { readFileSync, existsSync, readdirSync } from "fs";
5
+ import { join } from "path";
6
+ // ─── CLI ────────────────────────────────────────────────────────────────────
7
+ export function runReviewTeamDashboard(argv) {
8
+ const dirIdx = argv.indexOf("--dir");
9
+ const formatIdx = argv.indexOf("--format");
10
+ const dirPath = dirIdx >= 0 ? argv[dirIdx + 1] : process.cwd();
11
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
12
+ if (argv.includes("--help") || argv.includes("-h")) {
13
+ console.log(`
14
+ judges review-team-dashboard — Team review dashboard
15
+
16
+ Usage:
17
+ judges review-team-dashboard [--dir <path>] [--format table|json]
18
+
19
+ Options:
20
+ --dir <path> Directory with review JSON files (default: cwd)
21
+ --format <fmt> Output format: table (default), json
22
+ --help, -h Show this help
23
+ `);
24
+ return;
25
+ }
26
+ if (!existsSync(dirPath)) {
27
+ console.error(`Error: directory not found: ${dirPath}`);
28
+ process.exitCode = 1;
29
+ return;
30
+ }
31
+ const files = readdirSync(dirPath).filter((f) => typeof f === "string" && f.endsWith(".json"));
32
+ const verdicts = [];
33
+ for (const file of files) {
34
+ try {
35
+ const v = JSON.parse(readFileSync(join(dirPath, file), "utf-8"));
36
+ if (v.overallVerdict !== undefined && v.findings !== undefined) {
37
+ verdicts.push(v);
38
+ }
39
+ }
40
+ catch {
41
+ // skip
42
+ }
43
+ }
44
+ if (verdicts.length === 0) {
45
+ console.log("No review files found. Generate reviews first.");
46
+ return;
47
+ }
48
+ const ruleCounts = {};
49
+ const severityCounts = {};
50
+ const dateCounts = {};
51
+ let scoreSum = 0;
52
+ let passCount = 0;
53
+ for (const v of verdicts) {
54
+ scoreSum += v.overallScore;
55
+ if (v.overallVerdict === "pass")
56
+ passCount++;
57
+ const date = v.timestamp ? v.timestamp.split("T")[0] : "unknown";
58
+ dateCounts[date] = (dateCounts[date] ?? 0) + 1;
59
+ for (const f of v.findings) {
60
+ ruleCounts[f.ruleId] = (ruleCounts[f.ruleId] ?? 0) + 1;
61
+ severityCounts[f.severity] = (severityCounts[f.severity] ?? 0) + 1;
62
+ }
63
+ }
64
+ const metrics = {
65
+ totalReviews: verdicts.length,
66
+ totalFindings: verdicts.reduce((s, v) => s + v.findings.length, 0),
67
+ avgScore: Math.round((scoreSum / verdicts.length) * 100) / 100,
68
+ passRate: Math.round((passCount / verdicts.length) * 100),
69
+ topIssues: Object.entries(ruleCounts)
70
+ .sort((a, b) => b[1] - a[1])
71
+ .slice(0, 10)
72
+ .map(([ruleId, count]) => ({ ruleId, count })),
73
+ severityTrend: severityCounts,
74
+ reviewsPerDay: dateCounts,
75
+ };
76
+ if (format === "json") {
77
+ console.log(JSON.stringify(metrics, null, 2));
78
+ return;
79
+ }
80
+ console.log(`\nTeam Review Dashboard`);
81
+ console.log("═".repeat(55));
82
+ console.log(` Reviews: ${metrics.totalReviews}`);
83
+ console.log(` Findings: ${metrics.totalFindings}`);
84
+ console.log(` Avg Score: ${metrics.avgScore}`);
85
+ console.log(` Pass Rate: ${metrics.passRate}%`);
86
+ console.log(`\n Severity Distribution:`);
87
+ for (const [sev, count] of Object.entries(metrics.severityTrend)) {
88
+ const bar = "█".repeat(Math.min(count, 30));
89
+ console.log(` ${sev.padEnd(10)} ${String(count).padStart(4)} ${bar}`);
90
+ }
91
+ if (metrics.topIssues.length > 0) {
92
+ console.log(`\n Top Issues:`);
93
+ for (const issue of metrics.topIssues) {
94
+ console.log(` ${issue.ruleId.padEnd(25)} ${issue.count}`);
95
+ }
96
+ }
97
+ console.log("═".repeat(55));
98
+ }
99
+ //# sourceMappingURL=review-team-dashboard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-team-dashboard.js","sourceRoot":"","sources":["../../src/commands/review-team-dashboard.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-workspace-init — Initialize a workspace for Judges code review.
3
+ */
4
+ export declare function runReviewWorkspaceInit(argv: string[]): void;
5
+ //# sourceMappingURL=review-workspace-init.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-workspace-init.d.ts","sourceRoot":"","sources":["../../src/commands/review-workspace-init.ts"],"names":[],"mappings":"AAAA;;GAEG;AAuBH,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA2F3D"}
@@ -0,0 +1,105 @@
1
+ /**
2
+ * Review-workspace-init — Initialize a workspace for Judges code review.
3
+ */
4
+ import { writeFileSync, mkdirSync, existsSync } from "fs";
5
+ import { join } from "path";
6
+ // ─── Default configs ────────────────────────────────────────────────────────
7
+ const DEFAULT_JUDGESRC = {
8
+ preset: "default",
9
+ disabledJudges: [],
10
+ disabledRules: [],
11
+ ruleOverrides: {},
12
+ minSeverity: "low",
13
+ };
14
+ const DEFAULT_BASELINE = {
15
+ version: 1,
16
+ baselinedAt: new Date().toISOString().split("T")[0],
17
+ findings: [],
18
+ };
19
+ // ─── CLI ────────────────────────────────────────────────────────────────────
20
+ export function runReviewWorkspaceInit(argv) {
21
+ const dirIdx = argv.indexOf("--dir");
22
+ const dir = dirIdx >= 0 ? argv[dirIdx + 1] : ".";
23
+ const force = argv.includes("--force");
24
+ const formatIdx = argv.indexOf("--format");
25
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
26
+ if (argv.includes("--help") || argv.includes("-h")) {
27
+ console.log(`
28
+ judges review-workspace-init — Initialize workspace for Judges
29
+
30
+ Usage:
31
+ judges review-workspace-init [--dir <path>] [--force] [--format table|json]
32
+
33
+ Options:
34
+ --dir <path> Workspace root (default: current directory)
35
+ --force Overwrite existing config files
36
+ --format <fmt> Output format: table (default), json
37
+ --help, -h Show this help
38
+
39
+ This creates:
40
+ .judgesrc — Judges configuration file
41
+ .judges-baseline.json — Baseline for existing findings
42
+ .judges/ — Local data directory
43
+ `);
44
+ return;
45
+ }
46
+ const created = [];
47
+ const skipped = [];
48
+ // 1. .judgesrc
49
+ const rcPath = join(dir, ".judgesrc");
50
+ if (!existsSync(rcPath) || force) {
51
+ writeFileSync(rcPath, JSON.stringify(DEFAULT_JUDGESRC, null, 2));
52
+ created.push(".judgesrc");
53
+ }
54
+ else {
55
+ skipped.push(".judgesrc (exists)");
56
+ }
57
+ // 2. .judges-baseline.json
58
+ const baselinePath = join(dir, ".judges-baseline.json");
59
+ if (!existsSync(baselinePath) || force) {
60
+ writeFileSync(baselinePath, JSON.stringify(DEFAULT_BASELINE, null, 2));
61
+ created.push(".judges-baseline.json");
62
+ }
63
+ else {
64
+ skipped.push(".judges-baseline.json (exists)");
65
+ }
66
+ // 3. .judges/ directory
67
+ const judgesDir = join(dir, ".judges");
68
+ if (!existsSync(judgesDir)) {
69
+ mkdirSync(judgesDir, { recursive: true });
70
+ created.push(".judges/");
71
+ }
72
+ else {
73
+ skipped.push(".judges/ (exists)");
74
+ }
75
+ // 4. .judges/cache directory
76
+ const cacheDir = join(judgesDir, "cache");
77
+ if (!existsSync(cacheDir)) {
78
+ mkdirSync(cacheDir, { recursive: true });
79
+ created.push(".judges/cache/");
80
+ }
81
+ else {
82
+ skipped.push(".judges/cache/ (exists)");
83
+ }
84
+ if (format === "json") {
85
+ console.log(JSON.stringify({ created, skipped }, null, 2));
86
+ return;
87
+ }
88
+ console.log(`\nWorkspace Initialization`);
89
+ console.log("═".repeat(50));
90
+ if (created.length > 0) {
91
+ console.log(`\n Created:`);
92
+ for (const c of created) {
93
+ console.log(` + ${c}`);
94
+ }
95
+ }
96
+ if (skipped.length > 0) {
97
+ console.log(`\n Skipped:`);
98
+ for (const s of skipped) {
99
+ console.log(` - ${s}`);
100
+ }
101
+ }
102
+ console.log(`\n Workspace ready at: ${dir === "." ? process.cwd() : dir}`);
103
+ console.log("═".repeat(50));
104
+ }
105
+ //# sourceMappingURL=review-workspace-init.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-workspace-init.js","sourceRoot":"","sources":["../../src/commands/review-workspace-init.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.95.0",
3
+ "version": "3.96.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.95.0",
10
+ "version": "3.96.0",
11
11
  "packages": [
12
12
  {
13
13
  "registryType": "npm",
14
14
  "identifier": "@kevinrabun/judges",
15
- "version": "3.95.0",
15
+ "version": "3.96.0",
16
16
  "transport": {
17
17
  "type": "stdio"
18
18
  }