@kevinrabun/judges 3.93.0 → 3.95.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 (78) hide show
  1. package/CHANGELOG.md +26 -0
  2. package/dist/cli.d.ts.map +1 -1
  3. package/dist/cli.js +126 -0
  4. package/dist/cli.js.map +1 -1
  5. package/dist/commands/finding-code-context.d.ts +5 -0
  6. package/dist/commands/finding-code-context.d.ts.map +1 -0
  7. package/dist/commands/finding-code-context.js +97 -0
  8. package/dist/commands/finding-code-context.js.map +1 -0
  9. package/dist/commands/finding-correlation-map.d.ts +5 -0
  10. package/dist/commands/finding-correlation-map.d.ts.map +1 -0
  11. package/dist/commands/finding-correlation-map.js +102 -0
  12. package/dist/commands/finding-correlation-map.js.map +1 -0
  13. package/dist/commands/finding-dedup-cross.d.ts +5 -0
  14. package/dist/commands/finding-dedup-cross.d.ts.map +1 -0
  15. package/dist/commands/finding-dedup-cross.js +91 -0
  16. package/dist/commands/finding-dedup-cross.js.map +1 -0
  17. package/dist/commands/finding-explain.d.ts +5 -0
  18. package/dist/commands/finding-explain.d.ts.map +1 -0
  19. package/dist/commands/finding-explain.js +94 -0
  20. package/dist/commands/finding-explain.js.map +1 -0
  21. package/dist/commands/finding-filter-view.d.ts +5 -0
  22. package/dist/commands/finding-filter-view.d.ts.map +1 -0
  23. package/dist/commands/finding-filter-view.js +108 -0
  24. package/dist/commands/finding-filter-view.js.map +1 -0
  25. package/dist/commands/finding-groupby-file.d.ts +5 -0
  26. package/dist/commands/finding-groupby-file.d.ts.map +1 -0
  27. package/dist/commands/finding-groupby-file.js +95 -0
  28. package/dist/commands/finding-groupby-file.js.map +1 -0
  29. package/dist/commands/finding-resolution-track.d.ts +5 -0
  30. package/dist/commands/finding-resolution-track.d.ts.map +1 -0
  31. package/dist/commands/finding-resolution-track.js +151 -0
  32. package/dist/commands/finding-resolution-track.js.map +1 -0
  33. package/dist/commands/review-api-export.d.ts +5 -0
  34. package/dist/commands/review-api-export.d.ts.map +1 -0
  35. package/dist/commands/review-api-export.js +99 -0
  36. package/dist/commands/review-api-export.js.map +1 -0
  37. package/dist/commands/review-ide-sync.d.ts +5 -0
  38. package/dist/commands/review-ide-sync.d.ts.map +1 -0
  39. package/dist/commands/review-ide-sync.js +92 -0
  40. package/dist/commands/review-ide-sync.js.map +1 -0
  41. package/dist/commands/review-interactive.d.ts +5 -0
  42. package/dist/commands/review-interactive.d.ts.map +1 -0
  43. package/dist/commands/review-interactive.js +86 -0
  44. package/dist/commands/review-interactive.js.map +1 -0
  45. package/dist/commands/review-merge-request.d.ts +5 -0
  46. package/dist/commands/review-merge-request.d.ts.map +1 -0
  47. package/dist/commands/review-merge-request.js +96 -0
  48. package/dist/commands/review-merge-request.js.map +1 -0
  49. package/dist/commands/review-notification-config.d.ts +5 -0
  50. package/dist/commands/review-notification-config.d.ts.map +1 -0
  51. package/dist/commands/review-notification-config.js +123 -0
  52. package/dist/commands/review-notification-config.js.map +1 -0
  53. package/dist/commands/review-onboard-checklist.d.ts +5 -0
  54. package/dist/commands/review-onboard-checklist.d.ts.map +1 -0
  55. package/dist/commands/review-onboard-checklist.js +120 -0
  56. package/dist/commands/review-onboard-checklist.js.map +1 -0
  57. package/dist/commands/review-quickstart.d.ts +5 -0
  58. package/dist/commands/review-quickstart.d.ts.map +1 -0
  59. package/dist/commands/review-quickstart.js +108 -0
  60. package/dist/commands/review-quickstart.js.map +1 -0
  61. package/dist/commands/review-scope-select.d.ts +5 -0
  62. package/dist/commands/review-scope-select.d.ts.map +1 -0
  63. package/dist/commands/review-scope-select.js +99 -0
  64. package/dist/commands/review-scope-select.js.map +1 -0
  65. package/dist/commands/review-summary-dashboard.d.ts +5 -0
  66. package/dist/commands/review-summary-dashboard.d.ts.map +1 -0
  67. package/dist/commands/review-summary-dashboard.js +97 -0
  68. package/dist/commands/review-summary-dashboard.js.map +1 -0
  69. package/dist/commands/review-template-library.d.ts +5 -0
  70. package/dist/commands/review-template-library.d.ts.map +1 -0
  71. package/dist/commands/review-template-library.js +156 -0
  72. package/dist/commands/review-template-library.js.map +1 -0
  73. package/dist/commands/review-tenant-config.d.ts +5 -0
  74. package/dist/commands/review-tenant-config.d.ts.map +1 -0
  75. package/dist/commands/review-tenant-config.js +117 -0
  76. package/dist/commands/review-tenant-config.js.map +1 -0
  77. package/package.json +1 -1
  78. package/server.json +2 -2
