@angular/compiler-cli 11.2.3 → 11.2.7
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 +4 -4
- package/ngcc/src/analysis/decoration_analyzer.d.ts +2 -1
- package/ngcc/src/analysis/decoration_analyzer.js +6 -4
- package/ngcc/src/analysis/ngcc_trait_compiler.d.ts +3 -2
- package/ngcc/src/analysis/ngcc_trait_compiler.js +3 -2
- package/ngcc/src/analysis/util.js +1 -3
- package/ngcc/src/command_line_options.js +10 -2
- package/ngcc/src/entry_point_finder/utils.js +85 -24
- package/ngcc/src/execution/analyze_entry_points.d.ts +1 -1
- package/ngcc/src/execution/analyze_entry_points.js +18 -9
- package/ngcc/src/execution/create_compile_function.js +5 -5
- package/ngcc/src/execution/tasks/api.d.ts +23 -2
- package/ngcc/src/execution/tasks/api.js +22 -2
- package/ngcc/src/execution/tasks/completion.js +13 -9
- package/ngcc/src/execution/tasks/utils.js +6 -3
- package/ngcc/src/main.js +3 -3
- package/ngcc/src/ngcc_options.d.ts +12 -1
- package/ngcc/src/ngcc_options.js +8 -2
- package/ngcc/src/packages/build_marker.d.ts +1 -1
- package/ngcc/src/packages/build_marker.js +1 -1
- package/ngcc/src/packages/entry_point_bundle.d.ts +4 -2
- package/ngcc/src/packages/entry_point_bundle.js +9 -6
- package/ngcc/src/packages/transformer.js +10 -5
- package/package.json +2 -2
- package/src/ngtsc/annotations/src/component.d.ts +18 -4
- package/src/ngtsc/annotations/src/component.js +137 -23
- package/src/ngtsc/annotations/src/directive.d.ts +22 -3
- package/src/ngtsc/annotations/src/directive.js +122 -5
- package/src/ngtsc/annotations/src/injectable.d.ts +2 -1
- package/src/ngtsc/annotations/src/injectable.js +4 -1
- package/src/ngtsc/annotations/src/ng_module.d.ts +16 -5
- package/src/ngtsc/annotations/src/ng_module.js +121 -39
- package/src/ngtsc/annotations/src/pipe.d.ts +12 -1
- package/src/ngtsc/annotations/src/pipe.js +29 -3
- package/src/ngtsc/annotations/src/util.js +7 -7
- package/src/ngtsc/core/src/compiler.d.ts +0 -5
- package/src/ngtsc/core/src/compiler.js +19 -111
- package/src/ngtsc/core/src/host.d.ts +1 -0
- package/src/ngtsc/core/src/host.js +16 -1
- package/src/ngtsc/cycles/src/imports.d.ts +2 -3
- package/src/ngtsc/cycles/src/imports.js +28 -14
- package/src/ngtsc/diagnostics/src/error_code.d.ts +7 -1
- package/src/ngtsc/diagnostics/src/error_code.js +10 -4
- package/src/ngtsc/imports/index.d.ts +1 -1
- package/src/ngtsc/imports/index.js +1 -1
- package/src/ngtsc/imports/src/alias.d.ts +2 -2
- package/src/ngtsc/imports/src/alias.js +3 -3
- package/src/ngtsc/imports/src/emitter.d.ts +51 -10
- package/src/ngtsc/imports/src/emitter.js +26 -19
- package/src/ngtsc/incremental/api.d.ts +0 -14
- package/src/ngtsc/incremental/api.js +1 -1
- package/src/ngtsc/incremental/semantic_graph/index.d.ts +12 -0
- package/src/ngtsc/incremental/semantic_graph/index.js +34 -0
- package/src/ngtsc/incremental/semantic_graph/src/api.d.ts +98 -0
- package/src/ngtsc/incremental/semantic_graph/src/api.js +51 -0
- package/src/ngtsc/incremental/semantic_graph/src/graph.d.ts +105 -0
- package/src/ngtsc/incremental/semantic_graph/src/graph.js +302 -0
- package/src/ngtsc/incremental/semantic_graph/src/type_parameters.d.ts +30 -0
- package/src/ngtsc/incremental/semantic_graph/src/type_parameters.js +55 -0
- package/src/ngtsc/incremental/semantic_graph/src/util.d.ts +29 -0
- package/src/ngtsc/incremental/semantic_graph/src/util.js +111 -0
- package/src/ngtsc/incremental/src/dependency_tracking.d.ts +0 -3
- package/src/ngtsc/incremental/src/dependency_tracking.js +9 -50
- package/src/ngtsc/incremental/src/state.d.ts +2 -1
- package/src/ngtsc/incremental/src/state.js +61 -16
- package/src/ngtsc/modulewithproviders/src/scanner.js +2 -2
- package/src/ngtsc/scope/src/dependency.js +1 -2
- package/src/ngtsc/scope/src/local.d.ts +0 -13
- package/src/ngtsc/scope/src/local.js +2 -16
- package/src/ngtsc/transform/src/api.d.ts +16 -2
- package/src/ngtsc/transform/src/api.js +1 -1
- package/src/ngtsc/transform/src/compilation.d.ts +7 -4
- package/src/ngtsc/transform/src/compilation.js +25 -8
- package/src/ngtsc/transform/src/trait.d.ts +14 -11
- package/src/ngtsc/transform/src/trait.js +7 -3
- package/src/ngtsc/typecheck/api/api.d.ts +27 -0
- package/src/ngtsc/typecheck/api/api.js +1 -1
- package/src/ngtsc/typecheck/src/context.js +25 -28
- package/src/ngtsc/typecheck/src/environment.d.ts +1 -1
- package/src/ngtsc/typecheck/src/environment.js +3 -3
- package/src/ngtsc/typecheck/src/oob.d.ts +6 -0
- package/src/ngtsc/typecheck/src/oob.js +36 -1
- package/src/ngtsc/typecheck/src/type_check_block.js +107 -23
- package/src/ngtsc/typecheck/src/type_check_file.d.ts +1 -1
- package/src/ngtsc/typecheck/src/type_check_file.js +3 -3
- package/src/perform_compile.d.ts +1 -2
- package/src/perform_compile.js +58 -47
- package/src/transformers/node_emitter.js +1 -2
- package/src/version.js +1 -1
|
@@ -9,6 +9,7 @@
|
|
|
9
9
|
import { ConstantPool } from '@angular/compiler';
|
|
10
10
|
import * as ts from 'typescript';
|
|
11
11
|
import { IncrementalBuild } from '../../incremental/api';
|
|
12
|
+
import { SemanticDepGraphUpdater, SemanticSymbol } from '../../incremental/semantic_graph';
|
|
12
13
|
import { IndexingContext } from '../../indexer';
|
|
13
14
|
import { PerfRecorder } from '../../perf';
|
|
14
15
|
import { ClassDeclaration, DeclarationNode, Decorator, ReflectionHost } from '../../reflection';
|
|
@@ -27,7 +28,7 @@ export interface ClassRecord {
|
|
|
27
28
|
/**
|
|
28
29
|
* All traits which matched on the class.
|
|
29
30
|
*/
|
|
30
|
-
traits: Trait<unknown, unknown, unknown>[];
|
|
31
|
+
traits: Trait<unknown, unknown, SemanticSymbol | null, unknown>[];
|
|
31
32
|
/**
|
|
32
33
|
* Meta-diagnostics about the class, which are usually related to whether certain combinations of
|
|
33
34
|
* Angular decorators are not permitted.
|
|
@@ -61,6 +62,7 @@ export declare class TraitCompiler implements ProgramTypeCheckAdapter {
|
|
|
61
62
|
private compileNonExportedClasses;
|
|
62
63
|
private compilationMode;
|
|
63
64
|
private dtsTransforms;
|
|
65
|
+
private semanticDepGraphUpdater;
|
|
64
66
|
/**
|
|
65
67
|
* Maps class declarations to their `ClassRecord`, which tracks the Ivy traits being applied to
|
|
66
68
|
* those classes.
|
|
@@ -73,7 +75,7 @@ export declare class TraitCompiler implements ProgramTypeCheckAdapter {
|
|
|
73
75
|
protected fileToClasses: Map<ts.SourceFile, Set<ClassDeclaration<DeclarationNode>>>;
|
|
74
76
|
private reexportMap;
|
|
75
77
|
private handlersByName;
|
|
76
|
-
constructor(handlers: DecoratorHandler<unknown, unknown, unknown>[], reflector: ReflectionHost, perf: PerfRecorder, incrementalBuild: IncrementalBuild<ClassRecord, unknown>, compileNonExportedClasses: boolean, compilationMode: CompilationMode, dtsTransforms: DtsTransformRegistry);
|
|
78
|
+
constructor(handlers: DecoratorHandler<unknown, unknown, SemanticSymbol | null, unknown>[], reflector: ReflectionHost, perf: PerfRecorder, incrementalBuild: IncrementalBuild<ClassRecord, unknown>, compileNonExportedClasses: boolean, compilationMode: CompilationMode, dtsTransforms: DtsTransformRegistry, semanticDepGraphUpdater: SemanticDepGraphUpdater | null);
|
|
77
79
|
analyzeSync(sf: ts.SourceFile): void;
|
|
78
80
|
analyzeAsync(sf: ts.SourceFile): Promise<void> | undefined;
|
|
79
81
|
private analyze;
|
|
@@ -89,9 +91,10 @@ export declare class TraitCompiler implements ProgramTypeCheckAdapter {
|
|
|
89
91
|
*/
|
|
90
92
|
private adopt;
|
|
91
93
|
private scanClassForTraits;
|
|
92
|
-
protected detectTraits(clazz: ClassDeclaration, decorators: Decorator[] | null): PendingTrait<unknown, unknown, unknown>[] | null;
|
|
94
|
+
protected detectTraits(clazz: ClassDeclaration, decorators: Decorator[] | null): PendingTrait<unknown, unknown, SemanticSymbol | null, unknown>[] | null;
|
|
95
|
+
private makeSymbolForTrait;
|
|
93
96
|
protected analyzeClass(clazz: ClassDeclaration, preanalyzeQueue: Promise<void>[] | null): void;
|
|
94
|
-
protected analyzeTrait(clazz: ClassDeclaration, trait: Trait<unknown, unknown, unknown>, flags?: HandlerFlags): void;
|
|
97
|
+
protected analyzeTrait(clazz: ClassDeclaration, trait: Trait<unknown, unknown, SemanticSymbol | null, unknown>, flags?: HandlerFlags): void;
|
|
95
98
|
resolve(): void;
|
|
96
99
|
/**
|
|
97
100
|
* Generate type-checking code into the `TypeCheckContext` for any components within the given
|
|
@@ -35,7 +35,7 @@
|
|
|
35
35
|
* class (like adding fields or type declarations).
|
|
36
36
|
*/
|
|
37
37
|
var TraitCompiler = /** @class */ (function () {
|
|
38
|
-
function TraitCompiler(handlers, reflector, perf, incrementalBuild, compileNonExportedClasses, compilationMode, dtsTransforms) {
|
|
38
|
+
function TraitCompiler(handlers, reflector, perf, incrementalBuild, compileNonExportedClasses, compilationMode, dtsTransforms, semanticDepGraphUpdater) {
|
|
39
39
|
var e_1, _a;
|
|
40
40
|
this.handlers = handlers;
|
|
41
41
|
this.reflector = reflector;
|
|
@@ -44,6 +44,7 @@
|
|
|
44
44
|
this.compileNonExportedClasses = compileNonExportedClasses;
|
|
45
45
|
this.compilationMode = compilationMode;
|
|
46
46
|
this.dtsTransforms = dtsTransforms;
|
|
47
|
+
this.semanticDepGraphUpdater = semanticDepGraphUpdater;
|
|
47
48
|
/**
|
|
48
49
|
* Maps class declarations to their `ClassRecord`, which tracks the Ivy traits being applied to
|
|
49
50
|
* those classes.
|
|
@@ -170,7 +171,8 @@
|
|
|
170
171
|
var handler = this.handlersByName.get(priorTrait.handler.name);
|
|
171
172
|
var trait = trait_1.Trait.pending(handler, priorTrait.detected);
|
|
172
173
|
if (priorTrait.state === trait_1.TraitState.Analyzed || priorTrait.state === trait_1.TraitState.Resolved) {
|
|
173
|
-
|
|
174
|
+
var symbol = this.makeSymbolForTrait(handler, record.node, priorTrait.analysis);
|
|
175
|
+
trait = trait.toAnalyzed(priorTrait.analysis, priorTrait.analysisDiagnostics, symbol);
|
|
174
176
|
if (trait.analysis !== null && trait.handler.register !== undefined) {
|
|
175
177
|
trait.handler.register(record.node, trait.analysis);
|
|
176
178
|
}
|
|
@@ -284,6 +286,20 @@
|
|
|
284
286
|
}
|
|
285
287
|
return foundTraits.length > 0 ? foundTraits : null;
|
|
286
288
|
};
|
|
289
|
+
TraitCompiler.prototype.makeSymbolForTrait = function (handler, decl, analysis) {
|
|
290
|
+
if (analysis === null) {
|
|
291
|
+
return null;
|
|
292
|
+
}
|
|
293
|
+
var symbol = handler.symbol(decl, analysis);
|
|
294
|
+
if (symbol !== null && this.semanticDepGraphUpdater !== null) {
|
|
295
|
+
var isPrimary = handler.precedence === api_1.HandlerPrecedence.PRIMARY;
|
|
296
|
+
if (!isPrimary) {
|
|
297
|
+
throw new Error("AssertionError: " + handler.name + " returned a symbol but is not a primary handler.");
|
|
298
|
+
}
|
|
299
|
+
this.semanticDepGraphUpdater.registerSymbol(symbol);
|
|
300
|
+
}
|
|
301
|
+
return symbol;
|
|
302
|
+
};
|
|
287
303
|
TraitCompiler.prototype.analyzeClass = function (clazz, preanalyzeQueue) {
|
|
288
304
|
var e_6, _a;
|
|
289
305
|
var _this = this;
|
|
@@ -303,7 +319,7 @@
|
|
|
303
319
|
}
|
|
304
320
|
catch (err) {
|
|
305
321
|
if (err instanceof diagnostics_1.FatalDiagnosticError) {
|
|
306
|
-
trait.toAnalyzed(null, [err.toDiagnostic()]);
|
|
322
|
+
trait.toAnalyzed(null, [err.toDiagnostic()], null);
|
|
307
323
|
return { value: void 0 };
|
|
308
324
|
}
|
|
309
325
|
else {
|
|
@@ -335,7 +351,7 @@
|
|
|
335
351
|
}
|
|
336
352
|
};
|
|
337
353
|
TraitCompiler.prototype.analyzeTrait = function (clazz, trait, flags) {
|
|
338
|
-
var _a, _b;
|
|
354
|
+
var _a, _b, _c;
|
|
339
355
|
if (trait.state !== trait_1.TraitState.Pending) {
|
|
340
356
|
throw new Error("Attempt to analyze trait of " + clazz.name.text + " in state " + trait_1.TraitState[trait.state] + " (expected DETECTED)");
|
|
341
357
|
}
|
|
@@ -346,17 +362,18 @@
|
|
|
346
362
|
}
|
|
347
363
|
catch (err) {
|
|
348
364
|
if (err instanceof diagnostics_1.FatalDiagnosticError) {
|
|
349
|
-
trait.toAnalyzed(null, [err.toDiagnostic()]);
|
|
365
|
+
trait.toAnalyzed(null, [err.toDiagnostic()], null);
|
|
350
366
|
return;
|
|
351
367
|
}
|
|
352
368
|
else {
|
|
353
369
|
throw err;
|
|
354
370
|
}
|
|
355
371
|
}
|
|
372
|
+
var symbol = this.makeSymbolForTrait(trait.handler, clazz, (_a = result.analysis) !== null && _a !== void 0 ? _a : null);
|
|
356
373
|
if (result.analysis !== undefined && trait.handler.register !== undefined) {
|
|
357
374
|
trait.handler.register(clazz, result.analysis);
|
|
358
375
|
}
|
|
359
|
-
trait = trait.toAnalyzed((
|
|
376
|
+
trait = trait.toAnalyzed((_b = result.analysis) !== null && _b !== void 0 ? _b : null, (_c = result.diagnostics) !== null && _c !== void 0 ? _c : null, symbol);
|
|
360
377
|
};
|
|
361
378
|
TraitCompiler.prototype.resolve = function () {
|
|
362
379
|
var e_7, _a, e_8, _b, e_9, _c;
|
|
@@ -389,7 +406,7 @@
|
|
|
389
406
|
}
|
|
390
407
|
var result = void 0;
|
|
391
408
|
try {
|
|
392
|
-
result = handler.resolve(clazz, trait.analysis);
|
|
409
|
+
result = handler.resolve(clazz, trait.analysis, trait.symbol);
|
|
393
410
|
}
|
|
394
411
|
catch (err) {
|
|
395
412
|
if (err instanceof diagnostics_1.FatalDiagnosticError) {
|
|
@@ -704,4 +721,4 @@
|
|
|
704
721
|
}());
|
|
705
722
|
exports.TraitCompiler = TraitCompiler;
|
|
706
723
|
});
|
|
707
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compilation.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/transform/src/compilation.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;;IAGH,+BAAiC;IAEjC,2EAAkE;IAMlE,kFAAoE;IAEpE,yEAAuI;IAEvI,6EAAwD;IAqCxD;;;;;;;;;;OAUG;IACH;QAiBE,uBACY,QAAuD,EACvD,SAAyB,EAAU,IAAkB,EACrD,gBAAwD,EACxD,yBAAkC,EAAU,eAAgC,EAC5E,aAAmC;;YAJnC,aAAQ,GAAR,QAAQ,CAA+C;YACvD,cAAS,GAAT,SAAS,CAAgB;YAAU,SAAI,GAAJ,IAAI,CAAc;YACrD,qBAAgB,GAAhB,gBAAgB,CAAwC;YACxD,8BAAyB,GAAzB,yBAAyB,CAAS;YAAU,oBAAe,GAAf,eAAe,CAAiB;YAC5E,kBAAa,GAAb,aAAa,CAAsB;YArB/C;;;eAGG;YACK,YAAO,GAAG,IAAI,GAAG,EAAiC,CAAC;YAE3D;;;eAGG;YACO,kBAAa,GAAG,IAAI,GAAG,EAAwC,CAAC;YAElE,gBAAW,GAAG,IAAI,GAAG,EAAyC,CAAC;YAE/D,mBAAc,GAAG,IAAI,GAAG,EAAuD,CAAC;;gBAQtF,KAAsB,IAAA,aAAA,iBAAA,QAAQ,CAAA,kCAAA,wDAAE;oBAA3B,IAAM,OAAO,qBAAA;oBAChB,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;iBAChD;;;;;;;;;QACH,CAAC;QAED,mCAAW,GAAX,UAAY,EAAiB;YAC3B,IAAI,CAAC,OAAO,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;QAC1B,CAAC;QAED,oCAAY,GAAZ,UAAa,EAAiB;YAC5B,OAAO,IAAI,CAAC,OAAO,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;QAChC,CAAC;QAIO,+BAAO,GAAf,UAAgB,EAAiB,EAAE,UAAmB;;YAAtD,iBAkCC;YAjCC,0CAA0C;YAC1C,IAAI,EAAE,CAAC,iBAAiB,EAAE;gBACxB,OAAO,SAAS,CAAC;aAClB;YAED,+FAA+F;YAC/F,kDAAkD;YAClD,IAAM,QAAQ,GAAoB,EAAE,CAAC;YAErC,IAAM,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;YACzD,IAAI,SAAS,KAAK,IAAI,EAAE;;oBACtB,KAA0B,IAAA,cAAA,iBAAA,SAAS,CAAA,oCAAA,2DAAE;wBAAhC,IAAM,WAAW,sBAAA;wBACpB,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;qBACzB;;;;;;;;;gBAED,2EAA2E;gBAC3E,OAAO;aACR;YAED,IAAM,KAAK,GAAG,UAAC,IAAa;gBAC1B,IAAI,KAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;oBAChC,KAAI,CAAC,YAAY,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;iBACvD;gBACD,EAAE,CAAC,YAAY,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;YAC/B,CAAC,CAAC;YAEF,KAAK,CAAC,EAAE,CAAC,CAAC;YAEV,IAAI,UAAU,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;gBACrC,OAAO,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,cAAM,OAAA,SAAiB,EAAjB,CAAiB,CAAC,CAAC;aAC5D;iBAAM;gBACL,OAAO,SAAS,CAAC;aAClB;QACH,CAAC;QAED,iCAAS,GAAT,UAAU,KAAuB;YAC/B,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;gBAC3B,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAE,CAAC;aACjC;iBAAM;gBACL,OAAO,IAAI,CAAC;aACb;QACH,CAAC;QAED,kCAAU,GAAV,UAAW,EAAiB;;YAC1B,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;gBAC/B,OAAO,IAAI,CAAC;aACb;YACD,IAAM,OAAO,GAAkB,EAAE,CAAC;;gBAClC,KAAoB,IAAA,KAAA,iBAAA,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAE,CAAA,gBAAA,4BAAE;oBAA5C,IAAM,KAAK,WAAA;oBACd,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAE,CAAC,CAAC;iBACxC;;;;;;;;;YACD,OAAO,OAAO,CAAC;QACjB,CAAC;QAED;;;;;;;WAOG;QACK,6BAAK,GAAb,UAAc,WAAwB;;YACpC,IAAM,MAAM,GAAgB;gBAC1B,iBAAiB,EAAE,WAAW,CAAC,iBAAiB;gBAChD,eAAe,EAAE,WAAW,CAAC,eAAe;gBAC5C,eAAe,EAAE,WAAW,CAAC,eAAe;gBAC5C,IAAI,EAAE,WAAW,CAAC,IAAI;gBACtB,MAAM,EAAE,EAAE;aACX,CAAC;;gBAEF,KAAyB,IAAA,KAAA,iBAAA,WAAW,CAAC,MAAM,CAAA,gBAAA,4BAAE;oBAAxC,IAAM,UAAU,WAAA;oBACnB,IAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,CAAE,CAAC;oBAClE,IAAI,KAAK,GAAqC,aAAK,CAAC,OAAO,CAAC,OAAO,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;oBAE1F,IAAI,UAAU,CAAC,KAAK,KAAK,kBAAU,CAAC,QAAQ,IAAI,UAAU,CAAC,KAAK,KAAK,kBAAU,CAAC,QAAQ,EAAE;wBACxF,KAAK,GAAG,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,QAAQ,EAAE,UAAU,CAAC,mBAAmB,CAAC,CAAC;wBAC9E,IAAI,KAAK,CAAC,QAAQ,KAAK,IAAI,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,KAAK,SAAS,EAAE;4BACnE,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;yBACrD;qBACF;yBAAM,IAAI,UAAU,CAAC,KAAK,KAAK,kBAAU,CAAC,OAAO,EAAE;wBAClD,KAAK,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC;qBAC3B;oBAED,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;iBAC3B;;;;;;;;;YAED,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;YACtC,IAAM,EAAE,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YACvC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;gBAC/B,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,GAAG,EAAoB,CAAC,CAAC;aACzD;YACD,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAE,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC/C,CAAC;QAEO,0CAAkB,GAA1B,UAA2B,KAAuB;YAEhD,IAAI,CAAC,IAAI,CAAC,yBAAyB,IAAI,CAAC,uBAAU,CAAC,KAAK,CAAC,EAAE;gBACzD,OAAO,IAAI,CAAC;aACb;YAED,IAAM,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,0BAA0B,CAAC,KAAK,CAAC,CAAC;YAEpE,OAAO,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;QAC9C,CAAC;QAES,oCAAY,GAAtB,UAAuB,KAAuB,EAAE,UAA4B;;YAE1E,IAAI,MAAM,GAAqB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;YACrD,IAAI,WAAW,GAA8C,EAAE,CAAC;;gBAEhE,KAAsB,IAAA,KAAA,iBAAA,IAAI,CAAC,QAAQ,CAAA,gBAAA,4BAAE;oBAAhC,IAAM,OAAO,WAAA;oBAChB,IAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;oBACjD,IAAI,MAAM,KAAK,SAAS,EAAE;wBACxB,SAAS;qBACV;oBAED,IAAM,gBAAgB,GAAG,OAAO,CAAC,UAAU,KAAK,uBAAiB,CAAC,OAAO,CAAC;oBAC1E,IAAM,aAAa,GAAG,OAAO,CAAC,UAAU,KAAK,uBAAiB,CAAC,IAAI,CAAC;oBACpE,IAAM,KAAK,GAAG,aAAK,CAAC,OAAO,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;oBAE7C,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;oBAExB,IAAI,MAAM,KAAK,IAAI,EAAE;wBACnB,wFAAwF;wBACxF,0BAA0B;wBAC1B,MAAM,GAAG;4BACP,IAAI,EAAE,KAAK;4BACX,MAAM,EAAE,CAAC,KAAK,CAAC;4BACf,eAAe,EAAE,IAAI;4BACrB,iBAAiB,EAAE,gBAAgB;4BACnC,eAAe,EAAE,aAAa;yBAC/B,CAAC;wBAEF,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;wBAChC,IAAM,EAAE,GAAG,KAAK,CAAC,aAAa,EAAE,CAAC;wBACjC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;4BAC/B,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,GAAG,EAAoB,CAAC,CAAC;yBACzD;wBACD,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;qBACxC;yBAAM;wBACL,2FAA2F;wBAC3F,2FAA2F;wBAC3F,YAAY;wBAEZ,0CAA0C;wBAC1C,EAAE;wBACF,6DAA6D;wBAC7D,uFAAuF;wBACvF,wDAAwD;wBAExD,IAAI,CAAC,aAAa,IAAI,MAAM,CAAC,eAAe,EAAE;4BAC5C,oFAAoF;4BACpF,eAAe;4BACf,MAAM,CAAC,MAAM;gCACT,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,UAAA,KAAK,IAAI,OAAA,KAAK,CAAC,OAAO,CAAC,UAAU,KAAK,uBAAiB,CAAC,IAAI,EAAnD,CAAmD,CAAC,CAAC;4BACvF,MAAM,CAAC,eAAe,GAAG,KAAK,CAAC;yBAChC;6BAAM,IAAI,aAAa,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE;4BACnD,sFAAsF;4BACtF,wBAAwB;4BACxB,SAAS;yBACV;wBAED,IAAI,gBAAgB,IAAI,MAAM,CAAC,iBAAiB,EAAE;4BAChD,yEAAyE;4BACzE,MAAM,CAAC,eAAe,GAAG,CAAC;oCACxB,QAAQ,EAAE,EAAE,CAAC,kBAAkB,CAAC,KAAK;oCACrC,IAAI,EAAE,MAAM,CAAC,KAAK,GAAG,uBAAS,CAAC,mBAAmB,CAAC;oCACnD,IAAI,EAAE,0BAAa,CAAC,KAAK,CAAC;oCAC1B,KAAK,EAAE,KAAK,CAAC,QAAQ,CAAC,SAAS,EAAE,KAAK,CAAC;oCACvC,MAAM,EAAE,KAAK,CAAC,QAAQ,EAAE;oCACxB,WAAW,EAAE,sCAAsC;iCACpD,CAAC,CAAC;4BACH,MAAM,CAAC,MAAM,GAAG,WAAW,GAAG,EAAE,CAAC;4BACjC,MAAM;yBACP;wBAED,2FAA2F;wBAC3F,wBAAwB;wBACxB,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;wBAC1B,MAAM,CAAC,iBAAiB,GAAG,MAAM,CAAC,iBAAiB,IAAI,gBAAgB,CAAC;qBACzE;iBACF;;;;;;;;;YAED,OAAO,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC;QACrD,CAAC;QAES,oCAAY,GAAtB,UAAuB,KAAuB,EAAE,eAAqC;;YAArF,iBAgCC;YA/BC,IAAM,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;YAE9C,IAAI,MAAM,KAAK,IAAI,EAAE;gBACnB,qEAAqE;gBACrE,OAAO;aACR;oCAEU,KAAK;gBACd,IAAM,OAAO,GAAG,cAAM,OAAA,KAAI,CAAC,YAAY,CAAC,KAAK,EAAE,KAAK,CAAC,EAA/B,CAA+B,CAAC;gBAEtD,IAAI,WAAW,GAAuB,IAAI,CAAC;gBAC3C,IAAI,eAAe,KAAK,IAAI,IAAI,KAAK,CAAC,OAAO,CAAC,UAAU,KAAK,SAAS,EAAE;oBACtE,4FAA4F;oBAC5F,QAAQ;oBACR,IAAI;wBACF,WAAW,GAAG,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,EAAE,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC;qBAChF;oBAAC,OAAO,GAAG,EAAE;wBACZ,IAAI,GAAG,YAAY,kCAAoB,EAAE;4BACvC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;;yBAE9C;6BAAM;4BACL,MAAM,GAAG,CAAC;yBACX;qBACF;iBACF;gBACD,IAAI,WAAW,KAAK,IAAI,EAAE;oBACxB,eAAgB,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;iBAClD;qBAAM;oBACL,OAAO,EAAE,CAAC;iBACX;;;gBAtBH,KAAoB,IAAA,WAAA,iBAAA,MAAM,CAAA,8BAAA;oBAArB,IAAM,KAAK,mBAAA;0CAAL,KAAK;;;iBAuBf;;;;;;;;;QACH,CAAC;QAES,oCAAY,GAAtB,UACI,KAAuB,EAAE,KAAuC,EAChE,KAAoB;;YACtB,IAAI,KAAK,CAAC,KAAK,KAAK,kBAAU,CAAC,OAAO,EAAE;gBACtC,MAAM,IAAI,KAAK,CAAC,iCAA+B,KAAK,CAAC,IAAI,CAAC,IAAI,kBAC1D,kBAAU,CAAC,KAAK,CAAC,KAAK,CAAC,yBAAsB,CAAC,CAAC;aACpD;YAED,wFAAwF;YACxF,IAAI,MAA+B,CAAC;YACpC,IAAI;gBACF,MAAM,GAAG,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,QAAQ,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;aACvE;YAAC,OAAO,GAAG,EAAE;gBACZ,IAAI,GAAG,YAAY,kCAAoB,EAAE;oBACvC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;oBAC7C,OAAO;iBACR;qBAAM;oBACL,MAAM,GAAG,CAAC;iBACX;aACF;YAED,IAAI,MAAM,CAAC,QAAQ,KAAK,SAAS,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,KAAK,SAAS,EAAE;gBACzE,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC;aAChD;YAED,KAAK,GAAG,KAAK,CAAC,UAAU,OAAC,MAAM,CAAC,QAAQ,mCAAI,IAAI,QAAE,MAAM,CAAC,WAAW,mCAAI,IAAI,CAAC,CAAC;QAChF,CAAC;QAED,+BAAO,GAAP;;;YACE,IAAM,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;;gBAChD,KAAoB,IAAA,YAAA,iBAAA,OAAO,CAAA,gCAAA,qDAAE;oBAAxB,IAAM,KAAK,oBAAA;oBACd,IAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAE,CAAC;;wBACxC,KAAkB,IAAA,oBAAA,iBAAA,MAAM,CAAC,MAAM,CAAA,CAAA,gBAAA,4BAAE;4BAA5B,IAAI,KAAK,WAAA;4BACZ,IAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;4BAC9B,QAAQ,KAAK,CAAC,KAAK,EAAE;gCACnB,KAAK,kBAAU,CAAC,OAAO;oCACrB,SAAS;gCACX,KAAK,kBAAU,CAAC,OAAO;oCACrB,MAAM,IAAI,KAAK,CAAC,kDAAgD,KAAK,CAAC,IAAI,CAAC,IAAI,WAC3E,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,WAAW,CAAC,IAAM,CAAC,CAAC;gCAC/D,KAAK,kBAAU,CAAC,QAAQ;oCACtB,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;6BAC1D;4BAED,IAAI,KAAK,CAAC,QAAQ,KAAK,IAAI,EAAE;gCAC3B,0DAA0D;gCAC1D,SAAS;6BACV;4BAED,IAAI,OAAO,CAAC,OAAO,KAAK,SAAS,EAAE;gCACjC,8EAA8E;gCAC9E,KAAK,GAAG,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;gCACrC,SAAS;6BACV;4BAED,IAAI,MAAM,SAAwB,CAAC;4BACnC,IAAI;gCACF,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,QAA6B,CAAC,CAAC;6BACtE;4BAAC,OAAO,GAAG,EAAE;gCACZ,IAAI,GAAG,YAAY,kCAAoB,EAAE;oCACvC,KAAK,GAAG,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;oCACrD,SAAS;iCACV;qCAAM;oCACL,MAAM,GAAG,CAAC;iCACX;6BACF;4BAED,KAAK,GAAG,KAAK,CAAC,UAAU,OAAC,MAAM,CAAC,IAAI,mCAAI,IAAI,QAAE,MAAM,CAAC,WAAW,mCAAI,IAAI,CAAC,CAAC;4BAE1E,IAAI,MAAM,CAAC,SAAS,KAAK,SAAS,EAAE;gCAClC,IAAM,QAAQ,GAAG,KAAK,CAAC,aAAa,EAAE,CAAC,QAAQ,CAAC;gCAChD,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;oCACnC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,GAAG,EAA4B,CAAC,CAAC;iCACrE;gCACD,IAAM,aAAa,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAE,CAAC;;oCACtD,KAAuB,IAAA,oBAAA,iBAAA,MAAM,CAAC,SAAS,CAAA,CAAA,gBAAA,4BAAE;wCAApC,IAAM,QAAQ,WAAA;wCACjB,aAAa,CAAC,GAAG,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,UAAU,EAAE,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC;qCACjF;;;;;;;;;6BACF;yBACF;;;;;;;;;iBACF;;;;;;;;;QACH,CAAC;QAED;;;WAGG;QACH,iCAAS,GAAT,UAAU,EAAiB,EAAE,GAAqB;;YAChD,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;gBAC/B,OAAO;aACR;;gBAED,KAAoB,IAAA,KAAA,iBAAA,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAE,CAAA,gBAAA,4BAAE;oBAA5C,IAAM,KAAK,WAAA;oBACd,IAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAE,CAAC;;wBACxC,KAAoB,IAAA,qBAAA,iBAAA,MAAM,CAAC,MAAM,CAAA,CAAA,gBAAA,4BAAE;4BAA9B,IAAM,KAAK,WAAA;4BACd,IAAI,KAAK,CAAC,KAAK,KAAK,kBAAU,CAAC,QAAQ,EAAE;gCACvC,SAAS;6BACV;iCAAM,IAAI,KAAK,CAAC,OAAO,CAAC,SAAS,KAAK,SAAS,EAAE;gCAChD,SAAS;6BACV;4BACD,IAAI,KAAK,CAAC,UAAU,KAAK,IAAI,EAAE;gCAC7B,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;6BACvE;yBACF;;;;;;;;;iBACF;;;;;;;;;QACH,CAAC;QAED,6BAAK,GAAL,UAAM,GAAoB;;;gBACxB,KAAoB,IAAA,KAAA,iBAAA,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAA,gBAAA,4BAAE;oBAApC,IAAM,KAAK,WAAA;oBACd,IAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAE,CAAC;;wBACxC,KAAoB,IAAA,qBAAA,iBAAA,MAAM,CAAC,MAAM,CAAA,CAAA,gBAAA,4BAAE;4BAA9B,IAAM,KAAK,WAAA;4BACd,IAAI,KAAK,CAAC,KAAK,KAAK,kBAAU,CAAC,QAAQ,EAAE;gCACvC,uDAAuD;gCACvD,SAAS;6BACV;iCAAM,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,KAAK,SAAS,EAAE;gCAC5C,0CAA0C;gCAC1C,SAAS;6BACV;4BAED,IAAI,KAAK,CAAC,UAAU,KAAK,IAAI,EAAE;gCAC7B,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;6BACnE;yBACF;;;;;;;;;iBACF;;;;;;;;;QACH,CAAC;QAED,uCAAe,GAAf,UAAgB,KAAsB;;YACpC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;gBAC9D,OAAO;aACR;YACD,IAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAE,CAAC;;gBACxC,KAAoB,IAAA,KAAA,iBAAA,MAAM,CAAC,MAAM,CAAA,gBAAA,4BAAE;oBAA9B,IAAM,KAAK,WAAA;oBACd,IAAI,KAAK,CAAC,KAAK,KAAK,kBAAU,CAAC,QAAQ,IAAI,KAAK,CAAC,OAAO,CAAC,eAAe,KAAK,SAAS,EAAE;wBACtF,SAAS;qBACV;oBAED,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;iBACxE;;;;;;;;;QACH,CAAC;QAED,+BAAO,GAAP,UAAQ,KAAsB,EAAE,YAA0B;;YACxD,IAAM,QAAQ,GAAG,EAAE,CAAC,eAAe,CAAC,KAAK,CAAiB,CAAC;YAC3D,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC;gBACnE,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;gBAC/B,OAAO,IAAI,CAAC;aACb;YAED,IAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAE,CAAC;YAE3C,IAAI,GAAG,GAAoB,EAAE,CAAC;oCAEnB,KAAK;;gBACd,IAAI,KAAK,CAAC,KAAK,KAAK,kBAAU,CAAC,QAAQ,IAAI,KAAK,CAAC,mBAAmB,KAAK,IAAI;oBACzE,KAAK,CAAC,kBAAkB,KAAK,IAAI,EAAE;;iBAGtC;gBAED,IAAM,WAAW,GAAG,OAAK,IAAI,CAAC,KAAK,CAAC,cAAc,EAAE,QAAQ,CAAC,CAAC;gBAG9D,0FAA0F;gBAC1F,wFAAwF;gBACxF,oBAAoB;gBAEpB,IAAI,UAAU,SAA+B,CAAC;gBAC9C,IAAI,OAAK,eAAe,KAAK,qBAAe,CAAC,OAAO;oBAChD,KAAK,CAAC,OAAO,CAAC,cAAc,KAAK,SAAS,EAAE;oBAC9C,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,cAAc,CAAC,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,UAAW,CAAC,CAAC;iBACrF;qBAAM;oBACL,UAAU;wBACN,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,UAAW,EAAE,YAAY,CAAC,CAAC;iBACvF;gBAED,IAAM,eAAe,GAAG,UAAU,CAAC;gBACnC,OAAK,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBAC5B,IAAI,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,EAAE;4CACvB,MAAM;wBACf,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,IAAI,KAAK,MAAM,CAAC,IAAI,EAAtB,CAAsB,CAAC,EAAE;4BAC1C,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;yBAClB;;;wBAHH,KAAqB,IAAA,oCAAA,iBAAA,eAAe,CAAA,CAAA,gDAAA;4BAA/B,IAAM,MAAM,4BAAA;oCAAN,MAAM;yBAIhB;;;;;;;;;iBACF;qBAAM,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,UAAA,MAAM,IAAI,OAAA,MAAM,CAAC,IAAI,KAAK,eAAe,CAAC,IAAI,EAApC,CAAoC,CAAC,EAAE;oBACpE,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;iBAC3B;;;;gBAjCH,KAAoB,IAAA,KAAA,iBAAA,MAAM,CAAC,MAAM,CAAA,gBAAA;oBAA5B,IAAM,KAAK,WAAA;4BAAL,KAAK;iBAkCf;;;;;;;;;YAED,0FAA0F;YAC1F,iEAAiE;YACjE,IAAI,CAAC,aAAa,CAAC,0BAA0B,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC;iBAClE,SAAS,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;YAE9B,yEAAyE;YACzE,OAAO,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC;QACrC,CAAC;QAED,qCAAa,GAAb,UAAc,IAAoB;;YAChC,IAAM,QAAQ,GAAG,EAAE,CAAC,eAAe,CAAC,IAAI,CAAgB,CAAC;YACzD,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;gBACpE,OAAO,EAAE,CAAC;aACX;YAED,IAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAE,CAAC;YAC3C,IAAM,UAAU,GAAmB,EAAE,CAAC;;gBAEtC,KAAoB,IAAA,KAAA,iBAAA,MAAM,CAAC,MAAM,CAAA,gBAAA,4BAAE;oBAA9B,IAAM,KAAK,WAAA;oBACd,IAAI,KAAK,CAAC,KAAK,KAAK,kBAAU,CAAC,QAAQ,EAAE;wBACvC,SAAS;qBACV;oBAED,IAAI,KAAK,CAAC,QAAQ,CAAC,OAAO,KAAK,IAAI,IAAI,EAAE,CAAC,WAAW,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;wBAC7E,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;qBACzC;iBACF;;;;;;;;;YAED,OAAO,UAAU,CAAC;QACpB,CAAC;QAED,sBAAI,sCAAW;iBAAf;;gBACE,IAAM,WAAW,GAAoB,EAAE,CAAC;;oBACxC,KAAoB,IAAA,KAAA,iBAAA,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAA,gBAAA,4BAAE;wBAApC,IAAM,KAAK,WAAA;wBACd,IAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAE,CAAC;wBACxC,IAAI,MAAM,CAAC,eAAe,KAAK,IAAI,EAAE;4BACnC,WAAW,CAAC,IAAI,OAAhB,WAAW,mBAAS,MAAM,CAAC,eAAe,GAAE;yBAC7C;;4BACD,KAAoB,IAAA,qBAAA,iBAAA,MAAM,CAAC,MAAM,CAAA,CAAA,gBAAA,4BAAE;gCAA9B,IAAM,KAAK,WAAA;gCACd,IAAI,CAAC,KAAK,CAAC,KAAK,KAAK,kBAAU,CAAC,QAAQ,IAAI,KAAK,CAAC,KAAK,KAAK,kBAAU,CAAC,QAAQ,CAAC;oCAC5E,KAAK,CAAC,mBAAmB,KAAK,IAAI,EAAE;oCACtC,WAAW,CAAC,IAAI,OAAhB,WAAW,mBAAS,KAAK,CAAC,mBAAmB,GAAE;iCAChD;gCACD,IAAI,KAAK,CAAC,KAAK,KAAK,kBAAU,CAAC,QAAQ,IAAI,KAAK,CAAC,kBAAkB,KAAK,IAAI,EAAE;oCAC5E,WAAW,CAAC,IAAI,OAAhB,WAAW,mBAAS,KAAK,CAAC,kBAAkB,GAAE;iCAC/C;6BACF;;;;;;;;;qBACF;;;;;;;;;gBACD,OAAO,WAAW,CAAC;YACrB,CAAC;;;WAAA;QAED,sBAAI,2CAAgB;iBAApB;gBACE,OAAO,IAAI,CAAC,WAAW,CAAC;YAC1B,CAAC;;;WAAA;QACH,oBAAC;IAAD,CAAC,AArfD,IAqfC;IArfY,sCAAa","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 {ConstantPool} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {ErrorCode, FatalDiagnosticError} from '../../diagnostics';\nimport {IncrementalBuild} from '../../incremental/api';\nimport {IndexingContext} from '../../indexer';\nimport {PerfRecorder} from '../../perf';\nimport {ClassDeclaration, DeclarationNode, Decorator, ReflectionHost} from '../../reflection';\nimport {ProgramTypeCheckAdapter, TypeCheckContext} from '../../typecheck/api';\nimport {getSourceFile, isExported} from '../../util/src/typescript';\n\nimport {AnalysisOutput, CompilationMode, CompileResult, DecoratorHandler, HandlerFlags, HandlerPrecedence, ResolveResult} from './api';\nimport {DtsTransformRegistry} from './declaration';\nimport {PendingTrait, Trait, TraitState} from './trait';\n\n\n/**\n * Records information about a specific class that has matched traits.\n */\nexport interface ClassRecord {\n  /**\n   * The `ClassDeclaration` of the class which has Angular traits applied.\n   */\n  node: ClassDeclaration;\n\n  /**\n   * All traits which matched on the class.\n   */\n  traits: Trait<unknown, unknown, unknown>[];\n\n  /**\n   * Meta-diagnostics about the class, which are usually related to whether certain combinations of\n   * Angular decorators are not permitted.\n   */\n  metaDiagnostics: ts.Diagnostic[]|null;\n\n  // Subsequent fields are \"internal\" and used during the matching of `DecoratorHandler`s. This is\n  // mutable state during the `detect`/`analyze` phases of compilation.\n\n  /**\n   * Whether `traits` contains traits matched from `DecoratorHandler`s marked as `WEAK`.\n   */\n  hasWeakHandlers: boolean;\n\n  /**\n   * Whether `traits` contains a trait from a `DecoratorHandler` matched as `PRIMARY`.\n   */\n  hasPrimaryHandler: boolean;\n}\n\n/**\n * The heart of Angular compilation.\n *\n * The `TraitCompiler` is responsible for processing all classes in the program. Any time a\n * `DecoratorHandler` matches a class, a \"trait\" is created to represent that Angular aspect of the\n * class (such as the class having a component definition).\n *\n * The `TraitCompiler` transitions each trait through the various phases of compilation, culminating\n * in the production of `CompileResult`s instructing the compiler to apply various mutations to the\n * class (like adding fields or type declarations).\n */\nexport class TraitCompiler implements ProgramTypeCheckAdapter {\n  /**\n   * Maps class declarations to their `ClassRecord`, which tracks the Ivy traits being applied to\n   * those classes.\n   */\n  private classes = new Map<ClassDeclaration, ClassRecord>();\n\n  /**\n   * Maps source files to any class declaration(s) within them which have been discovered to contain\n   * Ivy traits.\n   */\n  protected fileToClasses = new Map<ts.SourceFile, Set<ClassDeclaration>>();\n\n  private reexportMap = new Map<string, Map<string, [string, string]>>();\n\n  private handlersByName = new Map<string, DecoratorHandler<unknown, unknown, unknown>>();\n\n  constructor(\n      private handlers: DecoratorHandler<unknown, unknown, unknown>[],\n      private reflector: ReflectionHost, private perf: PerfRecorder,\n      private incrementalBuild: IncrementalBuild<ClassRecord, unknown>,\n      private compileNonExportedClasses: boolean, private compilationMode: CompilationMode,\n      private dtsTransforms: DtsTransformRegistry) {\n    for (const handler of handlers) {\n      this.handlersByName.set(handler.name, handler);\n    }\n  }\n\n  analyzeSync(sf: ts.SourceFile): void {\n    this.analyze(sf, false);\n  }\n\n  analyzeAsync(sf: ts.SourceFile): Promise<void>|undefined {\n    return this.analyze(sf, true);\n  }\n\n  private analyze(sf: ts.SourceFile, preanalyze: false): void;\n  private analyze(sf: ts.SourceFile, preanalyze: true): Promise<void>|undefined;\n  private analyze(sf: ts.SourceFile, preanalyze: boolean): Promise<void>|undefined {\n    // We shouldn't analyze declaration files.\n    if (sf.isDeclarationFile) {\n      return undefined;\n    }\n\n    // analyze() really wants to return `Promise<void>|void`, but TypeScript cannot narrow a return\n    // type of 'void', so `undefined` is used instead.\n    const promises: Promise<void>[] = [];\n\n    const priorWork = this.incrementalBuild.priorWorkFor(sf);\n    if (priorWork !== null) {\n      for (const priorRecord of priorWork) {\n        this.adopt(priorRecord);\n      }\n\n      // Skip the rest of analysis, as this file's prior traits are being reused.\n      return;\n    }\n\n    const visit = (node: ts.Node): void => {\n      if (this.reflector.isClass(node)) {\n        this.analyzeClass(node, preanalyze ? promises : null);\n      }\n      ts.forEachChild(node, visit);\n    };\n\n    visit(sf);\n\n    if (preanalyze && promises.length > 0) {\n      return Promise.all(promises).then(() => undefined as void);\n    } else {\n      return undefined;\n    }\n  }\n\n  recordFor(clazz: ClassDeclaration): ClassRecord|null {\n    if (this.classes.has(clazz)) {\n      return this.classes.get(clazz)!;\n    } else {\n      return null;\n    }\n  }\n\n  recordsFor(sf: ts.SourceFile): ClassRecord[]|null {\n    if (!this.fileToClasses.has(sf)) {\n      return null;\n    }\n    const records: ClassRecord[] = [];\n    for (const clazz of this.fileToClasses.get(sf)!) {\n      records.push(this.classes.get(clazz)!);\n    }\n    return records;\n  }\n\n  /**\n   * Import a `ClassRecord` from a previous compilation.\n   *\n   * Traits from the `ClassRecord` have accurate metadata, but the `handler` is from the old program\n   * and needs to be updated (matching is done by name). A new pending trait is created and then\n   * transitioned to analyzed using the previous analysis. If the trait is in the errored state,\n   * instead the errors are copied over.\n   */\n  private adopt(priorRecord: ClassRecord): void {\n    const record: ClassRecord = {\n      hasPrimaryHandler: priorRecord.hasPrimaryHandler,\n      hasWeakHandlers: priorRecord.hasWeakHandlers,\n      metaDiagnostics: priorRecord.metaDiagnostics,\n      node: priorRecord.node,\n      traits: [],\n    };\n\n    for (const priorTrait of priorRecord.traits) {\n      const handler = this.handlersByName.get(priorTrait.handler.name)!;\n      let trait: Trait<unknown, unknown, unknown> = Trait.pending(handler, priorTrait.detected);\n\n      if (priorTrait.state === TraitState.Analyzed || priorTrait.state === TraitState.Resolved) {\n        trait = trait.toAnalyzed(priorTrait.analysis, priorTrait.analysisDiagnostics);\n        if (trait.analysis !== null && trait.handler.register !== undefined) {\n          trait.handler.register(record.node, trait.analysis);\n        }\n      } else if (priorTrait.state === TraitState.Skipped) {\n        trait = trait.toSkipped();\n      }\n\n      record.traits.push(trait);\n    }\n\n    this.classes.set(record.node, record);\n    const sf = record.node.getSourceFile();\n    if (!this.fileToClasses.has(sf)) {\n      this.fileToClasses.set(sf, new Set<ClassDeclaration>());\n    }\n    this.fileToClasses.get(sf)!.add(record.node);\n  }\n\n  private scanClassForTraits(clazz: ClassDeclaration):\n      PendingTrait<unknown, unknown, unknown>[]|null {\n    if (!this.compileNonExportedClasses && !isExported(clazz)) {\n      return null;\n    }\n\n    const decorators = this.reflector.getDecoratorsOfDeclaration(clazz);\n\n    return this.detectTraits(clazz, decorators);\n  }\n\n  protected detectTraits(clazz: ClassDeclaration, decorators: Decorator[]|null):\n      PendingTrait<unknown, unknown, unknown>[]|null {\n    let record: ClassRecord|null = this.recordFor(clazz);\n    let foundTraits: PendingTrait<unknown, unknown, unknown>[] = [];\n\n    for (const handler of this.handlers) {\n      const result = handler.detect(clazz, decorators);\n      if (result === undefined) {\n        continue;\n      }\n\n      const isPrimaryHandler = handler.precedence === HandlerPrecedence.PRIMARY;\n      const isWeakHandler = handler.precedence === HandlerPrecedence.WEAK;\n      const trait = Trait.pending(handler, result);\n\n      foundTraits.push(trait);\n\n      if (record === null) {\n        // This is the first handler to match this class. This path is a fast path through which\n        // most classes will flow.\n        record = {\n          node: clazz,\n          traits: [trait],\n          metaDiagnostics: null,\n          hasPrimaryHandler: isPrimaryHandler,\n          hasWeakHandlers: isWeakHandler,\n        };\n\n        this.classes.set(clazz, record);\n        const sf = clazz.getSourceFile();\n        if (!this.fileToClasses.has(sf)) {\n          this.fileToClasses.set(sf, new Set<ClassDeclaration>());\n        }\n        this.fileToClasses.get(sf)!.add(clazz);\n      } else {\n        // This is at least the second handler to match this class. This is a slower path that some\n        // classes will go through, which validates that the set of decorators applied to the class\n        // is valid.\n\n        // Validate according to rules as follows:\n        //\n        // * WEAK handlers are removed if a non-WEAK handler matches.\n        // * Only one PRIMARY handler can match at a time. Any other PRIMARY handler matching a\n        //   class with an existing PRIMARY handler is an error.\n\n        if (!isWeakHandler && record.hasWeakHandlers) {\n          // The current handler is not a WEAK handler, but the class has other WEAK handlers.\n          // Remove them.\n          record.traits =\n              record.traits.filter(field => field.handler.precedence !== HandlerPrecedence.WEAK);\n          record.hasWeakHandlers = false;\n        } else if (isWeakHandler && !record.hasWeakHandlers) {\n          // The current handler is a WEAK handler, but the class has non-WEAK handlers already.\n          // Drop the current one.\n          continue;\n        }\n\n        if (isPrimaryHandler && record.hasPrimaryHandler) {\n          // The class already has a PRIMARY handler, and another one just matched.\n          record.metaDiagnostics = [{\n            category: ts.DiagnosticCategory.Error,\n            code: Number('-99' + ErrorCode.DECORATOR_COLLISION),\n            file: getSourceFile(clazz),\n            start: clazz.getStart(undefined, false),\n            length: clazz.getWidth(),\n            messageText: 'Two incompatible decorators on class',\n          }];\n          record.traits = foundTraits = [];\n          break;\n        }\n\n        // Otherwise, it's safe to accept the multiple decorators here. Update some of the metadata\n        // regarding this class.\n        record.traits.push(trait);\n        record.hasPrimaryHandler = record.hasPrimaryHandler || isPrimaryHandler;\n      }\n    }\n\n    return foundTraits.length > 0 ? foundTraits : null;\n  }\n\n  protected analyzeClass(clazz: ClassDeclaration, preanalyzeQueue: Promise<void>[]|null): void {\n    const traits = this.scanClassForTraits(clazz);\n\n    if (traits === null) {\n      // There are no Ivy traits on the class, so it can safely be skipped.\n      return;\n    }\n\n    for (const trait of traits) {\n      const analyze = () => this.analyzeTrait(clazz, trait);\n\n      let preanalysis: Promise<void>|null = null;\n      if (preanalyzeQueue !== null && trait.handler.preanalyze !== undefined) {\n        // Attempt to run preanalysis. This could fail with a `FatalDiagnosticError`; catch it if it\n        // does.\n        try {\n          preanalysis = trait.handler.preanalyze(clazz, trait.detected.metadata) || null;\n        } catch (err) {\n          if (err instanceof FatalDiagnosticError) {\n            trait.toAnalyzed(null, [err.toDiagnostic()]);\n            return;\n          } else {\n            throw err;\n          }\n        }\n      }\n      if (preanalysis !== null) {\n        preanalyzeQueue!.push(preanalysis.then(analyze));\n      } else {\n        analyze();\n      }\n    }\n  }\n\n  protected analyzeTrait(\n      clazz: ClassDeclaration, trait: Trait<unknown, unknown, unknown>,\n      flags?: HandlerFlags): void {\n    if (trait.state !== TraitState.Pending) {\n      throw new Error(`Attempt to analyze trait of ${clazz.name.text} in state ${\n          TraitState[trait.state]} (expected DETECTED)`);\n    }\n\n    // Attempt analysis. This could fail with a `FatalDiagnosticError`; catch it if it does.\n    let result: AnalysisOutput<unknown>;\n    try {\n      result = trait.handler.analyze(clazz, trait.detected.metadata, flags);\n    } catch (err) {\n      if (err instanceof FatalDiagnosticError) {\n        trait.toAnalyzed(null, [err.toDiagnostic()]);\n        return;\n      } else {\n        throw err;\n      }\n    }\n\n    if (result.analysis !== undefined && trait.handler.register !== undefined) {\n      trait.handler.register(clazz, result.analysis);\n    }\n\n    trait = trait.toAnalyzed(result.analysis ?? null, result.diagnostics ?? null);\n  }\n\n  resolve(): void {\n    const classes = Array.from(this.classes.keys());\n    for (const clazz of classes) {\n      const record = this.classes.get(clazz)!;\n      for (let trait of record.traits) {\n        const handler = trait.handler;\n        switch (trait.state) {\n          case TraitState.Skipped:\n            continue;\n          case TraitState.Pending:\n            throw new Error(`Resolving a trait that hasn't been analyzed: ${clazz.name.text} / ${\n                Object.getPrototypeOf(trait.handler).constructor.name}`);\n          case TraitState.Resolved:\n            throw new Error(`Resolving an already resolved trait`);\n        }\n\n        if (trait.analysis === null) {\n          // No analysis results, cannot further process this trait.\n          continue;\n        }\n\n        if (handler.resolve === undefined) {\n          // No resolution of this trait needed - it's considered successful by default.\n          trait = trait.toResolved(null, null);\n          continue;\n        }\n\n        let result: ResolveResult<unknown>;\n        try {\n          result = handler.resolve(clazz, trait.analysis as Readonly<unknown>);\n        } catch (err) {\n          if (err instanceof FatalDiagnosticError) {\n            trait = trait.toResolved(null, [err.toDiagnostic()]);\n            continue;\n          } else {\n            throw err;\n          }\n        }\n\n        trait = trait.toResolved(result.data ?? null, result.diagnostics ?? null);\n\n        if (result.reexports !== undefined) {\n          const fileName = clazz.getSourceFile().fileName;\n          if (!this.reexportMap.has(fileName)) {\n            this.reexportMap.set(fileName, new Map<string, [string, string]>());\n          }\n          const fileReexports = this.reexportMap.get(fileName)!;\n          for (const reexport of result.reexports) {\n            fileReexports.set(reexport.asAlias, [reexport.fromModule, reexport.symbolName]);\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * Generate type-checking code into the `TypeCheckContext` for any components within the given\n   * `ts.SourceFile`.\n   */\n  typeCheck(sf: ts.SourceFile, ctx: TypeCheckContext): void {\n    if (!this.fileToClasses.has(sf)) {\n      return;\n    }\n\n    for (const clazz of this.fileToClasses.get(sf)!) {\n      const record = this.classes.get(clazz)!;\n      for (const trait of record.traits) {\n        if (trait.state !== TraitState.Resolved) {\n          continue;\n        } else if (trait.handler.typeCheck === undefined) {\n          continue;\n        }\n        if (trait.resolution !== null) {\n          trait.handler.typeCheck(ctx, clazz, trait.analysis, trait.resolution);\n        }\n      }\n    }\n  }\n\n  index(ctx: IndexingContext): void {\n    for (const clazz of this.classes.keys()) {\n      const record = this.classes.get(clazz)!;\n      for (const trait of record.traits) {\n        if (trait.state !== TraitState.Resolved) {\n          // Skip traits that haven't been resolved successfully.\n          continue;\n        } else if (trait.handler.index === undefined) {\n          // Skip traits that don't affect indexing.\n          continue;\n        }\n\n        if (trait.resolution !== null) {\n          trait.handler.index(ctx, clazz, trait.analysis, trait.resolution);\n        }\n      }\n    }\n  }\n\n  updateResources(clazz: DeclarationNode): void {\n    if (!this.reflector.isClass(clazz) || !this.classes.has(clazz)) {\n      return;\n    }\n    const record = this.classes.get(clazz)!;\n    for (const trait of record.traits) {\n      if (trait.state !== TraitState.Resolved || trait.handler.updateResources === undefined) {\n        continue;\n      }\n\n      trait.handler.updateResources(clazz, trait.analysis, trait.resolution);\n    }\n  }\n\n  compile(clazz: DeclarationNode, constantPool: ConstantPool): CompileResult[]|null {\n    const original = ts.getOriginalNode(clazz) as typeof clazz;\n    if (!this.reflector.isClass(clazz) || !this.reflector.isClass(original) ||\n        !this.classes.has(original)) {\n      return null;\n    }\n\n    const record = this.classes.get(original)!;\n\n    let res: CompileResult[] = [];\n\n    for (const trait of record.traits) {\n      if (trait.state !== TraitState.Resolved || trait.analysisDiagnostics !== null ||\n          trait.resolveDiagnostics !== null) {\n        // Cannot compile a trait that is not resolved, or had any errors in its declaration.\n        continue;\n      }\n\n      const compileSpan = this.perf.start('compileClass', original);\n\n\n      // `trait.resolution` is non-null asserted here because TypeScript does not recognize that\n      // `Readonly<unknown>` is nullable (as `unknown` itself is nullable) due to the way that\n      // `Readonly` works.\n\n      let compileRes: CompileResult|CompileResult[];\n      if (this.compilationMode === CompilationMode.PARTIAL &&\n          trait.handler.compilePartial !== undefined) {\n        compileRes = trait.handler.compilePartial(clazz, trait.analysis, trait.resolution!);\n      } else {\n        compileRes =\n            trait.handler.compileFull(clazz, trait.analysis, trait.resolution!, constantPool);\n      }\n\n      const compileMatchRes = compileRes;\n      this.perf.stop(compileSpan);\n      if (Array.isArray(compileMatchRes)) {\n        for (const result of compileMatchRes) {\n          if (!res.some(r => r.name === result.name)) {\n            res.push(result);\n          }\n        }\n      } else if (!res.some(result => result.name === compileMatchRes.name)) {\n        res.push(compileMatchRes);\n      }\n    }\n\n    // Look up the .d.ts transformer for the input file and record that at least one field was\n    // generated, which will allow the .d.ts to be transformed later.\n    this.dtsTransforms.getIvyDeclarationTransform(original.getSourceFile())\n        .addFields(original, res);\n\n    // Return the instruction to the transformer so the fields will be added.\n    return res.length > 0 ? res : null;\n  }\n\n  decoratorsFor(node: ts.Declaration): ts.Decorator[] {\n    const original = ts.getOriginalNode(node) as typeof node;\n    if (!this.reflector.isClass(original) || !this.classes.has(original)) {\n      return [];\n    }\n\n    const record = this.classes.get(original)!;\n    const decorators: ts.Decorator[] = [];\n\n    for (const trait of record.traits) {\n      if (trait.state !== TraitState.Resolved) {\n        continue;\n      }\n\n      if (trait.detected.trigger !== null && ts.isDecorator(trait.detected.trigger)) {\n        decorators.push(trait.detected.trigger);\n      }\n    }\n\n    return decorators;\n  }\n\n  get diagnostics(): ReadonlyArray<ts.Diagnostic> {\n    const diagnostics: ts.Diagnostic[] = [];\n    for (const clazz of this.classes.keys()) {\n      const record = this.classes.get(clazz)!;\n      if (record.metaDiagnostics !== null) {\n        diagnostics.push(...record.metaDiagnostics);\n      }\n      for (const trait of record.traits) {\n        if ((trait.state === TraitState.Analyzed || trait.state === TraitState.Resolved) &&\n            trait.analysisDiagnostics !== null) {\n          diagnostics.push(...trait.analysisDiagnostics);\n        }\n        if (trait.state === TraitState.Resolved && trait.resolveDiagnostics !== null) {\n          diagnostics.push(...trait.resolveDiagnostics);\n        }\n      }\n    }\n    return diagnostics;\n  }\n\n  get exportStatements(): Map<string, Map<string, [string, string]>> {\n    return this.reexportMap;\n  }\n}\n"]}
|
|
724
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compilation.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/transform/src/compilation.ts"],"names":[],"mappings":"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","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 {ConstantPool} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {ErrorCode, FatalDiagnosticError} from '../../diagnostics';\nimport {IncrementalBuild} from '../../incremental/api';\nimport {SemanticDepGraphUpdater, SemanticSymbol} from '../../incremental/semantic_graph';\nimport {IndexingContext} from '../../indexer';\nimport {PerfRecorder} from '../../perf';\nimport {ClassDeclaration, DeclarationNode, Decorator, ReflectionHost} from '../../reflection';\nimport {ProgramTypeCheckAdapter, TypeCheckContext} from '../../typecheck/api';\nimport {getSourceFile, isExported} from '../../util/src/typescript';\n\nimport {AnalysisOutput, CompilationMode, CompileResult, DecoratorHandler, HandlerFlags, HandlerPrecedence, ResolveResult} from './api';\nimport {DtsTransformRegistry} from './declaration';\nimport {PendingTrait, Trait, TraitState} from './trait';\n\n\n/**\n * Records information about a specific class that has matched traits.\n */\nexport interface ClassRecord {\n  /**\n   * The `ClassDeclaration` of the class which has Angular traits applied.\n   */\n  node: ClassDeclaration;\n\n  /**\n   * All traits which matched on the class.\n   */\n  traits: Trait<unknown, unknown, SemanticSymbol|null, unknown>[];\n\n  /**\n   * Meta-diagnostics about the class, which are usually related to whether certain combinations of\n   * Angular decorators are not permitted.\n   */\n  metaDiagnostics: ts.Diagnostic[]|null;\n\n  // Subsequent fields are \"internal\" and used during the matching of `DecoratorHandler`s. This is\n  // mutable state during the `detect`/`analyze` phases of compilation.\n\n  /**\n   * Whether `traits` contains traits matched from `DecoratorHandler`s marked as `WEAK`.\n   */\n  hasWeakHandlers: boolean;\n\n  /**\n   * Whether `traits` contains a trait from a `DecoratorHandler` matched as `PRIMARY`.\n   */\n  hasPrimaryHandler: boolean;\n}\n\n/**\n * The heart of Angular compilation.\n *\n * The `TraitCompiler` is responsible for processing all classes in the program. Any time a\n * `DecoratorHandler` matches a class, a \"trait\" is created to represent that Angular aspect of the\n * class (such as the class having a component definition).\n *\n * The `TraitCompiler` transitions each trait through the various phases of compilation, culminating\n * in the production of `CompileResult`s instructing the compiler to apply various mutations to the\n * class (like adding fields or type declarations).\n */\nexport class TraitCompiler implements ProgramTypeCheckAdapter {\n  /**\n   * Maps class declarations to their `ClassRecord`, which tracks the Ivy traits being applied to\n   * those classes.\n   */\n  private classes = new Map<ClassDeclaration, ClassRecord>();\n\n  /**\n   * Maps source files to any class declaration(s) within them which have been discovered to contain\n   * Ivy traits.\n   */\n  protected fileToClasses = new Map<ts.SourceFile, Set<ClassDeclaration>>();\n\n  private reexportMap = new Map<string, Map<string, [string, string]>>();\n\n  private handlersByName =\n      new Map<string, DecoratorHandler<unknown, unknown, SemanticSymbol|null, unknown>>();\n\n  constructor(\n      private handlers: DecoratorHandler<unknown, unknown, SemanticSymbol|null, unknown>[],\n      private reflector: ReflectionHost, private perf: PerfRecorder,\n      private incrementalBuild: IncrementalBuild<ClassRecord, unknown>,\n      private compileNonExportedClasses: boolean, private compilationMode: CompilationMode,\n      private dtsTransforms: DtsTransformRegistry,\n      private semanticDepGraphUpdater: SemanticDepGraphUpdater|null) {\n    for (const handler of handlers) {\n      this.handlersByName.set(handler.name, handler);\n    }\n  }\n\n  analyzeSync(sf: ts.SourceFile): void {\n    this.analyze(sf, false);\n  }\n\n  analyzeAsync(sf: ts.SourceFile): Promise<void>|undefined {\n    return this.analyze(sf, true);\n  }\n\n  private analyze(sf: ts.SourceFile, preanalyze: false): void;\n  private analyze(sf: ts.SourceFile, preanalyze: true): Promise<void>|undefined;\n  private analyze(sf: ts.SourceFile, preanalyze: boolean): Promise<void>|undefined {\n    // We shouldn't analyze declaration files.\n    if (sf.isDeclarationFile) {\n      return undefined;\n    }\n\n    // analyze() really wants to return `Promise<void>|void`, but TypeScript cannot narrow a return\n    // type of 'void', so `undefined` is used instead.\n    const promises: Promise<void>[] = [];\n\n    const priorWork = this.incrementalBuild.priorWorkFor(sf);\n    if (priorWork !== null) {\n      for (const priorRecord of priorWork) {\n        this.adopt(priorRecord);\n      }\n\n      // Skip the rest of analysis, as this file's prior traits are being reused.\n      return;\n    }\n\n    const visit = (node: ts.Node): void => {\n      if (this.reflector.isClass(node)) {\n        this.analyzeClass(node, preanalyze ? promises : null);\n      }\n      ts.forEachChild(node, visit);\n    };\n\n    visit(sf);\n\n    if (preanalyze && promises.length > 0) {\n      return Promise.all(promises).then(() => undefined as void);\n    } else {\n      return undefined;\n    }\n  }\n\n  recordFor(clazz: ClassDeclaration): ClassRecord|null {\n    if (this.classes.has(clazz)) {\n      return this.classes.get(clazz)!;\n    } else {\n      return null;\n    }\n  }\n\n  recordsFor(sf: ts.SourceFile): ClassRecord[]|null {\n    if (!this.fileToClasses.has(sf)) {\n      return null;\n    }\n    const records: ClassRecord[] = [];\n    for (const clazz of this.fileToClasses.get(sf)!) {\n      records.push(this.classes.get(clazz)!);\n    }\n    return records;\n  }\n\n  /**\n   * Import a `ClassRecord` from a previous compilation.\n   *\n   * Traits from the `ClassRecord` have accurate metadata, but the `handler` is from the old program\n   * and needs to be updated (matching is done by name). A new pending trait is created and then\n   * transitioned to analyzed using the previous analysis. If the trait is in the errored state,\n   * instead the errors are copied over.\n   */\n  private adopt(priorRecord: ClassRecord): void {\n    const record: ClassRecord = {\n      hasPrimaryHandler: priorRecord.hasPrimaryHandler,\n      hasWeakHandlers: priorRecord.hasWeakHandlers,\n      metaDiagnostics: priorRecord.metaDiagnostics,\n      node: priorRecord.node,\n      traits: [],\n    };\n\n    for (const priorTrait of priorRecord.traits) {\n      const handler = this.handlersByName.get(priorTrait.handler.name)!;\n      let trait: Trait<unknown, unknown, SemanticSymbol|null, unknown> =\n          Trait.pending(handler, priorTrait.detected);\n\n      if (priorTrait.state === TraitState.Analyzed || priorTrait.state === TraitState.Resolved) {\n        const symbol = this.makeSymbolForTrait(handler, record.node, priorTrait.analysis);\n        trait = trait.toAnalyzed(priorTrait.analysis, priorTrait.analysisDiagnostics, symbol);\n        if (trait.analysis !== null && trait.handler.register !== undefined) {\n          trait.handler.register(record.node, trait.analysis);\n        }\n      } else if (priorTrait.state === TraitState.Skipped) {\n        trait = trait.toSkipped();\n      }\n\n      record.traits.push(trait);\n    }\n\n    this.classes.set(record.node, record);\n    const sf = record.node.getSourceFile();\n    if (!this.fileToClasses.has(sf)) {\n      this.fileToClasses.set(sf, new Set<ClassDeclaration>());\n    }\n    this.fileToClasses.get(sf)!.add(record.node);\n  }\n\n  private scanClassForTraits(clazz: ClassDeclaration):\n      PendingTrait<unknown, unknown, SemanticSymbol|null, unknown>[]|null {\n    if (!this.compileNonExportedClasses && !isExported(clazz)) {\n      return null;\n    }\n\n    const decorators = this.reflector.getDecoratorsOfDeclaration(clazz);\n\n    return this.detectTraits(clazz, decorators);\n  }\n\n  protected detectTraits(clazz: ClassDeclaration, decorators: Decorator[]|null):\n      PendingTrait<unknown, unknown, SemanticSymbol|null, unknown>[]|null {\n    let record: ClassRecord|null = this.recordFor(clazz);\n    let foundTraits: PendingTrait<unknown, unknown, SemanticSymbol|null, unknown>[] = [];\n\n    for (const handler of this.handlers) {\n      const result = handler.detect(clazz, decorators);\n      if (result === undefined) {\n        continue;\n      }\n\n      const isPrimaryHandler = handler.precedence === HandlerPrecedence.PRIMARY;\n      const isWeakHandler = handler.precedence === HandlerPrecedence.WEAK;\n      const trait = Trait.pending(handler, result);\n\n      foundTraits.push(trait);\n\n      if (record === null) {\n        // This is the first handler to match this class. This path is a fast path through which\n        // most classes will flow.\n        record = {\n          node: clazz,\n          traits: [trait],\n          metaDiagnostics: null,\n          hasPrimaryHandler: isPrimaryHandler,\n          hasWeakHandlers: isWeakHandler,\n        };\n\n        this.classes.set(clazz, record);\n        const sf = clazz.getSourceFile();\n        if (!this.fileToClasses.has(sf)) {\n          this.fileToClasses.set(sf, new Set<ClassDeclaration>());\n        }\n        this.fileToClasses.get(sf)!.add(clazz);\n      } else {\n        // This is at least the second handler to match this class. This is a slower path that some\n        // classes will go through, which validates that the set of decorators applied to the class\n        // is valid.\n\n        // Validate according to rules as follows:\n        //\n        // * WEAK handlers are removed if a non-WEAK handler matches.\n        // * Only one PRIMARY handler can match at a time. Any other PRIMARY handler matching a\n        //   class with an existing PRIMARY handler is an error.\n\n        if (!isWeakHandler && record.hasWeakHandlers) {\n          // The current handler is not a WEAK handler, but the class has other WEAK handlers.\n          // Remove them.\n          record.traits =\n              record.traits.filter(field => field.handler.precedence !== HandlerPrecedence.WEAK);\n          record.hasWeakHandlers = false;\n        } else if (isWeakHandler && !record.hasWeakHandlers) {\n          // The current handler is a WEAK handler, but the class has non-WEAK handlers already.\n          // Drop the current one.\n          continue;\n        }\n\n        if (isPrimaryHandler && record.hasPrimaryHandler) {\n          // The class already has a PRIMARY handler, and another one just matched.\n          record.metaDiagnostics = [{\n            category: ts.DiagnosticCategory.Error,\n            code: Number('-99' + ErrorCode.DECORATOR_COLLISION),\n            file: getSourceFile(clazz),\n            start: clazz.getStart(undefined, false),\n            length: clazz.getWidth(),\n            messageText: 'Two incompatible decorators on class',\n          }];\n          record.traits = foundTraits = [];\n          break;\n        }\n\n        // Otherwise, it's safe to accept the multiple decorators here. Update some of the metadata\n        // regarding this class.\n        record.traits.push(trait);\n        record.hasPrimaryHandler = record.hasPrimaryHandler || isPrimaryHandler;\n      }\n    }\n\n    return foundTraits.length > 0 ? foundTraits : null;\n  }\n\n  private makeSymbolForTrait(\n      handler: DecoratorHandler<unknown, unknown, SemanticSymbol|null, unknown>,\n      decl: ClassDeclaration, analysis: Readonly<unknown>|null): SemanticSymbol|null {\n    if (analysis === null) {\n      return null;\n    }\n    const symbol = handler.symbol(decl, analysis);\n    if (symbol !== null && this.semanticDepGraphUpdater !== null) {\n      const isPrimary = handler.precedence === HandlerPrecedence.PRIMARY;\n      if (!isPrimary) {\n        throw new Error(\n            `AssertionError: ${handler.name} returned a symbol but is not a primary handler.`);\n      }\n      this.semanticDepGraphUpdater.registerSymbol(symbol);\n    }\n\n    return symbol;\n  }\n\n  protected analyzeClass(clazz: ClassDeclaration, preanalyzeQueue: Promise<void>[]|null): void {\n    const traits = this.scanClassForTraits(clazz);\n\n    if (traits === null) {\n      // There are no Ivy traits on the class, so it can safely be skipped.\n      return;\n    }\n\n    for (const trait of traits) {\n      const analyze = () => this.analyzeTrait(clazz, trait);\n\n      let preanalysis: Promise<void>|null = null;\n      if (preanalyzeQueue !== null && trait.handler.preanalyze !== undefined) {\n        // Attempt to run preanalysis. This could fail with a `FatalDiagnosticError`; catch it if it\n        // does.\n        try {\n          preanalysis = trait.handler.preanalyze(clazz, trait.detected.metadata) || null;\n        } catch (err) {\n          if (err instanceof FatalDiagnosticError) {\n            trait.toAnalyzed(null, [err.toDiagnostic()], null);\n            return;\n          } else {\n            throw err;\n          }\n        }\n      }\n      if (preanalysis !== null) {\n        preanalyzeQueue!.push(preanalysis.then(analyze));\n      } else {\n        analyze();\n      }\n    }\n  }\n\n  protected analyzeTrait(\n      clazz: ClassDeclaration, trait: Trait<unknown, unknown, SemanticSymbol|null, unknown>,\n      flags?: HandlerFlags): void {\n    if (trait.state !== TraitState.Pending) {\n      throw new Error(`Attempt to analyze trait of ${clazz.name.text} in state ${\n          TraitState[trait.state]} (expected DETECTED)`);\n    }\n\n    // Attempt analysis. This could fail with a `FatalDiagnosticError`; catch it if it does.\n    let result: AnalysisOutput<unknown>;\n    try {\n      result = trait.handler.analyze(clazz, trait.detected.metadata, flags);\n    } catch (err) {\n      if (err instanceof FatalDiagnosticError) {\n        trait.toAnalyzed(null, [err.toDiagnostic()], null);\n        return;\n      } else {\n        throw err;\n      }\n    }\n\n    const symbol = this.makeSymbolForTrait(trait.handler, clazz, result.analysis ?? null);\n    if (result.analysis !== undefined && trait.handler.register !== undefined) {\n      trait.handler.register(clazz, result.analysis);\n    }\n    trait = trait.toAnalyzed(result.analysis ?? null, result.diagnostics ?? null, symbol);\n  }\n\n  resolve(): void {\n    const classes = Array.from(this.classes.keys());\n    for (const clazz of classes) {\n      const record = this.classes.get(clazz)!;\n      for (let trait of record.traits) {\n        const handler = trait.handler;\n        switch (trait.state) {\n          case TraitState.Skipped:\n            continue;\n          case TraitState.Pending:\n            throw new Error(`Resolving a trait that hasn't been analyzed: ${clazz.name.text} / ${\n                Object.getPrototypeOf(trait.handler).constructor.name}`);\n          case TraitState.Resolved:\n            throw new Error(`Resolving an already resolved trait`);\n        }\n\n        if (trait.analysis === null) {\n          // No analysis results, cannot further process this trait.\n          continue;\n        }\n\n        if (handler.resolve === undefined) {\n          // No resolution of this trait needed - it's considered successful by default.\n          trait = trait.toResolved(null, null);\n          continue;\n        }\n\n        let result: ResolveResult<unknown>;\n        try {\n          result = handler.resolve(clazz, trait.analysis as Readonly<unknown>, trait.symbol);\n        } catch (err) {\n          if (err instanceof FatalDiagnosticError) {\n            trait = trait.toResolved(null, [err.toDiagnostic()]);\n            continue;\n          } else {\n            throw err;\n          }\n        }\n\n        trait = trait.toResolved(result.data ?? null, result.diagnostics ?? null);\n\n        if (result.reexports !== undefined) {\n          const fileName = clazz.getSourceFile().fileName;\n          if (!this.reexportMap.has(fileName)) {\n            this.reexportMap.set(fileName, new Map<string, [string, string]>());\n          }\n          const fileReexports = this.reexportMap.get(fileName)!;\n          for (const reexport of result.reexports) {\n            fileReexports.set(reexport.asAlias, [reexport.fromModule, reexport.symbolName]);\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * Generate type-checking code into the `TypeCheckContext` for any components within the given\n   * `ts.SourceFile`.\n   */\n  typeCheck(sf: ts.SourceFile, ctx: TypeCheckContext): void {\n    if (!this.fileToClasses.has(sf)) {\n      return;\n    }\n\n    for (const clazz of this.fileToClasses.get(sf)!) {\n      const record = this.classes.get(clazz)!;\n      for (const trait of record.traits) {\n        if (trait.state !== TraitState.Resolved) {\n          continue;\n        } else if (trait.handler.typeCheck === undefined) {\n          continue;\n        }\n        if (trait.resolution !== null) {\n          trait.handler.typeCheck(ctx, clazz, trait.analysis, trait.resolution);\n        }\n      }\n    }\n  }\n\n  index(ctx: IndexingContext): void {\n    for (const clazz of this.classes.keys()) {\n      const record = this.classes.get(clazz)!;\n      for (const trait of record.traits) {\n        if (trait.state !== TraitState.Resolved) {\n          // Skip traits that haven't been resolved successfully.\n          continue;\n        } else if (trait.handler.index === undefined) {\n          // Skip traits that don't affect indexing.\n          continue;\n        }\n\n        if (trait.resolution !== null) {\n          trait.handler.index(ctx, clazz, trait.analysis, trait.resolution);\n        }\n      }\n    }\n  }\n\n  updateResources(clazz: DeclarationNode): void {\n    if (!this.reflector.isClass(clazz) || !this.classes.has(clazz)) {\n      return;\n    }\n    const record = this.classes.get(clazz)!;\n    for (const trait of record.traits) {\n      if (trait.state !== TraitState.Resolved || trait.handler.updateResources === undefined) {\n        continue;\n      }\n\n      trait.handler.updateResources(clazz, trait.analysis, trait.resolution);\n    }\n  }\n\n  compile(clazz: DeclarationNode, constantPool: ConstantPool): CompileResult[]|null {\n    const original = ts.getOriginalNode(clazz) as typeof clazz;\n    if (!this.reflector.isClass(clazz) || !this.reflector.isClass(original) ||\n        !this.classes.has(original)) {\n      return null;\n    }\n\n    const record = this.classes.get(original)!;\n\n    let res: CompileResult[] = [];\n\n    for (const trait of record.traits) {\n      if (trait.state !== TraitState.Resolved || trait.analysisDiagnostics !== null ||\n          trait.resolveDiagnostics !== null) {\n        // Cannot compile a trait that is not resolved, or had any errors in its declaration.\n        continue;\n      }\n\n      const compileSpan = this.perf.start('compileClass', original);\n\n\n      // `trait.resolution` is non-null asserted here because TypeScript does not recognize that\n      // `Readonly<unknown>` is nullable (as `unknown` itself is nullable) due to the way that\n      // `Readonly` works.\n\n      let compileRes: CompileResult|CompileResult[];\n      if (this.compilationMode === CompilationMode.PARTIAL &&\n          trait.handler.compilePartial !== undefined) {\n        compileRes = trait.handler.compilePartial(clazz, trait.analysis, trait.resolution!);\n      } else {\n        compileRes =\n            trait.handler.compileFull(clazz, trait.analysis, trait.resolution!, constantPool);\n      }\n\n      const compileMatchRes = compileRes;\n      this.perf.stop(compileSpan);\n      if (Array.isArray(compileMatchRes)) {\n        for (const result of compileMatchRes) {\n          if (!res.some(r => r.name === result.name)) {\n            res.push(result);\n          }\n        }\n      } else if (!res.some(result => result.name === compileMatchRes.name)) {\n        res.push(compileMatchRes);\n      }\n    }\n\n    // Look up the .d.ts transformer for the input file and record that at least one field was\n    // generated, which will allow the .d.ts to be transformed later.\n    this.dtsTransforms.getIvyDeclarationTransform(original.getSourceFile())\n        .addFields(original, res);\n\n    // Return the instruction to the transformer so the fields will be added.\n    return res.length > 0 ? res : null;\n  }\n\n  decoratorsFor(node: ts.Declaration): ts.Decorator[] {\n    const original = ts.getOriginalNode(node) as typeof node;\n    if (!this.reflector.isClass(original) || !this.classes.has(original)) {\n      return [];\n    }\n\n    const record = this.classes.get(original)!;\n    const decorators: ts.Decorator[] = [];\n\n    for (const trait of record.traits) {\n      if (trait.state !== TraitState.Resolved) {\n        continue;\n      }\n\n      if (trait.detected.trigger !== null && ts.isDecorator(trait.detected.trigger)) {\n        decorators.push(trait.detected.trigger);\n      }\n    }\n\n    return decorators;\n  }\n\n  get diagnostics(): ReadonlyArray<ts.Diagnostic> {\n    const diagnostics: ts.Diagnostic[] = [];\n    for (const clazz of this.classes.keys()) {\n      const record = this.classes.get(clazz)!;\n      if (record.metaDiagnostics !== null) {\n        diagnostics.push(...record.metaDiagnostics);\n      }\n      for (const trait of record.traits) {\n        if ((trait.state === TraitState.Analyzed || trait.state === TraitState.Resolved) &&\n            trait.analysisDiagnostics !== null) {\n          diagnostics.push(...trait.analysisDiagnostics);\n        }\n        if (trait.state === TraitState.Resolved && trait.resolveDiagnostics !== null) {\n          diagnostics.push(...trait.resolveDiagnostics);\n        }\n      }\n    }\n    return diagnostics;\n  }\n\n  get exportStatements(): Map<string, Map<string, [string, string]>> {\n    return this.reexportMap;\n  }\n}\n"]}
|
|
@@ -7,6 +7,7 @@
|
|
|
7
7
|
*/
|
|
8
8
|
/// <amd-module name="@angular/compiler-cli/src/ngtsc/transform/src/trait" />
|
|
9
9
|
import * as ts from 'typescript';
|
|
10
|
+
import { SemanticSymbol } from '../../incremental/semantic_graph';
|
|
10
11
|
import { DecoratorHandler, DetectResult } from './api';
|
|
11
12
|
export declare enum TraitState {
|
|
12
13
|
/**
|
|
@@ -39,18 +40,18 @@ export declare enum TraitState {
|
|
|
39
40
|
* This not only simplifies the implementation, but ensures traits are monomorphic objects as
|
|
40
41
|
* they're all just "views" in the type system of the same object (which never changes shape).
|
|
41
42
|
*/
|
|
42
|
-
export declare type Trait<D, A, R> = PendingTrait<D, A, R> | SkippedTrait<D, A, R> | AnalyzedTrait<D, A, R> | ResolvedTrait<D, A, R>;
|
|
43
|
+
export declare type Trait<D, A, S extends SemanticSymbol | null, R> = PendingTrait<D, A, S, R> | SkippedTrait<D, A, S, R> | AnalyzedTrait<D, A, S, R> | ResolvedTrait<D, A, S, R>;
|
|
43
44
|
/**
|
|
44
45
|
* The value side of `Trait` exposes a helper to create a `Trait` in a pending state (by delegating
|
|
45
46
|
* to `TraitImpl`).
|
|
46
47
|
*/
|
|
47
48
|
export declare const Trait: {
|
|
48
|
-
pending: <D, A, R>(handler: DecoratorHandler<D, A, R>, detected: DetectResult<D>) => PendingTrait<D, A, R>;
|
|
49
|
+
pending: <D, A, S extends SemanticSymbol | null, R>(handler: DecoratorHandler<D, A, S, R>, detected: DetectResult<D>) => PendingTrait<D, A, S, R>;
|
|
49
50
|
};
|
|
50
51
|
/**
|
|
51
52
|
* The part of the `Trait` interface that's common to all trait states.
|
|
52
53
|
*/
|
|
53
|
-
export interface TraitBase<D, A, R> {
|
|
54
|
+
export interface TraitBase<D, A, S extends SemanticSymbol | null, R> {
|
|
54
55
|
/**
|
|
55
56
|
* Current state of the trait.
|
|
56
57
|
*
|
|
@@ -60,7 +61,7 @@ export interface TraitBase<D, A, R> {
|
|
|
60
61
|
/**
|
|
61
62
|
* The `DecoratorHandler` which matched on the class to create this trait.
|
|
62
63
|
*/
|
|
63
|
-
handler: DecoratorHandler<D, A, R>;
|
|
64
|
+
handler: DecoratorHandler<D, A, S, R>;
|
|
64
65
|
/**
|
|
65
66
|
* The detection result (of `handler.detect`) which indicated that this trait applied to the
|
|
66
67
|
* class.
|
|
@@ -74,18 +75,18 @@ export interface TraitBase<D, A, R> {
|
|
|
74
75
|
*
|
|
75
76
|
* Pending traits have yet to be analyzed in any way.
|
|
76
77
|
*/
|
|
77
|
-
export interface PendingTrait<D, A, R> extends TraitBase<D, A, R> {
|
|
78
|
+
export interface PendingTrait<D, A, S extends SemanticSymbol | null, R> extends TraitBase<D, A, S, R> {
|
|
78
79
|
state: TraitState.Pending;
|
|
79
80
|
/**
|
|
80
81
|
* This pending trait has been successfully analyzed, and should transition to the "analyzed"
|
|
81
82
|
* state.
|
|
82
83
|
*/
|
|
83
|
-
toAnalyzed(analysis: A | null, diagnostics: ts.Diagnostic[] | null): AnalyzedTrait<D, A, R>;
|
|
84
|
+
toAnalyzed(analysis: A | null, diagnostics: ts.Diagnostic[] | null, symbol: S): AnalyzedTrait<D, A, S, R>;
|
|
84
85
|
/**
|
|
85
86
|
* During analysis it was determined that this trait is not eligible for compilation after all,
|
|
86
87
|
* and should be transitioned to the "skipped" state.
|
|
87
88
|
*/
|
|
88
|
-
toSkipped(): SkippedTrait<D, A, R>;
|
|
89
|
+
toSkipped(): SkippedTrait<D, A, S, R>;
|
|
89
90
|
}
|
|
90
91
|
/**
|
|
91
92
|
* A trait in the "skipped" state.
|
|
@@ -94,7 +95,7 @@ export interface PendingTrait<D, A, R> extends TraitBase<D, A, R> {
|
|
|
94
95
|
*
|
|
95
96
|
* This is a terminal state.
|
|
96
97
|
*/
|
|
97
|
-
export interface SkippedTrait<D, A, R> extends TraitBase<D, A, R> {
|
|
98
|
+
export interface SkippedTrait<D, A, S extends SemanticSymbol | null, R> extends TraitBase<D, A, S, R> {
|
|
98
99
|
state: TraitState.Skipped;
|
|
99
100
|
}
|
|
100
101
|
/**
|
|
@@ -102,8 +103,9 @@ export interface SkippedTrait<D, A, R> extends TraitBase<D, A, R> {
|
|
|
102
103
|
*
|
|
103
104
|
* Analyzed traits have analysis results available, and are eligible for resolution.
|
|
104
105
|
*/
|
|
105
|
-
export interface AnalyzedTrait<D, A, R> extends TraitBase<D, A, R> {
|
|
106
|
+
export interface AnalyzedTrait<D, A, S extends SemanticSymbol | null, R> extends TraitBase<D, A, S, R> {
|
|
106
107
|
state: TraitState.Analyzed;
|
|
108
|
+
symbol: S;
|
|
107
109
|
/**
|
|
108
110
|
* Analysis results of the given trait (if able to be produced), or `null` if analysis failed
|
|
109
111
|
* completely.
|
|
@@ -117,7 +119,7 @@ export interface AnalyzedTrait<D, A, R> extends TraitBase<D, A, R> {
|
|
|
117
119
|
* This analyzed trait has been successfully resolved, and should be transitioned to the
|
|
118
120
|
* "resolved" state.
|
|
119
121
|
*/
|
|
120
|
-
toResolved(resolution: R | null, diagnostics: ts.Diagnostic[] | null): ResolvedTrait<D, A, R>;
|
|
122
|
+
toResolved(resolution: R | null, diagnostics: ts.Diagnostic[] | null): ResolvedTrait<D, A, S, R>;
|
|
121
123
|
}
|
|
122
124
|
/**
|
|
123
125
|
* A trait in the "resolved" state.
|
|
@@ -127,8 +129,9 @@ export interface AnalyzedTrait<D, A, R> extends TraitBase<D, A, R> {
|
|
|
127
129
|
*
|
|
128
130
|
* This is a terminal state.
|
|
129
131
|
*/
|
|
130
|
-
export interface ResolvedTrait<D, A, R> extends TraitBase<D, A, R> {
|
|
132
|
+
export interface ResolvedTrait<D, A, S extends SemanticSymbol | null, R> extends TraitBase<D, A, S, R> {
|
|
131
133
|
state: TraitState.Resolved;
|
|
134
|
+
symbol: S;
|
|
132
135
|
/**
|
|
133
136
|
* Resolved traits must have produced valid analysis results.
|
|
134
137
|
*/
|
|
@@ -41,7 +41,9 @@
|
|
|
41
41
|
* to `TraitImpl`).
|
|
42
42
|
*/
|
|
43
43
|
exports.Trait = {
|
|
44
|
-
pending: function (handler, detected) {
|
|
44
|
+
pending: function (handler, detected) {
|
|
45
|
+
return TraitImpl.pending(handler, detected);
|
|
46
|
+
},
|
|
45
47
|
};
|
|
46
48
|
/**
|
|
47
49
|
* An implementation of the `Trait` type which transitions safely between the various
|
|
@@ -51,17 +53,19 @@
|
|
|
51
53
|
function TraitImpl(handler, detected) {
|
|
52
54
|
this.state = TraitState.Pending;
|
|
53
55
|
this.analysis = null;
|
|
56
|
+
this.symbol = null;
|
|
54
57
|
this.resolution = null;
|
|
55
58
|
this.analysisDiagnostics = null;
|
|
56
59
|
this.resolveDiagnostics = null;
|
|
57
60
|
this.handler = handler;
|
|
58
61
|
this.detected = detected;
|
|
59
62
|
}
|
|
60
|
-
TraitImpl.prototype.toAnalyzed = function (analysis, diagnostics) {
|
|
63
|
+
TraitImpl.prototype.toAnalyzed = function (analysis, diagnostics, symbol) {
|
|
61
64
|
// Only pending traits can be analyzed.
|
|
62
65
|
this.assertTransitionLegal(TraitState.Pending, TraitState.Analyzed);
|
|
63
66
|
this.analysis = analysis;
|
|
64
67
|
this.analysisDiagnostics = diagnostics;
|
|
68
|
+
this.symbol = symbol;
|
|
65
69
|
this.state = TraitState.Analyzed;
|
|
66
70
|
return this;
|
|
67
71
|
};
|
|
@@ -104,4 +108,4 @@
|
|
|
104
108
|
return TraitImpl;
|
|
105
109
|
}());
|
|
106
110
|
});
|
|
107
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trait.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/transform/src/trait.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;IAKH,IAAY,UAoBX;IApBD,WAAY,UAAU;QACpB;;WAEG;QACH,iDAAO,CAAA;QAEP;;WAEG;QACH,mDAAQ,CAAA;QAER;;WAEG;QACH,mDAAQ,CAAA;QAER;;WAEG;QACH,iDAAO,CAAA;IACT,CAAC,EApBW,UAAU,GAAV,kBAAU,KAAV,kBAAU,QAoBrB;IAkBD;;;OAGG;IACU,QAAA,KAAK,GAAG;QACnB,OAAO,EAAE,UAAU,OAAkC,EAAE,QAAyB,IACnD,OAAA,SAAS,CAAC,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC,EAApC,CAAoC;KAClE,CAAC;IAsHF;;;OAGG;IACH;QASE,mBAAY,OAAkC,EAAE,QAAyB;YARzE,UAAK,GAAe,UAAU,CAAC,OAAO,CAAC;YAGvC,aAAQ,GAAqB,IAAI,CAAC;YAClC,eAAU,GAAqB,IAAI,CAAC;YACpC,wBAAmB,GAAyB,IAAI,CAAC;YACjD,uBAAkB,GAAyB,IAAI,CAAC;YAG9C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;YACvB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAC3B,CAAC;QAED,8BAAU,GAAV,UAAW,QAAgB,EAAE,WAAiC;YAC5D,uCAAuC;YACvC,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;YACpE,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;YACzB,IAAI,CAAC,mBAAmB,GAAG,WAAW,CAAC;YACvC,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,QAAQ,CAAC;YACjC,OAAO,IAA8B,CAAC;QACxC,CAAC;QAED,8BAAU,GAAV,UAAW,UAAkB,EAAE,WAAiC;YAC9D,wCAAwC;YACxC,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,QAAQ,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;YACrE,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE;gBAC1B,MAAM,IAAI,KAAK,CAAC,sEAAsE,CAAC,CAAC;aACzF;YACD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;YAC7B,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,QAAQ,CAAC;YACjC,IAAI,CAAC,kBAAkB,GAAG,WAAW,CAAC;YACtC,OAAO,IAA8B,CAAC;QACxC,CAAC;QAED,6BAAS,GAAT;YACE,sCAAsC;YACtC,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;YACnE,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,OAAO,CAAC;YAChC,OAAO,IAA6B,CAAC;QACvC,CAAC;QAED;;;;;;;WAOG;QACK,yCAAqB,GAA7B,UAA8B,YAAwB,EAAE,YAAwB;YAC9E,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,KAAK,YAAY,CAAC,EAAE;gBAClC,MAAM,IAAI,KAAK,CAAC,+CAA6C,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,YAC/E,UAAU,CAAC,YAAY,CAAC,MAAG,CAAC,CAAC;aAClC;QACH,CAAC;QAED;;WAEG;QACI,iBAAO,GAAd,UAAwB,OAAkC,EAAE,QAAyB;YAEnF,OAAO,IAAI,SAAS,CAAC,OAAO,EAAE,QAAQ,CAA0B,CAAC;QACnE,CAAC;QACH,gBAAC;IAAD,CAAC,AAhED,IAgEC","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 * as ts from 'typescript';\nimport {DecoratorHandler, DetectResult} from './api';\n\nexport enum TraitState {\n  /**\n   * Pending traits are freshly created and have never been analyzed.\n   */\n  Pending,\n\n  /**\n   * Analyzed traits have successfully been analyzed, but are pending resolution.\n   */\n  Analyzed,\n\n  /**\n   * Resolved traits have successfully been analyzed and resolved and are ready for compilation.\n   */\n  Resolved,\n\n  /**\n   * Skipped traits are no longer considered for compilation.\n   */\n  Skipped,\n}\n\n/**\n * An Ivy aspect added to a class (for example, the compilation of a component definition).\n *\n * Traits are created when a `DecoratorHandler` matches a class. Each trait begins in a pending\n * state and undergoes transitions as compilation proceeds through the various steps.\n *\n * In practice, traits are instances of the private class `TraitImpl` declared below. Through the\n * various interfaces included in this union type, the legal API of a trait in any given state is\n * represented in the type system. This includes any possible transitions from one type to the next.\n *\n * This not only simplifies the implementation, but ensures traits are monomorphic objects as\n * they're all just \"views\" in the type system of the same object (which never changes shape).\n */\nexport type Trait<D, A, R> =\n    PendingTrait<D, A, R>|SkippedTrait<D, A, R>|AnalyzedTrait<D, A, R>|ResolvedTrait<D, A, R>;\n\n/**\n * The value side of `Trait` exposes a helper to create a `Trait` in a pending state (by delegating\n * to `TraitImpl`).\n */\nexport const Trait = {\n  pending: <D, A, R>(handler: DecoratorHandler<D, A, R>, detected: DetectResult<D>):\n      PendingTrait<D, A, R> => TraitImpl.pending(handler, detected),\n};\n\n/**\n * The part of the `Trait` interface that's common to all trait states.\n */\nexport interface TraitBase<D, A, R> {\n  /**\n   * Current state of the trait.\n   *\n   * This will be narrowed in the interfaces for each specific state.\n   */\n  state: TraitState;\n\n  /**\n   * The `DecoratorHandler` which matched on the class to create this trait.\n   */\n  handler: DecoratorHandler<D, A, R>;\n\n  /**\n   * The detection result (of `handler.detect`) which indicated that this trait applied to the\n   * class.\n   *\n   * This is mainly used to cache the detection between pre-analysis and analysis.\n   */\n  detected: DetectResult<D>;\n}\n\n/**\n * A trait in the pending state.\n *\n * Pending traits have yet to be analyzed in any way.\n */\nexport interface PendingTrait<D, A, R> extends TraitBase<D, A, R> {\n  state: TraitState.Pending;\n\n  /**\n   * This pending trait has been successfully analyzed, and should transition to the \"analyzed\"\n   * state.\n   */\n  toAnalyzed(analysis: A|null, diagnostics: ts.Diagnostic[]|null): AnalyzedTrait<D, A, R>;\n\n  /**\n   * During analysis it was determined that this trait is not eligible for compilation after all,\n   * and should be transitioned to the \"skipped\" state.\n   */\n  toSkipped(): SkippedTrait<D, A, R>;\n}\n\n/**\n * A trait in the \"skipped\" state.\n *\n * Skipped traits aren't considered for compilation.\n *\n * This is a terminal state.\n */\nexport interface SkippedTrait<D, A, R> extends TraitBase<D, A, R> {\n  state: TraitState.Skipped;\n}\n\n/**\n * A trait in the \"analyzed\" state.\n *\n * Analyzed traits have analysis results available, and are eligible for resolution.\n */\nexport interface AnalyzedTrait<D, A, R> extends TraitBase<D, A, R> {\n  state: TraitState.Analyzed;\n\n  /**\n   * Analysis results of the given trait (if able to be produced), or `null` if analysis failed\n   * completely.\n   */\n  analysis: Readonly<A>|null;\n\n  /**\n   * Any diagnostics that resulted from analysis, or `null` if none.\n   */\n  analysisDiagnostics: ts.Diagnostic[]|null;\n\n  /**\n   * This analyzed trait has been successfully resolved, and should be transitioned to the\n   * \"resolved\" state.\n   */\n  toResolved(resolution: R|null, diagnostics: ts.Diagnostic[]|null): ResolvedTrait<D, A, R>;\n}\n\n/**\n * A trait in the \"resolved\" state.\n *\n * Resolved traits have been successfully analyzed and resolved, contain no errors, and are ready\n * for the compilation phase.\n *\n * This is a terminal state.\n */\nexport interface ResolvedTrait<D, A, R> extends TraitBase<D, A, R> {\n  state: TraitState.Resolved;\n\n  /**\n   * Resolved traits must have produced valid analysis results.\n   */\n  analysis: Readonly<A>;\n\n  /**\n   * Analysis may have still resulted in diagnostics.\n   */\n  analysisDiagnostics: ts.Diagnostic[]|null;\n\n  /**\n   * Diagnostics resulting from resolution are tracked separately from\n   */\n  resolveDiagnostics: ts.Diagnostic[]|null;\n\n  /**\n   * The results returned by a successful resolution of the given class/`DecoratorHandler`\n   * combination.\n   */\n  resolution: Readonly<R>|null;\n}\n\n/**\n * An implementation of the `Trait` type which transitions safely between the various\n * `TraitState`s.\n */\nclass TraitImpl<D, A, R> {\n  state: TraitState = TraitState.Pending;\n  handler: DecoratorHandler<D, A, R>;\n  detected: DetectResult<D>;\n  analysis: Readonly<A>|null = null;\n  resolution: Readonly<R>|null = null;\n  analysisDiagnostics: ts.Diagnostic[]|null = null;\n  resolveDiagnostics: ts.Diagnostic[]|null = null;\n\n  constructor(handler: DecoratorHandler<D, A, R>, detected: DetectResult<D>) {\n    this.handler = handler;\n    this.detected = detected;\n  }\n\n  toAnalyzed(analysis: A|null, diagnostics: ts.Diagnostic[]|null): AnalyzedTrait<D, A, R> {\n    // Only pending traits can be analyzed.\n    this.assertTransitionLegal(TraitState.Pending, TraitState.Analyzed);\n    this.analysis = analysis;\n    this.analysisDiagnostics = diagnostics;\n    this.state = TraitState.Analyzed;\n    return this as AnalyzedTrait<D, A, R>;\n  }\n\n  toResolved(resolution: R|null, diagnostics: ts.Diagnostic[]|null): ResolvedTrait<D, A, R> {\n    // Only analyzed traits can be resolved.\n    this.assertTransitionLegal(TraitState.Analyzed, TraitState.Resolved);\n    if (this.analysis === null) {\n      throw new Error(`Cannot transition an Analyzed trait with a null analysis to Resolved`);\n    }\n    this.resolution = resolution;\n    this.state = TraitState.Resolved;\n    this.resolveDiagnostics = diagnostics;\n    return this as ResolvedTrait<D, A, R>;\n  }\n\n  toSkipped(): SkippedTrait<D, A, R> {\n    // Only pending traits can be skipped.\n    this.assertTransitionLegal(TraitState.Pending, TraitState.Skipped);\n    this.state = TraitState.Skipped;\n    return this as SkippedTrait<D, A, R>;\n  }\n\n  /**\n   * Verifies that the trait is currently in one of the `allowedState`s.\n   *\n   * If correctly used, the `Trait` type and transition methods prevent illegal transitions from\n   * occurring. However, if a reference to the `TraitImpl` instance typed with the previous\n   * interface is retained after calling one of its transition methods, it will allow for illegal\n   * transitions to take place. Hence, this assertion provides a little extra runtime protection.\n   */\n  private assertTransitionLegal(allowedState: TraitState, transitionTo: TraitState): void {\n    if (!(this.state === allowedState)) {\n      throw new Error(`Assertion failure: cannot transition from ${TraitState[this.state]} to ${\n          TraitState[transitionTo]}.`);\n    }\n  }\n\n  /**\n   * Construct a new `TraitImpl` in the pending state.\n   */\n  static pending<D, A, R>(handler: DecoratorHandler<D, A, R>, detected: DetectResult<D>):\n      PendingTrait<D, A, R> {\n    return new TraitImpl(handler, detected) as PendingTrait<D, A, R>;\n  }\n}\n"]}
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trait.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/transform/src/trait.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;IAMH,IAAY,UAoBX;IApBD,WAAY,UAAU;QACpB;;WAEG;QACH,iDAAO,CAAA;QAEP;;WAEG;QACH,mDAAQ,CAAA;QAER;;WAEG;QACH,mDAAQ,CAAA;QAER;;WAEG;QACH,iDAAO,CAAA;IACT,CAAC,EApBW,UAAU,GAAV,kBAAU,KAAV,kBAAU,QAoBrB;IAkBD;;;OAGG;IACU,QAAA,KAAK,GAAG;QACnB,OAAO,EAAE,UACL,OAAqC,EAAE,QAAyB;YAChE,OAAA,SAAS,CAAC,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC;QAApC,CAAoC;KACzC,CAAC;IA6HF;;;OAGG;IACH;QAUE,mBAAY,OAAqC,EAAE,QAAyB;YAT5E,UAAK,GAAe,UAAU,CAAC,OAAO,CAAC;YAGvC,aAAQ,GAAqB,IAAI,CAAC;YAClC,WAAM,GAAW,IAAI,CAAC;YACtB,eAAU,GAAqB,IAAI,CAAC;YACpC,wBAAmB,GAAyB,IAAI,CAAC;YACjD,uBAAkB,GAAyB,IAAI,CAAC;YAG9C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;YACvB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAC3B,CAAC;QAED,8BAAU,GAAV,UAAW,QAAgB,EAAE,WAAiC,EAAE,MAAS;YAEvE,uCAAuC;YACvC,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;YACpE,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;YACzB,IAAI,CAAC,mBAAmB,GAAG,WAAW,CAAC;YACvC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;YACrB,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,QAAQ,CAAC;YACjC,OAAO,IAAiC,CAAC;QAC3C,CAAC;QAED,8BAAU,GAAV,UAAW,UAAkB,EAAE,WAAiC;YAC9D,wCAAwC;YACxC,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,QAAQ,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;YACrE,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE;gBAC1B,MAAM,IAAI,KAAK,CAAC,sEAAsE,CAAC,CAAC;aACzF;YACD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;YAC7B,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,QAAQ,CAAC;YACjC,IAAI,CAAC,kBAAkB,GAAG,WAAW,CAAC;YACtC,OAAO,IAAiC,CAAC;QAC3C,CAAC;QAED,6BAAS,GAAT;YACE,sCAAsC;YACtC,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;YACnE,IAAI,CAAC,KAAK,GAAG,UAAU,CAAC,OAAO,CAAC;YAChC,OAAO,IAAgC,CAAC;QAC1C,CAAC;QAED;;;;;;;WAOG;QACK,yCAAqB,GAA7B,UAA8B,YAAwB,EAAE,YAAwB;YAC9E,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,KAAK,YAAY,CAAC,EAAE;gBAClC,MAAM,IAAI,KAAK,CAAC,+CAA6C,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,YAC/E,UAAU,CAAC,YAAY,CAAC,MAAG,CAAC,CAAC;aAClC;QACH,CAAC;QAED;;WAEG;QACI,iBAAO,GAAd,UACI,OAAqC,EAAE,QAAyB;YAClE,OAAO,IAAI,SAAS,CAAC,OAAO,EAAE,QAAQ,CAA6B,CAAC;QACtE,CAAC;QACH,gBAAC;IAAD,CAAC,AAnED,IAmEC","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 * as ts from 'typescript';\nimport {SemanticSymbol} from '../../incremental/semantic_graph';\nimport {DecoratorHandler, DetectResult} from './api';\n\nexport enum TraitState {\n  /**\n   * Pending traits are freshly created and have never been analyzed.\n   */\n  Pending,\n\n  /**\n   * Analyzed traits have successfully been analyzed, but are pending resolution.\n   */\n  Analyzed,\n\n  /**\n   * Resolved traits have successfully been analyzed and resolved and are ready for compilation.\n   */\n  Resolved,\n\n  /**\n   * Skipped traits are no longer considered for compilation.\n   */\n  Skipped,\n}\n\n/**\n * An Ivy aspect added to a class (for example, the compilation of a component definition).\n *\n * Traits are created when a `DecoratorHandler` matches a class. Each trait begins in a pending\n * state and undergoes transitions as compilation proceeds through the various steps.\n *\n * In practice, traits are instances of the private class `TraitImpl` declared below. Through the\n * various interfaces included in this union type, the legal API of a trait in any given state is\n * represented in the type system. This includes any possible transitions from one type to the next.\n *\n * This not only simplifies the implementation, but ensures traits are monomorphic objects as\n * they're all just \"views\" in the type system of the same object (which never changes shape).\n */\nexport type Trait<D, A, S extends SemanticSymbol|null, R> = PendingTrait<D, A, S, R>|\n    SkippedTrait<D, A, S, R>|AnalyzedTrait<D, A, S, R>|ResolvedTrait<D, A, S, R>;\n\n/**\n * The value side of `Trait` exposes a helper to create a `Trait` in a pending state (by delegating\n * to `TraitImpl`).\n */\nexport const Trait = {\n  pending: <D, A, S extends SemanticSymbol|null, R>(\n      handler: DecoratorHandler<D, A, S, R>, detected: DetectResult<D>): PendingTrait<D, A, S, R> =>\n      TraitImpl.pending(handler, detected),\n};\n\n/**\n * The part of the `Trait` interface that's common to all trait states.\n */\nexport interface TraitBase<D, A, S extends SemanticSymbol|null, R> {\n  /**\n   * Current state of the trait.\n   *\n   * This will be narrowed in the interfaces for each specific state.\n   */\n  state: TraitState;\n\n  /**\n   * The `DecoratorHandler` which matched on the class to create this trait.\n   */\n  handler: DecoratorHandler<D, A, S, R>;\n\n  /**\n   * The detection result (of `handler.detect`) which indicated that this trait applied to the\n   * class.\n   *\n   * This is mainly used to cache the detection between pre-analysis and analysis.\n   */\n  detected: DetectResult<D>;\n}\n\n/**\n * A trait in the pending state.\n *\n * Pending traits have yet to be analyzed in any way.\n */\nexport interface PendingTrait<D, A, S extends SemanticSymbol|null, R> extends\n    TraitBase<D, A, S, R> {\n  state: TraitState.Pending;\n\n  /**\n   * This pending trait has been successfully analyzed, and should transition to the \"analyzed\"\n   * state.\n   */\n  toAnalyzed(analysis: A|null, diagnostics: ts.Diagnostic[]|null, symbol: S):\n      AnalyzedTrait<D, A, S, R>;\n\n  /**\n   * During analysis it was determined that this trait is not eligible for compilation after all,\n   * and should be transitioned to the \"skipped\" state.\n   */\n  toSkipped(): SkippedTrait<D, A, S, R>;\n}\n\n/**\n * A trait in the \"skipped\" state.\n *\n * Skipped traits aren't considered for compilation.\n *\n * This is a terminal state.\n */\nexport interface SkippedTrait<D, A, S extends SemanticSymbol|null, R> extends\n    TraitBase<D, A, S, R> {\n  state: TraitState.Skipped;\n}\n\n/**\n * A trait in the \"analyzed\" state.\n *\n * Analyzed traits have analysis results available, and are eligible for resolution.\n */\nexport interface AnalyzedTrait<D, A, S extends SemanticSymbol|null, R> extends\n    TraitBase<D, A, S, R> {\n  state: TraitState.Analyzed;\n  symbol: S;\n\n  /**\n   * Analysis results of the given trait (if able to be produced), or `null` if analysis failed\n   * completely.\n   */\n  analysis: Readonly<A>|null;\n\n  /**\n   * Any diagnostics that resulted from analysis, or `null` if none.\n   */\n  analysisDiagnostics: ts.Diagnostic[]|null;\n\n  /**\n   * This analyzed trait has been successfully resolved, and should be transitioned to the\n   * \"resolved\" state.\n   */\n  toResolved(resolution: R|null, diagnostics: ts.Diagnostic[]|null): ResolvedTrait<D, A, S, R>;\n}\n\n/**\n * A trait in the \"resolved\" state.\n *\n * Resolved traits have been successfully analyzed and resolved, contain no errors, and are ready\n * for the compilation phase.\n *\n * This is a terminal state.\n */\nexport interface ResolvedTrait<D, A, S extends SemanticSymbol|null, R> extends\n    TraitBase<D, A, S, R> {\n  state: TraitState.Resolved;\n  symbol: S;\n\n  /**\n   * Resolved traits must have produced valid analysis results.\n   */\n  analysis: Readonly<A>;\n\n  /**\n   * Analysis may have still resulted in diagnostics.\n   */\n  analysisDiagnostics: ts.Diagnostic[]|null;\n\n  /**\n   * Diagnostics resulting from resolution are tracked separately from\n   */\n  resolveDiagnostics: ts.Diagnostic[]|null;\n\n  /**\n   * The results returned by a successful resolution of the given class/`DecoratorHandler`\n   * combination.\n   */\n  resolution: Readonly<R>|null;\n}\n\n/**\n * An implementation of the `Trait` type which transitions safely between the various\n * `TraitState`s.\n */\nclass TraitImpl<D, A, S extends SemanticSymbol|null, R> {\n  state: TraitState = TraitState.Pending;\n  handler: DecoratorHandler<D, A, S, R>;\n  detected: DetectResult<D>;\n  analysis: Readonly<A>|null = null;\n  symbol: S|null = null;\n  resolution: Readonly<R>|null = null;\n  analysisDiagnostics: ts.Diagnostic[]|null = null;\n  resolveDiagnostics: ts.Diagnostic[]|null = null;\n\n  constructor(handler: DecoratorHandler<D, A, S, R>, detected: DetectResult<D>) {\n    this.handler = handler;\n    this.detected = detected;\n  }\n\n  toAnalyzed(analysis: A|null, diagnostics: ts.Diagnostic[]|null, symbol: S):\n      AnalyzedTrait<D, A, S, R> {\n    // Only pending traits can be analyzed.\n    this.assertTransitionLegal(TraitState.Pending, TraitState.Analyzed);\n    this.analysis = analysis;\n    this.analysisDiagnostics = diagnostics;\n    this.symbol = symbol;\n    this.state = TraitState.Analyzed;\n    return this as AnalyzedTrait<D, A, S, R>;\n  }\n\n  toResolved(resolution: R|null, diagnostics: ts.Diagnostic[]|null): ResolvedTrait<D, A, S, R> {\n    // Only analyzed traits can be resolved.\n    this.assertTransitionLegal(TraitState.Analyzed, TraitState.Resolved);\n    if (this.analysis === null) {\n      throw new Error(`Cannot transition an Analyzed trait with a null analysis to Resolved`);\n    }\n    this.resolution = resolution;\n    this.state = TraitState.Resolved;\n    this.resolveDiagnostics = diagnostics;\n    return this as ResolvedTrait<D, A, S, R>;\n  }\n\n  toSkipped(): SkippedTrait<D, A, S, R> {\n    // Only pending traits can be skipped.\n    this.assertTransitionLegal(TraitState.Pending, TraitState.Skipped);\n    this.state = TraitState.Skipped;\n    return this as SkippedTrait<D, A, S, R>;\n  }\n\n  /**\n   * Verifies that the trait is currently in one of the `allowedState`s.\n   *\n   * If correctly used, the `Trait` type and transition methods prevent illegal transitions from\n   * occurring. However, if a reference to the `TraitImpl` instance typed with the previous\n   * interface is retained after calling one of its transition methods, it will allow for illegal\n   * transitions to take place. Hence, this assertion provides a little extra runtime protection.\n   */\n  private assertTransitionLegal(allowedState: TraitState, transitionTo: TraitState): void {\n    if (!(this.state === allowedState)) {\n      throw new Error(`Assertion failure: cannot transition from ${TraitState[this.state]} to ${\n          TraitState[transitionTo]}.`);\n    }\n  }\n\n  /**\n   * Construct a new `TraitImpl` in the pending state.\n   */\n  static pending<D, A, S extends SemanticSymbol|null, R>(\n      handler: DecoratorHandler<D, A, S, R>, detected: DetectResult<D>): PendingTrait<D, A, S, R> {\n    return new TraitImpl(handler, detected) as PendingTrait<D, A, S, R>;\n  }\n}\n"]}
|
|
@@ -231,6 +231,33 @@ export interface TypeCheckingConfig {
|
|
|
231
231
|
* literals are cast to `any` when declared.
|
|
232
232
|
*/
|
|
233
233
|
strictLiteralTypes: boolean;
|
|
234
|
+
/**
|
|
235
|
+
* Whether to use inline type constructors.
|
|
236
|
+
*
|
|
237
|
+
* If this is `true`, create inline type constructors when required. For example, if a type
|
|
238
|
+
* constructor's parameters has private types, it cannot be created normally, so we inline it in
|
|
239
|
+
* the directives definition file.
|
|
240
|
+
*
|
|
241
|
+
* If false, do not create inline type constructors. Fall back to using `any` type for
|
|
242
|
+
* constructors that normally require inlining.
|
|
243
|
+
*
|
|
244
|
+
* This option requires the environment to support inlining. If the environment does not support
|
|
245
|
+
* inlining, this must be set to `false`.
|
|
246
|
+
*/
|
|
247
|
+
useInlineTypeConstructors: boolean;
|
|
248
|
+
/**
|
|
249
|
+
* Whether or not to produce diagnostic suggestions in cases where the compiler could have
|
|
250
|
+
* inferred a better type for a construct, but was prevented from doing so by the current type
|
|
251
|
+
* checking configuration.
|
|
252
|
+
*
|
|
253
|
+
* For example, if the compiler could have used a template context guard to infer a better type
|
|
254
|
+
* for a structural directive's context and `let-` variables, but the user is in
|
|
255
|
+
* `fullTemplateTypeCheck` mode and such guards are therefore disabled.
|
|
256
|
+
*
|
|
257
|
+
* This mode is useful for clients like the Language Service which want to inform users of
|
|
258
|
+
* opportunities to improve their own developer experience.
|
|
259
|
+
*/
|
|
260
|
+
suggestionsForSuboptimalTypeInference: boolean;
|
|
234
261
|
}
|
|
235
262
|
export declare type TemplateSourceMapping = DirectTemplateSourceMapping | IndirectTemplateSourceMapping | ExternalTemplateSourceMapping;
|
|
236
263
|
/**
|