fix(compiler): ensure jit external id arguments names are unique
Fixes: #17558, #17378, #8676
This commit is contained in:
parent
e20cfe1bbc
commit
95635c18c7
|
@ -43,7 +43,7 @@ export function jitStatements(sourceUrl: string, statements: o.Statement[]): {[k
|
||||||
return evalExpression(sourceUrl, ctx, converter.getArgs());
|
return evalExpression(sourceUrl, ctx, converter.getArgs());
|
||||||
}
|
}
|
||||||
|
|
||||||
class JitEmitterVisitor extends AbstractJsEmitterVisitor {
|
export class JitEmitterVisitor extends AbstractJsEmitterVisitor {
|
||||||
private _evalArgNames: string[] = [];
|
private _evalArgNames: string[] = [];
|
||||||
private _evalArgValues: any[] = [];
|
private _evalArgValues: any[] = [];
|
||||||
private _evalExportedVars: string[] = [];
|
private _evalExportedVars: string[] = [];
|
||||||
|
@ -69,7 +69,7 @@ class JitEmitterVisitor extends AbstractJsEmitterVisitor {
|
||||||
id = this._evalArgValues.length;
|
id = this._evalArgValues.length;
|
||||||
this._evalArgValues.push(value);
|
this._evalArgValues.push(value);
|
||||||
const name = identifierName({reference: ast.value.runtime}) || 'val';
|
const name = identifierName({reference: ast.value.runtime}) || 'val';
|
||||||
this._evalArgNames.push(`jit_${name}${id}`);
|
this._evalArgNames.push(`jit_${name}_${id}`);
|
||||||
}
|
}
|
||||||
ctx.print(ast, this._evalArgNames[id]);
|
ctx.print(ast, this._evalArgNames[id]);
|
||||||
return null;
|
return null;
|
||||||
|
|
|
@ -0,0 +1,35 @@
|
||||||
|
/**
|
||||||
|
* @license
|
||||||
|
* Copyright Google Inc. All Rights Reserved.
|
||||||
|
*
|
||||||
|
* Use of this source code is governed by an MIT-style license that can be
|
||||||
|
* found in the LICENSE file at https://angular.io/license
|
||||||
|
*/
|
||||||
|
|
||||||
|
import {EmitterVisitorContext} from '@angular/compiler/src/output/abstract_emitter';
|
||||||
|
import * as o from '@angular/compiler/src/output/output_ast';
|
||||||
|
import {JitEmitterVisitor} from '@angular/compiler/src/output/output_jit';
|
||||||
|
|
||||||
|
const anotherModuleUrl = 'somePackage/someOtherPath';
|
||||||
|
|
||||||
|
export function main() {
|
||||||
|
describe('Output JIT', () => {
|
||||||
|
describe('regression', () => {
|
||||||
|
it('should generate unique argument names', () => {
|
||||||
|
const externalIds = new Array(10).fill(1).map(
|
||||||
|
(_, index) =>
|
||||||
|
new o.ExternalReference(anotherModuleUrl, `id_${index}_`, {name: `id_${index}_`}));
|
||||||
|
const externalIds1 = new Array(10).fill(1).map(
|
||||||
|
(_, index) => new o.ExternalReference(
|
||||||
|
anotherModuleUrl, `id_${index}_1`, {name: `id_${index}_1`}));
|
||||||
|
const ctx = EmitterVisitorContext.createRoot();
|
||||||
|
const converter = new JitEmitterVisitor();
|
||||||
|
converter.visitAllStatements(
|
||||||
|
[o.literalArr([...externalIds1, ...externalIds].map(id => o.importExpr(id))).toStmt()],
|
||||||
|
ctx);
|
||||||
|
const args = converter.getArgs();
|
||||||
|
expect(Object.keys(args).length).toBe(20);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
})
|
||||||
|
}
|
Loading…
Reference in New Issue