@@ -0,0 +1,95 @@
1
+ /**
2
+ * Finding-groupby-file — Group findings by source file path.
3
+ */
4
+ import { readFileSync, existsSync } from "fs";
5
+ // ─── Helpers ────────────────────────────────────────────────────────────────
6
+ function inferFile(f) {
7
+ // Use provenance if available, otherwise group by rule prefix
8
+ if (f.provenance !== undefined && typeof f.provenance === "string" && f.provenance.length > 0) {
9
+ return f.provenance;
10
+ }
11
+ const prefix = f.ruleId.split("-")[0];
12
+ return `[${prefix}]`;
13
+ }
14
+ // ─── CLI ────────────────────────────────────────────────────────────────────
15
+ export function runFindingGroupbyFile(argv) {
16
+ const fileIdx = argv.indexOf("--file");
17
+ const formatIdx = argv.indexOf("--format");
18
+ const sortIdx = argv.indexOf("--sort");
19
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
20
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
21
+ const sortBy = sortIdx >= 0 ? argv[sortIdx + 1] : "count";
22
+ if (argv.includes("--help") || argv.includes("-h")) {
23
+ console.log(`
24
+ judges finding-groupby-file — Group findings by source file
25
+
26
+ Usage:
27
+ judges finding-groupby-file --file <review.json> [--sort count|name]
28
+ [--format table|json]
29
+
30
+ Options:
31
+ --file <path> Review result JSON file
32
+ --sort <by> Sort by: count (default), name
33
+ --format <fmt> Output format: table (default), json
34
+ --help, -h Show this help
35
+ `);
36
+ return;
37
+ }
38
+ if (!filePath) {
39
+ console.error("Error: --file is required");
40
+ process.exitCode = 1;
41
+ return;
42
+ }
43
+ if (!existsSync(filePath)) {
44
+ console.error(`Error: file not found: ${filePath}`);
45
+ process.exitCode = 1;
46
+ return;
47
+ }
48
+ let verdict;
49
+ try {
50
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
51
+ }
52
+ catch {
53
+ console.error(`Error: failed to parse review file: ${filePath}`);
54
+ process.exitCode = 1;
55
+ return;
56
+ }
57
+ const groupMap = new Map();
58
+ for (const f of verdict.findings) {
59
+ const fileName = inferFile(f);
60
+ let group = groupMap.get(fileName);
61
+ if (group === undefined) {
62
+ group = { file: fileName, findings: [], count: 0 };
63
+ groupMap.set(fileName, group);
64
+ }
65
+ group.findings.push({
66
+ ruleId: f.ruleId,
67
+ severity: f.severity,
68
+ title: f.title,
69
+ lineNumbers: f.lineNumbers !== undefined ? f.lineNumbers : [],
70
+ });
71
+ group.count++;
72
+ }
73
+ const groups = [...groupMap.values()];
74
+ if (sortBy === "name") {
75
+ groups.sort((a, b) => a.file.localeCompare(b.file));
76
+ }
77
+ else {
78
+ groups.sort((a, b) => b.count - a.count);
79
+ }
80
+ if (format === "json") {
81
+ console.log(JSON.stringify(groups, null, 2));
82
+ return;
83
+ }
84
+ console.log(`\nFindings by File: ${groups.length} group(s), ${verdict.findings.length} total`);
85
+ console.log("═".repeat(65));
86
+ for (const g of groups) {
87
+ console.log(`\n ${g.file} (${g.count} finding${g.count !== 1 ? "s" : ""})`);
88
+ for (const f of g.findings) {
89
+ const lines = f.lineNumbers.length > 0 ? ` L${f.lineNumbers.join(",")}` : "";
90
+ console.log(` [${f.severity}] ${f.ruleId}${lines}: ${f.title}`);
91
+ }
92
+ }
93
+ console.log("\n" + "═".repeat(65));
94
+ }
95
+ //# sourceMappingURL=finding-groupby-file.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"finding-groupby-file.js","sourceRoot":"","sources":["../../src/commands/finding-groupby-file.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Finding-resolution-track — Track finding resolution status over time.
3
+ */
4
+ export declare function runFindingResolutionTrack(argv: string[]): void;
5
+ //# sourceMappingURL=finding-resolution-track.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"finding-resolution-track.d.ts","sourceRoot":"","sources":["../../src/commands/finding-resolution-track.ts"],"names":[],"mappings":"AAAA;;GAEG;AAwBH,wBAAgB,yBAAyB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA0J9D"}
@@ -0,0 +1,151 @@
1
+ /**
2
+ * Finding-resolution-track — Track finding resolution status over time.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync } from "fs";
5
+ // ─── CLI ────────────────────────────────────────────────────────────────────
6
+ export function runFindingResolutionTrack(argv) {
7
+ const fileIdx = argv.indexOf("--file");
8
+ const storeIdx = argv.indexOf("--store");
9
+ const resolveIdx = argv.indexOf("--resolve");
10
+ const deferIdx = argv.indexOf("--defer");
11
+ const wontfixIdx = argv.indexOf("--wontfix");
12
+ const formatIdx = argv.indexOf("--format");
13
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
14
+ const storePath = storeIdx >= 0 ? argv[storeIdx + 1] : ".judges-resolutions.json";
15
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
16
+ if (argv.includes("--help") || argv.includes("-h")) {
17
+ console.log(`
18
+ judges finding-resolution-track — Track finding resolution status
19
+
20
+ Usage:
21
+ judges finding-resolution-track [--file <review.json>] [--store <path>]
22
+ [--resolve <ruleId>] [--defer <ruleId>]
23
+ [--wontfix <ruleId>] [--format table|json]
24
+
25
+ Options:
26
+ --file <path> Import findings from review result
27
+ --store <path> Resolution store file (default: .judges-resolutions.json)
28
+ --resolve <ruleId> Mark a rule as resolved
29
+ --defer <ruleId> Mark a rule as deferred
30
+ --wontfix <ruleId> Mark a rule as wontfix
31
+ --format <fmt> Output format: table (default), json
32
+ --help, -h Show this help
33
+ `);
34
+ return;
35
+ }
36
+ // Load or init store
37
+ let store;
38
+ if (existsSync(storePath)) {
39
+ store = JSON.parse(readFileSync(storePath, "utf-8"));
40
+ }
41
+ else {
42
+ store = { entries: [], lastUpdated: new Date().toISOString().split("T")[0] };
43
+ }
44
+ const today = new Date().toISOString().split("T")[0];
45
+ // Mark resolved
46
+ if (resolveIdx >= 0) {
47
+ const ruleId = argv[resolveIdx + 1];
48
+ const entry = store.entries.find((e) => e.ruleId === ruleId && e.status === "open");
49
+ if (entry) {
50
+ entry.status = "resolved";
51
+ entry.resolvedAt = today;
52
+ store.lastUpdated = today;
53
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
54
+ console.log(`Marked ${ruleId} as resolved.`);
55
+ }
56
+ else {
57
+ console.error(`No open entry found for ${ruleId}`);
58
+ process.exitCode = 1;
59
+ }
60
+ return;
61
+ }
62
+ // Mark deferred
63
+ if (deferIdx >= 0) {
64
+ const ruleId = argv[deferIdx + 1];
65
+ const entry = store.entries.find((e) => e.ruleId === ruleId && e.status === "open");
66
+ if (entry) {
67
+ entry.status = "deferred";
68
+ store.lastUpdated = today;
69
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
70
+ console.log(`Marked ${ruleId} as deferred.`);
71
+ }
72
+ else {
73
+ console.error(`No open entry found for ${ruleId}`);
74
+ process.exitCode = 1;
75
+ }
76
+ return;
77
+ }
78
+ // Mark wontfix
79
+ if (wontfixIdx >= 0) {
80
+ const ruleId = argv[wontfixIdx + 1];
81
+ const entry = store.entries.find((e) => e.ruleId === ruleId && e.status === "open");
82
+ if (entry) {
83
+ entry.status = "wontfix";
84
+ store.lastUpdated = today;
85
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
86
+ console.log(`Marked ${ruleId} as wontfix.`);
87
+ }
88
+ else {
89
+ console.error(`No open entry found for ${ruleId}`);
90
+ process.exitCode = 1;
91
+ }
92
+ return;
93
+ }
94
+ // Import findings from review
95
+ if (filePath) {
96
+ if (!existsSync(filePath)) {
97
+ console.error(`Error: file not found: ${filePath}`);
98
+ process.exitCode = 1;
99
+ return;
100
+ }
101
+ let verdict;
102
+ try {
103
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
104
+ }
105
+ catch {
106
+ console.error(`Error: failed to parse review file: ${filePath}`);
107
+ process.exitCode = 1;
108
+ return;
109
+ }
110
+ let added = 0;
111
+ for (const f of verdict.findings) {
112
+ const existing = store.entries.find((e) => e.ruleId === f.ruleId && e.title === f.title);
113
+ if (existing) {
114
+ existing.lastSeen = today;
115
+ }
116
+ else {
117
+ store.entries.push({
118
+ ruleId: f.ruleId,
119
+ severity: f.severity,
120
+ title: f.title,
121
+ status: "open",
122
+ firstSeen: today,
123
+ lastSeen: today,
124
+ });
125
+ added++;
126
+ }
127
+ }
128
+ store.lastUpdated = today;
129
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
130
+ console.log(`Imported ${added} new finding(s), updated ${verdict.findings.length - added} existing.`);
131
+ return;
132
+ }
133
+ // Display current state
134
+ if (format === "json") {
135
+ console.log(JSON.stringify(store, null, 2));
136
+ return;
137
+ }
138
+ const open = store.entries.filter((e) => e.status === "open");
139
+ const resolved = store.entries.filter((e) => e.status === "resolved");
140
+ const deferred = store.entries.filter((e) => e.status === "deferred");
141
+ console.log(`\nResolution Tracking: ${store.entries.length} total`);
142
+ console.log(` Open: ${open.length} Resolved: ${resolved.length} Deferred: ${deferred.length}`);
143
+ console.log("═".repeat(65));
144
+ for (const e of store.entries) {
145
+ const statusBadge = e.status === "open" ? "[ ]" : e.status === "resolved" ? "[✓]" : e.status === "deferred" ? "[~]" : "[x]";
146
+ console.log(` ${statusBadge} ${e.ruleId.padEnd(20)} [${e.severity}] ${e.title}`);
147
+ console.log(` First: ${e.firstSeen} Last: ${e.lastSeen}${e.resolvedAt ? ` Resolved: ${e.resolvedAt}` : ""}`);
148
+ }
149
+ console.log("═".repeat(65));
150
+ }
151
+ //# sourceMappingURL=finding-resolution-track.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"finding-resolution-track.js","sourceRoot":"","sources":["../../src/commands/finding-resolution-track.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-api-export — Export review data in API-compatible JSON format.
3
+ */
4
+ export declare function runReviewApiExport(argv: string[]): void;
5
+ //# sourceMappingURL=review-api-export.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-api-export.d.ts","sourceRoot":"","sources":["../../src/commands/review-api-export.ts"],"names":[],"mappings":"AAAA;;GAEG;AAgCH,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAgGvD"}
@@ -0,0 +1,99 @@
1
+ /**
2
+ * Review-api-export — Export review data in API-compatible JSON format.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync, readdirSync } from "fs";
5
+ import { join } from "path";
6
+ // ─── CLI ────────────────────────────────────────────────────────────────────
7
+ export function runReviewApiExport(argv) {
8
+ const fileIdx = argv.indexOf("--file");
9
+ const dirIdx = argv.indexOf("--dir");
10
+ const outputIdx = argv.indexOf("--output");
11
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
12
+ const dirPath = dirIdx >= 0 ? argv[dirIdx + 1] : undefined;
13
+ const outputPath = outputIdx >= 0 ? argv[outputIdx + 1] : undefined;
14
+ if (argv.includes("--help") || argv.includes("-h")) {
15
+ console.log(`
16
+ judges review-api-export — Export review data in API format
17
+
18
+ Usage:
19
+ judges review-api-export --file <review.json> [--output <file>]
20
+ judges review-api-export --dir <path> [--output <file>]
21
+
22
+ Options:
23
+ --file <path> Single review JSON file
24
+ --dir <path> Directory of review JSON files
25
+ --output <path> Write API export to file
26
+ --help, -h Show this help
27
+ `);
28
+ return;
29
+ }
30
+ const verdicts = [];
31
+ if (filePath) {
32
+ if (!existsSync(filePath)) {
33
+ console.error(`Error: file not found: ${filePath}`);
34
+ process.exitCode = 1;
35
+ return;
36
+ }
37
+ try {
38
+ verdicts.push(JSON.parse(readFileSync(filePath, "utf-8")));
39
+ }
40
+ catch {
41
+ console.error(`Error: failed to parse: ${filePath}`);
42
+ process.exitCode = 1;
43
+ return;
44
+ }
45
+ }
46
+ else if (dirPath) {
47
+ if (!existsSync(dirPath)) {
48
+ console.error(`Error: directory not found: ${dirPath}`);
49
+ process.exitCode = 1;
50
+ return;
51
+ }
52
+ const files = readdirSync(dirPath).filter((f) => typeof f === "string" && f.endsWith(".json"));
53
+ for (const file of files) {
54
+ try {
55
+ const v = JSON.parse(readFileSync(join(dirPath, file), "utf-8"));
56
+ if (v.overallVerdict !== undefined) {
57
+ verdicts.push(v);
58
+ }
59
+ }
60
+ catch {
61
+ // skip
62
+ }
63
+ }
64
+ }
65
+ else {
66
+ console.error("Error: --file or --dir is required");
67
+ process.exitCode = 1;
68
+ return;
69
+ }
70
+ const apiExport = {
71
+ version: "1.0",
72
+ exportedAt: new Date().toISOString(),
73
+ reviews: verdicts.map((v) => ({
74
+ verdict: v.overallVerdict,
75
+ score: v.overallScore,
76
+ findingCount: v.findings.length,
77
+ criticalCount: v.criticalCount,
78
+ highCount: v.highCount,
79
+ timestamp: v.timestamp ?? new Date().toISOString(),
80
+ findings: v.findings.map((f) => ({
81
+ ruleId: f.ruleId,
82
+ severity: f.severity,
83
+ title: f.title,
84
+ description: f.description,
85
+ recommendation: f.recommendation,
86
+ lineNumbers: f.lineNumbers,
87
+ confidence: f.confidence,
88
+ })),
89
+ })),
90
+ };
91
+ const output = JSON.stringify(apiExport, null, 2);
92
+ if (outputPath) {
93
+ writeFileSync(outputPath, output);
94
+ console.log(`API export written to ${outputPath} (${verdicts.length} review(s))`);
95
+ return;
96
+ }
97
+ console.log(output);
98
+ }
99
+ //# sourceMappingURL=review-api-export.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-api-export.js","sourceRoot":"","sources":["../../src/commands/review-api-export.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-ide-sync — Sync review results to IDE-compatible formats.
3
+ */
4
+ export declare function runReviewIdeSync(argv: string[]): void;
5
+ //# sourceMappingURL=review-ide-sync.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-ide-sync.d.ts","sourceRoot":"","sources":["../../src/commands/review-ide-sync.ts"],"names":[],"mappings":"AAAA;;GAEG;AA+CH,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAkErD"}
@@ -0,0 +1,92 @@
1
+ /**
2
+ * Review-ide-sync — Sync review results to IDE-compatible formats.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync } from "fs";
5
+ function toVscodeDiagnostics(findings, sourceFile) {
6
+ return findings.map((f) => ({
7
+ file: sourceFile,
8
+ line: f.lineNumbers !== undefined && f.lineNumbers.length > 0 ? f.lineNumbers[0] : 1,
9
+ severity: f.severity === "critical" || f.severity === "high"
10
+ ? "error"
11
+ : f.severity === "medium"
12
+ ? "warning"
13
+ : "information",
14
+ message: `${f.title}: ${f.recommendation}`,
15
+ source: "judges",
16
+ code: f.ruleId,
17
+ }));
18
+ }
19
+ function toJetbrainsDiagnostics(findings, sourceFile) {
20
+ return {
21
+ format: "jetbrains-inspections",
22
+ inspections: findings.map((f) => ({
23
+ file: sourceFile,
24
+ line: f.lineNumbers !== undefined && f.lineNumbers.length > 0 ? f.lineNumbers[0] : 1,
25
+ severity: f.severity === "critical" ? "ERROR" : f.severity === "high" ? "WARNING" : "WEAK WARNING",
26
+ description: `[${f.ruleId}] ${f.title} — ${f.recommendation}`,
27
+ category: "Judges Review",
28
+ })),
29
+ };
30
+ }
31
+ // ─── CLI ────────────────────────────────────────────────────────────────────
32
+ export function runReviewIdeSync(argv) {
33
+ const fileIdx = argv.indexOf("--file");
34
+ const targetIdx = argv.indexOf("--target");
35
+ const outputIdx = argv.indexOf("--output");
36
+ const sourceIdx = argv.indexOf("--source");
37
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
38
+ const target = targetIdx >= 0 ? argv[targetIdx + 1] : "vscode";
39
+ const outputPath = outputIdx >= 0 ? argv[outputIdx + 1] : undefined;
40
+ const sourceFile = sourceIdx >= 0 ? argv[sourceIdx + 1] : "unknown";
41
+ if (argv.includes("--help") || argv.includes("-h")) {
42
+ console.log(`
43
+ judges review-ide-sync — Sync review results to IDE format
44
+
45
+ Usage:
46
+ judges review-ide-sync --file <review.json> [--target vscode|jetbrains]
47
+ [--source <file>] [--output <path>]
48
+
49
+ Options:
50
+ --file <path> Review result JSON file
51
+ --target <ide> IDE format: vscode (default), jetbrains
52
+ --source <file> Original source file path for diagnostics
53
+ --output <path> Write output to file
54
+ --help, -h Show this help
55
+ `);
56
+ return;
57
+ }
58
+ if (!filePath) {
59
+ console.error("Error: --file is required");
60
+ process.exitCode = 1;
61
+ return;
62
+ }
63
+ if (!existsSync(filePath)) {
64
+ console.error(`Error: file not found: ${filePath}`);
65
+ process.exitCode = 1;
66
+ return;
67
+ }
68
+ let verdict;
69
+ try {
70
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
71
+ }
72
+ catch {
73
+ console.error(`Error: failed to parse review file: ${filePath}`);
74
+ process.exitCode = 1;
75
+ return;
76
+ }
77
+ let result;
78
+ if (target === "jetbrains") {
79
+ result = toJetbrainsDiagnostics(verdict.findings, sourceFile);
80
+ }
81
+ else {
82
+ result = toVscodeDiagnostics(verdict.findings, sourceFile);
83
+ }
84
+ const output = JSON.stringify(result, null, 2);
85
+ if (outputPath) {
86
+ writeFileSync(outputPath, output);
87
+ console.log(`IDE diagnostics written to ${outputPath} (${target} format)`);
88
+ return;
89
+ }
90
+ console.log(output);
91
+ }
92
+ //# sourceMappingURL=review-ide-sync.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-ide-sync.js","sourceRoot":"","sources":["../../src/commands/review-ide-sync.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-interactive — Interactive review session with step-by-step finding walkthrough.
3
+ */
4
+ export declare function runReviewInteractive(argv: string[]): void;
5
+ //# sourceMappingURL=review-interactive.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-interactive.d.ts","sourceRoot":"","sources":["../../src/commands/review-interactive.ts"],"names":[],"mappings":"AAAA;;GAEG;AA0BH,wBAAgB,oBAAoB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAuEzD"}
@@ -0,0 +1,86 @@
1
+ /**
2
+ * Review-interactive — Interactive review session with step-by-step finding walkthrough.
3
+ */
4
+ import { readFileSync, existsSync } from "fs";
5
+ // ─── Helpers ────────────────────────────────────────────────────────────────
6
+ function formatFinding(f, index) {
7
+ const lines = [];
8
+ lines.push(`\n── Finding ${index + 1} ──────────────────────────────────────`);
9
+ lines.push(` Rule: ${f.ruleId}`);
10
+ lines.push(` Severity: ${f.severity}`);
11
+ lines.push(` Title: ${f.title}`);
12
+ lines.push(` Details: ${f.description}`);
13
+ if (f.lineNumbers !== undefined && f.lineNumbers.length > 0) {
14
+ lines.push(` Lines: ${f.lineNumbers.join(", ")}`);
15
+ }
16
+ lines.push(` Fix: ${f.recommendation}`);
17
+ if (f.confidence !== undefined) {
18
+ lines.push(` Confidence: ${(f.confidence * 100).toFixed(0)}%`);
19
+ }
20
+ return lines.join("\n");
21
+ }
22
+ // ─── CLI ────────────────────────────────────────────────────────────────────
23
+ export function runReviewInteractive(argv) {
24
+ const fileIdx = argv.indexOf("--file");
25
+ const severityIdx = argv.indexOf("--severity");
26
+ const formatIdx = argv.indexOf("--format");
27
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
28
+ const severityFilter = severityIdx >= 0 ? argv[severityIdx + 1] : undefined;
29
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
30
+ if (argv.includes("--help") || argv.includes("-h")) {
31
+ console.log(`
32
+ judges review-interactive — Interactive finding walkthrough
33
+
34
+ Usage:
35
+ judges review-interactive --file <review.json> [--severity <level>]
36
+ [--format table|json]
37
+
38
+ Options:
39
+ --file <path> Review result JSON file
40
+ --severity <level> Filter: critical, high, medium, low, info
41
+ --format <fmt> Output format: table (default), json
42
+ --help, -h Show this help
43
+ `);
44
+ return;
45
+ }
46
+ if (!filePath) {
47
+ console.error("Error: --file is required");
48
+ process.exitCode = 1;
49
+ return;
50
+ }
51
+ if (!existsSync(filePath)) {
52
+ console.error(`Error: file not found: ${filePath}`);
53
+ process.exitCode = 1;
54
+ return;
55
+ }
56
+ let verdict;
57
+ try {
58
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
59
+ }
60
+ catch {
61
+ console.error(`Error: failed to parse review file: ${filePath}`);
62
+ process.exitCode = 1;
63
+ return;
64
+ }
65
+ let findings = verdict.findings;
66
+ if (severityFilter) {
67
+ findings = findings.filter((f) => f.severity === severityFilter);
68
+ }
69
+ if (format === "json") {
70
+ console.log(JSON.stringify({ total: findings.length, findings }, null, 2));
71
+ return;
72
+ }
73
+ console.log(`\nInteractive Review: ${findings.length} findings`);
74
+ console.log(`Overall: ${verdict.overallVerdict} (score: ${verdict.overallScore})`);
75
+ console.log("═".repeat(55));
76
+ if (findings.length === 0) {
77
+ console.log(" No findings match the current filter.");
78
+ return;
79
+ }
80
+ for (let i = 0; i < findings.length; i++) {
81
+ console.log(formatFinding(findings[i], i));
82
+ }
83
+ console.log("\n" + "═".repeat(55));
84
+ console.log(`Reviewed ${findings.length} finding(s). Use --severity to filter.`);
85
+ }
86
+ //# sourceMappingURL=review-interactive.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-interactive.js","sourceRoot":"","sources":["../../src/commands/review-interactive.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-merge-request — Format findings for merge/pull request comments.
3
+ */
4
+ export declare function runReviewMergeRequest(argv: string[]): void;
5
+ //# sourceMappingURL=review-merge-request.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-merge-request.d.ts","sourceRoot":"","sources":["../../src/commands/review-merge-request.ts"],"names":[],"mappings":"AAAA;;GAEG;AAsDH,wBAAgB,qBAAqB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA4D1D"}