diff options
author | 2021-06-02 09:53:24 -0600 | |
---|---|---|
committer | 2021-06-02 09:53:24 -0600 | |
commit | d2330a58256c212288bbba04ca41f1d65d37e711 (patch) | |
tree | ab0cd107b831f2ad50c35bec8b51e2991522780e /packages/astro-parser/src | |
parent | e3df5e80e16b6dec75ec7f44a1ea4c0692606fdb (diff) | |
download | astro-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.ts | 2 | ||||
-rw-r--r-- | packages/astro-parser/src/utils/error.ts | 29 |
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; } |