perf(ivy): ngcc - only render .d.ts analysis when necessary (#26403)
For each package entry-point there is only one format that is used to compile the typings files (.d.ts). This will be either esm2015 or fesm2015 (preferred). So we would not run any dts processing in the renderer if we are not compiling the appropriate format. PR Close #26403
This commit is contained in:
parent
603e7935aa
commit
2f30bbb495
|
@ -85,8 +85,8 @@ export class Transformer {
|
||||||
|
|
||||||
console.time(entryPoint.name + '(rendering)');
|
console.time(entryPoint.name + '(rendering)');
|
||||||
// Transform the source files and source maps.
|
// Transform the source files and source maps.
|
||||||
const renderer =
|
const renderer = this.getRenderer(
|
||||||
this.getRenderer(format, packageProgram, reflectionHost, isCore, r3SymbolsFile);
|
format, packageProgram, reflectionHost, isCore, r3SymbolsFile, transformDts);
|
||||||
const renderedFiles =
|
const renderedFiles =
|
||||||
renderer.renderProgram(packageProgram, decorationAnalyses, switchMarkerAnalyses);
|
renderer.renderProgram(packageProgram, decorationAnalyses, switchMarkerAnalyses);
|
||||||
console.timeEnd(entryPoint.name + '(rendering)');
|
console.timeEnd(entryPoint.name + '(rendering)');
|
||||||
|
@ -125,14 +125,14 @@ export class Transformer {
|
||||||
|
|
||||||
getRenderer(
|
getRenderer(
|
||||||
format: string, program: ts.Program, host: NgccReflectionHost, isCore: boolean,
|
format: string, program: ts.Program, host: NgccReflectionHost, isCore: boolean,
|
||||||
rewriteCoreImportsTo: ts.SourceFile|null): Renderer {
|
rewriteCoreImportsTo: ts.SourceFile|null, transformDts: boolean): Renderer {
|
||||||
switch (format) {
|
switch (format) {
|
||||||
case 'esm2015':
|
case 'esm2015':
|
||||||
case 'esm5':
|
case 'esm5':
|
||||||
case 'fesm2015':
|
case 'fesm2015':
|
||||||
case 'fesm5':
|
case 'fesm5':
|
||||||
return new EsmRenderer(
|
return new EsmRenderer(
|
||||||
host, isCore, rewriteCoreImportsTo, this.sourcePath, this.targetPath);
|
host, isCore, rewriteCoreImportsTo, this.sourcePath, this.targetPath, transformDts);
|
||||||
default:
|
default:
|
||||||
throw new Error(`Renderer for "${format}" not yet implemented.`);
|
throw new Error(`Renderer for "${format}" not yet implemented.`);
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,8 +15,8 @@ export class EsmRenderer extends Renderer {
|
||||||
constructor(
|
constructor(
|
||||||
protected host: NgccReflectionHost, protected isCore: boolean,
|
protected host: NgccReflectionHost, protected isCore: boolean,
|
||||||
protected rewriteCoreImportsTo: ts.SourceFile|null, protected sourcePath: string,
|
protected rewriteCoreImportsTo: ts.SourceFile|null, protected sourcePath: string,
|
||||||
protected targetPath: string) {
|
protected targetPath: string, transformDts: boolean) {
|
||||||
super(host, isCore, rewriteCoreImportsTo, sourcePath, targetPath);
|
super(host, isCore, rewriteCoreImportsTo, sourcePath, targetPath, transformDts);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -57,7 +57,7 @@ export abstract class Renderer {
|
||||||
constructor(
|
constructor(
|
||||||
protected host: NgccReflectionHost, protected isCore: boolean,
|
protected host: NgccReflectionHost, protected isCore: boolean,
|
||||||
protected rewriteCoreImportsTo: ts.SourceFile|null, protected sourcePath: string,
|
protected rewriteCoreImportsTo: ts.SourceFile|null, protected sourcePath: string,
|
||||||
protected targetPath: string) {}
|
protected targetPath: string, protected transformDts: boolean) {}
|
||||||
|
|
||||||
renderProgram(
|
renderProgram(
|
||||||
program: ts.Program, decorationAnalyses: DecorationAnalyses,
|
program: ts.Program, decorationAnalyses: DecorationAnalyses,
|
||||||
|
@ -74,9 +74,11 @@ export abstract class Renderer {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
if (this.transformDts) {
|
||||||
// Transform the .d.ts files
|
// Transform the .d.ts files
|
||||||
const dtsFiles = this.getTypingsFilesToRender(decorationAnalyses);
|
const dtsFiles = this.getTypingsFilesToRender(decorationAnalyses);
|
||||||
dtsFiles.forEach((classes, file) => renderedFiles.push(...this.renderDtsFile(file, classes)));
|
dtsFiles.forEach((classes, file) => renderedFiles.push(...this.renderDtsFile(file, classes)));
|
||||||
|
}
|
||||||
|
|
||||||
return renderedFiles;
|
return renderedFiles;
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,7 +23,7 @@ function setup(file: {name: string, contents: string}, transformDts: boolean = f
|
||||||
const decorationAnalyses =
|
const decorationAnalyses =
|
||||||
new DecorationAnalyzer(program.getTypeChecker(), host, [''], false).analyzeProgram(program);
|
new DecorationAnalyzer(program.getTypeChecker(), host, [''], false).analyzeProgram(program);
|
||||||
const switchMarkerAnalyses = new SwitchMarkerAnalyzer(host).analyzeProgram(program);
|
const switchMarkerAnalyses = new SwitchMarkerAnalyzer(host).analyzeProgram(program);
|
||||||
const renderer = new EsmRenderer(host, false, null, dir, dir);
|
const renderer = new EsmRenderer(host, false, null, dir, dir, false);
|
||||||
return {host, program, sourceFile, renderer, decorationAnalyses, switchMarkerAnalyses};
|
return {host, program, sourceFile, renderer, decorationAnalyses, switchMarkerAnalyses};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@ function setup(file: {name: string, contents: string}) {
|
||||||
const decorationAnalyses =
|
const decorationAnalyses =
|
||||||
new DecorationAnalyzer(program.getTypeChecker(), host, [''], false).analyzeProgram(program);
|
new DecorationAnalyzer(program.getTypeChecker(), host, [''], false).analyzeProgram(program);
|
||||||
const switchMarkerAnalyses = new SwitchMarkerAnalyzer(host).analyzeProgram(program);
|
const switchMarkerAnalyses = new SwitchMarkerAnalyzer(host).analyzeProgram(program);
|
||||||
const renderer = new EsmRenderer(host, false, null, '', '');
|
const renderer = new EsmRenderer(host, false, null, '', '', false);
|
||||||
return {host, program, sourceFile, renderer, decorationAnalyses, switchMarkerAnalyses};
|
return {host, program, sourceFile, renderer, decorationAnalyses, switchMarkerAnalyses};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,7 +17,7 @@ import {Esm2015ReflectionHost} from '../../src/host/esm2015_host';
|
||||||
import {Renderer} from '../../src/rendering/renderer';
|
import {Renderer} from '../../src/rendering/renderer';
|
||||||
|
|
||||||
class TestRenderer extends Renderer {
|
class TestRenderer extends Renderer {
|
||||||
constructor(host: Esm2015ReflectionHost) { super(host, false, null, '/src', '/dist'); }
|
constructor(host: Esm2015ReflectionHost) { super(host, false, null, '/src', '/dist', false); }
|
||||||
addImports(output: MagicString, imports: {name: string, as: string}[]) {
|
addImports(output: MagicString, imports: {name: string, as: string}[]) {
|
||||||
output.prepend('\n// ADD IMPORTS\n');
|
output.prepend('\n// ADD IMPORTS\n');
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue