@kevinrabun/judges 3.60.0 → 3.62.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 (74) hide show
  1. package/CHANGELOG.md +14 -0
  2. package/dist/cli.d.ts.map +1 -1
  3. package/dist/cli.js +112 -0
  4. package/dist/cli.js.map +1 -1
  5. package/dist/commands/ai-provenance.d.ts +5 -0
  6. package/dist/commands/ai-provenance.d.ts.map +1 -0
  7. package/dist/commands/ai-provenance.js +248 -0
  8. package/dist/commands/ai-provenance.js.map +1 -0
  9. package/dist/commands/batch-review.d.ts +5 -0
  10. package/dist/commands/batch-review.d.ts.map +1 -0
  11. package/dist/commands/batch-review.js +181 -0
  12. package/dist/commands/batch-review.js.map +1 -0
  13. package/dist/commands/blame-review.d.ts +5 -0
  14. package/dist/commands/blame-review.d.ts.map +1 -0
  15. package/dist/commands/blame-review.js +270 -0
  16. package/dist/commands/blame-review.js.map +1 -0
  17. package/dist/commands/custom-rule.d.ts +5 -0
  18. package/dist/commands/custom-rule.d.ts.map +1 -0
  19. package/dist/commands/custom-rule.js +211 -0
  20. package/dist/commands/custom-rule.js.map +1 -0
  21. package/dist/commands/diff-review.d.ts +5 -0
  22. package/dist/commands/diff-review.d.ts.map +1 -0
  23. package/dist/commands/diff-review.js +191 -0
  24. package/dist/commands/diff-review.js.map +1 -0
  25. package/dist/commands/evidence-chain.d.ts +5 -0
  26. package/dist/commands/evidence-chain.d.ts.map +1 -0
  27. package/dist/commands/evidence-chain.js +310 -0
  28. package/dist/commands/evidence-chain.js.map +1 -0
  29. package/dist/commands/focus-area.d.ts +6 -0
  30. package/dist/commands/focus-area.d.ts.map +1 -0
  31. package/dist/commands/focus-area.js +193 -0
  32. package/dist/commands/focus-area.js.map +1 -0
  33. package/dist/commands/merge-verdict.d.ts +5 -0
  34. package/dist/commands/merge-verdict.d.ts.map +1 -0
  35. package/dist/commands/merge-verdict.js +288 -0
  36. package/dist/commands/merge-verdict.js.map +1 -0
  37. package/dist/commands/quick-check.d.ts +5 -0
  38. package/dist/commands/quick-check.d.ts.map +1 -0
  39. package/dist/commands/quick-check.js +174 -0
  40. package/dist/commands/quick-check.js.map +1 -0
  41. package/dist/commands/review-compare.d.ts +5 -0
  42. package/dist/commands/review-compare.d.ts.map +1 -0
  43. package/dist/commands/review-compare.js +201 -0
  44. package/dist/commands/review-compare.js.map +1 -0
  45. package/dist/commands/review-contract.d.ts +5 -0
  46. package/dist/commands/review-contract.d.ts.map +1 -0
  47. package/dist/commands/review-contract.js +200 -0
  48. package/dist/commands/review-contract.js.map +1 -0
  49. package/dist/commands/review-explain.d.ts +6 -0
  50. package/dist/commands/review-explain.d.ts.map +1 -0
  51. package/dist/commands/review-explain.js +195 -0
  52. package/dist/commands/review-explain.js.map +1 -0
  53. package/dist/commands/review-gate.d.ts +5 -0
  54. package/dist/commands/review-gate.d.ts.map +1 -0
  55. package/dist/commands/review-gate.js +213 -0
  56. package/dist/commands/review-gate.js.map +1 -0
  57. package/dist/commands/review-handoff.d.ts +5 -0
  58. package/dist/commands/review-handoff.d.ts.map +1 -0
  59. package/dist/commands/review-handoff.js +209 -0
  60. package/dist/commands/review-handoff.js.map +1 -0
  61. package/dist/commands/review-receipt.d.ts +5 -0
  62. package/dist/commands/review-receipt.d.ts.map +1 -0
  63. package/dist/commands/review-receipt.js +221 -0
  64. package/dist/commands/review-receipt.js.map +1 -0
  65. package/dist/commands/severity-tune.d.ts +5 -0
  66. package/dist/commands/severity-tune.d.ts.map +1 -0
  67. package/dist/commands/severity-tune.js +209 -0
  68. package/dist/commands/severity-tune.js.map +1 -0
  69. package/dist/commands/trend-report.d.ts +5 -0
  70. package/dist/commands/trend-report.d.ts.map +1 -0
  71. package/dist/commands/trend-report.js +149 -0
  72. package/dist/commands/trend-report.js.map +1 -0
  73. package/package.json +1 -1
  74. package/server.json +2 -2
