forked from colbymchenry/codegraph
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy patherrors.ts
More file actions
240 lines (218 loc) · 5.69 KB
/
errors.ts
File metadata and controls
240 lines (218 loc) · 5.69 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
/**
* CodeGraph Error Classes
*
* Custom error types for better error handling and debugging.
*
* @module errors
*
* @example
* ```typescript
* import { FileError, ParseError, setLogger, silentLogger } from 'codegraph';
*
* // Catch specific error types
* try {
* await cg.indexAll();
* } catch (error) {
* if (error instanceof FileError) {
* console.log(`File error at ${error.filePath}: ${error.message}`);
* } else if (error instanceof ParseError) {
* console.log(`Parse error at ${error.filePath}:${error.line}`);
* }
* }
*
* // Disable logging for tests
* setLogger(silentLogger);
* ```
*/
/**
* Base error class for all CodeGraph errors.
*
* All CodeGraph-specific errors extend this class, allowing you to catch
* all CodeGraph errors with a single catch block.
*
* @example
* ```typescript
* try {
* await cg.indexAll();
* } catch (error) {
* if (error instanceof CodeGraphError) {
* console.log(`CodeGraph error [${error.code}]: ${error.message}`);
* }
* }
* ```
*/
export class CodeGraphError extends Error {
/** Error code for categorization (e.g., 'FILE_ERROR', 'PARSE_ERROR') */
readonly code: string;
/** Additional context about the error */
readonly context?: Record<string, unknown>;
constructor(message: string, code: string, context?: Record<string, unknown>) {
super(message);
this.name = 'CodeGraphError';
this.code = code;
this.context = context;
// Maintain proper stack trace for V8
if (Error.captureStackTrace) {
Error.captureStackTrace(this, this.constructor);
}
}
}
/**
* Error reading or accessing files
*/
export class FileError extends CodeGraphError {
readonly filePath: string;
constructor(message: string, filePath: string, cause?: Error) {
super(message, 'FILE_ERROR', { filePath, cause: cause?.message });
this.name = 'FileError';
this.filePath = filePath;
if (cause) {
this.cause = cause;
}
}
}
/**
* Error parsing source code
*/
export class ParseError extends CodeGraphError {
readonly filePath: string;
readonly line?: number;
readonly column?: number;
constructor(
message: string,
filePath: string,
options?: { line?: number; column?: number; cause?: Error }
) {
super(message, 'PARSE_ERROR', {
filePath,
line: options?.line,
column: options?.column,
cause: options?.cause?.message,
});
this.name = 'ParseError';
this.filePath = filePath;
this.line = options?.line;
this.column = options?.column;
if (options?.cause) {
this.cause = options.cause;
}
}
}
/**
* Error with database operations
*/
export class DatabaseError extends CodeGraphError {
readonly operation: string;
constructor(message: string, operation: string, cause?: Error) {
super(message, 'DATABASE_ERROR', { operation, cause: cause?.message });
this.name = 'DatabaseError';
this.operation = operation;
if (cause) {
this.cause = cause;
}
}
}
/**
* Error with search operations
*/
export class SearchError extends CodeGraphError {
readonly query: string;
constructor(message: string, query: string, cause?: Error) {
super(message, 'SEARCH_ERROR', { query, cause: cause?.message });
this.name = 'SearchError';
this.query = query;
if (cause) {
this.cause = cause;
}
}
}
/**
* Error with vector/embedding operations
*/
export class VectorError extends CodeGraphError {
constructor(message: string, operation: string, cause?: Error) {
super(message, 'VECTOR_ERROR', { operation, cause: cause?.message });
this.name = 'VectorError';
if (cause) {
this.cause = cause;
}
}
}
/**
* Error with configuration
*/
export class ConfigError extends CodeGraphError {
constructor(message: string, details?: Record<string, unknown>) {
super(message, 'CONFIG_ERROR', details);
this.name = 'ConfigError';
}
}
/**
* Simple logger for CodeGraph operations
*
* By default, logs to console.warn for warnings and console.error for errors.
* Can be configured to use custom logging.
*/
export interface Logger {
debug(message: string, context?: Record<string, unknown>): void;
warn(message: string, context?: Record<string, unknown>): void;
error(message: string, context?: Record<string, unknown>): void;
}
/**
* Default console-based logger
*/
export const defaultLogger: Logger = {
debug(message: string, context?: Record<string, unknown>): void {
if (process.env.CODEGRAPH_DEBUG) {
console.debug(`[CodeGraph] ${message}`, context ?? '');
}
},
warn(message: string, context?: Record<string, unknown>): void {
console.warn(`[CodeGraph] ${message}`, context ?? '');
},
error(message: string, context?: Record<string, unknown>): void {
console.error(`[CodeGraph] ${message}`, context ?? '');
},
};
/**
* Silent logger (no output) - useful for tests
*/
export const silentLogger: Logger = {
debug(): void {},
warn(): void {},
error(): void {},
};
/**
* Current logger instance (can be replaced)
*/
let currentLogger: Logger = defaultLogger;
/**
* Set the global logger
*/
export function setLogger(logger: Logger): void {
currentLogger = logger;
}
/**
* Get the current logger
*/
export function getLogger(): Logger {
return currentLogger;
}
/**
* Log a debug message
*/
export function logDebug(message: string, context?: Record<string, unknown>): void {
currentLogger.debug(message, context);
}
/**
* Log a warning message
*/
export function logWarn(message: string, context?: Record<string, unknown>): void {
currentLogger.warn(message, context);
}
/**
* Log an error message
*/
export function logError(message: string, context?: Record<string, unknown>): void {
currentLogger.error(message, context);
}