mirror of
https://github.com/withastro/astro.git
synced 2025-01-06 22:10:10 -05:00
chore: improve type fidelity for internal error class (#9478)
* chore: improve type fidelity for internal error class * add changeset * simplify * fix: adjust for new error --------- Co-authored-by: Princesseuh <3019731+Princesseuh@users.noreply.github.com>
This commit is contained in:
parent
60dc8da71b
commit
dfef925e1f
4 changed files with 13 additions and 9 deletions
5
.changeset/rare-ants-swim.md
Normal file
5
.changeset/rare-ants-swim.md
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
'astro': patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Improves errors in certain places to also report their causes.
|
|
@ -226,7 +226,6 @@ export async function generateImagesForPath(
|
||||||
...AstroErrorData.CouldNotTransformImage,
|
...AstroErrorData.CouldNotTransformImage,
|
||||||
message: AstroErrorData.CouldNotTransformImage.message(originalFilePath),
|
message: AstroErrorData.CouldNotTransformImage.message(originalFilePath),
|
||||||
},
|
},
|
||||||
undefined,
|
|
||||||
{ cause: e }
|
{ cause: e }
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
|
@ -38,10 +38,10 @@ export class AstroError extends Error {
|
||||||
|
|
||||||
type: ErrorTypes = 'AstroError';
|
type: ErrorTypes = 'AstroError';
|
||||||
|
|
||||||
constructor(props: ErrorProperties, ...params: any) {
|
constructor(props: ErrorProperties, options?: ErrorOptions) {
|
||||||
super(...params);
|
|
||||||
|
|
||||||
const { name, title, message, stack, location, hint, frame } = props;
|
const { name, title, message, stack, location, hint, frame } = props;
|
||||||
|
super(message, options);
|
||||||
|
|
||||||
this.title = title;
|
this.title = title;
|
||||||
this.name = name;
|
this.name = name;
|
||||||
|
|
||||||
|
@ -81,8 +81,8 @@ export class AstroError extends Error {
|
||||||
export class CompilerError extends AstroError {
|
export class CompilerError extends AstroError {
|
||||||
type: ErrorTypes = 'CompilerError';
|
type: ErrorTypes = 'CompilerError';
|
||||||
|
|
||||||
constructor(props: ErrorProperties, ...params: any) {
|
constructor(props: ErrorProperties, options?: ErrorOptions) {
|
||||||
super(props, ...params);
|
super(props, options);
|
||||||
}
|
}
|
||||||
|
|
||||||
static is(err: unknown): err is CompilerError {
|
static is(err: unknown): err is CompilerError {
|
||||||
|
@ -120,8 +120,8 @@ export class AggregateError extends AstroError {
|
||||||
|
|
||||||
// Despite being a collection of errors, AggregateError still needs to have a main error attached to it
|
// Despite being a collection of errors, AggregateError still needs to have a main error attached to it
|
||||||
// This is because Vite expects every thrown errors handled during HMR to be, well, Error and have a message
|
// This is because Vite expects every thrown errors handled during HMR to be, well, Error and have a message
|
||||||
constructor(props: ErrorProperties & { errors: AstroError[] }, ...params: any) {
|
constructor(props: ErrorProperties & { errors: AstroError[] }, options?: ErrorOptions) {
|
||||||
super(props, ...params);
|
super(props, options);
|
||||||
|
|
||||||
this.errors = props.errors;
|
this.errors = props.errors;
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,7 @@ export async function loadMiddleware(moduleLoader: ModuleLoader) {
|
||||||
try {
|
try {
|
||||||
return await moduleLoader.import(MIDDLEWARE_MODULE_ID);
|
return await moduleLoader.import(MIDDLEWARE_MODULE_ID);
|
||||||
} catch (error: any) {
|
} catch (error: any) {
|
||||||
const astroError = new AstroError(MiddlewareCantBeLoaded, undefined, { cause: error });
|
const astroError = new AstroError(MiddlewareCantBeLoaded, { cause: error });
|
||||||
throw astroError;
|
throw astroError;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue