@angular/compiler-cli 11.0.0-rc.3 → 11.0.3

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.
@@ -6,6 +6,7 @@
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
8
  /// <amd-module name="@angular/compiler-cli/src/ngtsc/scope/src/api" />
9
+ import { Reference } from '../../imports';
9
10
  import { DirectiveMeta, PipeMeta } from '../../metadata';
10
11
  import { ClassDeclaration } from '../../reflection';
11
12
  /**
@@ -35,3 +36,17 @@ export interface ExportScope {
35
36
  */
36
37
  exported: ScopeData;
37
38
  }
39
+ /**
40
+ * A resolved scope for a given component that cannot be set locally in the component definition,
41
+ * and must be set via remote scoping call in the component's NgModule file.
42
+ */
43
+ export interface RemoteScope {
44
+ /**
45
+ * Those directives used by the component that requires this scope to be set remotely.
46
+ */
47
+ directives: Reference[];
48
+ /**
49
+ * Those pipes used by the component that requires this scope to be set remotely.
50
+ */
51
+ pipes: Reference[];
52
+ }
@@ -17,4 +17,4 @@
17
17
  "use strict";
18
18
  Object.defineProperty(exports, "__esModule", { value: true });
19
19
  });
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcGlsZXItY2xpL3NyYy9uZ3RzYy9zY29wZS9zcmMvYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQge0RpcmVjdGl2ZU1ldGEsIFBpcGVNZXRhfSBmcm9tICcuLi8uLi9tZXRhZGF0YSc7XG5pbXBvcnQge0NsYXNzRGVjbGFyYXRpb259IGZyb20gJy4uLy4uL3JlZmxlY3Rpb24nO1xuXG5cbi8qKlxuICogRGF0YSBmb3Igb25lIG9mIGEgZ2l2ZW4gTmdNb2R1bGUncyBzY29wZXMgKGVpdGhlciBjb21waWxhdGlvbiBzY29wZSBvciBleHBvcnQgc2NvcGVzKS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTY29wZURhdGEge1xuICAvKipcbiAgICogRGlyZWN0aXZlcyBpbiB0aGUgZXhwb3J0ZWQgc2NvcGUgb2YgdGhlIG1vZHVsZS5cbiAgICovXG4gIGRpcmVjdGl2ZXM6IERpcmVjdGl2ZU1ldGFbXTtcblxuICAvKipcbiAgICogUGlwZXMgaW4gdGhlIGV4cG9ydGVkIHNjb3BlIG9mIHRoZSBtb2R1bGUuXG4gICAqL1xuICBwaXBlczogUGlwZU1ldGFbXTtcblxuICAvKipcbiAgICogTmdNb2R1bGVzIHdoaWNoIGNvbnRyaWJ1dGVkIHRvIHRoZSBzY29wZSBvZiB0aGUgbW9kdWxlLlxuICAgKi9cbiAgbmdNb2R1bGVzOiBDbGFzc0RlY2xhcmF0aW9uW107XG59XG5cbi8qKlxuICogQW4gZXhwb3J0IHNjb3BlIG9mIGFuIE5nTW9kdWxlLCBjb250YWluaW5nIHRoZSBkaXJlY3RpdmVzL3BpcGVzIGl0IGNvbnRyaWJ1dGVzIHRvIG90aGVyIE5nTW9kdWxlc1xuICogd2hpY2ggaW1wb3J0IGl0LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEV4cG9ydFNjb3BlIHtcbiAgLyoqXG4gICAqIFRoZSBzY29wZSBleHBvcnRlZCBieSBhbiBOZ01vZHVsZSwgYW5kIGF2YWlsYWJsZSBmb3IgaW1wb3J0LlxuICAgKi9cbiAgZXhwb3J0ZWQ6IFNjb3BlRGF0YTtcbn1cbiJdfQ==
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcGlsZXItY2xpL3NyYy9uZ3RzYy9zY29wZS9zcmMvYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQge1JlZmVyZW5jZX0gZnJvbSAnLi4vLi4vaW1wb3J0cyc7XG5pbXBvcnQge0RpcmVjdGl2ZU1ldGEsIFBpcGVNZXRhfSBmcm9tICcuLi8uLi9tZXRhZGF0YSc7XG5pbXBvcnQge0NsYXNzRGVjbGFyYXRpb259IGZyb20gJy4uLy4uL3JlZmxlY3Rpb24nO1xuXG5cbi8qKlxuICogRGF0YSBmb3Igb25lIG9mIGEgZ2l2ZW4gTmdNb2R1bGUncyBzY29wZXMgKGVpdGhlciBjb21waWxhdGlvbiBzY29wZSBvciBleHBvcnQgc2NvcGVzKS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTY29wZURhdGEge1xuICAvKipcbiAgICogRGlyZWN0aXZlcyBpbiB0aGUgZXhwb3J0ZWQgc2NvcGUgb2YgdGhlIG1vZHVsZS5cbiAgICovXG4gIGRpcmVjdGl2ZXM6IERpcmVjdGl2ZU1ldGFbXTtcblxuICAvKipcbiAgICogUGlwZXMgaW4gdGhlIGV4cG9ydGVkIHNjb3BlIG9mIHRoZSBtb2R1bGUuXG4gICAqL1xuICBwaXBlczogUGlwZU1ldGFbXTtcblxuICAvKipcbiAgICogTmdNb2R1bGVzIHdoaWNoIGNvbnRyaWJ1dGVkIHRvIHRoZSBzY29wZSBvZiB0aGUgbW9kdWxlLlxuICAgKi9cbiAgbmdNb2R1bGVzOiBDbGFzc0RlY2xhcmF0aW9uW107XG59XG5cbi8qKlxuICogQW4gZXhwb3J0IHNjb3BlIG9mIGFuIE5nTW9kdWxlLCBjb250YWluaW5nIHRoZSBkaXJlY3RpdmVzL3BpcGVzIGl0IGNvbnRyaWJ1dGVzIHRvIG90aGVyIE5nTW9kdWxlc1xuICogd2hpY2ggaW1wb3J0IGl0LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEV4cG9ydFNjb3BlIHtcbiAgLyoqXG4gICAqIFRoZSBzY29wZSBleHBvcnRlZCBieSBhbiBOZ01vZHVsZSwgYW5kIGF2YWlsYWJsZSBmb3IgaW1wb3J0LlxuICAgKi9cbiAgZXhwb3J0ZWQ6IFNjb3BlRGF0YTtcbn1cblxuLyoqXG4gKiBBIHJlc29sdmVkIHNjb3BlIGZvciBhIGdpdmVuIGNvbXBvbmVudCB0aGF0IGNhbm5vdCBiZSBzZXQgbG9jYWxseSBpbiB0aGUgY29tcG9uZW50IGRlZmluaXRpb24sXG4gKiBhbmQgbXVzdCBiZSBzZXQgdmlhIHJlbW90ZSBzY29waW5nIGNhbGwgaW4gdGhlIGNvbXBvbmVudCdzIE5nTW9kdWxlIGZpbGUuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVtb3RlU2NvcGUge1xuICAvKipcbiAgICogVGhvc2UgZGlyZWN0aXZlcyB1c2VkIGJ5IHRoZSBjb21wb25lbnQgdGhhdCByZXF1aXJlcyB0aGlzIHNjb3BlIHRvIGJlIHNldCByZW1vdGVseS5cbiAgICovXG4gIGRpcmVjdGl2ZXM6IFJlZmVyZW5jZVtdO1xuXG4gIC8qKlxuICAgKiBUaG9zZSBwaXBlcyB1c2VkIGJ5IHRoZSBjb21wb25lbnQgdGhhdCByZXF1aXJlcyB0aGlzIHNjb3BlIHRvIGJlIHNldCByZW1vdGVseS5cbiAgICovXG4gIHBpcGVzOiBSZWZlcmVuY2VbXTtcbn0iXX0=
@@ -7,13 +7,20 @@
7
7
  * found in the LICENSE file at https://angular.io/license
8
8
  */
9
9
  import { ClassDeclaration } from '../../reflection';
10
+ import { RemoteScope } from './api';
10
11
  import { LocalModuleScope } from './local';
11
12
  /**
12
13
  * Read information about the compilation scope of components.
13
14
  */
14
15
  export interface ComponentScopeReader {
15
16
  getScopeForComponent(clazz: ClassDeclaration): LocalModuleScope | null | 'error';
16
- getRequiresRemoteScope(clazz: ClassDeclaration): boolean | null;
17
+ /**
18
+ * Get the `RemoteScope` required for this component, if any.
19
+ *
20
+ * If the component requires remote scoping, then retrieve the directives/pipes registered for
21
+ * that component. If remote scoping is not required (the common case), returns `null`.
22
+ */
23
+ getRemoteScope(clazz: ClassDeclaration): RemoteScope | null;
17
24
  }
18
25
  /**
19
26
  * A `ComponentScopeReader` that reads from an ordered set of child readers until it obtains the
@@ -26,5 +33,5 @@ export declare class CompoundComponentScopeReader implements ComponentScopeReade
26
33
  private readers;
27
34
  constructor(readers: ComponentScopeReader[]);
28
35
  getScopeForComponent(clazz: ClassDeclaration): LocalModuleScope | null | 'error';
29
- getRequiresRemoteScope(clazz: ClassDeclaration): boolean | null;
36
+ getRemoteScope(clazz: ClassDeclaration): RemoteScope | null;
30
37
  }
@@ -42,14 +42,14 @@
42
42
  }
43
43
  return null;
44
44
  };
45
- CompoundComponentScopeReader.prototype.getRequiresRemoteScope = function (clazz) {
45
+ CompoundComponentScopeReader.prototype.getRemoteScope = function (clazz) {
46
46
  var e_2, _a;
47
47
  try {
48
48
  for (var _b = tslib_1.__values(this.readers), _c = _b.next(); !_c.done; _c = _b.next()) {
49
49
  var reader = _c.value;
50
- var requiredScoping = reader.getRequiresRemoteScope(clazz);
51
- if (requiredScoping !== null) {
52
- return requiredScoping;
50
+ var remoteScope = reader.getRemoteScope(clazz);
51
+ if (remoteScope !== null) {
52
+ return remoteScope;
53
53
  }
54
54
  }
55
55
  }
@@ -66,4 +66,4 @@
66
66
  }());
67
67
  exports.CompoundComponentScopeReader = CompoundComponentScopeReader;
68
68
  });
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50X3Njb3BlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcGlsZXItY2xpL3NyYy9uZ3RzYy9zY29wZS9zcmMvY29tcG9uZW50X3Njb3BlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7SUFrQkE7Ozs7OztPQU1HO0lBQ0g7UUFDRSxzQ0FBb0IsT0FBK0I7WUFBL0IsWUFBTyxHQUFQLE9BQU8sQ0FBd0I7UUFBRyxDQUFDO1FBRXZELDJEQUFvQixHQUFwQixVQUFxQixLQUF1Qjs7O2dCQUMxQyxLQUFxQixJQUFBLEtBQUEsaUJBQUEsSUFBSSxDQUFDLE9BQU8sQ0FBQSxnQkFBQSw0QkFBRTtvQkFBOUIsSUFBTSxNQUFNLFdBQUE7b0JBQ2YsSUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDLG9CQUFvQixDQUFDLEtBQUssQ0FBQyxDQUFDO29CQUNoRCxJQUFJLElBQUksS0FBSyxJQUFJLEVBQUU7d0JBQ2pCLE9BQU8sSUFBSSxDQUFDO3FCQUNiO2lCQUNGOzs7Ozs7Ozs7WUFDRCxPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7UUFFRCw2REFBc0IsR0FBdEIsVUFBdUIsS0FBdUI7OztnQkFDNUMsS0FBcUIsSUFBQSxLQUFBLGlCQUFBLElBQUksQ0FBQyxPQUFPLENBQUEsZ0JBQUEsNEJBQUU7b0JBQTlCLElBQU0sTUFBTSxXQUFBO29CQUNmLElBQU0sZUFBZSxHQUFHLE1BQU0sQ0FBQyxzQkFBc0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztvQkFDN0QsSUFBSSxlQUFlLEtBQUssSUFBSSxFQUFFO3dCQUM1QixPQUFPLGVBQWUsQ0FBQztxQkFDeEI7aUJBQ0Y7Ozs7Ozs7OztZQUNELE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQztRQUNILG1DQUFDO0lBQUQsQ0FBQyxBQXRCRCxJQXNCQztJQXRCWSxvRUFBNEIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7Q2xhc3NEZWNsYXJhdGlvbn0gZnJvbSAnLi4vLi4vcmVmbGVjdGlvbic7XG5pbXBvcnQge0xvY2FsTW9kdWxlU2NvcGV9IGZyb20gJy4vbG9jYWwnO1xuXG4vKipcbiAqIFJlYWQgaW5mb3JtYXRpb24gYWJvdXQgdGhlIGNvbXBpbGF0aW9uIHNjb3BlIG9mIGNvbXBvbmVudHMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ29tcG9uZW50U2NvcGVSZWFkZXIge1xuICBnZXRTY29wZUZvckNvbXBvbmVudChjbGF6ejogQ2xhc3NEZWNsYXJhdGlvbik6IExvY2FsTW9kdWxlU2NvcGV8bnVsbHwnZXJyb3InO1xuICBnZXRSZXF1aXJlc1JlbW90ZVNjb3BlKGNsYXp6OiBDbGFzc0RlY2xhcmF0aW9uKTogYm9vbGVhbnxudWxsO1xufVxuXG4vKipcbiAqIEEgYENvbXBvbmVudFNjb3BlUmVhZGVyYCB0aGF0IHJlYWRzIGZyb20gYW4gb3JkZXJlZCBzZXQgb2YgY2hpbGQgcmVhZGVycyB1bnRpbCBpdCBvYnRhaW5zIHRoZVxuICogcmVxdWVzdGVkIHNjb3BlLlxuICpcbiAqIFRoaXMgaXMgdXNlZCB0byBjb21iaW5lIGBDb21wb25lbnRTY29wZVJlYWRlcmBzIHRoYXQgcmVhZCBmcm9tIGRpZmZlcmVudCBzb3VyY2VzIChlLmcuIGZyb20gYVxuICogcmVnaXN0cnkgYW5kIGZyb20gdGhlIGluY3JlbWVudGFsIHN0YXRlKS5cbiAqL1xuZXhwb3J0IGNsYXNzIENvbXBvdW5kQ29tcG9uZW50U2NvcGVSZWFkZXIgaW1wbGVtZW50cyBDb21wb25lbnRTY29wZVJlYWRlciB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZGVyczogQ29tcG9uZW50U2NvcGVSZWFkZXJbXSkge31cblxuICBnZXRTY29wZUZvckNvbXBvbmVudChjbGF6ejogQ2xhc3NEZWNsYXJhdGlvbik6IExvY2FsTW9kdWxlU2NvcGV8bnVsbHwnZXJyb3InIHtcbiAgICBmb3IgKGNvbnN0IHJlYWRlciBvZiB0aGlzLnJlYWRlcnMpIHtcbiAgICAgIGNvbnN0IG1ldGEgPSByZWFkZXIuZ2V0U2NvcGVGb3JDb21wb25lbnQoY2xhenopO1xuICAgICAgaWYgKG1ldGEgIT09IG51bGwpIHtcbiAgICAgICAgcmV0dXJuIG1ldGE7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgZ2V0UmVxdWlyZXNSZW1vdGVTY29wZShjbGF6ejogQ2xhc3NEZWNsYXJhdGlvbik6IGJvb2xlYW58bnVsbCB7XG4gICAgZm9yIChjb25zdCByZWFkZXIgb2YgdGhpcy5yZWFkZXJzKSB7XG4gICAgICBjb25zdCByZXF1aXJlZFNjb3BpbmcgPSByZWFkZXIuZ2V0UmVxdWlyZXNSZW1vdGVTY29wZShjbGF6eik7XG4gICAgICBpZiAocmVxdWlyZWRTY29waW5nICE9PSBudWxsKSB7XG4gICAgICAgIHJldHVybiByZXF1aXJlZFNjb3Bpbmc7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBudWxsO1xuICB9XG59XG4iXX0=
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50X3Njb3BlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcGlsZXItY2xpL3NyYy9uZ3RzYy9zY29wZS9zcmMvY29tcG9uZW50X3Njb3BlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7SUEwQkE7Ozs7OztPQU1HO0lBQ0g7UUFDRSxzQ0FBb0IsT0FBK0I7WUFBL0IsWUFBTyxHQUFQLE9BQU8sQ0FBd0I7UUFBRyxDQUFDO1FBRXZELDJEQUFvQixHQUFwQixVQUFxQixLQUF1Qjs7O2dCQUMxQyxLQUFxQixJQUFBLEtBQUEsaUJBQUEsSUFBSSxDQUFDLE9BQU8sQ0FBQSxnQkFBQSw0QkFBRTtvQkFBOUIsSUFBTSxNQUFNLFdBQUE7b0JBQ2YsSUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDLG9CQUFvQixDQUFDLEtBQUssQ0FBQyxDQUFDO29CQUNoRCxJQUFJLElBQUksS0FBSyxJQUFJLEVBQUU7d0JBQ2pCLE9BQU8sSUFBSSxDQUFDO3FCQUNiO2lCQUNGOzs7Ozs7Ozs7WUFDRCxPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7UUFFRCxxREFBYyxHQUFkLFVBQWUsS0FBdUI7OztnQkFDcEMsS0FBcUIsSUFBQSxLQUFBLGlCQUFBLElBQUksQ0FBQyxPQUFPLENBQUEsZ0JBQUEsNEJBQUU7b0JBQTlCLElBQU0sTUFBTSxXQUFBO29CQUNmLElBQU0sV0FBVyxHQUFHLE1BQU0sQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLENBQUM7b0JBQ2pELElBQUksV0FBVyxLQUFLLElBQUksRUFBRTt3QkFDeEIsT0FBTyxXQUFXLENBQUM7cUJBQ3BCO2lCQUNGOzs7Ozs7Ozs7WUFDRCxPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7UUFDSCxtQ0FBQztJQUFELENBQUMsQUF0QkQsSUFzQkM7SUF0Qlksb0VBQTRCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQge0NsYXNzRGVjbGFyYXRpb259IGZyb20gJy4uLy4uL3JlZmxlY3Rpb24nO1xuaW1wb3J0IHtSZW1vdGVTY29wZX0gZnJvbSAnLi9hcGknO1xuaW1wb3J0IHtMb2NhbE1vZHVsZVNjb3BlfSBmcm9tICcuL2xvY2FsJztcblxuLyoqXG4gKiBSZWFkIGluZm9ybWF0aW9uIGFib3V0IHRoZSBjb21waWxhdGlvbiBzY29wZSBvZiBjb21wb25lbnRzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIENvbXBvbmVudFNjb3BlUmVhZGVyIHtcbiAgZ2V0U2NvcGVGb3JDb21wb25lbnQoY2xheno6IENsYXNzRGVjbGFyYXRpb24pOiBMb2NhbE1vZHVsZVNjb3BlfG51bGx8J2Vycm9yJztcblxuICAvKipcbiAgICogR2V0IHRoZSBgUmVtb3RlU2NvcGVgIHJlcXVpcmVkIGZvciB0aGlzIGNvbXBvbmVudCwgaWYgYW55LlxuICAgKlxuICAgKiBJZiB0aGUgY29tcG9uZW50IHJlcXVpcmVzIHJlbW90ZSBzY29waW5nLCB0aGVuIHJldHJpZXZlIHRoZSBkaXJlY3RpdmVzL3BpcGVzIHJlZ2lzdGVyZWQgZm9yXG4gICAqIHRoYXQgY29tcG9uZW50LiBJZiByZW1vdGUgc2NvcGluZyBpcyBub3QgcmVxdWlyZWQgKHRoZSBjb21tb24gY2FzZSksIHJldHVybnMgYG51bGxgLlxuICAgKi9cbiAgZ2V0UmVtb3RlU2NvcGUoY2xheno6IENsYXNzRGVjbGFyYXRpb24pOiBSZW1vdGVTY29wZXxudWxsO1xufVxuXG4vKipcbiAqIEEgYENvbXBvbmVudFNjb3BlUmVhZGVyYCB0aGF0IHJlYWRzIGZyb20gYW4gb3JkZXJlZCBzZXQgb2YgY2hpbGQgcmVhZGVycyB1bnRpbCBpdCBvYnRhaW5zIHRoZVxuICogcmVxdWVzdGVkIHNjb3BlLlxuICpcbiAqIFRoaXMgaXMgdXNlZCB0byBjb21iaW5lIGBDb21wb25lbnRTY29wZVJlYWRlcmBzIHRoYXQgcmVhZCBmcm9tIGRpZmZlcmVudCBzb3VyY2VzIChlLmcuIGZyb20gYVxuICogcmVnaXN0cnkgYW5kIGZyb20gdGhlIGluY3JlbWVudGFsIHN0YXRlKS5cbiAqL1xuZXhwb3J0IGNsYXNzIENvbXBvdW5kQ29tcG9uZW50U2NvcGVSZWFkZXIgaW1wbGVtZW50cyBDb21wb25lbnRTY29wZVJlYWRlciB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZGVyczogQ29tcG9uZW50U2NvcGVSZWFkZXJbXSkge31cblxuICBnZXRTY29wZUZvckNvbXBvbmVudChjbGF6ejogQ2xhc3NEZWNsYXJhdGlvbik6IExvY2FsTW9kdWxlU2NvcGV8bnVsbHwnZXJyb3InIHtcbiAgICBmb3IgKGNvbnN0IHJlYWRlciBvZiB0aGlzLnJlYWRlcnMpIHtcbiAgICAgIGNvbnN0IG1ldGEgPSByZWFkZXIuZ2V0U2NvcGVGb3JDb21wb25lbnQoY2xhenopO1xuICAgICAgaWYgKG1ldGEgIT09IG51bGwpIHtcbiAgICAgICAgcmV0dXJuIG1ldGE7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgZ2V0UmVtb3RlU2NvcGUoY2xheno6IENsYXNzRGVjbGFyYXRpb24pOiBSZW1vdGVTY29wZXxudWxsIHtcbiAgICBmb3IgKGNvbnN0IHJlYWRlciBvZiB0aGlzLnJlYWRlcnMpIHtcbiAgICAgIGNvbnN0IHJlbW90ZVNjb3BlID0gcmVhZGVyLmdldFJlbW90ZVNjb3BlKGNsYXp6KTtcbiAgICAgIGlmIChyZW1vdGVTY29wZSAhPT0gbnVsbCkge1xuICAgICAgICByZXR1cm4gcmVtb3RlU2NvcGU7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBudWxsO1xuICB9XG59XG4iXX0=
@@ -11,7 +11,7 @@ import * as ts from 'typescript';
11
11
  import { AliasingHost, Reexport, Reference, ReferenceEmitter } from '../../imports';
12
12
  import { DirectiveMeta, MetadataReader, MetadataRegistry, NgModuleMeta, PipeMeta } from '../../metadata';
13
13
  import { ClassDeclaration } from '../../reflection';
14
- import { ExportScope, ScopeData } from './api';
14
+ import { ExportScope, RemoteScope, ScopeData } from './api';
15
15
  import { ComponentScopeReader } from './component_scope';
16
16
  import { DtsModuleScopeResolver } from './dependency';
17
17
  export interface LocalNgModuleData {
@@ -86,7 +86,7 @@ export declare class LocalModuleScopeRegistry implements MetadataRegistry, Compo
86
86
  */
87
87
  private cache;
88
88
  /**
89
- * Tracks whether a given component requires "remote scoping".
89
+ * Tracks the `RemoteScope` for components requiring "remote scoping".
90
90
  *
91
91
  * Remote scoping is when the set of directives which apply to a given component is set in the
92
92
  * NgModule's file instead of directly on the component def (which is sometimes needed to get
@@ -152,11 +152,12 @@ export declare class LocalModuleScopeRegistry implements MetadataRegistry, Compo
152
152
  /**
153
153
  * Check whether a component requires remote scoping.
154
154
  */
155
- getRequiresRemoteScope(node: ClassDeclaration): boolean;
155
+ getRemoteScope(node: ClassDeclaration): RemoteScope | null;
156
156
  /**
157
- * Set a component as requiring remote scoping.
157
+ * Set a component as requiring remote scoping, with the given directives and pipes to be
158
+ * registered remotely.
158
159
  */
159
- setComponentAsRequiringRemoteScoping(node: ClassDeclaration): void;
160
+ setComponentRemoteScope(node: ClassDeclaration, directives: Reference[], pipes: Reference[]): void;
160
161
  /**
161
162
  * Look up the `ExportScope` of a given `Reference` to an NgModule.
162
163
  *
@@ -75,14 +75,14 @@
75
75
  */
76
76
  this.cache = new Map();
77
77
  /**
78
- * Tracks whether a given component requires "remote scoping".
78
+ * Tracks the `RemoteScope` for components requiring "remote scoping".
79
79
  *
80
80
  * Remote scoping is when the set of directives which apply to a given component is set in the
81
81
  * NgModule's file instead of directly on the component def (which is sometimes needed to get
82
82
  * around cyclic import issues). This is not used in calculation of `LocalModuleScope`s, but is
83
83
  * tracked here for convenience.
84
84
  */
85
- this.remoteScoping = new Set();
85
+ this.remoteScoping = new Map();
86
86
  /**
87
87
  * Tracks errors accumulated in the processing of scopes for each module declaration.
88
88
  */
@@ -493,14 +493,15 @@
493
493
  /**
494
494
  * Check whether a component requires remote scoping.
495
495
  */
496
- LocalModuleScopeRegistry.prototype.getRequiresRemoteScope = function (node) {
497
- return this.remoteScoping.has(node);
496
+ LocalModuleScopeRegistry.prototype.getRemoteScope = function (node) {
497
+ return this.remoteScoping.has(node) ? this.remoteScoping.get(node) : null;
498
498
  };
499
499
  /**
500
- * Set a component as requiring remote scoping.
500
+ * Set a component as requiring remote scoping, with the given directives and pipes to be
501
+ * registered remotely.
501
502
  */
502
- LocalModuleScopeRegistry.prototype.setComponentAsRequiringRemoteScoping = function (node) {
503
- this.remoteScoping.add(node);
503
+ LocalModuleScopeRegistry.prototype.setComponentRemoteScope = function (node, directives, pipes) {
504
+ this.remoteScoping.set(node, { directives: directives, pipes: pipes });
504
505
  };
505
506
  /**
506
507
  * Look up the `ExportScope` of a given `Reference` to an NgModule.
@@ -675,4 +676,4 @@
675
676
  ]);
676
677
  }
677
678
  });
678
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"local.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/scope/src/local.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 {ExternalExpr, SchemaMetadata} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {ErrorCode, makeDiagnostic, makeRelatedInformation} from '../../diagnostics';\nimport {AliasingHost, Reexport, Reference, ReferenceEmitter} from '../../imports';\nimport {DirectiveMeta, MetadataReader, MetadataRegistry, NgModuleMeta, PipeMeta} from '../../metadata';\nimport {ClassDeclaration, DeclarationNode} from '../../reflection';\nimport {identifierOfNode, nodeNameForError} from '../../util/src/typescript';\n\nimport {ExportScope, ScopeData} from './api';\nimport {ComponentScopeReader} from './component_scope';\nimport {DtsModuleScopeResolver} from './dependency';\n\nexport interface LocalNgModuleData {\n  declarations: Reference<ClassDeclaration>[];\n  imports: Reference<ClassDeclaration>[];\n  exports: Reference<ClassDeclaration>[];\n}\n\nexport interface LocalModuleScope extends ExportScope {\n  ngModule: ClassDeclaration;\n  compilation: ScopeData;\n  reexports: Reexport[]|null;\n  schemas: SchemaMetadata[];\n}\n\n/**\n * Information about the compilation scope of a registered declaration.\n */\nexport interface CompilationScope extends ScopeData {\n  /** The declaration whose compilation scope is described here. */\n  declaration: ClassDeclaration;\n  /** The declaration of the NgModule that declares this `declaration`. */\n  ngModule: ClassDeclaration;\n}\n\n/**\n * A registry which collects information about NgModules, Directives, Components, and Pipes which\n * are local (declared in the ts.Program being compiled), and can produce `LocalModuleScope`s\n * which summarize the compilation scope of a component.\n *\n * This class implements the logic of NgModule declarations, imports, and exports and can produce,\n * for a given component, the set of directives and pipes which are \"visible\" in that component's\n * template.\n *\n * The `LocalModuleScopeRegistry` has two \"modes\" of operation. During analysis, data for each\n * individual NgModule, Directive, Component, and Pipe is added to the registry. No attempt is made\n * to traverse or validate the NgModule graph (imports, exports, etc). After analysis, one of\n * `getScopeOfModule` or `getScopeForComponent` can be called, which traverses the NgModule graph\n * and applies the NgModule logic to generate a `LocalModuleScope`, the full scope for the given\n * module or component.\n *\n * The `LocalModuleScopeRegistry` is also capable of producing `ts.Diagnostic` errors when Angular\n * semantics are violated.\n */\nexport class LocalModuleScopeRegistry implements MetadataRegistry, ComponentScopeReader {\n  /**\n   * Tracks whether the registry has been asked to produce scopes for a module or component. Once\n   * this is true, the registry cannot accept registrations of new directives/pipes/modules as it\n   * would invalidate the cached scope data.\n   */\n  private sealed = false;\n\n  /**\n   * A map of components from the current compilation unit to the NgModule which declared them.\n   *\n   * As components and directives are not distinguished at the NgModule level, this map may also\n   * contain directives. This doesn't cause any problems but isn't useful as there is no concept of\n   * a directive's compilation scope.\n   */\n  private declarationToModule = new Map<ClassDeclaration, DeclarationData>();\n\n  /**\n   * This maps from the directive/pipe class to a map of data for each NgModule that declares the\n   * directive/pipe. This data is needed to produce an error for the given class.\n   */\n  private duplicateDeclarations =\n      new Map<ClassDeclaration, Map<ClassDeclaration, DeclarationData>>();\n\n  private moduleToRef = new Map<ClassDeclaration, Reference<ClassDeclaration>>();\n\n  /**\n   * A cache of calculated `LocalModuleScope`s for each NgModule declared in the current program.\n   *\n   * A value of `undefined` indicates the scope was invalid and produced errors (therefore,\n   * diagnostics should exist in the `scopeErrors` map).\n   */\n  private cache = new Map<ClassDeclaration, LocalModuleScope|undefined|null>();\n\n  /**\n   * Tracks whether a given component requires \"remote scoping\".\n   *\n   * Remote scoping is when the set of directives which apply to a given component is set in the\n   * NgModule's file instead of directly on the component def (which is sometimes needed to get\n   * around cyclic import issues). This is not used in calculation of `LocalModuleScope`s, but is\n   * tracked here for convenience.\n   */\n  private remoteScoping = new Set<ClassDeclaration>();\n\n  /**\n   * Tracks errors accumulated in the processing of scopes for each module declaration.\n   */\n  private scopeErrors = new Map<ClassDeclaration, ts.Diagnostic[]>();\n\n  /**\n   * Tracks which NgModules are unreliable due to errors within their declarations.\n   *\n   * This provides a unified view of which modules have errors, across all of the different\n   * diagnostic categories that can be produced. Theoretically this can be inferred from the other\n   * properties of this class, but is tracked explicitly to simplify the logic.\n   */\n  private taintedModules = new Set<ClassDeclaration>();\n\n  constructor(\n      private localReader: MetadataReader, private dependencyScopeReader: DtsModuleScopeResolver,\n      private refEmitter: ReferenceEmitter, private aliasingHost: AliasingHost|null) {}\n\n  /**\n   * Add an NgModule's data to the registry.\n   */\n  registerNgModuleMetadata(data: NgModuleMeta): void {\n    this.assertCollecting();\n    const ngModule = data.ref.node;\n    this.moduleToRef.set(data.ref.node, data.ref);\n    // Iterate over the module's declarations, and add them to declarationToModule. If duplicates\n    // are found, they're instead tracked in duplicateDeclarations.\n    for (const decl of data.declarations) {\n      this.registerDeclarationOfModule(ngModule, decl, data.rawDeclarations);\n    }\n  }\n\n  registerDirectiveMetadata(directive: DirectiveMeta): void {}\n\n  registerPipeMetadata(pipe: PipeMeta): void {}\n\n  getScopeForComponent(clazz: ClassDeclaration): LocalModuleScope|null|'error' {\n    const scope = !this.declarationToModule.has(clazz) ?\n        null :\n        this.getScopeOfModule(this.declarationToModule.get(clazz)!.ngModule);\n    return scope;\n  }\n\n  /**\n   * If `node` is declared in more than one NgModule (duplicate declaration), then get the\n   * `DeclarationData` for each offending declaration.\n   *\n   * Ordinarily a class is only declared in one NgModule, in which case this function returns\n   * `null`.\n   */\n  getDuplicateDeclarations(node: ClassDeclaration): DeclarationData[]|null {\n    if (!this.duplicateDeclarations.has(node)) {\n      return null;\n    }\n\n    return Array.from(this.duplicateDeclarations.get(node)!.values());\n  }\n\n  /**\n   * Collects registered data for a module and its directives/pipes and convert it into a full\n   * `LocalModuleScope`.\n   *\n   * This method implements the logic of NgModule imports and exports. It returns the\n   * `LocalModuleScope` for the given NgModule if one can be produced, `null` if no scope was ever\n   * defined, or the string `'error'` if the scope contained errors.\n   */\n  getScopeOfModule(clazz: ClassDeclaration): LocalModuleScope|'error'|null {\n    const scope = this.moduleToRef.has(clazz) ?\n        this.getScopeOfModuleReference(this.moduleToRef.get(clazz)!) :\n        null;\n    // If the NgModule class is marked as tainted, consider it an error.\n    if (this.taintedModules.has(clazz)) {\n      return 'error';\n    }\n\n    // Translate undefined -> 'error'.\n    return scope !== undefined ? scope : 'error';\n  }\n\n  /**\n   * Retrieves any `ts.Diagnostic`s produced during the calculation of the `LocalModuleScope` for\n   * the given NgModule, or `null` if no errors were present.\n   */\n  getDiagnosticsOfModule(clazz: ClassDeclaration): ts.Diagnostic[]|null {\n    // Required to ensure the errors are populated for the given class. If it has been processed\n    // before, this will be a no-op due to the scope cache.\n    this.getScopeOfModule(clazz);\n\n    if (this.scopeErrors.has(clazz)) {\n      return this.scopeErrors.get(clazz)!;\n    } else {\n      return null;\n    }\n  }\n\n  /**\n   * Returns a collection of the compilation scope for each registered declaration.\n   */\n  getCompilationScopes(): CompilationScope[] {\n    const scopes: CompilationScope[] = [];\n    this.declarationToModule.forEach((declData, declaration) => {\n      const scope = this.getScopeOfModule(declData.ngModule);\n      if (scope !== null && scope !== 'error') {\n        scopes.push({declaration, ngModule: declData.ngModule, ...scope.compilation});\n      }\n    });\n    return scopes;\n  }\n\n  private registerDeclarationOfModule(\n      ngModule: ClassDeclaration, decl: Reference<ClassDeclaration>,\n      rawDeclarations: ts.Expression|null): void {\n    const declData: DeclarationData = {\n      ngModule,\n      ref: decl,\n      rawDeclarations,\n    };\n\n    // First, check for duplicate declarations of the same directive/pipe.\n    if (this.duplicateDeclarations.has(decl.node)) {\n      // This directive/pipe has already been identified as being duplicated. Add this module to the\n      // map of modules for which a duplicate declaration exists.\n      this.duplicateDeclarations.get(decl.node)!.set(ngModule, declData);\n    } else if (\n        this.declarationToModule.has(decl.node) &&\n        this.declarationToModule.get(decl.node)!.ngModule !== ngModule) {\n      // This directive/pipe is already registered as declared in another module. Mark it as a\n      // duplicate instead.\n      const duplicateDeclMap = new Map<ClassDeclaration, DeclarationData>();\n      const firstDeclData = this.declarationToModule.get(decl.node)!;\n\n      // Mark both modules as tainted, since their declarations are missing a component.\n      this.taintedModules.add(firstDeclData.ngModule);\n      this.taintedModules.add(ngModule);\n\n      // Being detected as a duplicate means there are two NgModules (for now) which declare this\n      // directive/pipe. Add both of them to the duplicate tracking map.\n      duplicateDeclMap.set(firstDeclData.ngModule, firstDeclData);\n      duplicateDeclMap.set(ngModule, declData);\n      this.duplicateDeclarations.set(decl.node, duplicateDeclMap);\n\n      // Remove the directive/pipe from `declarationToModule` as it's a duplicate declaration, and\n      // therefore not valid.\n      this.declarationToModule.delete(decl.node);\n    } else {\n      // This is the first declaration of this directive/pipe, so map it.\n      this.declarationToModule.set(decl.node, declData);\n    }\n  }\n\n  /**\n   * Implementation of `getScopeOfModule` which accepts a reference to a class and differentiates\n   * between:\n   *\n   * * no scope being available (returns `null`)\n   * * a scope being produced with errors (returns `undefined`).\n   */\n  private getScopeOfModuleReference(ref: Reference<ClassDeclaration>): LocalModuleScope|null\n      |undefined {\n    if (this.cache.has(ref.node)) {\n      return this.cache.get(ref.node);\n    }\n\n    // Seal the registry to protect the integrity of the `LocalModuleScope` cache.\n    this.sealed = true;\n\n    // `ref` should be an NgModule previously added to the registry. If not, a scope for it\n    // cannot be produced.\n    const ngModule = this.localReader.getNgModuleMetadata(ref);\n    if (ngModule === null) {\n      this.cache.set(ref.node, null);\n      return null;\n    }\n\n    // Modules which contributed to the compilation scope of this module.\n    const compilationModules = new Set<ClassDeclaration>([ngModule.ref.node]);\n    // Modules which contributed to the export scope of this module.\n    const exportedModules = new Set<ClassDeclaration>([ngModule.ref.node]);\n\n    // Errors produced during computation of the scope are recorded here. At the end, if this array\n    // isn't empty then `undefined` will be cached and returned to indicate this scope is invalid.\n    const diagnostics: ts.Diagnostic[] = [];\n\n    // At this point, the goal is to produce two distinct transitive sets:\n    // - the directives and pipes which are visible to components declared in the NgModule.\n    // - the directives and pipes which are exported to any NgModules which import this one.\n\n    // Directives and pipes in the compilation scope.\n    const compilationDirectives = new Map<DeclarationNode, DirectiveMeta>();\n    const compilationPipes = new Map<DeclarationNode, PipeMeta>();\n\n    const declared = new Set<DeclarationNode>();\n\n    // Directives and pipes exported to any importing NgModules.\n    const exportDirectives = new Map<DeclarationNode, DirectiveMeta>();\n    const exportPipes = new Map<DeclarationNode, PipeMeta>();\n\n    // The algorithm is as follows:\n    // 1) Add all of the directives/pipes from each NgModule imported into the current one to the\n    //    compilation scope.\n    // 2) Add directives/pipes declared in the NgModule to the compilation scope. At this point, the\n    //    compilation scope is complete.\n    // 3) For each entry in the NgModule's exports:\n    //    a) Attempt to resolve it as an NgModule with its own exported directives/pipes. If it is\n    //       one, add them to the export scope of this NgModule.\n    //    b) Otherwise, it should be a class in the compilation scope of this NgModule. If it is,\n    //       add it to the export scope.\n    //    c) If it's neither an NgModule nor a directive/pipe in the compilation scope, then this\n    //       is an error.\n\n    // 1) process imports.\n    for (const decl of ngModule.imports) {\n      const importScope = this.getExportedScope(decl, diagnostics, ref.node, 'import');\n      if (importScope === null) {\n        // An import wasn't an NgModule, so record an error.\n        diagnostics.push(invalidRef(ref.node, decl, 'import'));\n        continue;\n      } else if (importScope === undefined) {\n        // An import was an NgModule but contained errors of its own. Record this as an error too,\n        // because this scope is always going to be incorrect if one of its imports could not be\n        // read.\n        diagnostics.push(invalidTransitiveNgModuleRef(ref.node, decl, 'import'));\n        continue;\n      }\n      for (const directive of importScope.exported.directives) {\n        compilationDirectives.set(directive.ref.node, directive);\n      }\n      for (const pipe of importScope.exported.pipes) {\n        compilationPipes.set(pipe.ref.node, pipe);\n      }\n      for (const importedModule of importScope.exported.ngModules) {\n        compilationModules.add(importedModule);\n      }\n    }\n\n    // 2) add declarations.\n    for (const decl of ngModule.declarations) {\n      const directive = this.localReader.getDirectiveMetadata(decl);\n      const pipe = this.localReader.getPipeMetadata(decl);\n      if (directive !== null) {\n        compilationDirectives.set(decl.node, {...directive, ref: decl});\n      } else if (pipe !== null) {\n        compilationPipes.set(decl.node, {...pipe, ref: decl});\n      } else {\n        this.taintedModules.add(ngModule.ref.node);\n\n        const errorNode = decl.getOriginForDiagnostics(ngModule.rawDeclarations!);\n        diagnostics.push(makeDiagnostic(\n            ErrorCode.NGMODULE_INVALID_DECLARATION, errorNode,\n            `The class '${decl.node.name.text}' is listed in the declarations ` +\n                `of the NgModule '${\n                    ngModule.ref.node.name\n                        .text}', but is not a directive, a component, or a pipe. ` +\n                `Either remove it from the NgModule's declarations, or add an appropriate Angular decorator.`,\n            [makeRelatedInformation(\n                decl.node.name, `'${decl.node.name.text}' is declared here.`)]));\n        continue;\n      }\n\n      declared.add(decl.node);\n    }\n\n    // 3) process exports.\n    // Exports can contain modules, components, or directives. They're processed differently.\n    // Modules are straightforward. Directives and pipes from exported modules are added to the\n    // export maps. Directives/pipes are different - they might be exports of declared types or\n    // imported types.\n    for (const decl of ngModule.exports) {\n      // Attempt to resolve decl as an NgModule.\n      const importScope = this.getExportedScope(decl, diagnostics, ref.node, 'export');\n      if (importScope === undefined) {\n        // An export was an NgModule but contained errors of its own. Record this as an error too,\n        // because this scope is always going to be incorrect if one of its exports could not be\n        // read.\n        diagnostics.push(invalidTransitiveNgModuleRef(ref.node, decl, 'export'));\n        continue;\n      } else if (importScope !== null) {\n        // decl is an NgModule.\n        for (const directive of importScope.exported.directives) {\n          exportDirectives.set(directive.ref.node, directive);\n        }\n        for (const pipe of importScope.exported.pipes) {\n          exportPipes.set(pipe.ref.node, pipe);\n        }\n        for (const exportedModule of importScope.exported.ngModules) {\n          exportedModules.add(exportedModule);\n        }\n      } else if (compilationDirectives.has(decl.node)) {\n        // decl is a directive or component in the compilation scope of this NgModule.\n        const directive = compilationDirectives.get(decl.node)!;\n        exportDirectives.set(decl.node, directive);\n      } else if (compilationPipes.has(decl.node)) {\n        // decl is a pipe in the compilation scope of this NgModule.\n        const pipe = compilationPipes.get(decl.node)!;\n        exportPipes.set(decl.node, pipe);\n      } else {\n        // decl is an unknown export.\n        if (this.localReader.getDirectiveMetadata(decl) !== null ||\n            this.localReader.getPipeMetadata(decl) !== null) {\n          diagnostics.push(invalidReexport(ref.node, decl));\n        } else {\n          diagnostics.push(invalidRef(ref.node, decl, 'export'));\n        }\n        continue;\n      }\n    }\n\n    const exported = {\n      directives: Array.from(exportDirectives.values()),\n      pipes: Array.from(exportPipes.values()),\n      ngModules: Array.from(exportedModules),\n    };\n\n    const reexports = this.getReexports(ngModule, ref, declared, exported, diagnostics);\n\n    // Check if this scope had any errors during production.\n    if (diagnostics.length > 0) {\n      // Cache undefined, to mark the fact that the scope is invalid.\n      this.cache.set(ref.node, undefined);\n\n      // Save the errors for retrieval.\n      this.scopeErrors.set(ref.node, diagnostics);\n\n      // Mark this module as being tainted.\n      this.taintedModules.add(ref.node);\n      return undefined;\n    }\n\n    // Finally, produce the `LocalModuleScope` with both the compilation and export scopes.\n    const scope: LocalModuleScope = {\n      ngModule: ngModule.ref.node,\n      compilation: {\n        directives: Array.from(compilationDirectives.values()),\n        pipes: Array.from(compilationPipes.values()),\n        ngModules: Array.from(compilationModules),\n      },\n      exported,\n      reexports,\n      schemas: ngModule.schemas,\n    };\n    this.cache.set(ref.node, scope);\n    return scope;\n  }\n\n  /**\n   * Check whether a component requires remote scoping.\n   */\n  getRequiresRemoteScope(node: ClassDeclaration): boolean {\n    return this.remoteScoping.has(node);\n  }\n\n  /**\n   * Set a component as requiring remote scoping.\n   */\n  setComponentAsRequiringRemoteScoping(node: ClassDeclaration): void {\n    this.remoteScoping.add(node);\n  }\n\n  /**\n   * Look up the `ExportScope` of a given `Reference` to an NgModule.\n   *\n   * The NgModule in question may be declared locally in the current ts.Program, or it may be\n   * declared in a .d.ts file.\n   *\n   * @returns `null` if no scope could be found, or `undefined` if an invalid scope\n   * was found.\n   *\n   * May also contribute diagnostics of its own by adding to the given `diagnostics`\n   * array parameter.\n   */\n  private getExportedScope(\n      ref: Reference<ClassDeclaration>, diagnostics: ts.Diagnostic[],\n      ownerForErrors: DeclarationNode, type: 'import'|'export'): ExportScope|null|undefined {\n    if (ref.node.getSourceFile().isDeclarationFile) {\n      // The NgModule is declared in a .d.ts file. Resolve it with the `DependencyScopeReader`.\n      if (!ts.isClassDeclaration(ref.node)) {\n        // The NgModule is in a .d.ts file but is not declared as a ts.ClassDeclaration. This is an\n        // error in the .d.ts metadata.\n        const code = type === 'import' ? ErrorCode.NGMODULE_INVALID_IMPORT :\n                                         ErrorCode.NGMODULE_INVALID_EXPORT;\n        diagnostics.push(makeDiagnostic(\n            code, identifierOfNode(ref.node) || ref.node,\n            `Appears in the NgModule.${type}s of ${\n                nodeNameForError(ownerForErrors)}, but could not be resolved to an NgModule`));\n        return undefined;\n      }\n      return this.dependencyScopeReader.resolve(ref);\n    } else {\n      // The NgModule is declared locally in the current program. Resolve it from the registry.\n      return this.getScopeOfModuleReference(ref);\n    }\n  }\n\n  private getReexports(\n      ngModule: NgModuleMeta, ref: Reference<ClassDeclaration>, declared: Set<DeclarationNode>,\n      exported: {directives: DirectiveMeta[], pipes: PipeMeta[]},\n      diagnostics: ts.Diagnostic[]): Reexport[]|null {\n    let reexports: Reexport[]|null = null;\n    const sourceFile = ref.node.getSourceFile();\n    if (this.aliasingHost === null) {\n      return null;\n    }\n    reexports = [];\n    // Track re-exports by symbol name, to produce diagnostics if two alias re-exports would share\n    // the same name.\n    const reexportMap = new Map<string, Reference<ClassDeclaration>>();\n    // Alias ngModuleRef added for readability below.\n    const ngModuleRef = ref;\n    const addReexport = (exportRef: Reference<ClassDeclaration>) => {\n      if (exportRef.node.getSourceFile() === sourceFile) {\n        return;\n      }\n      const isReExport = !declared.has(exportRef.node);\n      const exportName = this.aliasingHost!.maybeAliasSymbolAs(\n          exportRef, sourceFile, ngModule.ref.node.name.text, isReExport);\n      if (exportName === null) {\n        return;\n      }\n      if (!reexportMap.has(exportName)) {\n        if (exportRef.alias && exportRef.alias instanceof ExternalExpr) {\n          reexports!.push({\n            fromModule: exportRef.alias.value.moduleName!,\n            symbolName: exportRef.alias.value.name!,\n            asAlias: exportName,\n          });\n        } else {\n          const expr = this.refEmitter.emit(exportRef.cloneWithNoIdentifiers(), sourceFile);\n          if (!(expr instanceof ExternalExpr) || expr.value.moduleName === null ||\n              expr.value.name === null) {\n            throw new Error('Expected ExternalExpr');\n          }\n          reexports!.push({\n            fromModule: expr.value.moduleName,\n            symbolName: expr.value.name,\n            asAlias: exportName,\n          });\n        }\n        reexportMap.set(exportName, exportRef);\n      } else {\n        // Another re-export already used this name. Produce a diagnostic.\n        const prevRef = reexportMap.get(exportName)!;\n        diagnostics.push(reexportCollision(ngModuleRef.node, prevRef, exportRef));\n      }\n    };\n    for (const {ref} of exported.directives) {\n      addReexport(ref);\n    }\n    for (const {ref} of exported.pipes) {\n      addReexport(ref);\n    }\n    return reexports;\n  }\n\n  private assertCollecting(): void {\n    if (this.sealed) {\n      throw new Error(`Assertion: LocalModuleScopeRegistry is not COLLECTING`);\n    }\n  }\n}\n\n/**\n * Produce a `ts.Diagnostic` for an invalid import or export from an NgModule.\n */\nfunction invalidRef(\n    clazz: DeclarationNode, decl: Reference<DeclarationNode>,\n    type: 'import'|'export'): ts.Diagnostic {\n  const code =\n      type === 'import' ? ErrorCode.NGMODULE_INVALID_IMPORT : ErrorCode.NGMODULE_INVALID_EXPORT;\n  const resolveTarget = type === 'import' ? 'NgModule' : 'NgModule, Component, Directive, or Pipe';\n  let message =\n      `Appears in the NgModule.${type}s of ${\n          nodeNameForError(clazz)}, but could not be resolved to an ${resolveTarget} class.` +\n      '\\n\\n';\n  const library = decl.ownedByModuleGuess !== null ? ` (${decl.ownedByModuleGuess})` : '';\n  const sf = decl.node.getSourceFile();\n\n  // Provide extra context to the error for the user.\n  if (!sf.isDeclarationFile) {\n    // This is a file in the user's program.\n    const annotationType = type === 'import' ? '@NgModule' : 'Angular';\n    message += `Is it missing an ${annotationType} annotation?`;\n  } else if (sf.fileName.indexOf('node_modules') !== -1) {\n    // This file comes from a third-party library in node_modules.\n    message +=\n        `This likely means that the library${library} which declares ${decl.debugName} has not ` +\n        'been processed correctly by ngcc, or is not compatible with Angular Ivy. Check if a ' +\n        'newer version of the library is available, and update if so. Also consider checking ' +\n        'with the library\\'s authors to see if the library is expected to be compatible with Ivy.';\n  } else {\n    // This is a monorepo style local dependency. Unfortunately these are too different to really\n    // offer much more advice than this.\n    message += `This likely means that the dependency${library} which declares ${\n        decl.debugName} has not been processed correctly by ngcc.`;\n  }\n\n  return makeDiagnostic(code, identifierOfNode(decl.node) || decl.node, message);\n}\n\n/**\n * Produce a `ts.Diagnostic` for an import or export which itself has errors.\n */\nfunction invalidTransitiveNgModuleRef(\n    clazz: DeclarationNode, decl: Reference<DeclarationNode>,\n    type: 'import'|'export'): ts.Diagnostic {\n  const code =\n      type === 'import' ? ErrorCode.NGMODULE_INVALID_IMPORT : ErrorCode.NGMODULE_INVALID_EXPORT;\n  return makeDiagnostic(\n      code, identifierOfNode(decl.node) || decl.node,\n      `Appears in the NgModule.${type}s of ${nodeNameForError(clazz)}, but itself has errors`);\n}\n\n/**\n * Produce a `ts.Diagnostic` for an exported directive or pipe which was not declared or imported\n * by the NgModule in question.\n */\nfunction invalidReexport(clazz: DeclarationNode, decl: Reference<DeclarationNode>): ts.Diagnostic {\n  return makeDiagnostic(\n      ErrorCode.NGMODULE_INVALID_REEXPORT, identifierOfNode(decl.node) || decl.node,\n      `Present in the NgModule.exports of ${\n          nodeNameForError(clazz)} but neither declared nor imported`);\n}\n\n/**\n * Produce a `ts.Diagnostic` for a collision in re-export names between two directives/pipes.\n */\nfunction reexportCollision(\n    module: ClassDeclaration, refA: Reference<ClassDeclaration>,\n    refB: Reference<ClassDeclaration>): ts.Diagnostic {\n  const childMessageText = `This directive/pipe is part of the exports of '${\n      module.name.text}' and shares the same name as another exported directive/pipe.`;\n  return makeDiagnostic(\n      ErrorCode.NGMODULE_REEXPORT_NAME_COLLISION, module.name,\n      `\n    There was a name collision between two classes named '${\n          refA.node.name.text}', which are both part of the exports of '${module.name.text}'.\n\n    Angular generates re-exports of an NgModule's exported directives/pipes from the module's source file in certain cases, using the declared name of the class. If two classes of the same name are exported, this automatic naming does not work.\n\n    To fix this problem please re-export one or both classes directly from this file.\n  `.trim(),\n      [\n        makeRelatedInformation(refA.node.name, childMessageText),\n        makeRelatedInformation(refB.node.name, childMessageText),\n      ]);\n}\n\nexport interface DeclarationData {\n  ngModule: ClassDeclaration;\n  ref: Reference;\n  rawDeclarations: ts.Expression|null;\n}\n"]}
679
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"local.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/scope/src/local.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;;IAEH,8CAA+D;IAC/D,+BAAiC;IAEjC,2EAAoF;IAIpF,kFAA6E;IA6B7E;;;;;;;;;;;;;;;;;;OAkBG;IACH;QA0DE,kCACY,WAA2B,EAAU,qBAA6C,EAClF,UAA4B,EAAU,YAA+B;YADrE,gBAAW,GAAX,WAAW,CAAgB;YAAU,0BAAqB,GAArB,qBAAqB,CAAwB;YAClF,eAAU,GAAV,UAAU,CAAkB;YAAU,iBAAY,GAAZ,YAAY,CAAmB;YA3DjF;;;;eAIG;YACK,WAAM,GAAG,KAAK,CAAC;YAEvB;;;;;;eAMG;YACK,wBAAmB,GAAG,IAAI,GAAG,EAAqC,CAAC;YAE3E;;;eAGG;YACK,0BAAqB,GACzB,IAAI,GAAG,EAA4D,CAAC;YAEhE,gBAAW,GAAG,IAAI,GAAG,EAAiD,CAAC;YAE/E;;;;;eAKG;YACK,UAAK,GAAG,IAAI,GAAG,EAAqD,CAAC;YAE7E;;;;;;;eAOG;YACK,kBAAa,GAAG,IAAI,GAAG,EAAiC,CAAC;YAEjE;;eAEG;YACK,gBAAW,GAAG,IAAI,GAAG,EAAqC,CAAC;YAEnE;;;;;;eAMG;YACK,mBAAc,GAAG,IAAI,GAAG,EAAoB,CAAC;QAI+B,CAAC;QAErF;;WAEG;QACH,2DAAwB,GAAxB,UAAyB,IAAkB;;YACzC,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,IAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC;YAC/B,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;;gBAC9C,6FAA6F;gBAC7F,+DAA+D;gBAC/D,KAAmB,IAAA,KAAA,iBAAA,IAAI,CAAC,YAAY,CAAA,gBAAA,4BAAE;oBAAjC,IAAM,IAAI,WAAA;oBACb,IAAI,CAAC,2BAA2B,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;iBACxE;;;;;;;;;QACH,CAAC;QAED,4DAAyB,GAAzB,UAA0B,SAAwB,IAAS,CAAC;QAE5D,uDAAoB,GAApB,UAAqB,IAAc,IAAS,CAAC;QAE7C,uDAAoB,GAApB,UAAqB,KAAuB;YAC1C,IAAM,KAAK,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;gBAChD,IAAI,CAAC,CAAC;gBACN,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,KAAK,CAAE,CAAC,QAAQ,CAAC,CAAC;YACzE,OAAO,KAAK,CAAC;QACf,CAAC;QAED;;;;;;WAMG;QACH,2DAAwB,GAAxB,UAAyB,IAAsB;YAC7C,IAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;gBACzC,OAAO,IAAI,CAAC;aACb;YAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,IAAI,CAAE,CAAC,MAAM,EAAE,CAAC,CAAC;QACpE,CAAC;QAED;;;;;;;WAOG;QACH,mDAAgB,GAAhB,UAAiB,KAAuB;YACtC,IAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;gBACvC,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAE,CAAC,CAAC,CAAC;gBAC9D,IAAI,CAAC;YACT,oEAAoE;YACpE,IAAI,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;gBAClC,OAAO,OAAO,CAAC;aAChB;YAED,kCAAkC;YAClC,OAAO,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC;QAC/C,CAAC;QAED;;;WAGG;QACH,yDAAsB,GAAtB,UAAuB,KAAuB;YAC5C,4FAA4F;YAC5F,uDAAuD;YACvD,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;YAE7B,IAAI,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;gBAC/B,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAE,CAAC;aACrC;iBAAM;gBACL,OAAO,IAAI,CAAC;aACb;QACH,CAAC;QAED;;WAEG;QACH,uDAAoB,GAApB;YAAA,iBASC;YARC,IAAM,MAAM,GAAuB,EAAE,CAAC;YACtC,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,UAAC,QAAQ,EAAE,WAAW;gBACrD,IAAM,KAAK,GAAG,KAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;gBACvD,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,OAAO,EAAE;oBACvC,MAAM,CAAC,IAAI,oBAAE,WAAW,aAAA,EAAE,QAAQ,EAAE,QAAQ,CAAC,QAAQ,IAAK,KAAK,CAAC,WAAW,EAAE,CAAC;iBAC/E;YACH,CAAC,CAAC,CAAC;YACH,OAAO,MAAM,CAAC;QAChB,CAAC;QAEO,8DAA2B,GAAnC,UACI,QAA0B,EAAE,IAAiC,EAC7D,eAAmC;YACrC,IAAM,QAAQ,GAAoB;gBAChC,QAAQ,UAAA;gBACR,GAAG,EAAE,IAAI;gBACT,eAAe,iBAAA;aAChB,CAAC;YAEF,sEAAsE;YACtE,IAAI,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;gBAC7C,8FAA8F;gBAC9F,2DAA2D;gBAC3D,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAE,CAAC,GAAG,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;aACpE;iBAAM,IACH,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC;gBACvC,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAE,CAAC,QAAQ,KAAK,QAAQ,EAAE;gBAClE,wFAAwF;gBACxF,qBAAqB;gBACrB,IAAM,gBAAgB,GAAG,IAAI,GAAG,EAAqC,CAAC;gBACtE,IAAM,aAAa,GAAG,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAE,CAAC;gBAE/D,kFAAkF;gBAClF,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;gBAChD,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;gBAElC,2FAA2F;gBAC3F,kEAAkE;gBAClE,gBAAgB,CAAC,GAAG,CAAC,aAAa,CAAC,QAAQ,EAAE,aAAa,CAAC,CAAC;gBAC5D,gBAAgB,CAAC,GAAG,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;gBACzC,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,gBAAgB,CAAC,CAAC;gBAE5D,4FAA4F;gBAC5F,uBAAuB;gBACvB,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aAC5C;iBAAM;gBACL,mEAAmE;gBACnE,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;aACnD;QACH,CAAC;QAED;;;;;;WAMG;QACK,4DAAyB,GAAjC,UAAkC,GAAgC;;YAEhE,IAAI,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;gBAC5B,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;aACjC;YAED,8EAA8E;YAC9E,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;YAEnB,uFAAuF;YACvF,sBAAsB;YACtB,IAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC;YAC3D,IAAI,QAAQ,KAAK,IAAI,EAAE;gBACrB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;gBAC/B,OAAO,IAAI,CAAC;aACb;YAED,qEAAqE;YACrE,IAAM,kBAAkB,GAAG,IAAI,GAAG,CAAmB,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;YAC1E,gEAAgE;YAChE,IAAM,eAAe,GAAG,IAAI,GAAG,CAAmB,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;YAEvE,+FAA+F;YAC/F,8FAA8F;YAC9F,IAAM,WAAW,GAAoB,EAAE,CAAC;YAExC,sEAAsE;YACtE,uFAAuF;YACvF,wFAAwF;YAExF,iDAAiD;YACjD,IAAM,qBAAqB,GAAG,IAAI,GAAG,EAAkC,CAAC;YACxE,IAAM,gBAAgB,GAAG,IAAI,GAAG,EAA6B,CAAC;YAE9D,IAAM,QAAQ,GAAG,IAAI,GAAG,EAAmB,CAAC;YAE5C,4DAA4D;YAC5D,IAAM,gBAAgB,GAAG,IAAI,GAAG,EAAkC,CAAC;YACnE,IAAM,WAAW,GAAG,IAAI,GAAG,EAA6B,CAAC;;gBAEzD,+BAA+B;gBAC/B,6FAA6F;gBAC7F,wBAAwB;gBACxB,gGAAgG;gBAChG,oCAAoC;gBACpC,+CAA+C;gBAC/C,8FAA8F;gBAC9F,4DAA4D;gBAC5D,6FAA6F;gBAC7F,oCAAoC;gBACpC,6FAA6F;gBAC7F,qBAAqB;gBAErB,sBAAsB;gBACtB,KAAmB,IAAA,KAAA,iBAAA,QAAQ,CAAC,OAAO,CAAA,gBAAA,4BAAE;oBAAhC,IAAM,IAAI,WAAA;oBACb,IAAM,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,WAAW,EAAE,GAAG,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;oBACjF,IAAI,WAAW,KAAK,IAAI,EAAE;wBACxB,oDAAoD;wBACpD,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC;wBACvD,SAAS;qBACV;yBAAM,IAAI,WAAW,KAAK,SAAS,EAAE;wBACpC,0FAA0F;wBAC1F,wFAAwF;wBACxF,QAAQ;wBACR,WAAW,CAAC,IAAI,CAAC,4BAA4B,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC;wBACzE,SAAS;qBACV;;wBACD,KAAwB,IAAA,oBAAA,iBAAA,WAAW,CAAC,QAAQ,CAAC,UAAU,CAAA,CAAA,gBAAA,4BAAE;4BAApD,IAAM,SAAS,WAAA;4BAClB,qBAAqB,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;yBAC1D;;;;;;;;;;wBACD,KAAmB,IAAA,oBAAA,iBAAA,WAAW,CAAC,QAAQ,CAAC,KAAK,CAAA,CAAA,gBAAA,4BAAE;4BAA1C,IAAM,IAAI,WAAA;4BACb,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;yBAC3C;;;;;;;;;;wBACD,KAA6B,IAAA,oBAAA,iBAAA,WAAW,CAAC,QAAQ,CAAC,SAAS,CAAA,CAAA,gBAAA,4BAAE;4BAAxD,IAAM,cAAc,WAAA;4BACvB,kBAAkB,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;yBACxC;;;;;;;;;iBACF;;;;;;;;;;gBAED,uBAAuB;gBACvB,KAAmB,IAAA,KAAA,iBAAA,QAAQ,CAAC,YAAY,CAAA,gBAAA,4BAAE;oBAArC,IAAM,IAAI,WAAA;oBACb,IAAM,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;oBAC9D,IAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;oBACpD,IAAI,SAAS,KAAK,IAAI,EAAE;wBACtB,qBAAqB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,wCAAM,SAAS,KAAE,GAAG,EAAE,IAAI,IAAE,CAAC;qBACjE;yBAAM,IAAI,IAAI,KAAK,IAAI,EAAE;wBACxB,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,wCAAM,IAAI,KAAE,GAAG,EAAE,IAAI,IAAE,CAAC;qBACvD;yBAAM;wBACL,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;wBAE3C,IAAM,SAAS,GAAG,IAAI,CAAC,uBAAuB,CAAC,QAAQ,CAAC,eAAgB,CAAC,CAAC;wBAC1E,WAAW,CAAC,IAAI,CAAC,4BAAc,CAC3B,uBAAS,CAAC,4BAA4B,EAAE,SAAS,EACjD,gBAAc,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,qCAAkC;6BAC/D,sBACI,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI;iCACjB,IAAI,wDAAqD,CAAA;4BAClE,6FAA6F,EACjG,CAAC,oCAAsB,CACnB,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,MAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,wBAAqB,CAAC,CAAC,CAAC,CAAC,CAAC;wBACzE,SAAS;qBACV;oBAED,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iBACzB;;;;;;;;;;gBAED,sBAAsB;gBACtB,yFAAyF;gBACzF,2FAA2F;gBAC3F,2FAA2F;gBAC3F,kBAAkB;gBAClB,KAAmB,IAAA,KAAA,iBAAA,QAAQ,CAAC,OAAO,CAAA,gBAAA,4BAAE;oBAAhC,IAAM,IAAI,WAAA;oBACb,0CAA0C;oBAC1C,IAAM,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,WAAW,EAAE,GAAG,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;oBACjF,IAAI,WAAW,KAAK,SAAS,EAAE;wBAC7B,0FAA0F;wBAC1F,wFAAwF;wBACxF,QAAQ;wBACR,WAAW,CAAC,IAAI,CAAC,4BAA4B,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC;wBACzE,SAAS;qBACV;yBAAM,IAAI,WAAW,KAAK,IAAI,EAAE;;4BAC/B,uBAAuB;4BACvB,KAAwB,IAAA,oBAAA,iBAAA,WAAW,CAAC,QAAQ,CAAC,UAAU,CAAA,CAAA,gBAAA,4BAAE;gCAApD,IAAM,SAAS,WAAA;gCAClB,gBAAgB,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;6BACrD;;;;;;;;;;4BACD,KAAmB,IAAA,oBAAA,iBAAA,WAAW,CAAC,QAAQ,CAAC,KAAK,CAAA,CAAA,gBAAA,4BAAE;gCAA1C,IAAM,IAAI,WAAA;gCACb,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;6BACtC;;;;;;;;;;4BACD,KAA6B,IAAA,qBAAA,iBAAA,WAAW,CAAC,QAAQ,CAAC,SAAS,CAAA,CAAA,gBAAA,4BAAE;gCAAxD,IAAM,cAAc,WAAA;gCACvB,eAAe,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;6BACrC;;;;;;;;;qBACF;yBAAM,IAAI,qBAAqB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;wBAC/C,8EAA8E;wBAC9E,IAAM,SAAS,GAAG,qBAAqB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAE,CAAC;wBACxD,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;qBAC5C;yBAAM,IAAI,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;wBAC1C,4DAA4D;wBAC5D,IAAM,IAAI,GAAG,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAE,CAAC;wBAC9C,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;qBAClC;yBAAM;wBACL,6BAA6B;wBAC7B,IAAI,IAAI,CAAC,WAAW,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,IAAI;4BACpD,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE;4BACnD,WAAW,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;yBACnD;6BAAM;4BACL,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC;yBACxD;wBACD,SAAS;qBACV;iBACF;;;;;;;;;YAED,IAAM,QAAQ,GAAG;gBACf,UAAU,EAAE,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC;gBACjD,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;gBACvC,SAAS,EAAE,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC;aACvC,CAAC;YAEF,IAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAC;YAEpF,wDAAwD;YACxD,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;gBAC1B,+DAA+D;gBAC/D,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;gBAEpC,iCAAiC;gBACjC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;gBAE5C,qCAAqC;gBACrC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;gBAClC,OAAO,SAAS,CAAC;aAClB;YAED,uFAAuF;YACvF,IAAM,KAAK,GAAqB;gBAC9B,QAAQ,EAAE,QAAQ,CAAC,GAAG,CAAC,IAAI;gBAC3B,WAAW,EAAE;oBACX,UAAU,EAAE,KAAK,CAAC,IAAI,CAAC,qBAAqB,CAAC,MAAM,EAAE,CAAC;oBACtD,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC;oBAC5C,SAAS,EAAE,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC;iBAC1C;gBACD,QAAQ,UAAA;gBACR,SAAS,WAAA;gBACT,OAAO,EAAE,QAAQ,CAAC,OAAO;aAC1B,CAAC;YACF,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;YAChC,OAAO,KAAK,CAAC;QACf,CAAC;QAED;;WAEG;QACH,iDAAc,GAAd,UAAe,IAAsB;YACnC,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAE,CAAC,CAAC,CAAC,IAAI,CAAC;QAC7E,CAAC;QAED;;;WAGG;QACH,0DAAuB,GAAvB,UAAwB,IAAsB,EAAE,UAAuB,EAAE,KAAkB;YAEzF,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,EAAE,EAAC,UAAU,YAAA,EAAE,KAAK,OAAA,EAAC,CAAC,CAAC;QACpD,CAAC;QAED;;;;;;;;;;;WAWG;QACK,mDAAgB,GAAxB,UACI,GAAgC,EAAE,WAA4B,EAC9D,cAA+B,EAAE,IAAuB;YAC1D,IAAI,GAAG,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,iBAAiB,EAAE;gBAC9C,yFAAyF;gBACzF,IAAI,CAAC,EAAE,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;oBACpC,2FAA2F;oBAC3F,+BAA+B;oBAC/B,IAAM,IAAI,GAAG,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,uBAAS,CAAC,uBAAuB,CAAC,CAAC;wBACnC,uBAAS,CAAC,uBAAuB,CAAC;oBACnE,WAAW,CAAC,IAAI,CAAC,4BAAc,CAC3B,IAAI,EAAE,6BAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,IAAI,EAC5C,6BAA2B,IAAI,aAC3B,6BAAgB,CAAC,cAAc,CAAC,+CAA4C,CAAC,CAAC,CAAC;oBACvF,OAAO,SAAS,CAAC;iBAClB;gBACD,OAAO,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;aAChD;iBAAM;gBACL,yFAAyF;gBACzF,OAAO,IAAI,CAAC,yBAAyB,CAAC,GAAG,CAAC,CAAC;aAC5C;QACH,CAAC;QAEO,+CAAY,GAApB,UACI,QAAsB,EAAE,GAAgC,EAAE,QAA8B,EACxF,QAA0D,EAC1D,WAA4B;;YAHhC,iBA0DC;YAtDC,IAAI,SAAS,GAAoB,IAAI,CAAC;YACtC,IAAM,UAAU,GAAG,GAAG,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YAC5C,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,EAAE;gBAC9B,OAAO,IAAI,CAAC;aACb;YACD,SAAS,GAAG,EAAE,CAAC;YACf,8FAA8F;YAC9F,iBAAiB;YACjB,IAAM,WAAW,GAAG,IAAI,GAAG,EAAuC,CAAC;YACnE,iDAAiD;YACjD,IAAM,WAAW,GAAG,GAAG,CAAC;YACxB,IAAM,WAAW,GAAG,UAAC,SAAsC;gBACzD,IAAI,SAAS,CAAC,IAAI,CAAC,aAAa,EAAE,KAAK,UAAU,EAAE;oBACjD,OAAO;iBACR;gBACD,IAAM,UAAU,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;gBACjD,IAAM,UAAU,GAAG,KAAI,CAAC,YAAa,CAAC,kBAAkB,CACpD,SAAS,EAAE,UAAU,EAAE,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;gBACpE,IAAI,UAAU,KAAK,IAAI,EAAE;oBACvB,OAAO;iBACR;gBACD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE;oBAChC,IAAI,SAAS,CAAC,KAAK,IAAI,SAAS,CAAC,KAAK,YAAY,uBAAY,EAAE;wBAC9D,SAAU,CAAC,IAAI,CAAC;4BACd,UAAU,EAAE,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,UAAW;4BAC7C,UAAU,EAAE,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,IAAK;4BACvC,OAAO,EAAE,UAAU;yBACpB,CAAC,CAAC;qBACJ;yBAAM;wBACL,IAAM,IAAI,GAAG,KAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,sBAAsB,EAAE,EAAE,UAAU,CAAC,CAAC;wBAClF,IAAI,CAAC,CAAC,IAAI,YAAY,uBAAY,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,KAAK,IAAI;4BACjE,IAAI,CAAC,KAAK,CAAC,IAAI,KAAK,IAAI,EAAE;4BAC5B,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;yBAC1C;wBACD,SAAU,CAAC,IAAI,CAAC;4BACd,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU;4BACjC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI;4BAC3B,OAAO,EAAE,UAAU;yBACpB,CAAC,CAAC;qBACJ;oBACD,WAAW,CAAC,GAAG,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;iBACxC;qBAAM;oBACL,kEAAkE;oBAClE,IAAM,OAAO,GAAG,WAAW,CAAC,GAAG,CAAC,UAAU,CAAE,CAAC;oBAC7C,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,IAAI,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC,CAAC;iBAC3E;YACH,CAAC,CAAC;;gBACF,KAAoB,IAAA,KAAA,iBAAA,QAAQ,CAAC,UAAU,CAAA,gBAAA,4BAAE;oBAA7B,IAAA,KAAG,eAAA;oBACb,WAAW,CAAC,KAAG,CAAC,CAAC;iBAClB;;;;;;;;;;gBACD,KAAoB,IAAA,KAAA,iBAAA,QAAQ,CAAC,KAAK,CAAA,gBAAA,4BAAE;oBAAxB,IAAA,KAAG,eAAA;oBACb,WAAW,CAAC,KAAG,CAAC,CAAC;iBAClB;;;;;;;;;YACD,OAAO,SAAS,CAAC;QACnB,CAAC;QAEO,mDAAgB,GAAxB;YACE,IAAI,IAAI,CAAC,MAAM,EAAE;gBACf,MAAM,IAAI,KAAK,CAAC,uDAAuD,CAAC,CAAC;aAC1E;QACH,CAAC;QACH,+BAAC;IAAD,CAAC,AAxfD,IAwfC;IAxfY,4DAAwB;IA0frC;;OAEG;IACH,SAAS,UAAU,CACf,KAAsB,EAAE,IAAgC,EACxD,IAAuB;QACzB,IAAM,IAAI,GACN,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,uBAAS,CAAC,uBAAuB,CAAC,CAAC,CAAC,uBAAS,CAAC,uBAAuB,CAAC;QAC9F,IAAM,aAAa,GAAG,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,yCAAyC,CAAC;QACjG,IAAI,OAAO,GACP,6BAA2B,IAAI,aAC3B,6BAAgB,CAAC,KAAK,CAAC,0CAAqC,aAAa,YAAS;YACtF,MAAM,CAAC;QACX,IAAM,OAAO,GAAG,IAAI,CAAC,kBAAkB,KAAK,IAAI,CAAC,CAAC,CAAC,OAAK,IAAI,CAAC,kBAAkB,MAAG,CAAC,CAAC,CAAC,EAAE,CAAC;QACxF,IAAM,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;QAErC,mDAAmD;QACnD,IAAI,CAAC,EAAE,CAAC,iBAAiB,EAAE;YACzB,wCAAwC;YACxC,IAAM,cAAc,GAAG,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC;YACnE,OAAO,IAAI,sBAAoB,cAAc,iBAAc,CAAC;SAC7D;aAAM,IAAI,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,EAAE;YACrD,8DAA8D;YAC9D,OAAO;gBACH,uCAAqC,OAAO,wBAAmB,IAAI,CAAC,SAAS,cAAW;oBACxF,sFAAsF;oBACtF,sFAAsF;oBACtF,0FAA0F,CAAC;SAChG;aAAM;YACL,6FAA6F;YAC7F,oCAAoC;YACpC,OAAO,IAAI,0CAAwC,OAAO,wBACtD,IAAI,CAAC,SAAS,+CAA4C,CAAC;SAChE;QAED,OAAO,4BAAc,CAAC,IAAI,EAAE,6BAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IACjF,CAAC;IAED;;OAEG;IACH,SAAS,4BAA4B,CACjC,KAAsB,EAAE,IAAgC,EACxD,IAAuB;QACzB,IAAM,IAAI,GACN,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,uBAAS,CAAC,uBAAuB,CAAC,CAAC,CAAC,uBAAS,CAAC,uBAAuB,CAAC;QAC9F,OAAO,4BAAc,CACjB,IAAI,EAAE,6BAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,EAC9C,6BAA2B,IAAI,aAAQ,6BAAgB,CAAC,KAAK,CAAC,4BAAyB,CAAC,CAAC;IAC/F,CAAC;IAED;;;OAGG;IACH,SAAS,eAAe,CAAC,KAAsB,EAAE,IAAgC;QAC/E,OAAO,4BAAc,CACjB,uBAAS,CAAC,yBAAyB,EAAE,6BAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,EAC7E,wCACI,6BAAgB,CAAC,KAAK,CAAC,uCAAoC,CAAC,CAAC;IACvE,CAAC;IAED;;OAEG;IACH,SAAS,iBAAiB,CACtB,MAAwB,EAAE,IAAiC,EAC3D,IAAiC;QACnC,IAAM,gBAAgB,GAAG,oDACrB,MAAM,CAAC,IAAI,CAAC,IAAI,mEAAgE,CAAC;QACrF,OAAO,4BAAc,CACjB,uBAAS,CAAC,gCAAgC,EAAE,MAAM,CAAC,IAAI,EACvD,CAAA,iEAEI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,kDAA6C,MAAM,CAAC,IAAI,CAAC,IAAI,4VAKvF,CAAA,CAAC,IAAI,EAAE,EACJ;YACE,oCAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,gBAAgB,CAAC;YACxD,oCAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,gBAAgB,CAAC;SACzD,CAAC,CAAC;IACT,CAAC","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 {ExternalExpr, SchemaMetadata} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {ErrorCode, makeDiagnostic, makeRelatedInformation} from '../../diagnostics';\nimport {AliasingHost, Reexport, Reference, ReferenceEmitter} from '../../imports';\nimport {DirectiveMeta, MetadataReader, MetadataRegistry, NgModuleMeta, PipeMeta} from '../../metadata';\nimport {ClassDeclaration, DeclarationNode} from '../../reflection';\nimport {identifierOfNode, nodeNameForError} from '../../util/src/typescript';\n\nimport {ExportScope, RemoteScope, ScopeData} from './api';\nimport {ComponentScopeReader} from './component_scope';\nimport {DtsModuleScopeResolver} from './dependency';\n\nexport interface LocalNgModuleData {\n  declarations: Reference<ClassDeclaration>[];\n  imports: Reference<ClassDeclaration>[];\n  exports: Reference<ClassDeclaration>[];\n}\n\nexport interface LocalModuleScope extends ExportScope {\n  ngModule: ClassDeclaration;\n  compilation: ScopeData;\n  reexports: Reexport[]|null;\n  schemas: SchemaMetadata[];\n}\n\n/**\n * Information about the compilation scope of a registered declaration.\n */\nexport interface CompilationScope extends ScopeData {\n  /** The declaration whose compilation scope is described here. */\n  declaration: ClassDeclaration;\n  /** The declaration of the NgModule that declares this `declaration`. */\n  ngModule: ClassDeclaration;\n}\n\n/**\n * A registry which collects information about NgModules, Directives, Components, and Pipes which\n * are local (declared in the ts.Program being compiled), and can produce `LocalModuleScope`s\n * which summarize the compilation scope of a component.\n *\n * This class implements the logic of NgModule declarations, imports, and exports and can produce,\n * for a given component, the set of directives and pipes which are \"visible\" in that component's\n * template.\n *\n * The `LocalModuleScopeRegistry` has two \"modes\" of operation. During analysis, data for each\n * individual NgModule, Directive, Component, and Pipe is added to the registry. No attempt is made\n * to traverse or validate the NgModule graph (imports, exports, etc). After analysis, one of\n * `getScopeOfModule` or `getScopeForComponent` can be called, which traverses the NgModule graph\n * and applies the NgModule logic to generate a `LocalModuleScope`, the full scope for the given\n * module or component.\n *\n * The `LocalModuleScopeRegistry` is also capable of producing `ts.Diagnostic` errors when Angular\n * semantics are violated.\n */\nexport class LocalModuleScopeRegistry implements MetadataRegistry, ComponentScopeReader {\n  /**\n   * Tracks whether the registry has been asked to produce scopes for a module or component. Once\n   * this is true, the registry cannot accept registrations of new directives/pipes/modules as it\n   * would invalidate the cached scope data.\n   */\n  private sealed = false;\n\n  /**\n   * A map of components from the current compilation unit to the NgModule which declared them.\n   *\n   * As components and directives are not distinguished at the NgModule level, this map may also\n   * contain directives. This doesn't cause any problems but isn't useful as there is no concept of\n   * a directive's compilation scope.\n   */\n  private declarationToModule = new Map<ClassDeclaration, DeclarationData>();\n\n  /**\n   * This maps from the directive/pipe class to a map of data for each NgModule that declares the\n   * directive/pipe. This data is needed to produce an error for the given class.\n   */\n  private duplicateDeclarations =\n      new Map<ClassDeclaration, Map<ClassDeclaration, DeclarationData>>();\n\n  private moduleToRef = new Map<ClassDeclaration, Reference<ClassDeclaration>>();\n\n  /**\n   * A cache of calculated `LocalModuleScope`s for each NgModule declared in the current program.\n   *\n   * A value of `undefined` indicates the scope was invalid and produced errors (therefore,\n   * diagnostics should exist in the `scopeErrors` map).\n   */\n  private cache = new Map<ClassDeclaration, LocalModuleScope|undefined|null>();\n\n  /**\n   * Tracks the `RemoteScope` for components requiring \"remote scoping\".\n   *\n   * Remote scoping is when the set of directives which apply to a given component is set in the\n   * NgModule's file instead of directly on the component def (which is sometimes needed to get\n   * around cyclic import issues). This is not used in calculation of `LocalModuleScope`s, but is\n   * tracked here for convenience.\n   */\n  private remoteScoping = new Map<ClassDeclaration, RemoteScope>();\n\n  /**\n   * Tracks errors accumulated in the processing of scopes for each module declaration.\n   */\n  private scopeErrors = new Map<ClassDeclaration, ts.Diagnostic[]>();\n\n  /**\n   * Tracks which NgModules are unreliable due to errors within their declarations.\n   *\n   * This provides a unified view of which modules have errors, across all of the different\n   * diagnostic categories that can be produced. Theoretically this can be inferred from the other\n   * properties of this class, but is tracked explicitly to simplify the logic.\n   */\n  private taintedModules = new Set<ClassDeclaration>();\n\n  constructor(\n      private localReader: MetadataReader, private dependencyScopeReader: DtsModuleScopeResolver,\n      private refEmitter: ReferenceEmitter, private aliasingHost: AliasingHost|null) {}\n\n  /**\n   * Add an NgModule's data to the registry.\n   */\n  registerNgModuleMetadata(data: NgModuleMeta): void {\n    this.assertCollecting();\n    const ngModule = data.ref.node;\n    this.moduleToRef.set(data.ref.node, data.ref);\n    // Iterate over the module's declarations, and add them to declarationToModule. If duplicates\n    // are found, they're instead tracked in duplicateDeclarations.\n    for (const decl of data.declarations) {\n      this.registerDeclarationOfModule(ngModule, decl, data.rawDeclarations);\n    }\n  }\n\n  registerDirectiveMetadata(directive: DirectiveMeta): void {}\n\n  registerPipeMetadata(pipe: PipeMeta): void {}\n\n  getScopeForComponent(clazz: ClassDeclaration): LocalModuleScope|null|'error' {\n    const scope = !this.declarationToModule.has(clazz) ?\n        null :\n        this.getScopeOfModule(this.declarationToModule.get(clazz)!.ngModule);\n    return scope;\n  }\n\n  /**\n   * If `node` is declared in more than one NgModule (duplicate declaration), then get the\n   * `DeclarationData` for each offending declaration.\n   *\n   * Ordinarily a class is only declared in one NgModule, in which case this function returns\n   * `null`.\n   */\n  getDuplicateDeclarations(node: ClassDeclaration): DeclarationData[]|null {\n    if (!this.duplicateDeclarations.has(node)) {\n      return null;\n    }\n\n    return Array.from(this.duplicateDeclarations.get(node)!.values());\n  }\n\n  /**\n   * Collects registered data for a module and its directives/pipes and convert it into a full\n   * `LocalModuleScope`.\n   *\n   * This method implements the logic of NgModule imports and exports. It returns the\n   * `LocalModuleScope` for the given NgModule if one can be produced, `null` if no scope was ever\n   * defined, or the string `'error'` if the scope contained errors.\n   */\n  getScopeOfModule(clazz: ClassDeclaration): LocalModuleScope|'error'|null {\n    const scope = this.moduleToRef.has(clazz) ?\n        this.getScopeOfModuleReference(this.moduleToRef.get(clazz)!) :\n        null;\n    // If the NgModule class is marked as tainted, consider it an error.\n    if (this.taintedModules.has(clazz)) {\n      return 'error';\n    }\n\n    // Translate undefined -> 'error'.\n    return scope !== undefined ? scope : 'error';\n  }\n\n  /**\n   * Retrieves any `ts.Diagnostic`s produced during the calculation of the `LocalModuleScope` for\n   * the given NgModule, or `null` if no errors were present.\n   */\n  getDiagnosticsOfModule(clazz: ClassDeclaration): ts.Diagnostic[]|null {\n    // Required to ensure the errors are populated for the given class. If it has been processed\n    // before, this will be a no-op due to the scope cache.\n    this.getScopeOfModule(clazz);\n\n    if (this.scopeErrors.has(clazz)) {\n      return this.scopeErrors.get(clazz)!;\n    } else {\n      return null;\n    }\n  }\n\n  /**\n   * Returns a collection of the compilation scope for each registered declaration.\n   */\n  getCompilationScopes(): CompilationScope[] {\n    const scopes: CompilationScope[] = [];\n    this.declarationToModule.forEach((declData, declaration) => {\n      const scope = this.getScopeOfModule(declData.ngModule);\n      if (scope !== null && scope !== 'error') {\n        scopes.push({declaration, ngModule: declData.ngModule, ...scope.compilation});\n      }\n    });\n    return scopes;\n  }\n\n  private registerDeclarationOfModule(\n      ngModule: ClassDeclaration, decl: Reference<ClassDeclaration>,\n      rawDeclarations: ts.Expression|null): void {\n    const declData: DeclarationData = {\n      ngModule,\n      ref: decl,\n      rawDeclarations,\n    };\n\n    // First, check for duplicate declarations of the same directive/pipe.\n    if (this.duplicateDeclarations.has(decl.node)) {\n      // This directive/pipe has already been identified as being duplicated. Add this module to the\n      // map of modules for which a duplicate declaration exists.\n      this.duplicateDeclarations.get(decl.node)!.set(ngModule, declData);\n    } else if (\n        this.declarationToModule.has(decl.node) &&\n        this.declarationToModule.get(decl.node)!.ngModule !== ngModule) {\n      // This directive/pipe is already registered as declared in another module. Mark it as a\n      // duplicate instead.\n      const duplicateDeclMap = new Map<ClassDeclaration, DeclarationData>();\n      const firstDeclData = this.declarationToModule.get(decl.node)!;\n\n      // Mark both modules as tainted, since their declarations are missing a component.\n      this.taintedModules.add(firstDeclData.ngModule);\n      this.taintedModules.add(ngModule);\n\n      // Being detected as a duplicate means there are two NgModules (for now) which declare this\n      // directive/pipe. Add both of them to the duplicate tracking map.\n      duplicateDeclMap.set(firstDeclData.ngModule, firstDeclData);\n      duplicateDeclMap.set(ngModule, declData);\n      this.duplicateDeclarations.set(decl.node, duplicateDeclMap);\n\n      // Remove the directive/pipe from `declarationToModule` as it's a duplicate declaration, and\n      // therefore not valid.\n      this.declarationToModule.delete(decl.node);\n    } else {\n      // This is the first declaration of this directive/pipe, so map it.\n      this.declarationToModule.set(decl.node, declData);\n    }\n  }\n\n  /**\n   * Implementation of `getScopeOfModule` which accepts a reference to a class and differentiates\n   * between:\n   *\n   * * no scope being available (returns `null`)\n   * * a scope being produced with errors (returns `undefined`).\n   */\n  private getScopeOfModuleReference(ref: Reference<ClassDeclaration>): LocalModuleScope|null\n      |undefined {\n    if (this.cache.has(ref.node)) {\n      return this.cache.get(ref.node);\n    }\n\n    // Seal the registry to protect the integrity of the `LocalModuleScope` cache.\n    this.sealed = true;\n\n    // `ref` should be an NgModule previously added to the registry. If not, a scope for it\n    // cannot be produced.\n    const ngModule = this.localReader.getNgModuleMetadata(ref);\n    if (ngModule === null) {\n      this.cache.set(ref.node, null);\n      return null;\n    }\n\n    // Modules which contributed to the compilation scope of this module.\n    const compilationModules = new Set<ClassDeclaration>([ngModule.ref.node]);\n    // Modules which contributed to the export scope of this module.\n    const exportedModules = new Set<ClassDeclaration>([ngModule.ref.node]);\n\n    // Errors produced during computation of the scope are recorded here. At the end, if this array\n    // isn't empty then `undefined` will be cached and returned to indicate this scope is invalid.\n    const diagnostics: ts.Diagnostic[] = [];\n\n    // At this point, the goal is to produce two distinct transitive sets:\n    // - the directives and pipes which are visible to components declared in the NgModule.\n    // - the directives and pipes which are exported to any NgModules which import this one.\n\n    // Directives and pipes in the compilation scope.\n    const compilationDirectives = new Map<DeclarationNode, DirectiveMeta>();\n    const compilationPipes = new Map<DeclarationNode, PipeMeta>();\n\n    const declared = new Set<DeclarationNode>();\n\n    // Directives and pipes exported to any importing NgModules.\n    const exportDirectives = new Map<DeclarationNode, DirectiveMeta>();\n    const exportPipes = new Map<DeclarationNode, PipeMeta>();\n\n    // The algorithm is as follows:\n    // 1) Add all of the directives/pipes from each NgModule imported into the current one to the\n    //    compilation scope.\n    // 2) Add directives/pipes declared in the NgModule to the compilation scope. At this point, the\n    //    compilation scope is complete.\n    // 3) For each entry in the NgModule's exports:\n    //    a) Attempt to resolve it as an NgModule with its own exported directives/pipes. If it is\n    //       one, add them to the export scope of this NgModule.\n    //    b) Otherwise, it should be a class in the compilation scope of this NgModule. If it is,\n    //       add it to the export scope.\n    //    c) If it's neither an NgModule nor a directive/pipe in the compilation scope, then this\n    //       is an error.\n\n    // 1) process imports.\n    for (const decl of ngModule.imports) {\n      const importScope = this.getExportedScope(decl, diagnostics, ref.node, 'import');\n      if (importScope === null) {\n        // An import wasn't an NgModule, so record an error.\n        diagnostics.push(invalidRef(ref.node, decl, 'import'));\n        continue;\n      } else if (importScope === undefined) {\n        // An import was an NgModule but contained errors of its own. Record this as an error too,\n        // because this scope is always going to be incorrect if one of its imports could not be\n        // read.\n        diagnostics.push(invalidTransitiveNgModuleRef(ref.node, decl, 'import'));\n        continue;\n      }\n      for (const directive of importScope.exported.directives) {\n        compilationDirectives.set(directive.ref.node, directive);\n      }\n      for (const pipe of importScope.exported.pipes) {\n        compilationPipes.set(pipe.ref.node, pipe);\n      }\n      for (const importedModule of importScope.exported.ngModules) {\n        compilationModules.add(importedModule);\n      }\n    }\n\n    // 2) add declarations.\n    for (const decl of ngModule.declarations) {\n      const directive = this.localReader.getDirectiveMetadata(decl);\n      const pipe = this.localReader.getPipeMetadata(decl);\n      if (directive !== null) {\n        compilationDirectives.set(decl.node, {...directive, ref: decl});\n      } else if (pipe !== null) {\n        compilationPipes.set(decl.node, {...pipe, ref: decl});\n      } else {\n        this.taintedModules.add(ngModule.ref.node);\n\n        const errorNode = decl.getOriginForDiagnostics(ngModule.rawDeclarations!);\n        diagnostics.push(makeDiagnostic(\n            ErrorCode.NGMODULE_INVALID_DECLARATION, errorNode,\n            `The class '${decl.node.name.text}' is listed in the declarations ` +\n                `of the NgModule '${\n                    ngModule.ref.node.name\n                        .text}', but is not a directive, a component, or a pipe. ` +\n                `Either remove it from the NgModule's declarations, or add an appropriate Angular decorator.`,\n            [makeRelatedInformation(\n                decl.node.name, `'${decl.node.name.text}' is declared here.`)]));\n        continue;\n      }\n\n      declared.add(decl.node);\n    }\n\n    // 3) process exports.\n    // Exports can contain modules, components, or directives. They're processed differently.\n    // Modules are straightforward. Directives and pipes from exported modules are added to the\n    // export maps. Directives/pipes are different - they might be exports of declared types or\n    // imported types.\n    for (const decl of ngModule.exports) {\n      // Attempt to resolve decl as an NgModule.\n      const importScope = this.getExportedScope(decl, diagnostics, ref.node, 'export');\n      if (importScope === undefined) {\n        // An export was an NgModule but contained errors of its own. Record this as an error too,\n        // because this scope is always going to be incorrect if one of its exports could not be\n        // read.\n        diagnostics.push(invalidTransitiveNgModuleRef(ref.node, decl, 'export'));\n        continue;\n      } else if (importScope !== null) {\n        // decl is an NgModule.\n        for (const directive of importScope.exported.directives) {\n          exportDirectives.set(directive.ref.node, directive);\n        }\n        for (const pipe of importScope.exported.pipes) {\n          exportPipes.set(pipe.ref.node, pipe);\n        }\n        for (const exportedModule of importScope.exported.ngModules) {\n          exportedModules.add(exportedModule);\n        }\n      } else if (compilationDirectives.has(decl.node)) {\n        // decl is a directive or component in the compilation scope of this NgModule.\n        const directive = compilationDirectives.get(decl.node)!;\n        exportDirectives.set(decl.node, directive);\n      } else if (compilationPipes.has(decl.node)) {\n        // decl is a pipe in the compilation scope of this NgModule.\n        const pipe = compilationPipes.get(decl.node)!;\n        exportPipes.set(decl.node, pipe);\n      } else {\n        // decl is an unknown export.\n        if (this.localReader.getDirectiveMetadata(decl) !== null ||\n            this.localReader.getPipeMetadata(decl) !== null) {\n          diagnostics.push(invalidReexport(ref.node, decl));\n        } else {\n          diagnostics.push(invalidRef(ref.node, decl, 'export'));\n        }\n        continue;\n      }\n    }\n\n    const exported = {\n      directives: Array.from(exportDirectives.values()),\n      pipes: Array.from(exportPipes.values()),\n      ngModules: Array.from(exportedModules),\n    };\n\n    const reexports = this.getReexports(ngModule, ref, declared, exported, diagnostics);\n\n    // Check if this scope had any errors during production.\n    if (diagnostics.length > 0) {\n      // Cache undefined, to mark the fact that the scope is invalid.\n      this.cache.set(ref.node, undefined);\n\n      // Save the errors for retrieval.\n      this.scopeErrors.set(ref.node, diagnostics);\n\n      // Mark this module as being tainted.\n      this.taintedModules.add(ref.node);\n      return undefined;\n    }\n\n    // Finally, produce the `LocalModuleScope` with both the compilation and export scopes.\n    const scope: LocalModuleScope = {\n      ngModule: ngModule.ref.node,\n      compilation: {\n        directives: Array.from(compilationDirectives.values()),\n        pipes: Array.from(compilationPipes.values()),\n        ngModules: Array.from(compilationModules),\n      },\n      exported,\n      reexports,\n      schemas: ngModule.schemas,\n    };\n    this.cache.set(ref.node, scope);\n    return scope;\n  }\n\n  /**\n   * Check whether a component requires remote scoping.\n   */\n  getRemoteScope(node: ClassDeclaration): RemoteScope|null {\n    return this.remoteScoping.has(node) ? this.remoteScoping.get(node)! : null;\n  }\n\n  /**\n   * Set a component as requiring remote scoping, with the given directives and pipes to be\n   * registered remotely.\n   */\n  setComponentRemoteScope(node: ClassDeclaration, directives: Reference[], pipes: Reference[]):\n      void {\n    this.remoteScoping.set(node, {directives, pipes});\n  }\n\n  /**\n   * Look up the `ExportScope` of a given `Reference` to an NgModule.\n   *\n   * The NgModule in question may be declared locally in the current ts.Program, or it may be\n   * declared in a .d.ts file.\n   *\n   * @returns `null` if no scope could be found, or `undefined` if an invalid scope\n   * was found.\n   *\n   * May also contribute diagnostics of its own by adding to the given `diagnostics`\n   * array parameter.\n   */\n  private getExportedScope(\n      ref: Reference<ClassDeclaration>, diagnostics: ts.Diagnostic[],\n      ownerForErrors: DeclarationNode, type: 'import'|'export'): ExportScope|null|undefined {\n    if (ref.node.getSourceFile().isDeclarationFile) {\n      // The NgModule is declared in a .d.ts file. Resolve it with the `DependencyScopeReader`.\n      if (!ts.isClassDeclaration(ref.node)) {\n        // The NgModule is in a .d.ts file but is not declared as a ts.ClassDeclaration. This is an\n        // error in the .d.ts metadata.\n        const code = type === 'import' ? ErrorCode.NGMODULE_INVALID_IMPORT :\n                                         ErrorCode.NGMODULE_INVALID_EXPORT;\n        diagnostics.push(makeDiagnostic(\n            code, identifierOfNode(ref.node) || ref.node,\n            `Appears in the NgModule.${type}s of ${\n                nodeNameForError(ownerForErrors)}, but could not be resolved to an NgModule`));\n        return undefined;\n      }\n      return this.dependencyScopeReader.resolve(ref);\n    } else {\n      // The NgModule is declared locally in the current program. Resolve it from the registry.\n      return this.getScopeOfModuleReference(ref);\n    }\n  }\n\n  private getReexports(\n      ngModule: NgModuleMeta, ref: Reference<ClassDeclaration>, declared: Set<DeclarationNode>,\n      exported: {directives: DirectiveMeta[], pipes: PipeMeta[]},\n      diagnostics: ts.Diagnostic[]): Reexport[]|null {\n    let reexports: Reexport[]|null = null;\n    const sourceFile = ref.node.getSourceFile();\n    if (this.aliasingHost === null) {\n      return null;\n    }\n    reexports = [];\n    // Track re-exports by symbol name, to produce diagnostics if two alias re-exports would share\n    // the same name.\n    const reexportMap = new Map<string, Reference<ClassDeclaration>>();\n    // Alias ngModuleRef added for readability below.\n    const ngModuleRef = ref;\n    const addReexport = (exportRef: Reference<ClassDeclaration>) => {\n      if (exportRef.node.getSourceFile() === sourceFile) {\n        return;\n      }\n      const isReExport = !declared.has(exportRef.node);\n      const exportName = this.aliasingHost!.maybeAliasSymbolAs(\n          exportRef, sourceFile, ngModule.ref.node.name.text, isReExport);\n      if (exportName === null) {\n        return;\n      }\n      if (!reexportMap.has(exportName)) {\n        if (exportRef.alias && exportRef.alias instanceof ExternalExpr) {\n          reexports!.push({\n            fromModule: exportRef.alias.value.moduleName!,\n            symbolName: exportRef.alias.value.name!,\n            asAlias: exportName,\n          });\n        } else {\n          const expr = this.refEmitter.emit(exportRef.cloneWithNoIdentifiers(), sourceFile);\n          if (!(expr instanceof ExternalExpr) || expr.value.moduleName === null ||\n              expr.value.name === null) {\n            throw new Error('Expected ExternalExpr');\n          }\n          reexports!.push({\n            fromModule: expr.value.moduleName,\n            symbolName: expr.value.name,\n            asAlias: exportName,\n          });\n        }\n        reexportMap.set(exportName, exportRef);\n      } else {\n        // Another re-export already used this name. Produce a diagnostic.\n        const prevRef = reexportMap.get(exportName)!;\n        diagnostics.push(reexportCollision(ngModuleRef.node, prevRef, exportRef));\n      }\n    };\n    for (const {ref} of exported.directives) {\n      addReexport(ref);\n    }\n    for (const {ref} of exported.pipes) {\n      addReexport(ref);\n    }\n    return reexports;\n  }\n\n  private assertCollecting(): void {\n    if (this.sealed) {\n      throw new Error(`Assertion: LocalModuleScopeRegistry is not COLLECTING`);\n    }\n  }\n}\n\n/**\n * Produce a `ts.Diagnostic` for an invalid import or export from an NgModule.\n */\nfunction invalidRef(\n    clazz: DeclarationNode, decl: Reference<DeclarationNode>,\n    type: 'import'|'export'): ts.Diagnostic {\n  const code =\n      type === 'import' ? ErrorCode.NGMODULE_INVALID_IMPORT : ErrorCode.NGMODULE_INVALID_EXPORT;\n  const resolveTarget = type === 'import' ? 'NgModule' : 'NgModule, Component, Directive, or Pipe';\n  let message =\n      `Appears in the NgModule.${type}s of ${\n          nodeNameForError(clazz)}, but could not be resolved to an ${resolveTarget} class.` +\n      '\\n\\n';\n  const library = decl.ownedByModuleGuess !== null ? ` (${decl.ownedByModuleGuess})` : '';\n  const sf = decl.node.getSourceFile();\n\n  // Provide extra context to the error for the user.\n  if (!sf.isDeclarationFile) {\n    // This is a file in the user's program.\n    const annotationType = type === 'import' ? '@NgModule' : 'Angular';\n    message += `Is it missing an ${annotationType} annotation?`;\n  } else if (sf.fileName.indexOf('node_modules') !== -1) {\n    // This file comes from a third-party library in node_modules.\n    message +=\n        `This likely means that the library${library} which declares ${decl.debugName} has not ` +\n        'been processed correctly by ngcc, or is not compatible with Angular Ivy. Check if a ' +\n        'newer version of the library is available, and update if so. Also consider checking ' +\n        'with the library\\'s authors to see if the library is expected to be compatible with Ivy.';\n  } else {\n    // This is a monorepo style local dependency. Unfortunately these are too different to really\n    // offer much more advice than this.\n    message += `This likely means that the dependency${library} which declares ${\n        decl.debugName} has not been processed correctly by ngcc.`;\n  }\n\n  return makeDiagnostic(code, identifierOfNode(decl.node) || decl.node, message);\n}\n\n/**\n * Produce a `ts.Diagnostic` for an import or export which itself has errors.\n */\nfunction invalidTransitiveNgModuleRef(\n    clazz: DeclarationNode, decl: Reference<DeclarationNode>,\n    type: 'import'|'export'): ts.Diagnostic {\n  const code =\n      type === 'import' ? ErrorCode.NGMODULE_INVALID_IMPORT : ErrorCode.NGMODULE_INVALID_EXPORT;\n  return makeDiagnostic(\n      code, identifierOfNode(decl.node) || decl.node,\n      `Appears in the NgModule.${type}s of ${nodeNameForError(clazz)}, but itself has errors`);\n}\n\n/**\n * Produce a `ts.Diagnostic` for an exported directive or pipe which was not declared or imported\n * by the NgModule in question.\n */\nfunction invalidReexport(clazz: DeclarationNode, decl: Reference<DeclarationNode>): ts.Diagnostic {\n  return makeDiagnostic(\n      ErrorCode.NGMODULE_INVALID_REEXPORT, identifierOfNode(decl.node) || decl.node,\n      `Present in the NgModule.exports of ${\n          nodeNameForError(clazz)} but neither declared nor imported`);\n}\n\n/**\n * Produce a `ts.Diagnostic` for a collision in re-export names between two directives/pipes.\n */\nfunction reexportCollision(\n    module: ClassDeclaration, refA: Reference<ClassDeclaration>,\n    refB: Reference<ClassDeclaration>): ts.Diagnostic {\n  const childMessageText = `This directive/pipe is part of the exports of '${\n      module.name.text}' and shares the same name as another exported directive/pipe.`;\n  return makeDiagnostic(\n      ErrorCode.NGMODULE_REEXPORT_NAME_COLLISION, module.name,\n      `\n    There was a name collision between two classes named '${\n          refA.node.name.text}', which are both part of the exports of '${module.name.text}'.\n\n    Angular generates re-exports of an NgModule's exported directives/pipes from the module's source file in certain cases, using the declared name of the class. If two classes of the same name are exported, this automatic naming does not work.\n\n    To fix this problem please re-export one or both classes directly from this file.\n  `.trim(),\n      [\n        makeRelatedInformation(refA.node.name, childMessageText),\n        makeRelatedInformation(refB.node.name, childMessageText),\n      ]);\n}\n\nexport interface DeclarationData {\n  ngModule: ClassDeclaration;\n  ref: Reference;\n  rawDeclarations: ts.Expression|null;\n}\n"]}
@@ -7,14 +7,7 @@
7
7
  */
8
8
  /// <amd-module name="@angular/compiler-cli/src/ngtsc/typecheck/src/host" />
9
9
  import * as ts from 'typescript';
10
- /**
11
- * Represents the `ts.CompilerHost` interface, with a transformation applied that turns all
12
- * methods (even optional ones) into required fields (which may be `undefined`, if the method was
13
- * optional).
14
- */
15
- export declare type RequiredCompilerHostDelegations = {
16
- [M in keyof Required<ts.CompilerHost>]: ts.CompilerHost[M];
17
- };
10
+ import { RequiredDelegations } from '../../util/src/typescript';
18
11
  /**
19
12
  * Delegates all methods of `ts.CompilerHost` to a delegate, with the exception of
20
13
  * `getSourceFile`, `fileExists` and `writeFile` which are implemented in `TypeCheckProgramHost`.
@@ -22,7 +15,7 @@ export declare type RequiredCompilerHostDelegations = {
22
15
  * If a new method is added to `ts.CompilerHost` which is not delegated, a type error will be
23
16
  * generated for this class.
24
17
  */
25
- export declare class DelegatingCompilerHost implements Omit<RequiredCompilerHostDelegations, 'getSourceFile' | 'fileExists' | 'writeFile'> {
18
+ export declare class DelegatingCompilerHost implements Omit<RequiredDelegations<ts.CompilerHost>, 'getSourceFile' | 'fileExists' | 'writeFile'> {
26
19
  protected delegate: ts.CompilerHost;
27
20
  constructor(delegate: ts.CompilerHost);
28
21
  private delegateMethod;
@@ -125,4 +125,4 @@
125
125
  }(DelegatingCompilerHost));
126
126
  exports.TypeCheckProgramHost = TypeCheckProgramHost;
127
127
  });
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"host.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/typecheck/src/host.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 * as ts from 'typescript';\n\nimport {copyFileShimData, ShimReferenceTagger} from '../../shims';\n\n/**\n * Represents the `ts.CompilerHost` interface, with a transformation applied that turns all\n * methods (even optional ones) into required fields (which may be `undefined`, if the method was\n * optional).\n */\nexport type RequiredCompilerHostDelegations = {\n  [M in keyof Required<ts.CompilerHost>]: ts.CompilerHost[M];\n};\n\n/**\n * Delegates all methods of `ts.CompilerHost` to a delegate, with the exception of\n * `getSourceFile`, `fileExists` and `writeFile` which are implemented in `TypeCheckProgramHost`.\n *\n * If a new method is added to `ts.CompilerHost` which is not delegated, a type error will be\n * generated for this class.\n */\nexport class DelegatingCompilerHost implements\n    Omit<RequiredCompilerHostDelegations, 'getSourceFile'|'fileExists'|'writeFile'> {\n  constructor(protected delegate: ts.CompilerHost) {}\n\n  private delegateMethod<M extends keyof ts.CompilerHost>(name: M): ts.CompilerHost[M] {\n    return this.delegate[name] !== undefined ? (this.delegate[name] as any).bind(this.delegate) :\n                                               undefined;\n  }\n\n  // Excluded are 'getSourceFile', 'fileExists' and 'writeFile', which are actually implemented by\n  // `TypeCheckProgramHost` below.\n  createHash = this.delegateMethod('createHash');\n  directoryExists = this.delegateMethod('directoryExists');\n  getCancellationToken = this.delegateMethod('getCancellationToken');\n  getCanonicalFileName = this.delegateMethod('getCanonicalFileName');\n  getCurrentDirectory = this.delegateMethod('getCurrentDirectory');\n  getDefaultLibFileName = this.delegateMethod('getDefaultLibFileName');\n  getDefaultLibLocation = this.delegateMethod('getDefaultLibLocation');\n  getDirectories = this.delegateMethod('getDirectories');\n  getEnvironmentVariable = this.delegateMethod('getEnvironmentVariable');\n  getNewLine = this.delegateMethod('getNewLine');\n  getParsedCommandLine = this.delegateMethod('getParsedCommandLine');\n  getSourceFileByPath = this.delegateMethod('getSourceFileByPath');\n  readDirectory = this.delegateMethod('readDirectory');\n  readFile = this.delegateMethod('readFile');\n  realpath = this.delegateMethod('realpath');\n  resolveModuleNames = this.delegateMethod('resolveModuleNames');\n  resolveTypeReferenceDirectives = this.delegateMethod('resolveTypeReferenceDirectives');\n  trace = this.delegateMethod('trace');\n  useCaseSensitiveFileNames = this.delegateMethod('useCaseSensitiveFileNames');\n}\n\n/**\n * A `ts.CompilerHost` which augments source files with type checking code from a\n * `TypeCheckContext`.\n */\nexport class TypeCheckProgramHost extends DelegatingCompilerHost {\n  /**\n   * Map of source file names to `ts.SourceFile` instances.\n   */\n  private sfMap: Map<string, ts.SourceFile>;\n\n  /**\n   * The `ShimReferenceTagger` responsible for tagging `ts.SourceFile`s loaded via this host.\n   *\n   * The `TypeCheckProgramHost` is used in the creation of a new `ts.Program`. Even though this new\n   * program is based on a prior one, TypeScript will still start from the root files and enumerate\n   * all source files to include in the new program.  This means that just like during the original\n   * program's creation, these source files must be tagged with references to per-file shims in\n   * order for those shims to be loaded, and then cleaned up afterwards. Thus the\n   * `TypeCheckProgramHost` has its own `ShimReferenceTagger` to perform this function.\n   */\n  private shimTagger = new ShimReferenceTagger(this.shimExtensionPrefixes);\n\n  constructor(\n      sfMap: Map<string, ts.SourceFile>, private originalProgram: ts.Program,\n      delegate: ts.CompilerHost, private shimExtensionPrefixes: string[]) {\n    super(delegate);\n    this.sfMap = sfMap;\n  }\n\n  getSourceFile(\n      fileName: string, languageVersion: ts.ScriptTarget,\n      onError?: ((message: string) => void)|undefined,\n      shouldCreateNewSourceFile?: boolean|undefined): ts.SourceFile|undefined {\n    // Try to use the same `ts.SourceFile` as the original program, if possible. This guarantees\n    // that program reuse will be as efficient as possible.\n    let delegateSf: ts.SourceFile|undefined = this.originalProgram.getSourceFile(fileName);\n    if (delegateSf === undefined) {\n      // Something went wrong and a source file is being requested that's not in the original\n      // program. Just in case, try to retrieve it from the delegate.\n      delegateSf = this.delegate.getSourceFile(\n          fileName, languageVersion, onError, shouldCreateNewSourceFile)!;\n    }\n    if (delegateSf === undefined) {\n      return undefined;\n    }\n\n    // Look for replacements.\n    let sf: ts.SourceFile;\n    if (this.sfMap.has(fileName)) {\n      sf = this.sfMap.get(fileName)!;\n      copyFileShimData(delegateSf, sf);\n    } else {\n      sf = delegateSf;\n    }\n    // TypeScript doesn't allow returning redirect source files. To avoid unforseen errors we\n    // return the original source file instead of the redirect target.\n    const redirectInfo = (sf as any).redirectInfo;\n    if (redirectInfo !== undefined) {\n      sf = redirectInfo.unredirected;\n    }\n\n    this.shimTagger.tag(sf);\n    return sf;\n  }\n\n  postProgramCreationCleanup(): void {\n    this.shimTagger.finalize();\n  }\n\n  writeFile(): never {\n    throw new Error(`TypeCheckProgramHost should never write files`);\n  }\n\n  fileExists(fileName: string): boolean {\n    return this.sfMap.has(fileName) || this.delegate.fileExists(fileName);\n  }\n}\n"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"host.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/typecheck/src/host.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 * as ts from 'typescript';\n\nimport {copyFileShimData, ShimReferenceTagger} from '../../shims';\nimport {RequiredDelegations} from '../../util/src/typescript';\n\n/**\n * Delegates all methods of `ts.CompilerHost` to a delegate, with the exception of\n * `getSourceFile`, `fileExists` and `writeFile` which are implemented in `TypeCheckProgramHost`.\n *\n * If a new method is added to `ts.CompilerHost` which is not delegated, a type error will be\n * generated for this class.\n */\nexport class DelegatingCompilerHost implements\n    Omit<RequiredDelegations<ts.CompilerHost>, 'getSourceFile'|'fileExists'|'writeFile'> {\n  constructor(protected delegate: ts.CompilerHost) {}\n\n  private delegateMethod<M extends keyof ts.CompilerHost>(name: M): ts.CompilerHost[M] {\n    return this.delegate[name] !== undefined ? (this.delegate[name] as any).bind(this.delegate) :\n                                               undefined;\n  }\n\n  // Excluded are 'getSourceFile', 'fileExists' and 'writeFile', which are actually implemented by\n  // `TypeCheckProgramHost` below.\n  createHash = this.delegateMethod('createHash');\n  directoryExists = this.delegateMethod('directoryExists');\n  getCancellationToken = this.delegateMethod('getCancellationToken');\n  getCanonicalFileName = this.delegateMethod('getCanonicalFileName');\n  getCurrentDirectory = this.delegateMethod('getCurrentDirectory');\n  getDefaultLibFileName = this.delegateMethod('getDefaultLibFileName');\n  getDefaultLibLocation = this.delegateMethod('getDefaultLibLocation');\n  getDirectories = this.delegateMethod('getDirectories');\n  getEnvironmentVariable = this.delegateMethod('getEnvironmentVariable');\n  getNewLine = this.delegateMethod('getNewLine');\n  getParsedCommandLine = this.delegateMethod('getParsedCommandLine');\n  getSourceFileByPath = this.delegateMethod('getSourceFileByPath');\n  readDirectory = this.delegateMethod('readDirectory');\n  readFile = this.delegateMethod('readFile');\n  realpath = this.delegateMethod('realpath');\n  resolveModuleNames = this.delegateMethod('resolveModuleNames');\n  resolveTypeReferenceDirectives = this.delegateMethod('resolveTypeReferenceDirectives');\n  trace = this.delegateMethod('trace');\n  useCaseSensitiveFileNames = this.delegateMethod('useCaseSensitiveFileNames');\n}\n\n/**\n * A `ts.CompilerHost` which augments source files with type checking code from a\n * `TypeCheckContext`.\n */\nexport class TypeCheckProgramHost extends DelegatingCompilerHost {\n  /**\n   * Map of source file names to `ts.SourceFile` instances.\n   */\n  private sfMap: Map<string, ts.SourceFile>;\n\n  /**\n   * The `ShimReferenceTagger` responsible for tagging `ts.SourceFile`s loaded via this host.\n   *\n   * The `TypeCheckProgramHost` is used in the creation of a new `ts.Program`. Even though this new\n   * program is based on a prior one, TypeScript will still start from the root files and enumerate\n   * all source files to include in the new program.  This means that just like during the original\n   * program's creation, these source files must be tagged with references to per-file shims in\n   * order for those shims to be loaded, and then cleaned up afterwards. Thus the\n   * `TypeCheckProgramHost` has its own `ShimReferenceTagger` to perform this function.\n   */\n  private shimTagger = new ShimReferenceTagger(this.shimExtensionPrefixes);\n\n  constructor(\n      sfMap: Map<string, ts.SourceFile>, private originalProgram: ts.Program,\n      delegate: ts.CompilerHost, private shimExtensionPrefixes: string[]) {\n    super(delegate);\n    this.sfMap = sfMap;\n  }\n\n  getSourceFile(\n      fileName: string, languageVersion: ts.ScriptTarget,\n      onError?: ((message: string) => void)|undefined,\n      shouldCreateNewSourceFile?: boolean|undefined): ts.SourceFile|undefined {\n    // Try to use the same `ts.SourceFile` as the original program, if possible. This guarantees\n    // that program reuse will be as efficient as possible.\n    let delegateSf: ts.SourceFile|undefined = this.originalProgram.getSourceFile(fileName);\n    if (delegateSf === undefined) {\n      // Something went wrong and a source file is being requested that's not in the original\n      // program. Just in case, try to retrieve it from the delegate.\n      delegateSf = this.delegate.getSourceFile(\n          fileName, languageVersion, onError, shouldCreateNewSourceFile)!;\n    }\n    if (delegateSf === undefined) {\n      return undefined;\n    }\n\n    // Look for replacements.\n    let sf: ts.SourceFile;\n    if (this.sfMap.has(fileName)) {\n      sf = this.sfMap.get(fileName)!;\n      copyFileShimData(delegateSf, sf);\n    } else {\n      sf = delegateSf;\n    }\n    // TypeScript doesn't allow returning redirect source files. To avoid unforseen errors we\n    // return the original source file instead of the redirect target.\n    const redirectInfo = (sf as any).redirectInfo;\n    if (redirectInfo !== undefined) {\n      sf = redirectInfo.unredirected;\n    }\n\n    this.shimTagger.tag(sf);\n    return sf;\n  }\n\n  postProgramCreationCleanup(): void {\n    this.shimTagger.finalize();\n  }\n\n  writeFile(): never {\n    throw new Error(`TypeCheckProgramHost should never write files`);\n  }\n\n  fileExists(fileName: string): boolean {\n    return this.sfMap.has(fileName) || this.delegate.fileExists(fileName);\n  }\n}\n"]}