localpov 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +309 -0
  3. package/bin/localpov-mcp.js +15 -0
  4. package/bin/localpov.js +599 -0
  5. package/dashboard/index.html +909 -0
  6. package/dist/collectors/browser-capture.d.ts +124 -0
  7. package/dist/collectors/browser-capture.js +327 -0
  8. package/dist/collectors/browser-capture.js.map +1 -0
  9. package/dist/collectors/build-parser.d.ts +18 -0
  10. package/dist/collectors/build-parser.js +192 -0
  11. package/dist/collectors/build-parser.js.map +1 -0
  12. package/dist/collectors/docker-watcher.d.ts +42 -0
  13. package/dist/collectors/docker-watcher.js +101 -0
  14. package/dist/collectors/docker-watcher.js.map +1 -0
  15. package/dist/collectors/terminal.d.ts +42 -0
  16. package/dist/collectors/terminal.js +128 -0
  17. package/dist/collectors/terminal.js.map +1 -0
  18. package/dist/index.d.ts +1 -0
  19. package/dist/index.js +6 -0
  20. package/dist/index.js.map +1 -0
  21. package/dist/mcp-server.d.ts +1 -0
  22. package/dist/mcp-server.js +466 -0
  23. package/dist/mcp-server.js.map +1 -0
  24. package/dist/utils/inject.d.ts +11 -0
  25. package/dist/utils/inject.js +241 -0
  26. package/dist/utils/inject.js.map +1 -0
  27. package/dist/utils/network.d.ts +7 -0
  28. package/dist/utils/network.js +42 -0
  29. package/dist/utils/network.js.map +1 -0
  30. package/dist/utils/proxy.d.ts +24 -0
  31. package/dist/utils/proxy.js +363 -0
  32. package/dist/utils/proxy.js.map +1 -0
  33. package/dist/utils/scanner.d.ts +9 -0
  34. package/dist/utils/scanner.js +96 -0
  35. package/dist/utils/scanner.js.map +1 -0
  36. package/dist/utils/session-manager.d.ts +109 -0
  37. package/dist/utils/session-manager.js +488 -0
  38. package/dist/utils/session-manager.js.map +1 -0
  39. package/dist/utils/shell-init.d.ts +26 -0
  40. package/dist/utils/shell-init.js +422 -0
  41. package/dist/utils/shell-init.js.map +1 -0
  42. package/dist/utils/system-info.d.ts +51 -0
  43. package/dist/utils/system-info.js +170 -0
  44. package/dist/utils/system-info.js.map +1 -0
  45. package/package.json +64 -0
