refactor: re-enable dynamic queries migration (#32992)
Re-enables the dynamic queries migration, now that we have all of the necessary framework changes in place. Also moves the logic that identifies static queries out of the compiler and into the static queries migration, because that's the only place left that's using it. PR Close #32992
This commit is contained in:
parent
94b9b7e154
commit
7f6429d802
|
@ -86,7 +86,7 @@ export * from './schema/dom_element_schema_registry';
|
||||||
export * from './selector';
|
export * from './selector';
|
||||||
export * from './style_compiler';
|
export * from './style_compiler';
|
||||||
export * from './template_parser/template_parser';
|
export * from './template_parser/template_parser';
|
||||||
export {ViewCompiler, findStaticQueryIds, staticViewQueryIds} from './view_compiler/view_compiler';
|
export {ViewCompiler} from './view_compiler/view_compiler';
|
||||||
export {getParseErrors, isSyntaxError, syntaxError, Version} from './util';
|
export {getParseErrors, isSyntaxError, syntaxError, Version} from './util';
|
||||||
export {SourceMap} from './output/source_map';
|
export {SourceMap} from './output/source_map';
|
||||||
export * from './injectable_compiler_2';
|
export * from './injectable_compiler_2';
|
||||||
|
|
|
@ -1013,57 +1013,6 @@ function callUnwrapValue(nodeIndex: number, bindingIdx: number, expr: o.Expressi
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
interface StaticAndDynamicQueryIds {
|
|
||||||
staticQueryIds: Set<number>;
|
|
||||||
dynamicQueryIds: Set<number>;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
export function findStaticQueryIds(
|
|
||||||
nodes: TemplateAst[], result = new Map<TemplateAst, StaticAndDynamicQueryIds>()):
|
|
||||||
Map<TemplateAst, StaticAndDynamicQueryIds> {
|
|
||||||
nodes.forEach((node) => {
|
|
||||||
const staticQueryIds = new Set<number>();
|
|
||||||
const dynamicQueryIds = new Set<number>();
|
|
||||||
let queryMatches: QueryMatch[] = undefined !;
|
|
||||||
if (node instanceof ElementAst) {
|
|
||||||
findStaticQueryIds(node.children, result);
|
|
||||||
node.children.forEach((child) => {
|
|
||||||
const childData = result.get(child) !;
|
|
||||||
childData.staticQueryIds.forEach(queryId => staticQueryIds.add(queryId));
|
|
||||||
childData.dynamicQueryIds.forEach(queryId => dynamicQueryIds.add(queryId));
|
|
||||||
});
|
|
||||||
queryMatches = node.queryMatches;
|
|
||||||
} else if (node instanceof EmbeddedTemplateAst) {
|
|
||||||
findStaticQueryIds(node.children, result);
|
|
||||||
node.children.forEach((child) => {
|
|
||||||
const childData = result.get(child) !;
|
|
||||||
childData.staticQueryIds.forEach(queryId => dynamicQueryIds.add(queryId));
|
|
||||||
childData.dynamicQueryIds.forEach(queryId => dynamicQueryIds.add(queryId));
|
|
||||||
});
|
|
||||||
queryMatches = node.queryMatches;
|
|
||||||
}
|
|
||||||
if (queryMatches) {
|
|
||||||
queryMatches.forEach((match) => staticQueryIds.add(match.queryId));
|
|
||||||
}
|
|
||||||
dynamicQueryIds.forEach(queryId => staticQueryIds.delete(queryId));
|
|
||||||
result.set(node, {staticQueryIds, dynamicQueryIds});
|
|
||||||
});
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function staticViewQueryIds(nodeStaticQueryIds: Map<TemplateAst, StaticAndDynamicQueryIds>):
|
|
||||||
StaticAndDynamicQueryIds {
|
|
||||||
const staticQueryIds = new Set<number>();
|
|
||||||
const dynamicQueryIds = new Set<number>();
|
|
||||||
Array.from(nodeStaticQueryIds.values()).forEach((entry) => {
|
|
||||||
entry.staticQueryIds.forEach(queryId => staticQueryIds.add(queryId));
|
|
||||||
entry.dynamicQueryIds.forEach(queryId => dynamicQueryIds.add(queryId));
|
|
||||||
});
|
|
||||||
dynamicQueryIds.forEach(queryId => staticQueryIds.delete(queryId));
|
|
||||||
return {staticQueryIds, dynamicQueryIds};
|
|
||||||
}
|
|
||||||
|
|
||||||
function elementEventNameAndTarget(
|
function elementEventNameAndTarget(
|
||||||
eventAst: BoundEventAst, dirAst: DirectiveAst | null): {name: string, target: string | null} {
|
eventAst: BoundEventAst, dirAst: DirectiveAst | null): {name: string, target: string | null} {
|
||||||
if (eventAst.isAnimation) {
|
if (eventAst.isAnimation) {
|
||||||
|
|
|
@ -34,6 +34,11 @@
|
||||||
"version": "9-beta",
|
"version": "9-beta",
|
||||||
"description": "Adds an Angular decorator to undecorated classes that have decorated fields",
|
"description": "Adds an Angular decorator to undecorated classes that have decorated fields",
|
||||||
"factory": "./migrations/undecorated-classes-with-decorated-fields/index"
|
"factory": "./migrations/undecorated-classes-with-decorated-fields/index"
|
||||||
|
},
|
||||||
|
"migration-v9-dynamic-queries": {
|
||||||
|
"version": "9-beta",
|
||||||
|
"description": "Removes the `static` flag from dynamic queries.",
|
||||||
|
"factory": "./migrations/dynamic-queries/index"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
* found in the LICENSE file at https://angular.io/license
|
* found in the LICENSE file at https://angular.io/license
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import {AotCompiler, CompileDirectiveMetadata, CompileMetadataResolver, CompileNgModuleMetadata, CompileStylesheetMetadata, NgAnalyzedModules, StaticSymbol, TemplateAst, findStaticQueryIds, staticViewQueryIds} from '@angular/compiler';
|
import {AotCompiler, CompileDirectiveMetadata, CompileMetadataResolver, CompileNgModuleMetadata, CompileStylesheetMetadata, ElementAst, EmbeddedTemplateAst, NgAnalyzedModules, QueryMatch, StaticSymbol, TemplateAst} from '@angular/compiler';
|
||||||
import {Diagnostic, createProgram, readConfiguration} from '@angular/compiler-cli';
|
import {Diagnostic, createProgram, readConfiguration} from '@angular/compiler-cli';
|
||||||
import {resolve} from 'path';
|
import {resolve} from 'path';
|
||||||
import * as ts from 'typescript';
|
import * as ts from 'typescript';
|
||||||
|
@ -188,3 +188,55 @@ export class QueryTemplateStrategy implements TimingStrategy {
|
||||||
return `${resolve(filePath)}#${className}-${propName}`;
|
return `${resolve(filePath)}#${className}-${propName}`;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
interface StaticAndDynamicQueryIds {
|
||||||
|
staticQueryIds: Set<number>;
|
||||||
|
dynamicQueryIds: Set<number>;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Figures out which queries are static and which ones are dynamic. */
|
||||||
|
function findStaticQueryIds(
|
||||||
|
nodes: TemplateAst[], result = new Map<TemplateAst, StaticAndDynamicQueryIds>()):
|
||||||
|
Map<TemplateAst, StaticAndDynamicQueryIds> {
|
||||||
|
nodes.forEach((node) => {
|
||||||
|
const staticQueryIds = new Set<number>();
|
||||||
|
const dynamicQueryIds = new Set<number>();
|
||||||
|
let queryMatches: QueryMatch[] = undefined !;
|
||||||
|
if (node instanceof ElementAst) {
|
||||||
|
findStaticQueryIds(node.children, result);
|
||||||
|
node.children.forEach((child) => {
|
||||||
|
const childData = result.get(child) !;
|
||||||
|
childData.staticQueryIds.forEach(queryId => staticQueryIds.add(queryId));
|
||||||
|
childData.dynamicQueryIds.forEach(queryId => dynamicQueryIds.add(queryId));
|
||||||
|
});
|
||||||
|
queryMatches = node.queryMatches;
|
||||||
|
} else if (node instanceof EmbeddedTemplateAst) {
|
||||||
|
findStaticQueryIds(node.children, result);
|
||||||
|
node.children.forEach((child) => {
|
||||||
|
const childData = result.get(child) !;
|
||||||
|
childData.staticQueryIds.forEach(queryId => dynamicQueryIds.add(queryId));
|
||||||
|
childData.dynamicQueryIds.forEach(queryId => dynamicQueryIds.add(queryId));
|
||||||
|
});
|
||||||
|
queryMatches = node.queryMatches;
|
||||||
|
}
|
||||||
|
if (queryMatches) {
|
||||||
|
queryMatches.forEach((match) => staticQueryIds.add(match.queryId));
|
||||||
|
}
|
||||||
|
dynamicQueryIds.forEach(queryId => staticQueryIds.delete(queryId));
|
||||||
|
result.set(node, {staticQueryIds, dynamicQueryIds});
|
||||||
|
});
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Splits queries into static and dynamic. */
|
||||||
|
function staticViewQueryIds(nodeStaticQueryIds: Map<TemplateAst, StaticAndDynamicQueryIds>):
|
||||||
|
StaticAndDynamicQueryIds {
|
||||||
|
const staticQueryIds = new Set<number>();
|
||||||
|
const dynamicQueryIds = new Set<number>();
|
||||||
|
Array.from(nodeStaticQueryIds.values()).forEach((entry) => {
|
||||||
|
entry.staticQueryIds.forEach(queryId => staticQueryIds.add(queryId));
|
||||||
|
entry.dynamicQueryIds.forEach(queryId => dynamicQueryIds.add(queryId));
|
||||||
|
});
|
||||||
|
dynamicQueryIds.forEach(queryId => staticQueryIds.delete(queryId));
|
||||||
|
return {staticQueryIds, dynamicQueryIds};
|
||||||
|
}
|
||||||
|
|
|
@ -5,7 +5,6 @@ ts_library(
|
||||||
testonly = True,
|
testonly = True,
|
||||||
srcs = glob(["**/*.ts"]),
|
srcs = glob(["**/*.ts"]),
|
||||||
data = [
|
data = [
|
||||||
"test-migrations.json",
|
|
||||||
"//packages/core/schematics:migrations.json",
|
"//packages/core/schematics:migrations.json",
|
||||||
],
|
],
|
||||||
deps = [
|
deps = [
|
||||||
|
|
|
@ -20,7 +20,7 @@ describe('dynamic queries migration', () => {
|
||||||
let previousWorkingDir: string;
|
let previousWorkingDir: string;
|
||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
runner = new SchematicTestRunner('test', require.resolve('./test-migrations.json'));
|
runner = new SchematicTestRunner('test', require.resolve('../migrations.json'));
|
||||||
host = new TempScopedNodeJsSyncHost();
|
host = new TempScopedNodeJsSyncHost();
|
||||||
tree = new UnitTestTree(new HostTree(host));
|
tree = new UnitTestTree(new HostTree(host));
|
||||||
|
|
||||||
|
|
|
@ -1,9 +0,0 @@
|
||||||
{
|
|
||||||
"schematics": {
|
|
||||||
"migration-v9-dynamic-queries": {
|
|
||||||
"version": "9-beta",
|
|
||||||
"description": "Removes the `static` flag from dynamic queries.",
|
|
||||||
"factory": "../migrations/dynamic-queries/index"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue