Only crash when not watching after everything is pre-compiled
This commit is contained in:
parent
076cda8008
commit
423f19de68
@ -11,6 +11,8 @@ export default abstract class AssetPreCompiler {
|
|||||||
private afterPreCompileHandlers: ((watch: boolean) => Promise<void>)[] = [];
|
private afterPreCompileHandlers: ((watch: boolean) => Promise<void>)[] = [];
|
||||||
private inputChangeHandler?: (restart: boolean) => Promise<void>;
|
private inputChangeHandler?: (restart: boolean) => Promise<void>;
|
||||||
|
|
||||||
|
private hadError: boolean = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param targetDir The directory to put pre-compiled assets into.
|
* @param targetDir The directory to put pre-compiled assets into.
|
||||||
* @param assetType This must be the assets sub-directory name of the asset type this pre-compiler will handle.
|
* @param assetType This must be the assets sub-directory name of the asset type this pre-compiler will handle.
|
||||||
@ -71,6 +73,10 @@ export default abstract class AssetPreCompiler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public async preCompileAll(watch: boolean): Promise<void> {
|
public async preCompileAll(watch: boolean): Promise<void> {
|
||||||
|
if (watch) {
|
||||||
|
await this.watch();
|
||||||
|
}
|
||||||
|
|
||||||
logger.info(`Pre-compiling ${this.extension} views...`);
|
logger.info(`Pre-compiling ${this.extension} views...`);
|
||||||
|
|
||||||
// List all views
|
// List all views
|
||||||
@ -84,15 +90,25 @@ export default abstract class AssetPreCompiler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Deduplicate and pre-compile
|
// Deduplicate and pre-compile
|
||||||
|
const hasInputChanged = this.hadError;
|
||||||
|
this.hadError = false;
|
||||||
for (const canonicalName of [...new Set<string>(views)]) {
|
for (const canonicalName of [...new Set<string>(views)]) {
|
||||||
|
try {
|
||||||
await this.preCompile(canonicalName, false);
|
await this.preCompile(canonicalName, false);
|
||||||
|
} catch (e) {
|
||||||
|
logger.error(e);
|
||||||
|
this.hadError = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// If previous preCompileAll had errors, not all output files were generated.
|
||||||
|
if (hasInputChanged) {
|
||||||
|
await this.inputChangeHandler?.(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
await this.afterPreCompile(watch);
|
await this.afterPreCompile(watch);
|
||||||
|
|
||||||
if (watch) {
|
if (this.hadError && !watch) throw new Error('Errors while precompiling assets.');
|
||||||
await this.watch();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public async watch(): Promise<void> {
|
public async watch(): Promise<void> {
|
||||||
|
Loading…
Reference in New Issue
Block a user