39 lines
1.6 KiB
TypeScript
39 lines
1.6 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright Google LLC 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 * as ts from 'typescript';
|
|
|
|
import {getImportOfIdentifier} from '../../utils/typescript/imports';
|
|
|
|
/** Finds all the Identifier nodes in a file that refer to `Native` view encapsulation. */
|
|
export function findNativeEncapsulationNodes(
|
|
typeChecker: ts.TypeChecker, sourceFile: ts.SourceFile): Set<ts.Identifier> {
|
|
const results = new Set<ts.Identifier>();
|
|
|
|
sourceFile.forEachChild(function walkNode(node: ts.Node) {
|
|
// Note that we look directly for nodes in the form of `<something>.Native`, rather than going
|
|
// for `Component` class decorators, because it's much simpler and it allows us to handle cases
|
|
// where `ViewEncapsulation.Native` might be used in a different context (e.g. a variable).
|
|
// Using the encapsulation outside of a decorator is an edge case, but we do have public APIs
|
|
// where it can be passed in (see the `defaultViewEncapsulation` property on the
|
|
// `COMPILER_OPTIONS` provider).
|
|
if (ts.isPropertyAccessExpression(node) && ts.isIdentifier(node.name) &&
|
|
node.name.text === 'Native' && ts.isIdentifier(node.expression)) {
|
|
const expressionImport = getImportOfIdentifier(typeChecker, node.expression);
|
|
if (expressionImport && expressionImport.name === 'ViewEncapsulation' &&
|
|
expressionImport.importModule === '@angular/core') {
|
|
results.add(node.name);
|
|
}
|
|
} else {
|
|
node.forEachChild(walkNode);
|
|
}
|
|
});
|
|
|
|
return results;
|
|
}
|