summaryrefslogtreecommitdiff
path: root/packages/astro-parser/src
diff options
context:
space:
mode:
authorGravatar Drew Powers <1369770+drwpow@users.noreply.github.com> 2021-06-02 09:53:24 -0600
committerGravatar GitHub <noreply@github.com> 2021-06-02 09:53:24 -0600
commitd2330a58256c212288bbba04ca41f1d65d37e711 (patch)
treeab0cd107b831f2ad50c35bec8b51e2991522780e /packages/astro-parser/src
parente3df5e80e16b6dec75ec7f44a1ea4c0692606fdb (diff)
downloadastro-d2330a58256c212288bbba04ca41f1d65d37e711.tar.gz
astro-d2330a58256c212288bbba04ca41f1d65d37e711.tar.zst
astro-d2330a58256c212288bbba04ca41f1d65d37e711.zip
Improve “file not found” error display (#288)
Diffstat (limited to 'packages/astro-parser/src')
-rw-r--r--packages/astro-parser/src/interfaces.ts2
-rw-r--r--packages/astro-parser/src/utils/error.ts29
2 files changed, 14 insertions, 17 deletions
diff --git a/packages/astro-parser/src/interfaces.ts b/packages/astro-parser/src/interfaces.ts
index 40eeb04f5..f3fa5da9d 100644
--- a/packages/astro-parser/src/interfaces.ts
+++ b/packages/astro-parser/src/interfaces.ts
@@ -1,5 +1,5 @@
import type { SourceMap } from 'magic-string';
-export type { CompileError } from './utils/error';
+export { CompileError } from './utils/error';
export interface BaseNode {
start: number;
diff --git a/packages/astro-parser/src/utils/error.ts b/packages/astro-parser/src/utils/error.ts
index 8ebb5b093..00eed866f 100644
--- a/packages/astro-parser/src/utils/error.ts
+++ b/packages/astro-parser/src/utils/error.ts
@@ -5,14 +5,23 @@ import get_code_frame from './get_code_frame.js';
export class CompileError extends Error {
code: string;
- start: { line: number; column: number };
end: { line: number; column: number };
- pos: number;
filename: string;
frame: string;
+ start: { line: number; column: number };
+
+ constructor({ code, filename, start, end, message }: { code: string; filename: string; start: number; message: string; end?: number }) {
+ super(message);
+
+ this.start = locate(code, start, { offsetLine: 1 });
+ this.end = locate(code, end || start, { offsetLine: 1 });
+ this.filename = filename;
+ this.message = message;
+ this.frame = get_code_frame(code, this.start.line - 1, this.start.column);
+ }
toString() {
- return `${this.message} (${this.start.line}:${this.start.column})\n${this.frame}`;
+ return `${this.filename}:${this.start.line}:${this.start.column}\n\t${this.message}\n${this.frame}`;
}
}
@@ -21,26 +30,14 @@ export default function error(
message: string,
props: {
name: string;
- code: string;
source: string;
filename: string;
start: number;
end?: number;
}
): never {
- const err = new CompileError(message);
+ const err = new CompileError({ message, start: props.start, end: props.end, filename: props.filename });
err.name = props.name;
- const start = locate(props.source, props.start, { offsetLine: 1 });
- const end = locate(props.source, props.end || props.start, { offsetLine: 1 });
-
- err.code = props.code;
- err.start = start;
- err.end = end;
- err.pos = props.start;
- err.filename = props.filename;
-
- err.frame = get_code_frame(props.source, start.line - 1, start.column);
-
throw err;
}