@angular/compiler-cli 11.1.1 → 11.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/linker/src/file_linker/partial_linkers/partial_linker_selector.d.ts +1 -1
- package/linker/src/file_linker/partial_linkers/partial_linker_selector.js +3 -3
- package/ngcc/src/packages/build_marker.d.ts +1 -1
- package/ngcc/src/packages/build_marker.js +1 -1
- package/package.json +2 -2
- package/src/ngtsc/annotations/src/component.js +6 -3
- package/src/ngtsc/typecheck/api/checker.d.ts +1 -19
- package/src/ngtsc/typecheck/api/checker.js +1 -1
- package/src/ngtsc/typecheck/src/checker.d.ts +9 -20
- package/src/ngtsc/typecheck/src/checker.js +42 -121
- package/src/ngtsc/typecheck/src/context.d.ts +0 -9
- package/src/ngtsc/typecheck/src/context.js +1 -7
- package/src/version.js +1 -1
|
@@ -41,4 +41,4 @@
|
|
|
41
41
|
OptimizeFor[OptimizeFor["WholeProgram"] = 1] = "WholeProgram";
|
|
42
42
|
})(OptimizeFor = exports.OptimizeFor || (exports.OptimizeFor = {}));
|
|
43
43
|
});
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checker.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/typecheck/api/checker.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;IAyKH;;OAEG;IACH,IAAY,WAmBX;IAnBD,WAAY,WAAW;QACrB;;;;;;WAMG;QACH,yDAAU,CAAA;QAEV;;;;;;;WAOG;QACH,6DAAY,CAAA;IACd,CAAC,EAnBW,WAAW,GAAX,mBAAW,KAAX,mBAAW,QAmBtB","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {AST, MethodCall, ParseError, PropertyRead, SafeMethodCall, SafePropertyRead, TmplAstElement, TmplAstNode, TmplAstTemplate} from '@angular/compiler';\nimport {AbsoluteFsPath} from '@angular/compiler-cli/src/ngtsc/file_system';\nimport * as ts from 'typescript';\n\nimport {FullTemplateMapping, TypeCheckableDirectiveMeta} from './api';\nimport {GlobalCompletion} from './completion';\nimport {DirectiveInScope, PipeInScope} from './scope';\nimport {DirectiveSymbol, ElementSymbol, ShimLocation, Symbol, TemplateSymbol} from './symbols';\n\n/**\n * Interface to the Angular Template Type Checker to extract diagnostics and intelligence from the\n * compiler's understanding of component templates.\n *\n * This interface is analogous to TypeScript's own `ts.TypeChecker` API.\n *\n * In general, this interface supports two kinds of operations:\n *  - updating Type Check Blocks (TCB)s that capture the template in the form of TypeScript code\n *  - querying information about available TCBs, including diagnostics\n *\n * Once a TCB is available, information about it can be queried. If no TCB is available to answer a\n * query, depending on the method either `null` will be returned or an error will be thrown.\n */\nexport interface TemplateTypeChecker {\n  /**\n   * Clear all overrides and return the template type-checker to the original input program state.\n   */\n  resetOverrides(): void;\n\n  /**\n   * Retrieve the template in use for the given component.\n   *\n   * If the template has been overridden via `overrideComponentTemplate`, this will retrieve the\n   * overridden template nodes.\n   */\n  getTemplate(component: ts.ClassDeclaration): TmplAstNode[]|null;\n\n  /**\n   * Provide a new template string that will be used in place of the user-defined template when\n   * checking or operating on the given component.\n   *\n   * The compiler will parse this template for diagnostics, and will return any parsing errors if it\n   * is not valid. If the template cannot be parsed correctly, no override will occur.\n   */\n  overrideComponentTemplate(component: ts.ClassDeclaration, template: string):\n      {nodes: TmplAstNode[], errors: ParseError[]|null};\n\n  /**\n   * Get all `ts.Diagnostic`s currently available for the given `ts.SourceFile`.\n   *\n   * This method will fail (throw) if there are components within the `ts.SourceFile` that do not\n   * have TCBs available.\n   *\n   * Generating a template type-checking program is expensive, and in some workflows (e.g. checking\n   * an entire program before emit), it should ideally only be done once. The `optimizeFor` flag\n   * allows the caller to hint to `getDiagnosticsForFile` (which internally will create a template\n   * type-checking program if needed) whether the caller is interested in just the results of the\n   * single file, or whether they plan to query about other files in the program. Based on this\n   * flag, `getDiagnosticsForFile` will determine how much of the user's program to prepare for\n   * checking as part of the template type-checking program it creates.\n   */\n  getDiagnosticsForFile(sf: ts.SourceFile, optimizeFor: OptimizeFor): ts.Diagnostic[];\n\n  /**\n   * Given a `shim` and position within the file, returns information for mapping back to a template\n   * location.\n   */\n  getTemplateMappingAtShimLocation(shimLocation: ShimLocation): FullTemplateMapping|null;\n\n  /**\n   * Get all `ts.Diagnostic`s currently available that pertain to the given component.\n   *\n   * This method always runs in `OptimizeFor.SingleFile` mode.\n   */\n  getDiagnosticsForComponent(component: ts.ClassDeclaration): ts.Diagnostic[];\n\n  /**\n   * Ensures shims for the whole program are generated. This type of operation would be required by\n   * operations like \"find references\" and \"refactor/rename\" because references may appear in type\n   * check blocks generated from templates anywhere in the program.\n   */\n  generateAllTypeCheckBlocks(): void;\n\n  /**\n   * Returns `true` if the given file is in the record of known shims generated by the compiler,\n   * `false` if we cannot find the file in the shim records.\n   */\n  isTrackedTypeCheckFile(filePath: AbsoluteFsPath): boolean;\n\n  /**\n   * Retrieve the top-level node representing the TCB for the given component.\n   *\n   * This can return `null` if there is no TCB available for the component.\n   *\n   * This method always runs in `OptimizeFor.SingleFile` mode.\n   */\n  getTypeCheckBlock(component: ts.ClassDeclaration): ts.Node|null;\n\n  /**\n   * Retrieves a `Symbol` for the node in a component's template.\n   *\n   * This method can return `null` if a valid `Symbol` cannot be determined for the node.\n   *\n   * @see Symbol\n   */\n  getSymbolOfNode(node: TmplAstElement, component: ts.ClassDeclaration): ElementSymbol|null;\n  getSymbolOfNode(node: TmplAstTemplate, component: ts.ClassDeclaration): TemplateSymbol|null;\n  getSymbolOfNode(node: AST|TmplAstNode, component: ts.ClassDeclaration): Symbol|null;\n\n  /**\n   * Get \"global\" `Completion`s in the given context.\n   *\n   * Global completions are completions in the global context, as opposed to completions within an\n   * existing expression. For example, completing inside a new interpolation expression (`{{|}}`) or\n   * inside a new property binding `[input]=\"|\" should retrieve global completions, which will\n   * include completions from the template's context component, as well as any local references or\n   * template variables which are in scope for that expression.\n   */\n  getGlobalCompletions(context: TmplAstTemplate|null, component: ts.ClassDeclaration):\n      GlobalCompletion|null;\n\n\n  /**\n   * For the given expression node, retrieve a `ShimLocation` that can be used to perform\n   * autocompletion at that point in the expression, if such a location exists.\n   */\n  getExpressionCompletionLocation(\n      expr: PropertyRead|SafePropertyRead|MethodCall|SafeMethodCall,\n      component: ts.ClassDeclaration): ShimLocation|null;\n\n  /**\n   * Get basic metadata on the directives which are in scope for the given component.\n   */\n  getDirectivesInScope(component: ts.ClassDeclaration): DirectiveInScope[]|null;\n\n  /**\n   * Get basic metadata on the pipes which are in scope for the given component.\n   */\n  getPipesInScope(component: ts.ClassDeclaration): PipeInScope[]|null;\n\n  /**\n   * Retrieve a `Map` of potential template element tags, to either the `DirectiveInScope` that\n   * declares them (if the tag is from a directive/component), or `null` if the tag originates from\n   * the DOM schema.\n   */\n  getPotentialElementTags(component: ts.ClassDeclaration): Map<string, DirectiveInScope|null>;\n\n  /**\n   * Retrieve any potential DOM bindings for the given element.\n   *\n   * This returns an array of objects which list both the attribute and property names of each\n   * binding, which are usually identical but can vary if the HTML attribute name is for example a\n   * reserved keyword in JS, like the `for` attribute which corresponds to the `htmlFor` property.\n   */\n  getPotentialDomBindings(tagName: string): {attribute: string, property: string}[];\n\n  /**\n   * Retrieve the type checking engine's metadata for the given directive class, if available.\n   */\n  getDirectiveMetadata(dir: ts.ClassDeclaration): TypeCheckableDirectiveMeta|null;\n\n  /**\n   * Reset the `TemplateTypeChecker`'s state for the given class, so that it will be recomputed on\n   * the next request.\n   */\n  invalidateClass(clazz: ts.ClassDeclaration): void;\n}\n\n/**\n * Describes the scope of the caller's interest in template type-checking results.\n */\nexport enum OptimizeFor {\n  /**\n   * Indicates that a consumer of a `TemplateTypeChecker` is only interested in results for a given\n   * file, and wants them as fast as possible.\n   *\n   * Calling `TemplateTypeChecker` methods successively for multiple files while specifying\n   * `OptimizeFor.SingleFile` can result in significant unnecessary overhead overall.\n   */\n  SingleFile,\n\n  /**\n   * Indicates that a consumer of a `TemplateTypeChecker` intends to query for results pertaining to\n   * the entire user program, and so the type-checker should internally optimize for this case.\n   *\n   * Initial calls to retrieve type-checking information may take longer, but repeated calls to\n   * gather information for the whole user program will be significantly faster with this mode of\n   * optimization.\n   */\n  WholeProgram,\n}\n"]}
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checker.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/typecheck/api/checker.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;IAuJH;;OAEG;IACH,IAAY,WAmBX;IAnBD,WAAY,WAAW;QACrB;;;;;;WAMG;QACH,yDAAU,CAAA;QAEV;;;;;;;WAOG;QACH,6DAAY,CAAA;IACd,CAAC,EAnBW,WAAW,GAAX,mBAAW,KAAX,mBAAW,QAmBtB","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {AST, MethodCall, ParseError, PropertyRead, SafeMethodCall, SafePropertyRead, TmplAstElement, TmplAstNode, TmplAstTemplate} from '@angular/compiler';\nimport {AbsoluteFsPath} from '@angular/compiler-cli/src/ngtsc/file_system';\nimport * as ts from 'typescript';\n\nimport {FullTemplateMapping, TypeCheckableDirectiveMeta} from './api';\nimport {GlobalCompletion} from './completion';\nimport {DirectiveInScope, PipeInScope} from './scope';\nimport {DirectiveSymbol, ElementSymbol, ShimLocation, Symbol, TemplateSymbol} from './symbols';\n\n/**\n * Interface to the Angular Template Type Checker to extract diagnostics and intelligence from the\n * compiler's understanding of component templates.\n *\n * This interface is analogous to TypeScript's own `ts.TypeChecker` API.\n *\n * In general, this interface supports two kinds of operations:\n *  - updating Type Check Blocks (TCB)s that capture the template in the form of TypeScript code\n *  - querying information about available TCBs, including diagnostics\n *\n * Once a TCB is available, information about it can be queried. If no TCB is available to answer a\n * query, depending on the method either `null` will be returned or an error will be thrown.\n */\nexport interface TemplateTypeChecker {\n  /**\n   * Retrieve the template in use for the given component.\n   */\n  getTemplate(component: ts.ClassDeclaration): TmplAstNode[]|null;\n\n  /**\n   * Get all `ts.Diagnostic`s currently available for the given `ts.SourceFile`.\n   *\n   * This method will fail (throw) if there are components within the `ts.SourceFile` that do not\n   * have TCBs available.\n   *\n   * Generating a template type-checking program is expensive, and in some workflows (e.g. checking\n   * an entire program before emit), it should ideally only be done once. The `optimizeFor` flag\n   * allows the caller to hint to `getDiagnosticsForFile` (which internally will create a template\n   * type-checking program if needed) whether the caller is interested in just the results of the\n   * single file, or whether they plan to query about other files in the program. Based on this\n   * flag, `getDiagnosticsForFile` will determine how much of the user's program to prepare for\n   * checking as part of the template type-checking program it creates.\n   */\n  getDiagnosticsForFile(sf: ts.SourceFile, optimizeFor: OptimizeFor): ts.Diagnostic[];\n\n  /**\n   * Given a `shim` and position within the file, returns information for mapping back to a template\n   * location.\n   */\n  getTemplateMappingAtShimLocation(shimLocation: ShimLocation): FullTemplateMapping|null;\n\n  /**\n   * Get all `ts.Diagnostic`s currently available that pertain to the given component.\n   *\n   * This method always runs in `OptimizeFor.SingleFile` mode.\n   */\n  getDiagnosticsForComponent(component: ts.ClassDeclaration): ts.Diagnostic[];\n\n  /**\n   * Ensures shims for the whole program are generated. This type of operation would be required by\n   * operations like \"find references\" and \"refactor/rename\" because references may appear in type\n   * check blocks generated from templates anywhere in the program.\n   */\n  generateAllTypeCheckBlocks(): void;\n\n  /**\n   * Returns `true` if the given file is in the record of known shims generated by the compiler,\n   * `false` if we cannot find the file in the shim records.\n   */\n  isTrackedTypeCheckFile(filePath: AbsoluteFsPath): boolean;\n\n  /**\n   * Retrieve the top-level node representing the TCB for the given component.\n   *\n   * This can return `null` if there is no TCB available for the component.\n   *\n   * This method always runs in `OptimizeFor.SingleFile` mode.\n   */\n  getTypeCheckBlock(component: ts.ClassDeclaration): ts.Node|null;\n\n  /**\n   * Retrieves a `Symbol` for the node in a component's template.\n   *\n   * This method can return `null` if a valid `Symbol` cannot be determined for the node.\n   *\n   * @see Symbol\n   */\n  getSymbolOfNode(node: TmplAstElement, component: ts.ClassDeclaration): ElementSymbol|null;\n  getSymbolOfNode(node: TmplAstTemplate, component: ts.ClassDeclaration): TemplateSymbol|null;\n  getSymbolOfNode(node: AST|TmplAstNode, component: ts.ClassDeclaration): Symbol|null;\n\n  /**\n   * Get \"global\" `Completion`s in the given context.\n   *\n   * Global completions are completions in the global context, as opposed to completions within an\n   * existing expression. For example, completing inside a new interpolation expression (`{{|}}`) or\n   * inside a new property binding `[input]=\"|\" should retrieve global completions, which will\n   * include completions from the template's context component, as well as any local references or\n   * template variables which are in scope for that expression.\n   */\n  getGlobalCompletions(context: TmplAstTemplate|null, component: ts.ClassDeclaration):\n      GlobalCompletion|null;\n\n\n  /**\n   * For the given expression node, retrieve a `ShimLocation` that can be used to perform\n   * autocompletion at that point in the expression, if such a location exists.\n   */\n  getExpressionCompletionLocation(\n      expr: PropertyRead|SafePropertyRead|MethodCall|SafeMethodCall,\n      component: ts.ClassDeclaration): ShimLocation|null;\n\n  /**\n   * Get basic metadata on the directives which are in scope for the given component.\n   */\n  getDirectivesInScope(component: ts.ClassDeclaration): DirectiveInScope[]|null;\n\n  /**\n   * Get basic metadata on the pipes which are in scope for the given component.\n   */\n  getPipesInScope(component: ts.ClassDeclaration): PipeInScope[]|null;\n\n  /**\n   * Retrieve a `Map` of potential template element tags, to either the `DirectiveInScope` that\n   * declares them (if the tag is from a directive/component), or `null` if the tag originates from\n   * the DOM schema.\n   */\n  getPotentialElementTags(component: ts.ClassDeclaration): Map<string, DirectiveInScope|null>;\n\n  /**\n   * Retrieve any potential DOM bindings for the given element.\n   *\n   * This returns an array of objects which list both the attribute and property names of each\n   * binding, which are usually identical but can vary if the HTML attribute name is for example a\n   * reserved keyword in JS, like the `for` attribute which corresponds to the `htmlFor` property.\n   */\n  getPotentialDomBindings(tagName: string): {attribute: string, property: string}[];\n\n  /**\n   * Retrieve the type checking engine's metadata for the given directive class, if available.\n   */\n  getDirectiveMetadata(dir: ts.ClassDeclaration): TypeCheckableDirectiveMeta|null;\n\n  /**\n   * Reset the `TemplateTypeChecker`'s state for the given class, so that it will be recomputed on\n   * the next request.\n   */\n  invalidateClass(clazz: ts.ClassDeclaration): void;\n}\n\n/**\n * Describes the scope of the caller's interest in template type-checking results.\n */\nexport enum OptimizeFor {\n  /**\n   * Indicates that a consumer of a `TemplateTypeChecker` is only interested in results for a given\n   * file, and wants them as fast as possible.\n   *\n   * Calling `TemplateTypeChecker` methods successively for multiple files while specifying\n   * `OptimizeFor.SingleFile` can result in significant unnecessary overhead overall.\n   */\n  SingleFile,\n\n  /**\n   * Indicates that a consumer of a `TemplateTypeChecker` intends to query for results pertaining to\n   * the entire user program, and so the type-checker should internally optimize for this case.\n   *\n   * Initial calls to retrieve type-checking information may take longer, but repeated calls to\n   * gather information for the whole user program will be significantly faster with this mode of\n   * optimization.\n   */\n  WholeProgram,\n}\n"]}
|
|
@@ -6,15 +6,15 @@
|
|
|
6
6
|
* found in the LICENSE file at https://angular.io/license
|
|
7
7
|
*/
|
|
8
8
|
/// <amd-module name="@angular/compiler-cli/src/ngtsc/typecheck/src/checker" />
|
|
9
|
-
import { MethodCall,
|
|
9
|
+
import { MethodCall, PropertyRead, SafeMethodCall, SafePropertyRead, TmplAstElement, TmplAstNode, TmplAstTemplate } from '@angular/compiler';
|
|
10
10
|
import * as ts from 'typescript';
|
|
11
11
|
import { AbsoluteFsPath } from '../../file_system';
|
|
12
12
|
import { ReferenceEmitter } from '../../imports';
|
|
13
13
|
import { IncrementalBuild } from '../../incremental/api';
|
|
14
14
|
import { ReflectionHost } from '../../reflection';
|
|
15
15
|
import { ComponentScopeReader, TypeCheckScopeRegistry } from '../../scope';
|
|
16
|
-
import { DirectiveInScope, ElementSymbol, FullTemplateMapping, GlobalCompletion, OptimizeFor, PipeInScope, ProgramTypeCheckAdapter, ShimLocation,
|
|
17
|
-
import { ShimTypeCheckingData
|
|
16
|
+
import { DirectiveInScope, ElementSymbol, FullTemplateMapping, GlobalCompletion, OptimizeFor, PipeInScope, ProgramTypeCheckAdapter, ShimLocation, TemplateSymbol, TemplateTypeChecker, TypeCheckableDirectiveMeta, TypeCheckingConfig, TypeCheckingProgramStrategy } from '../api';
|
|
17
|
+
import { ShimTypeCheckingData } from './context';
|
|
18
18
|
import { TemplateSourceManager } from './source';
|
|
19
19
|
/**
|
|
20
20
|
* Primary template type-checking engine, which performs type-checking using a
|
|
@@ -52,31 +52,24 @@ export declare class TemplateTypeCheckerImpl implements TemplateTypeChecker {
|
|
|
52
52
|
/**
|
|
53
53
|
* Stores directives and pipes that are in scope for each component.
|
|
54
54
|
*
|
|
55
|
-
* Unlike other caches, the scope of a component is not affected by its template
|
|
56
|
-
*
|
|
57
|
-
*
|
|
58
|
-
* replaced.
|
|
55
|
+
* Unlike other caches, the scope of a component is not affected by its template. It will be
|
|
56
|
+
* destroyed when the `ts.Program` changes and the `TemplateTypeCheckerImpl` as a whole is
|
|
57
|
+
* destroyed and replaced.
|
|
59
58
|
*/
|
|
60
59
|
private scopeCache;
|
|
61
60
|
/**
|
|
62
61
|
* Stores potential element tags for each component (a union of DOM tags as well as directive
|
|
63
62
|
* tags).
|
|
64
63
|
*
|
|
65
|
-
* Unlike other caches, the scope of a component is not affected by its template
|
|
66
|
-
*
|
|
67
|
-
*
|
|
68
|
-
* replaced.
|
|
64
|
+
* Unlike other caches, the scope of a component is not affected by its template. It will be
|
|
65
|
+
* destroyed when the `ts.Program` changes and the `TemplateTypeCheckerImpl` as a whole is
|
|
66
|
+
* destroyed and replaced.
|
|
69
67
|
*/
|
|
70
68
|
private elementTagCache;
|
|
71
69
|
private isComplete;
|
|
72
70
|
constructor(originalProgram: ts.Program, typeCheckingStrategy: TypeCheckingProgramStrategy, typeCheckAdapter: ProgramTypeCheckAdapter, config: TypeCheckingConfig, refEmitter: ReferenceEmitter, reflector: ReflectionHost, compilerHost: Pick<ts.CompilerHost, 'getCanonicalFileName'>, priorBuild: IncrementalBuild<unknown, FileTypeCheckingData>, componentScopeReader: ComponentScopeReader, typeCheckScopeRegistry: TypeCheckScopeRegistry);
|
|
73
|
-
resetOverrides(): void;
|
|
74
71
|
getTemplate(component: ts.ClassDeclaration): TmplAstNode[] | null;
|
|
75
72
|
private getLatestComponentState;
|
|
76
|
-
overrideComponentTemplate(component: ts.ClassDeclaration, template: string): {
|
|
77
|
-
nodes: TmplAstNode[];
|
|
78
|
-
errors: ParseError[] | null;
|
|
79
|
-
};
|
|
80
73
|
isTrackedTypeCheckFile(filePath: AbsoluteFsPath): boolean;
|
|
81
74
|
private getFileAndShimRecordsForPath;
|
|
82
75
|
getTemplateMappingAtShimLocation({ shimPath, positionInShimFile }: ShimLocation): FullTemplateMapping | null;
|
|
@@ -134,10 +127,6 @@ export interface FileTypeCheckingData {
|
|
|
134
127
|
* original template.
|
|
135
128
|
*/
|
|
136
129
|
sourceManager: TemplateSourceManager;
|
|
137
|
-
/**
|
|
138
|
-
* Map of template overrides applied to any components in this input file.
|
|
139
|
-
*/
|
|
140
|
-
templateOverrides: Map<TemplateId, TemplateOverride> | null;
|
|
141
130
|
/**
|
|
142
131
|
* Data for each shim generated from this input file.
|
|
143
132
|
*
|