@@ -0,0 +1,124 @@
1
+ import { EventEmitter } from 'events';
2
+ export interface ConsoleEntry {
3
+ level: string;
4
+ message: string;
5
+ stack: string | null;
6
+ source: string | null;
7
+ ts: number;
8
+ url: string | null;
9
+ }
10
+ export interface NetworkEntry {
11
+ method: string;
12
+ url: string;
13
+ status: number;
14
+ statusText: string;
15
+ duration: number;
16
+ size: number;
17
+ type: string;
18
+ error: string | null;
19
+ requestHeaders: Record<string, string> | null;
20
+ responseHeaders: Record<string, string> | null;
21
+ responseBody: string | null;
22
+ ts: number;
23
+ }
24
+ interface ConsoleQueryOptions {
25
+ level?: string | string[];
26
+ since?: number;
27
+ limit?: number;
28
+ }
29
+ interface NetworkQueryOptions {
30
+ errorsOnly?: boolean;
31
+ slowOnly?: boolean;
32
+ slowThreshold?: number;
33
+ since?: number;
34
+ limit?: number;
35
+ }
36
+ interface ScreenshotData {
37
+ data: string;
38
+ ts: number;
39
+ age: number;
40
+ }
41
+ interface BrowserSummary {
42
+ console: {
43
+ total: number;
44
+ errors: number;
45
+ warnings: number;
46
+ recentErrors: Array<{
47
+ message: string;
48
+ source: string | null;
49
+ ts: number;
50
+ }>;
51
+ };
52
+ network: {
53
+ total: number;
54
+ failed: number;
55
+ slow: number;
56
+ recentErrors: Array<{
57
+ method: string;
58
+ url: string;
59
+ status: number;
60
+ error: string | null;
61
+ ts: number;
62
+ }>;
63
+ };
64
+ hasScreenshot: boolean;
65
+ screenshotAge: number | null;
66
+ }
67
+ interface BrowserCaptureOptions {
68
+ persistDir?: string;
69
+ }
70
+ interface IncomingMessage {
71
+ type: string;
72
+ level?: string;
73
+ message?: string;
74
+ stack?: string;
75
+ source?: string;
76
+ url?: string;
77
+ ts?: number;
78
+ method?: string;
79
+ status?: number;
80
+ statusText?: string;
81
+ duration?: number;
82
+ size?: number;
83
+ error?: string;
84
+ requestHeaders?: Record<string, string>;
85
+ responseHeaders?: Record<string, string>;
86
+ responseBody?: string;
87
+ data?: string;
88
+ }
89
+ /**
90
+ * Stores browser console logs and network requests received from
91
+ * the injected client-side script via WebSocket.
92
+ */
93
+ export declare class BrowserCapture extends EventEmitter {
94
+ consoleEntries: ConsoleEntry[];
95
+ networkEntries: NetworkEntry[];
96
+ private _screenshotData;
97
+ private _screenshotTs;
98
+ persistDir: string;
99
+ private _consolePath;
100
+ private _networkPath;
101
+ private _screenshotPath;
102
+ constructor(options?: BrowserCaptureOptions);
103
+ cleanStale(maxAgeMs?: number): void;
104
+ private _appendLine;
105
+ private _readJsonl;
106
+ loadFromDisk(): void;
107
+ private _persistConsole;
108
+ private _persistNetwork;
109
+ private _persistScreenshot;
110
+ addConsoleEntry(entry: Partial<ConsoleEntry>): ConsoleEntry;
111
+ getConsoleEntries(options?: ConsoleQueryOptions): ConsoleEntry[];
112
+ getConsoleErrors(limit?: number): ConsoleEntry[];
113
+ addNetworkEntry(entry: Partial<NetworkEntry>): NetworkEntry;
114
+ getNetworkEntries(options?: NetworkQueryOptions): NetworkEntry[];
115
+ getNetworkErrors(limit?: number): NetworkEntry[];
116
+ setScreenshot(dataUrl: string): void;
117
+ getScreenshot(): ScreenshotData | null;
118
+ getSummary(): BrowserSummary;
119
+ handleMessage(msg: string | IncomingMessage): ConsoleEntry | NetworkEntry | {
120
+ ok: boolean;
121
+ } | null;
122
+ clear(): void;
123
+ }
124
+ export {};
@@ -0,0 +1,327 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.BrowserCapture = void 0;
7
+ const events_1 = require("events");
8
+ const fs_1 = __importDefault(require("fs"));
9
+ const path_1 = __importDefault(require("path"));
10
+ const os_1 = __importDefault(require("os"));
11
+ const MAX_CONSOLE_ENTRIES = 500;
12
+ const MAX_NETWORK_ENTRIES = 500;
13
+ const MAX_FILE_LINES = 1000;
14
+ /**
15
+ * Stores browser console logs and network requests received from
16
+ * the injected client-side script via WebSocket.
17
+ */
18
+ class BrowserCapture extends events_1.EventEmitter {
19
+ consoleEntries;
20
+ networkEntries;
21
+ _screenshotData;
22
+ _screenshotTs;
23
+ persistDir;
24
+ _consolePath;
25
+ _networkPath;
26
+ _screenshotPath;
27
+ constructor(options = {}) {
28
+ super();
29
+ this.consoleEntries = [];
30
+ this.networkEntries = [];
31
+ this._screenshotData = null;
32
+ this._screenshotTs = 0;
33
+ this.persistDir = options.persistDir || path_1.default.join(os_1.default.homedir(), '.localpov', 'browser');
34
+ this._consolePath = path_1.default.join(this.persistDir, 'console.jsonl');
35
+ this._networkPath = path_1.default.join(this.persistDir, 'network.jsonl');
36
+ this._screenshotPath = path_1.default.join(this.persistDir, 'screenshot.jpg');
37
+ try {
38
+ fs_1.default.mkdirSync(this.persistDir, { recursive: true });
39
+ }
40
+ catch {
41
+ // ignore
42
+ }
43
+ this.cleanStale();
44
+ this.loadFromDisk();
45
+ }
46
+ // ── Cleanup ──
47
+ cleanStale(maxAgeMs = 4 * 60 * 60 * 1000) {
48
+ const MAX_FILE_SIZE = 5 * 1024 * 1024;
49
+ const now = Date.now();
50
+ for (const filePath of [this._consolePath, this._networkPath]) {
51
+ try {
52
+ if (!fs_1.default.existsSync(filePath))
53
+ continue;
54
+ const stat = fs_1.default.statSync(filePath);
55
+ if (now - stat.mtimeMs > maxAgeMs) {
56
+ fs_1.default.writeFileSync(filePath, '', 'utf8');
57
+ continue;
58
+ }
59
+ if (stat.size > MAX_FILE_SIZE) {
60
+ const raw = fs_1.default.readFileSync(filePath, 'utf8');
61
+ const lines = raw.split('\n').filter(l => l.trim());
62
+ const trimmed = lines.slice(-500).join('\n') + '\n';
63
+ fs_1.default.writeFileSync(filePath, trimmed, 'utf8');
64
+ }
65
+ }
66
+ catch {
67
+ // non-fatal
68
+ }
69
+ }
70
+ try {
71
+ if (fs_1.default.existsSync(this._screenshotPath)) {
72
+ const stat = fs_1.default.statSync(this._screenshotPath);
73
+ if (now - stat.mtimeMs > maxAgeMs) {
74
+ fs_1.default.unlinkSync(this._screenshotPath);
75
+ }
76
+ }
77
+ }
78
+ catch { }
79
+ }
80
+ // ── Persistence helpers ──
81
+ _appendLine(filePath, obj) {
82
+ try {
83
+ fs_1.default.appendFileSync(filePath, JSON.stringify(obj) + '\n', 'utf8');
84
+ }
85
+ catch {
86
+ // non-fatal
87
+ }
88
+ }
89
+ _readJsonl(filePath) {
90
+ try {
91
+ if (!fs_1.default.existsSync(filePath))
92
+ return [];
93
+ const raw = fs_1.default.readFileSync(filePath, 'utf8');
94
+ const lines = raw.split('\n').filter(l => l.trim());
95
+ const trimmed = lines.slice(-MAX_FILE_LINES);
96
+ const items = [];
97
+ for (const line of trimmed) {
98
+ try {
99
+ items.push(JSON.parse(line));
100
+ }
101
+ catch {
102
+ // skip malformed lines
103
+ }
104
+ }
105
+ return items;
106
+ }
107
+ catch {
108
+ return [];
109
+ }
110
+ }
111
+ loadFromDisk() {
112
+ this.consoleEntries = this._readJsonl(this._consolePath);
113
+ this.networkEntries = this._readJsonl(this._networkPath);
114
+ try {
115
+ if (fs_1.default.existsSync(this._screenshotPath)) {
116
+ const buf = fs_1.default.readFileSync(this._screenshotPath);
117
+ if (buf.length > 0) {
118
+ this._screenshotData = 'data:image/jpeg;base64,' + buf.toString('base64');
119
+ const stat = fs_1.default.statSync(this._screenshotPath);
120
+ this._screenshotTs = stat.mtimeMs;
121
+ }
122
+ }
123
+ }
124
+ catch {
125
+ // non-fatal
126
+ }
127
+ }
128
+ _persistConsole(item) {
129
+ this._appendLine(this._consolePath, item);
130
+ }
131
+ _persistNetwork(item) {
132
+ this._appendLine(this._networkPath, item);
133
+ }
134
+ _persistScreenshot(dataUrl) {
135
+ try {
136
+ const base64 = dataUrl.replace(/^data:image\/\w+;base64,/, '');
137
+ fs_1.default.writeFileSync(this._screenshotPath, Buffer.from(base64, 'base64'));
138
+ }
139
+ catch {
140
+ // non-fatal
141
+ }
142
+ }
143
+ // ── Console ──
144
+ addConsoleEntry(entry) {
145
+ const item = {
146
+ level: entry.level || 'log',
147
+ message: String(entry.message || '').slice(0, 2000),
148
+ stack: entry.stack || null,
149
+ source: entry.source || null,
150
+ ts: entry.ts || Date.now(),
151
+ url: entry.url || null,
152
+ };
153
+ this.consoleEntries.push(item);
154
+ while (this.consoleEntries.length > MAX_CONSOLE_ENTRIES) {
155
+ this.consoleEntries.shift();
156
+ }
157
+ this._persistConsole(item);
158
+ this.emit('console', item);
159
+ return item;
160
+ }
161
+ getConsoleEntries(options = {}) {
162
+ let entries = this.consoleEntries;
163
+ if (options.level) {
164
+ const levels = Array.isArray(options.level) ? options.level : [options.level];
165
+ entries = entries.filter(e => levels.includes(e.level));
166
+ }
167
+ if (options.since) {
168
+ entries = entries.filter(e => e.ts >= options.since);
169
+ }
170
+ const limit = options.limit || 50;
171
+ return entries.slice(-limit);
172
+ }
173
+ getConsoleErrors(limit = 20) {
174
+ return this.getConsoleEntries({ level: ['error', 'warn'], limit });
175
+ }
176
+ // ── Network ──
177
+ addNetworkEntry(entry) {
178
+ const item = {
179
+ method: entry.method || 'GET',
180
+ url: String(entry.url || '').slice(0, 500),
181
+ status: entry.status || 0,
182
+ statusText: entry.statusText || '',
183
+ duration: entry.duration || 0,
184
+ size: entry.size || 0,
185
+ type: entry.type || '',
186
+ error: entry.error || null,
187
+ requestHeaders: entry.requestHeaders || null,
188
+ responseHeaders: entry.responseHeaders || null,
189
+ responseBody: entry.responseBody ? String(entry.responseBody).slice(0, 5000) : null,
190
+ ts: entry.ts || Date.now(),
191
+ };
192
+ this.networkEntries.push(item);
193
+ while (this.networkEntries.length > MAX_NETWORK_ENTRIES) {
194
+ this.networkEntries.shift();
195
+ }
196
+ this._persistNetwork(item);
197
+ this.emit('network', item);
198
+ return item;
199
+ }
200
+ getNetworkEntries(options = {}) {
201
+ let entries = this.networkEntries;
202
+ if (options.errorsOnly) {
203
+ entries = entries.filter(e => e.status >= 400 || e.error);
204
+ }
205
+ if (options.slowOnly) {
206
+ const threshold = options.slowThreshold || 1000;
207
+ entries = entries.filter(e => e.duration >= threshold);
208
+ }
209
+ if (options.since) {
210
+ entries = entries.filter(e => e.ts >= options.since);
211
+ }
212
+ const limit = options.limit || 50;
213
+ return entries.slice(-limit);
214
+ }
215
+ getNetworkErrors(limit = 20) {
216
+ return this.getNetworkEntries({ errorsOnly: true, limit });
217
+ }
218
+ // ── Screenshots ──
219
+ setScreenshot(dataUrl) {
220
+ this._screenshotData = dataUrl;
221
+ this._screenshotTs = Date.now();
222
+ this._persistScreenshot(dataUrl);
223
+ this.emit('screenshot', { ts: this._screenshotTs });
224
+ }
225
+ getScreenshot() {
226
+ if (!this._screenshotData)
227
+ return null;
228
+ return {
229
+ data: this._screenshotData,
230
+ ts: this._screenshotTs,
231
+ age: Date.now() - this._screenshotTs,
232
+ };
233
+ }
234
+ // ── Summary ──
235
+ getSummary() {
236
+ const consoleErrors = this.consoleEntries.filter(e => e.level === 'error');
237
+ const consoleWarns = this.consoleEntries.filter(e => e.level === 'warn');
238
+ const networkErrors = this.networkEntries.filter(e => e.status >= 400 || e.error);
239
+ const slowRequests = this.networkEntries.filter(e => e.duration >= 1000);
240
+ return {
241
+ console: {
242
+ total: this.consoleEntries.length,
243
+ errors: consoleErrors.length,
244
+ warnings: consoleWarns.length,
245
+ recentErrors: consoleErrors.slice(-5).map(e => ({
246
+ message: e.message.slice(0, 200),
247
+ source: e.source,
248
+ ts: e.ts,
249
+ })),
250
+ },
251
+ network: {
252
+ total: this.networkEntries.length,
253
+ failed: networkErrors.length,
254
+ slow: slowRequests.length,
255
+ recentErrors: networkErrors.slice(-5).map(e => ({
256
+ method: e.method,
257
+ url: e.url.slice(0, 100),
258
+ status: e.status,
259
+ error: e.error,
260
+ ts: e.ts,
261
+ })),
262
+ },
263
+ hasScreenshot: !!this._screenshotData,
264
+ screenshotAge: this._screenshotData ? Date.now() - this._screenshotTs : null,
265
+ };
266
+ }
267
+ // ── Handle incoming WebSocket message from injected script ──
268
+ handleMessage(msg) {
269
+ let data;
270
+ try {
271
+ data = typeof msg === 'string' ? JSON.parse(msg) : msg;
272
+ }
273
+ catch {
274
+ return null;
275
+ }
276
+ if (!data || typeof data !== 'object' || !data.type)
277
+ return null;
278
+ try {
279
+ switch (data.type) {
280
+ case 'console':
281
+ return this.addConsoleEntry(data);
282
+ case 'network':
283
+ return this.addNetworkEntry(data);
284
+ case 'screenshot':
285
+ if (typeof data.data !== 'string' || !data.data.startsWith('data:image/'))
286
+ return null;
287
+ this.setScreenshot(data.data);
288
+ return { ok: true };
289
+ case 'error':
290
+ return this.addConsoleEntry({
291
+ level: 'error',
292
+ message: data.message || 'Unknown error',
293
+ stack: data.stack || null,
294
+ source: data.source || null,
295
+ url: data.url || null,
296
+ ts: data.ts || Date.now(),
297
+ });
298
+ default:
299
+ return null;
300
+ }
301
+ }
302
+ catch (e) {
303
+ this.emit('error', e);
304
+ return null;
305
+ }
306
+ }
307
+ clear() {
308
+ this.consoleEntries = [];
309
+ this.networkEntries = [];
310
+ this._screenshotData = null;
311
+ this._screenshotTs = 0;
312
+ try {
313
+ fs_1.default.writeFileSync(this._consolePath, '', 'utf8');
314
+ }
315
+ catch { /* ignore */ }
316
+ try {
317
+ fs_1.default.writeFileSync(this._networkPath, '', 'utf8');
318
+ }
319
+ catch { /* ignore */ }
320
+ try {
321
+ fs_1.default.unlinkSync(this._screenshotPath);
322
+ }
323
+ catch { /* ignore */ }
324
+ }
325
+ }
326
+ exports.BrowserCapture = BrowserCapture;
327
+ //# sourceMappingURL=browser-capture.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"browser-capture.js","sourceRoot":"","sources":["../../src/collectors/browser-capture.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ interface BuildError {
2
+ file: string;
3
+ line: number;
4
+ col: number;
5
+ severity: string;
6
+ code: string;
7
+ message: string;
8
+ }
9
+ interface ParsedBuildError extends BuildError {
10
+ parser: string;
11
+ raw: string;
12
+ }
13
+ /**
14
+ * Parse build errors from raw text output.
15
+ */
16
+ export declare function parseBuildErrors(text: string): ParsedBuildError[];
17
+ export declare function parse(text: string): ParsedBuildError[];
18
+ export {};
@@ -0,0 +1,192 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.parseBuildErrors = parseBuildErrors;
4
+ exports.parse = parse;
5
+ const PARSERS = [
6
+ {
7
+ name: 'typescript',
8
+ patterns: [
9
+ {
10
+ re: /^(.+?)\((\d+),(\d+)\):\s*(error|warning)\s+(TS\d+):\s*(.+)$/,
11
+ extract: (m) => ({
12
+ file: m[1], line: +m[2], col: +m[3],
13
+ severity: m[4], code: m[5], message: m[6],
14
+ }),
15
+ },
16
+ {
17
+ re: /^(.+?):(\d+):(\d+)\s*-\s*(error|warning)\s+(TS\d+):\s*(.+)$/,
18
+ extract: (m) => ({
19
+ file: m[1], line: +m[2], col: +m[3],
20
+ severity: m[4], code: m[5], message: m[6],
21
+ }),
22
+ },
23
+ ],
24
+ },
25
+ {
26
+ name: 'eslint',
27
+ patterns: [
28
+ {
29
+ re: /^\s*(.+?):(\d+):(\d+)\s+(error|warning)\s+(.+?)\s{2,}(\S+)\s*$/,
30
+ extract: (m) => ({
31
+ file: m[1], line: +m[2], col: +m[3],
32
+ severity: m[4], message: m[5].trim(), code: m[6],
33
+ }),
34
+ },
35
+ ],
36
+ },
37
+ {
38
+ name: 'webpack',
39
+ patterns: [
40
+ {
41
+ re: /^ERROR\s+in\s+(.+?)\s+(\d+):(\d+)$/,
42
+ extract: (m) => ({
43
+ file: m[1], line: +m[2], col: +m[3],
44
+ severity: 'error', code: 'webpack', message: 'Build error',
45
+ }),
46
+ },
47
+ {
48
+ re: /^Module not found:\s*Error:\s*(.+)$/,
49
+ extract: (m) => ({
50
+ file: '', line: 0, col: 0,
51
+ severity: 'error', code: 'module-not-found', message: m[1],
52
+ }),
53
+ },
54
+ ],
55
+ },
56
+ {
57
+ name: 'vite',
58
+ patterns: [
59
+ {
60
+ re: /^\[vite\]\s*(.+?):\s*(.+?)(?:\s+file:\s*(.+?))?$/,
61
+ extract: (m) => {
62
+ const fileParts = (m[3] || '').match(/(.+?):(\d+):(\d+)/);
63
+ return {
64
+ file: fileParts ? fileParts[1] : '',
65
+ line: fileParts ? +fileParts[2] : 0,
66
+ col: fileParts ? +fileParts[3] : 0,
67
+ severity: 'error', code: 'vite', message: m[2],
68
+ };
69
+ },
70
+ },
71
+ ],
72
+ },
73
+ {
74
+ name: 'rust',
75
+ patterns: [
76
+ {
77
+ re: /^(error|warning)\[(\w+)\]:\s*(.+)$/,
78
+ extract: (m) => ({
79
+ file: '', line: 0, col: 0,
80
+ severity: m[1], code: m[2], message: m[3],
81
+ }),
82
+ },
83
+ {
84
+ re: /^\s*-->\s*(.+?):(\d+):(\d+)$/,
85
+ extract: (m) => ({
86
+ file: m[1], line: +m[2], col: +m[3],
87
+ severity: 'error', code: 'rust', message: '',
88
+ }),
89
+ },
90
+ ],
91
+ },
92
+ {
93
+ name: 'go',
94
+ patterns: [
95
+ {
96
+ re: /^(.+?\.go):(\d+):(\d+):\s*(.+)$/,
97
+ extract: (m) => ({
98
+ file: m[1], line: +m[2], col: +m[3],
99
+ severity: 'error', code: 'go', message: m[4],
100
+ }),
101
+ },
102
+ ],
103
+ },
104
+ {
105
+ name: 'python',
106
+ patterns: [
107
+ {
108
+ re: /^\s*File\s+"(.+?)",\s*line\s+(\d+)/,
109
+ extract: (m) => ({
110
+ file: m[1], line: +m[2], col: 0,
111
+ severity: 'error', code: 'python', message: '',
112
+ }),
113
+ },
114
+ ],
115
+ },
116
+ {
117
+ name: 'generic',
118
+ patterns: [
119
+ {
120
+ re: /^(.+?\.\w+):(\d+):(\d+):\s*(error|Error|ERROR)[:.]?\s*(.+)$/,
121
+ extract: (m) => ({
122
+ file: m[1], line: +m[2], col: +m[3],
123
+ severity: 'error', code: 'generic', message: m[5],
124
+ }),
125
+ },
126
+ ],
127
+ },
128
+ ];
129
+ /**
130
+ * Parse build errors from raw text output.
131
+ */
132
+ function parseBuildErrors(text) {
133
+ const errors = [];
134
+ const lines = text.split('\n');
135
+ for (let i = 0; i < lines.length; i++) {
136
+ const line = lines[i];
137
+ if (!line.trim())
138
+ continue;
139
+ for (const parser of PARSERS) {
140
+ let matched = false;
141
+ for (const { re, extract } of parser.patterns) {
142
+ const m = line.match(re);
143
+ if (m) {
144
+ const err = extract(m);
145
+ if (!err.message && i + 1 < lines.length) {
146
+ err.message = lines[i + 1].trim();
147
+ }
148
+ errors.push({
149
+ ...err,
150
+ parser: parser.name,
151
+ raw: line,
152
+ });
153
+ matched = true;
154
+ break;
155
+ }
156
+ }
157
+ if (matched)
158
+ break;
159
+ }
160
+ }
161
+ const seen = new Set();
162
+ return errors.filter(e => {
163
+ const key = `${e.file}:${e.line}:${e.message}`;
164
+ if (seen.has(key))
165
+ return false;
166
+ seen.add(key);
167
+ return true;
168
+ });
169
+ }
170
+ /**
171
+ * Merge Rust errors where the location is on a separate line from the message.
172
+ */
173
+ function mergeBuildErrors(errors) {
174
+ const merged = [];
175
+ for (let i = 0; i < errors.length; i++) {
176
+ const curr = errors[i];
177
+ if (curr.parser === 'rust' && !curr.file && i + 1 < errors.length) {
178
+ const next = errors[i + 1];
179
+ if (next.parser === 'rust' && next.file && !next.message) {
180
+ merged.push({ ...next, message: curr.message, code: curr.code, severity: curr.severity });
181
+ i++;
182
+ continue;
183
+ }
184
+ }
185
+ merged.push(curr);
186
+ }
187
+ return merged;
188
+ }
189
+ function parse(text) {
190
+ return mergeBuildErrors(parseBuildErrors(text));
191
+ }
192
+ //# sourceMappingURL=build-parser.js.map