@@ -0,0 +1,248 @@
1
+ /**
2
+ * AI-provenance — detect and annotate which code regions were AI-generated.
3
+ */
4
+ import { readFileSync, readdirSync, statSync } from "fs";
5
+ import { join, extname, relative } from "path";
6
+ // ─── File Collection ────────────────────────────────────────────────────────
7
+ const CODE_EXTS = new Set([".ts", ".tsx", ".js", ".jsx", ".py", ".java", ".go", ".cs", ".rs", ".rb"]);
8
+ function collectFiles(dir, max = 300) {
9
+ const files = [];
10
+ function walk(d) {
11
+ if (files.length >= max)
12
+ return;
13
+ let entries;
14
+ try {
15
+ entries = readdirSync(d);
16
+ }
17
+ catch {
18
+ return;
19
+ }
20
+ for (const e of entries) {
21
+ if (files.length >= max)
22
+ return;
23
+ if (e.startsWith(".") || e === "node_modules" || e === "dist" || e === "build")
24
+ continue;
25
+ const full = join(d, e);
26
+ try {
27
+ if (statSync(full).isDirectory())
28
+ walk(full);
29
+ else if (CODE_EXTS.has(extname(full)))
30
+ files.push(full);
31
+ }
32
+ catch {
33
+ /* skip */
34
+ }
35
+ }
36
+ }
37
+ walk(dir);
38
+ return files;
39
+ }
40
+ const AI_SIGNALS = [
41
+ // Explicit AI markers
42
+ {
43
+ regex: /(?:Generated|Created|Written)\s+(?:by|with|using)\s+(?:Copilot|ChatGPT|GPT-4|Claude|Gemini|Cursor|Codewhisperer|AI|LLM)/i,
44
+ signal: "AI attribution comment",
45
+ source: "comment-declared",
46
+ weight: 90,
47
+ },
48
+ {
49
+ regex: /(?:copilot|ai-generated|machine-generated|auto-generated)/i,
50
+ signal: "AI tag/marker",
51
+ source: "metadata-tag",
52
+ weight: 85,
53
+ },
54
+ {
55
+ regex: /@(?:generated|auto-generated|ai-generated)/,
56
+ signal: "Generated annotation",
57
+ source: "annotation",
58
+ weight: 80,
59
+ },
60
+ // Common AI code patterns
61
+ {
62
+ regex: /\/\/\s*(?:TODO|FIXME):\s*(?:implement|add|replace|update)\s+(?:this|here|the)/i,
63
+ signal: "Generic placeholder TODO",
64
+ source: "pattern-heuristic",
65
+ weight: 30,
66
+ },
67
+ {
68
+ regex: /\/\/\s*(?:This|The)\s+(?:function|method|class|module)\s+(?:is|does|handles|provides)/i,
69
+ signal: "Overly explanatory inline comment",
70
+ source: "style-heuristic",
71
+ weight: 25,
72
+ },
73
+ {
74
+ regex: /\/\*\*\s*\n\s*\*\s+(?:This|The)\s+(?:function|method|class)\s+/m,
75
+ signal: "Verbose JSDoc with article start",
76
+ source: "style-heuristic",
77
+ weight: 20,
78
+ },
79
+ // Structural patterns typical of AI
80
+ {
81
+ regex: /try\s*\{[^}]*\}\s*catch\s*\(\s*(?:error|err|e)\s*\)\s*\{\s*console\.(?:error|log)\s*\(\s*['"](?:Error|Failed|An error)/i,
82
+ signal: "Template error handling",
83
+ source: "pattern-heuristic",
84
+ weight: 25,
85
+ },
86
+ {
87
+ regex: /if\s*\(!.*\)\s*\{\s*throw\s+new\s+Error\s*\(\s*['"].*is required['"]\s*\)/i,
88
+ signal: "Template validation pattern",
89
+ source: "pattern-heuristic",
90
+ weight: 20,
91
+ },
92
+ { regex: /(?:Example|Usage|How to use):/i, signal: "Example-style comments", source: "style-heuristic", weight: 15 },
93
+ ];
94
+ // ─── Analysis ───────────────────────────────────────────────────────────────
95
+ function analyzeFile(filepath, baseDir) {
96
+ const regions = [];
97
+ let content;
98
+ try {
99
+ content = readFileSync(filepath, "utf-8");
100
+ }
101
+ catch {
102
+ return regions;
103
+ }
104
+ const lines = content.split("\n");
105
+ const rel = relative(baseDir, filepath);
106
+ // Track signal hits per line
107
+ const lineSignals = [];
108
+ for (let i = 0; i < lines.length; i++) {
109
+ const line = lines[i];
110
+ const hits = [];
111
+ for (const sig of AI_SIGNALS) {
112
+ if (sig.regex.test(line)) {
113
+ hits.push({ signal: sig.signal, source: sig.source, weight: sig.weight });
114
+ }
115
+ }
116
+ lineSignals.push({
117
+ signals: hits.map((h) => h.signal),
118
+ source: hits.length > 0 ? hits[0].source : "",
119
+ weight: hits.reduce((sum, h) => sum + h.weight, 0),
120
+ });
121
+ }
122
+ // Merge adjacent high-signal lines into regions
123
+ let regionStart = -1;
124
+ let regionWeight = 0;
125
+ let regionSignals = [];
126
+ let regionSource = "";
127
+ for (let i = 0; i <= lines.length; i++) {
128
+ const ls = i < lines.length ? lineSignals[i] : { signals: [], source: "", weight: 0 };
129
+ if (ls.weight > 0) {
130
+ if (regionStart === -1) {
131
+ regionStart = i;
132
+ regionWeight = 0;
133
+ regionSignals = [];
134
+ regionSource = ls.source;
135
+ }
136
+ regionWeight += ls.weight;
137
+ for (const s of ls.signals) {
138
+ if (!regionSignals.includes(s))
139
+ regionSignals.push(s);
140
+ }
141
+ if (ls.source && !regionSource)
142
+ regionSource = ls.source;
143
+ }
144
+ else if (regionStart !== -1) {
145
+ // Gap — check if we should merge (gap of 1-3 lines)
146
+ const lookAhead = lineSignals.slice(i, Math.min(i + 4, lines.length));
147
+ const hasMore = lookAhead.some((la) => la.weight > 0);
148
+ if (!hasMore || i - regionStart > 50) {
149
+ // Close region
150
+ const confidence = Math.min(95, Math.round((regionWeight / Math.max(1, i - regionStart)) * 2));
151
+ if (confidence >= 15) {
152
+ regions.push({
153
+ file: rel,
154
+ lineStart: regionStart + 1,
155
+ lineEnd: i,
156
+ confidence,
157
+ signals: regionSignals,
158
+ probableSource: regionSource || "unknown",
159
+ });
160
+ }
161
+ regionStart = -1;
162
+ regionSignals = [];
163
+ regionSource = "";
164
+ }
165
+ }
166
+ }
167
+ return regions;
168
+ }
169
+ // ─── CLI ────────────────────────────────────────────────────────────────────
170
+ export function runAiProvenance(argv) {
171
+ if (argv.includes("--help") || argv.includes("-h")) {
172
+ console.log(`
173
+ judges ai-provenance — Detect and annotate AI-generated code regions
174
+
175
+ Usage:
176
+ judges ai-provenance [dir]
177
+ judges ai-provenance src/ --format json
178
+
179
+ Options:
180
+ [dir] Directory to scan (default: .)
181
+ --min-confidence <n> Minimum confidence % to report (default: 20)
182
+ --format json JSON output
183
+ --help, -h Show this help
184
+
185
+ Identifies AI-generated code regions using: attribution comments,
186
+ metadata tags, coding style heuristics, structural patterns, and
187
+ template signatures. Outputs provenance annotations for compliance.
188
+
189
+ Note: All analysis is local — no data is sent externally.
190
+ `);
191
+ return;
192
+ }
193
+ const format = argv.find((_a, i) => argv[i - 1] === "--format") || "text";
194
+ const minConfStr = argv.find((_a, i) => argv[i - 1] === "--min-confidence");
195
+ const minConfidence = minConfStr ? parseInt(minConfStr, 10) : 20;
196
+ const dir = argv.find((a) => !a.startsWith("-") &&
197
+ argv.indexOf(a) > 0 &&
198
+ argv[argv.indexOf(a) - 1] !== "--format" &&
199
+ argv[argv.indexOf(a) - 1] !== "--min-confidence") || ".";
200
+ const files = collectFiles(dir);
201
+ const allRegions = [];
202
+ let totalLines = 0;
203
+ for (const f of files) {
204
+ try {
205
+ const content = readFileSync(f, "utf-8");
206
+ totalLines += content.split("\n").length;
207
+ }
208
+ catch {
209
+ /* skip */
210
+ }
211
+ allRegions.push(...analyzeFile(f, dir));
212
+ }
213
+ const filtered = allRegions.filter((r) => r.confidence >= minConfidence);
214
+ const aiLines = filtered.reduce((sum, r) => sum + (r.lineEnd - r.lineStart + 1), 0);
215
+ const filesWithAi = new Set(filtered.map((r) => r.file)).size;
216
+ const aiPct = totalLines > 0 ? Math.round((aiLines / totalLines) * 1000) / 10 : 0;
217
+ const report = {
218
+ totalFiles: files.length,
219
+ filesWithAiCode: filesWithAi,
220
+ aiRegions: filtered,
221
+ aiLinePercentage: aiPct,
222
+ totalLines,
223
+ aiLines,
224
+ };
225
+ if (format === "json") {
226
+ console.log(JSON.stringify({ ...report, timestamp: new Date().toISOString() }, null, 2));
227
+ }
228
+ else {
229
+ console.log(`\n AI Provenance Report\n ─────────────────────────────`);
230
+ console.log(` Files scanned: ${report.totalFiles}`);
231
+ console.log(` Files with AI code: ${report.filesWithAiCode}`);
232
+ console.log(` AI-attributed lines: ${report.aiLines}/${report.totalLines} (${report.aiLinePercentage}%)\n`);
233
+ if (filtered.length === 0) {
234
+ console.log(" No AI-generated code regions detected.\n");
235
+ return;
236
+ }
237
+ for (const region of filtered.slice(0, 20)) {
238
+ const confIcon = region.confidence >= 70 ? "🔴" : region.confidence >= 40 ? "🟡" : "🔵";
239
+ console.log(` ${confIcon} ${region.file}:${region.lineStart}-${region.lineEnd} (${region.confidence}% confidence)`);
240
+ console.log(` Source: ${region.probableSource}`);
241
+ console.log(` Signals: ${region.signals.join(", ")}`);
242
+ }
243
+ if (filtered.length > 20)
244
+ console.log(`\n ... and ${filtered.length - 20} more regions`);
245
+ console.log();
246
+ }
247
+ }
248
+ //# sourceMappingURL=ai-provenance.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ai-provenance.js","sourceRoot":"","sources":["../../src/commands/ai-provenance.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Batch-review — Parallel review of multiple files with aggregated results.
3
+ */
4
+ export declare function runBatchReview(argv: string[]): void;
5
+ //# sourceMappingURL=batch-review.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"batch-review.d.ts","sourceRoot":"","sources":["../../src/commands/batch-review.ts"],"names":[],"mappings":"AAAA;;GAEG;AAkHH,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAuGnD"}
@@ -0,0 +1,181 @@
1
+ /**
2
+ * Batch-review — Parallel review of multiple files with aggregated results.
3
+ */
4
+ import { readFileSync, readdirSync, statSync } from "fs";
5
+ import { join, extname, relative } from "path";
6
+ // ─── Patterns ──────────────────────────────────────────────────────────────
7
+ const BATCH_PATTERNS = [
8
+ {
9
+ name: "hardcoded-secret",
10
+ severity: "critical",
11
+ regex: /(?:password|secret|api_key|token)\s*[:=]\s*["'][^"']{8,}/i,
12
+ },
13
+ { name: "eval-usage", severity: "critical", regex: /\beval\s*\(/ },
14
+ { name: "sql-concat", severity: "critical", regex: /(?:query|execute)\s*\(\s*["'`].*\+/ },
15
+ { name: "xss-risk", severity: "high", regex: /innerHTML\s*=|document\.write\s*\(/ },
16
+ { name: "command-injection", severity: "critical", regex: /exec(?:Sync)?\s*\(\s*`[^`]*\$\{/ },
17
+ { name: "empty-catch", severity: "medium", regex: /catch\s*\([^)]*\)\s*\{\s*\}/ },
18
+ { name: "any-type", severity: "medium", regex: /:\s*any\b/ },
19
+ { name: "unsafe-regex", severity: "high", regex: /new\s+RegExp\s*\([^)]*\+/ },
20
+ { name: "deprecated-api", severity: "medium", regex: /new\s+Buffer\s*\(|\.substr\s*\(/ },
21
+ { name: "console-log", severity: "low", regex: /console\.log\s*\(/ },
22
+ { name: "todo-fixme", severity: "low", regex: /\/\/\s*(?:TODO|FIXME|HACK)\b/i },
23
+ ];
24
+ // ─── Helpers ────────────────────────────────────────────────────────────────
25
+ function collectSourceFiles(dir) {
26
+ const exts = new Set([".ts", ".js", ".tsx", ".jsx", ".py", ".java", ".go", ".rs", ".cs", ".rb", ".php"]);
27
+ const files = [];
28
+ const skipDirs = new Set(["node_modules", ".git", "dist", "build", "coverage", ".next"]);
29
+ function walk(d) {
30
+ let entries;
31
+ try {
32
+ entries = readdirSync(d);
33
+ }
34
+ catch {
35
+ return;
36
+ }
37
+ for (const name of entries) {
38
+ if (skipDirs.has(name))
39
+ continue;
40
+ const full = join(d, name);
41
+ try {
42
+ const st = statSync(full);
43
+ if (st.isDirectory())
44
+ walk(full);
45
+ else if (exts.has(extname(name)))
46
+ files.push(full);
47
+ }
48
+ catch {
49
+ // skip
50
+ }
51
+ }
52
+ }
53
+ walk(dir);
54
+ return files;
55
+ }
56
+ function reviewFile(filePath, baseDir, failSeverity) {
57
+ const relPath = relative(baseDir, filePath);
58
+ const findings = [];
59
+ let content;
60
+ try {
61
+ content = readFileSync(filePath, "utf-8");
62
+ }
63
+ catch {
64
+ return { file: relPath, findings: [], passed: true };
65
+ }
66
+ const lines = content.split("\n");
67
+ for (let i = 0; i < lines.length; i++) {
68
+ for (const pat of BATCH_PATTERNS) {
69
+ if (pat.regex.test(lines[i])) {
70
+ findings.push({
71
+ pattern: pat.name,
72
+ severity: pat.severity,
73
+ line: i + 1,
74
+ content: lines[i].trim().slice(0, 100),
75
+ });
76
+ }
77
+ }
78
+ }
79
+ const severityRank = { critical: 4, high: 3, medium: 2, low: 1 };
80
+ const threshold = severityRank[failSeverity] || 2;
81
+ const hasFailing = findings.some((f) => (severityRank[f.severity] || 0) >= threshold);
82
+ return { file: relPath, findings, passed: !hasFailing };
83
+ }
84
+ // ─── CLI ────────────────────────────────────────────────────────────────────
85
+ export function runBatchReview(argv) {
86
+ if (argv.includes("--help") || argv.includes("-h")) {
87
+ console.log(`
88
+ judges batch-review — Review multiple files with aggregated results
89
+
90
+ Usage:
91
+ judges batch-review [dir] Review all source files
92
+ judges batch-review --fail-on medium Set failure threshold
93
+ judges batch-review --format json JSON output
94
+ judges batch-review --summary Show only summary
95
+
96
+ Options:
97
+ [dir] Target directory (default: .)
98
+ --fail-on <severity> Fail threshold: critical/high/medium/low (default: medium)
99
+ --summary Summary only, no per-file details
100
+ --format json JSON output
101
+ --help, -h Show this help
102
+
103
+ Reviews all source files in a directory and aggregates results. Each file
104
+ gets a pass/fail based on the severity threshold. Exit code 1 if any file fails.
105
+ `);
106
+ return;
107
+ }
108
+ const start = Date.now();
109
+ const format = argv.find((_a, i) => argv[i - 1] === "--format") || "text";
110
+ const failSeverity = argv.find((_a, i) => argv[i - 1] === "--fail-on") || "medium";
111
+ const summaryOnly = argv.includes("--summary");
112
+ const dir = argv.find((a) => !a.startsWith("-") &&
113
+ a !== "batch-review" &&
114
+ argv[argv.indexOf(a) - 1] !== "--format" &&
115
+ argv[argv.indexOf(a) - 1] !== "--fail-on") || ".";
116
+ const files = collectSourceFiles(dir);
117
+ if (files.length === 0) {
118
+ console.log("No source files found.");
119
+ return;
120
+ }
121
+ const fileResults = files.map((f) => reviewFile(f, dir, failSeverity));
122
+ const duration = Date.now() - start;
123
+ const counts = { critical: 0, high: 0, medium: 0, low: 0 };
124
+ let totalFindings = 0;
125
+ for (const fr of fileResults) {
126
+ for (const f of fr.findings) {
127
+ totalFindings++;
128
+ if (f.severity === "critical")
129
+ counts.critical++;
130
+ else if (f.severity === "high")
131
+ counts.high++;
132
+ else if (f.severity === "medium")
133
+ counts.medium++;
134
+ else
135
+ counts.low++;
136
+ }
137
+ }
138
+ const passedFiles = fileResults.filter((r) => r.passed).length;
139
+ const failedFiles = fileResults.filter((r) => !r.passed).length;
140
+ const result = {
141
+ totalFiles: files.length,
142
+ passedFiles,
143
+ failedFiles,
144
+ totalFindings,
145
+ counts,
146
+ fileResults: summaryOnly ? [] : fileResults.filter((r) => r.findings.length > 0),
147
+ duration,
148
+ };
149
+ if (format === "json") {
150
+ console.log(JSON.stringify(result, null, 2));
151
+ if (failedFiles > 0)
152
+ process.exitCode = 1;
153
+ return;
154
+ }
155
+ const icon = failedFiles === 0 ? "✅" : "❌";
156
+ console.log(`\n Batch Review: ${icon}\n ─────────────────────────────`);
157
+ console.log(` Files: ${passedFiles} passed, ${failedFiles} failed (${files.length} total)`);
158
+ console.log(` Findings: ${totalFindings} (C:${counts.critical} H:${counts.high} M:${counts.medium} L:${counts.low})`);
159
+ console.log(` Duration: ${duration}ms`);
160
+ console.log(` Fail threshold: ${failSeverity}`);
161
+ if (!summaryOnly) {
162
+ const failedResults = fileResults.filter((r) => !r.passed);
163
+ if (failedResults.length > 0) {
164
+ console.log("\n Failed files:");
165
+ for (const fr of failedResults.slice(0, 20)) {
166
+ console.log(` ❌ ${fr.file} (${fr.findings.length} findings)`);
167
+ for (const f of fr.findings.slice(0, 5)) {
168
+ console.log(` [${f.severity}] ${f.pattern} L${f.line}`);
169
+ }
170
+ if (fr.findings.length > 5)
171
+ console.log(` ... +${fr.findings.length - 5} more`);
172
+ }
173
+ if (failedResults.length > 20)
174
+ console.log(` ... +${failedResults.length - 20} more files`);
175
+ }
176
+ }
177
+ console.log();
178
+ if (failedFiles > 0)
179
+ process.exitCode = 1;
180
+ }
181
+ //# sourceMappingURL=batch-review.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"batch-review.js","sourceRoot":"","sources":["../../src/commands/batch-review.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Blame-review — git-blame integrated historical finding attribution.
3
+ */
4
+ export declare function runBlameReview(argv: string[]): void;
5
+ //# sourceMappingURL=blame-review.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blame-review.d.ts","sourceRoot":"","sources":["../../src/commands/blame-review.ts"],"names":[],"mappings":"AAAA;;GAEG;AA4OH,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA4FnD"}