@angular/compiler-cli 11.1.0 → 11.1.1

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.
Files changed (41) hide show
  1. package/linker/src/file_linker/partial_linkers/partial_linker_selector.d.ts +1 -1
  2. package/linker/src/file_linker/partial_linkers/partial_linker_selector.js +15 -16
  3. package/ngcc/src/packages/build_marker.d.ts +1 -1
  4. package/ngcc/src/packages/build_marker.js +1 -1
  5. package/ngcc/src/rendering/source_maps.js +18 -19
  6. package/package.json +2 -2
  7. package/src/ngtsc/annotations/src/component.d.ts +48 -3
  8. package/src/ngtsc/annotations/src/component.js +197 -116
  9. package/src/ngtsc/core/api/src/public_options.d.ts +2 -2
  10. package/src/ngtsc/core/api/src/public_options.js +1 -1
  11. package/src/ngtsc/core/index.d.ts +1 -1
  12. package/src/ngtsc/core/index.js +5 -5
  13. package/src/ngtsc/core/src/compiler.d.ts +79 -7
  14. package/src/ngtsc/core/src/compiler.js +191 -49
  15. package/src/ngtsc/diagnostics/src/error_code.d.ts +6 -1
  16. package/src/ngtsc/diagnostics/src/error_code.js +9 -1
  17. package/src/ngtsc/incremental/src/strategy.d.ts +7 -0
  18. package/src/ngtsc/incremental/src/strategy.js +7 -1
  19. package/src/ngtsc/program.js +47 -19
  20. package/src/ngtsc/resource/src/loader.d.ts +4 -0
  21. package/src/ngtsc/resource/src/loader.js +7 -1
  22. package/src/ngtsc/sourcemaps/index.d.ts +3 -2
  23. package/src/ngtsc/sourcemaps/index.js +12 -3
  24. package/src/ngtsc/sourcemaps/src/content_origin.d.ts +34 -0
  25. package/src/ngtsc/sourcemaps/src/content_origin.js +48 -0
  26. package/src/ngtsc/sourcemaps/src/raw_source_map.d.ts +19 -1
  27. package/src/ngtsc/sourcemaps/src/raw_source_map.js +1 -8
  28. package/src/ngtsc/sourcemaps/src/source_file.d.ts +5 -9
  29. package/src/ngtsc/sourcemaps/src/source_file.js +3 -6
  30. package/src/ngtsc/sourcemaps/src/source_file_loader.d.ts +34 -14
  31. package/src/ngtsc/sourcemaps/src/source_file_loader.js +72 -19
  32. package/src/ngtsc/transform/src/api.d.ts +5 -0
  33. package/src/ngtsc/transform/src/api.js +1 -1
  34. package/src/ngtsc/transform/src/compilation.d.ts +1 -0
  35. package/src/ngtsc/transform/src/compilation.js +40 -17
  36. package/src/ngtsc/tsc_plugin.js +20 -3
  37. package/src/ngtsc/typecheck/api/checker.d.ts +5 -0
  38. package/src/ngtsc/typecheck/api/checker.js +1 -1
  39. package/src/ngtsc/typecheck/src/checker.d.ts +1 -0
  40. package/src/ngtsc/typecheck/src/checker.js +17 -1
  41. package/src/version.js +1 -1
@@ -17,7 +17,7 @@ export declare const declarationFunctions: string[];
17
17
  * Also, ranges are matched to include "pre-releases", therefore if the range is `>=11.1.0-next.1`
18
18
  * then this includes `11.1.0-next.2` and also `12.0.0-next.1`.
19
19
  *
20
- * Finally, note that we always start with the current version (i.e. `11.1.0`). This
20
+ * Finally, note that we always start with the current version (i.e. `11.1.1`). This
21
21
  * allows the linker to work on local builds effectively.
22
22
  */
23
23
  export declare class PartialLinkerSelector<TStatement, TExpression> {
@@ -37,7 +37,7 @@
37
37
  * Also, ranges are matched to include "pre-releases", therefore if the range is `>=11.1.0-next.1`
38
38
  * then this includes `11.1.0-next.2` and also `12.0.0-next.1`.
39
39
  *
40
- * Finally, note that we always start with the current version (i.e. `11.1.0`). This
40
+ * Finally, note that we always start with the current version (i.e. `11.1.1`). This
41
41
  * allows the linker to work on local builds effectively.
42
42
  */
43
43
  var PartialLinkerSelector = /** @class */ (function () {
@@ -48,7 +48,7 @@
48
48
  * Returns true if there are `PartialLinker` classes that can handle functions with this name.
49
49
  */
50
50
  PartialLinkerSelector.prototype.supportsDeclaration = function (functionName) {
51
- return this.linkers[functionName] !== undefined;
51
+ return this.linkers.has(functionName);
52
52
  };
53
53
  /**
54
54
  * Returns the `PartialLinker` that can handle functions with the given name and version.
@@ -56,10 +56,10 @@
56
56
  */
57
57
  PartialLinkerSelector.prototype.getLinker = function (functionName, version) {
58
58
  var e_1, _a;
59
- var versions = this.linkers[functionName];
60
- if (versions === undefined) {
59
+ if (!this.linkers.has(functionName)) {
61
60
  throw new Error("Unknown partial declaration function " + functionName + ".");
62
61
  }
62
+ var versions = this.linkers.get(functionName);
63
63
  try {
64
64
  for (var versions_1 = tslib_1.__values(versions), versions_1_1 = versions_1.next(); !versions_1_1.done; versions_1_1 = versions_1.next()) {
65
65
  var _b = versions_1_1.value, range = _b.range, linker = _b.linker;
@@ -79,22 +79,21 @@
79
79
  'Valid version ranges are:\n' + versions.map(function (v) { return " - " + v.range; }).join('\n'));
80
80
  };
81
81
  PartialLinkerSelector.prototype.createLinkerMap = function (environment, sourceUrl, code) {
82
- var _a;
83
82
  var partialDirectiveLinkerVersion1 = new partial_directive_linker_1_1.PartialDirectiveLinkerVersion1(sourceUrl, code);
84
83
  var partialComponentLinkerVersion1 = new partial_component_linker_1_1.PartialComponentLinkerVersion1(environment, get_source_file_1.createGetSourceFile(sourceUrl, code, environment.sourceFileLoader), sourceUrl, code);
85
- return _a = {},
86
- _a[exports.ɵɵngDeclareDirective] = [
87
- { range: '11.1.0', linker: partialDirectiveLinkerVersion1 },
88
- { range: '>=11.1.0-next.1', linker: partialDirectiveLinkerVersion1 },
89
- ],
90
- _a[exports.ɵɵngDeclareComponent] = [
91
- { range: '11.1.0', linker: partialComponentLinkerVersion1 },
92
- { range: '>=11.1.0-next.1', linker: partialComponentLinkerVersion1 },
93
- ],
94
- _a;
84
+ var linkers = new Map();
85
+ linkers.set(exports.ɵɵngDeclareDirective, [
86
+ { range: '11.1.1', linker: partialDirectiveLinkerVersion1 },
87
+ { range: '>=11.1.0-next.1', linker: partialDirectiveLinkerVersion1 },
88
+ ]);
89
+ linkers.set(exports.ɵɵngDeclareComponent, [
90
+ { range: '11.1.1', linker: partialComponentLinkerVersion1 },
91
+ { range: '>=11.1.0-next.1', linker: partialComponentLinkerVersion1 },
92
+ ]);
93
+ return linkers;
95
94
  };
96
95
  return PartialLinkerSelector;
97
96
  }());
98
97
  exports.PartialLinkerSelector = PartialLinkerSelector;
99
98
  });
100
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFydGlhbF9saW5rZXJfc2VsZWN0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci1jbGkvbGlua2VyL3NyYy9maWxlX2xpbmtlci9wYXJ0aWFsX2xpbmtlcnMvcGFydGlhbF9saW5rZXJfc2VsZWN0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztJQUFBOzs7Ozs7T0FNRztJQUNILGlDQUFpQztJQUdqQyxnR0FBdUQ7SUFHdkQsc0lBQTRFO0lBQzVFLHNJQUE0RTtJQUcvRCxRQUFBLG9CQUFvQixHQUFHLHNCQUFzQixDQUFDO0lBQzlDLFFBQUEsb0JBQW9CLEdBQUcsc0JBQXNCLENBQUM7SUFDOUMsUUFBQSxvQkFBb0IsR0FBRyxDQUFDLDRCQUFvQixFQUFFLDRCQUFvQixDQUFDLENBQUM7SUFFakY7Ozs7Ozs7Ozs7Ozs7O09BY0c7SUFDSDtRQUdFLCtCQUNJLFdBQXVELEVBQUUsU0FBeUIsRUFDbEYsSUFBWTtZQUNkLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQyxXQUFXLEVBQUUsU0FBUyxFQUFFLElBQUksQ0FBQyxDQUFDO1FBQ3BFLENBQUM7UUFFRDs7V0FFRztRQUNILG1EQUFtQixHQUFuQixVQUFvQixZQUFvQjtZQUN0QyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsWUFBWSxDQUFDLEtBQUssU0FBUyxDQUFDO1FBQ2xELENBQUM7UUFFRDs7O1dBR0c7UUFDSCx5Q0FBUyxHQUFULFVBQVUsWUFBb0IsRUFBRSxPQUFlOztZQUM3QyxJQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxDQUFDO1lBQzVDLElBQUksUUFBUSxLQUFLLFNBQVMsRUFBRTtnQkFDMUIsTUFBTSxJQUFJLEtBQUssQ0FBQywwQ0FBd0MsWUFBWSxNQUFHLENBQUMsQ0FBQzthQUMxRTs7Z0JBQ0QsS0FBOEIsSUFBQSxhQUFBLGlCQUFBLFFBQVEsQ0FBQSxrQ0FBQSx3REFBRTtvQkFBN0IsSUFBQSx1QkFBZSxFQUFkLEtBQUssV0FBQSxFQUFFLE1BQU0sWUFBQTtvQkFDdkIsSUFBSSxrQkFBUyxDQUFDLE9BQU8sRUFBRSxLQUFLLEVBQUUsRUFBQyxpQkFBaUIsRUFBRSxJQUFJLEVBQUMsQ0FBQyxFQUFFO3dCQUN4RCxPQUFPLE1BQU0sQ0FBQztxQkFDZjtpQkFDRjs7Ozs7Ozs7O1lBQ0QsTUFBTSxJQUFJLEtBQUssQ0FDWCw2Q0FBMkMsT0FBTyxhQUFRLFlBQVksUUFBSztnQkFDM0UsNkJBQTZCLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxVQUFBLENBQUMsSUFBSSxPQUFBLFFBQU0sQ0FBQyxDQUFDLEtBQU8sRUFBZixDQUFlLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUNyRixDQUFDO1FBRU8sK0NBQWUsR0FBdkIsVUFDSSxXQUF1RCxFQUFFLFNBQXlCLEVBQ2xGLElBQVk7O1lBQ2QsSUFBTSw4QkFBOEIsR0FBRyxJQUFJLDJEQUE4QixDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsQ0FBQztZQUMzRixJQUFNLDhCQUE4QixHQUFHLElBQUksMkRBQThCLENBQ3JFLFdBQVcsRUFBRSxxQ0FBbUIsQ0FBQyxTQUFTLEVBQUUsSUFBSSxFQUFFLFdBQVcsQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFLFNBQVMsRUFDMUYsSUFBSSxDQUFDLENBQUM7WUFFVjtnQkFDRSxHQUFDLDRCQUFvQixJQUFHO29CQUN0QixFQUFDLEtBQUssRUFBRSxtQkFBbUIsRUFBRSxNQUFNLEVBQUUsOEJBQThCLEVBQUM7b0JBQ3BFLEVBQUMsS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sRUFBRSw4QkFBOEIsRUFBQztpQkFDbkU7Z0JBQ0QsR0FBQyw0QkFBb0IsSUFBRztvQkFDdEIsRUFBQyxLQUFLLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxFQUFFLDhCQUE4QixFQUFDO29CQUNwRSxFQUFDLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxNQUFNLEVBQUUsOEJBQThCLEVBQUM7aUJBQ25FO21CQUNEO1FBQ0osQ0FBQztRQUNILDRCQUFDO0lBQUQsQ0FBQyxBQXRERCxJQXNEQztJQXREWSxzREFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7c2F0aXNmaWVzfSBmcm9tICdzZW12ZXInO1xuXG5pbXBvcnQge0Fic29sdXRlRnNQYXRofSBmcm9tICcuLi8uLi8uLi8uLi9zcmMvbmd0c2MvZmlsZV9zeXN0ZW0nO1xuaW1wb3J0IHtjcmVhdGVHZXRTb3VyY2VGaWxlfSBmcm9tICcuLi9nZXRfc291cmNlX2ZpbGUnO1xuaW1wb3J0IHtMaW5rZXJFbnZpcm9ubWVudH0gZnJvbSAnLi4vbGlua2VyX2Vudmlyb25tZW50JztcblxuaW1wb3J0IHtQYXJ0aWFsQ29tcG9uZW50TGlua2VyVmVyc2lvbjF9IGZyb20gJy4vcGFydGlhbF9jb21wb25lbnRfbGlua2VyXzEnO1xuaW1wb3J0IHtQYXJ0aWFsRGlyZWN0aXZlTGlua2VyVmVyc2lvbjF9IGZyb20gJy4vcGFydGlhbF9kaXJlY3RpdmVfbGlua2VyXzEnO1xuaW1wb3J0IHtQYXJ0aWFsTGlua2VyfSBmcm9tICcuL3BhcnRpYWxfbGlua2VyJztcblxuZXhwb3J0IGNvbnN0IMm1ybVuZ0RlY2xhcmVEaXJlY3RpdmUgPSAnybXJtW5nRGVjbGFyZURpcmVjdGl2ZSc7XG5leHBvcnQgY29uc3QgybXJtW5nRGVjbGFyZUNvbXBvbmVudCA9ICfJtcm1bmdEZWNsYXJlQ29tcG9uZW50JztcbmV4cG9ydCBjb25zdCBkZWNsYXJhdGlvbkZ1bmN0aW9ucyA9IFvJtcm1bmdEZWNsYXJlRGlyZWN0aXZlLCDJtcm1bmdEZWNsYXJlQ29tcG9uZW50XTtcblxuLyoqXG4gKiBBIGhlbHBlciB0aGF0IHNlbGVjdHMgdGhlIGFwcHJvcHJpYXRlIGBQYXJ0aWFsTGlua2VyYCBmb3IgYSBnaXZlbiBkZWNsYXJhdGlvbi5cbiAqXG4gKiBUaGUgc2VsZWN0aW9uIGlzIG1hZGUgZnJvbSBhIGRhdGFiYXNlIG9mIGxpbmtlciBpbnN0YW5jZXMsIGNob3NlbiBpZiB0aGVpciBnaXZlbiBzZW12ZXIgcmFuZ2VcbiAqIHNhdGlzZmllcyB0aGUgdmVyc2lvbiBmb3VuZCBpbiB0aGUgY29kZSB0byBiZSBsaW5rZWQuXG4gKlxuICogTm90ZSB0aGF0IHRoZSByYW5nZXMgYXJlIGNoZWNrZWQgaW4gb3JkZXIsIGFuZCB0aGUgZmlyc3QgbWF0Y2hpbmcgcmFuZ2Ugd2lsbCBiZSBzZWxlY3RlZCwgc29cbiAqIHJhbmdlcyBzaG91bGQgYmUgbW9zdCByZXN0cmljdGl2ZSBmaXJzdC5cbiAqXG4gKiBBbHNvLCByYW5nZXMgYXJlIG1hdGNoZWQgdG8gaW5jbHVkZSBcInByZS1yZWxlYXNlc1wiLCB0aGVyZWZvcmUgaWYgdGhlIHJhbmdlIGlzIGA+PTExLjEuMC1uZXh0LjFgXG4gKiB0aGVuIHRoaXMgaW5jbHVkZXMgYDExLjEuMC1uZXh0LjJgIGFuZCBhbHNvIGAxMi4wLjAtbmV4dC4xYC5cbiAqXG4gKiBGaW5hbGx5LCBub3RlIHRoYXQgd2UgYWx3YXlzIHN0YXJ0IHdpdGggdGhlIGN1cnJlbnQgdmVyc2lvbiAoaS5lLiBgMC4wLjAtUExBQ0VIT0xERVJgKS4gVGhpc1xuICogYWxsb3dzIHRoZSBsaW5rZXIgdG8gd29yayBvbiBsb2NhbCBidWlsZHMgZWZmZWN0aXZlbHkuXG4gKi9cbmV4cG9ydCBjbGFzcyBQYXJ0aWFsTGlua2VyU2VsZWN0b3I8VFN0YXRlbWVudCwgVEV4cHJlc3Npb24+IHtcbiAgcHJpdmF0ZSByZWFkb25seSBsaW5rZXJzOiBSZWNvcmQ8c3RyaW5nLCB7cmFuZ2U6IHN0cmluZywgbGlua2VyOiBQYXJ0aWFsTGlua2VyPFRFeHByZXNzaW9uPn1bXT47XG5cbiAgY29uc3RydWN0b3IoXG4gICAgICBlbnZpcm9ubWVudDogTGlua2VyRW52aXJvbm1lbnQ8VFN0YXRlbWVudCwgVEV4cHJlc3Npb24+LCBzb3VyY2VVcmw6IEFic29sdXRlRnNQYXRoLFxuICAgICAgY29kZTogc3RyaW5nKSB7XG4gICAgdGhpcy5saW5rZXJzID0gdGhpcy5jcmVhdGVMaW5rZXJNYXAoZW52aXJvbm1lbnQsIHNvdXJjZVVybCwgY29kZSk7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyB0cnVlIGlmIHRoZXJlIGFyZSBgUGFydGlhbExpbmtlcmAgY2xhc3NlcyB0aGF0IGNhbiBoYW5kbGUgZnVuY3Rpb25zIHdpdGggdGhpcyBuYW1lLlxuICAgKi9cbiAgc3VwcG9ydHNEZWNsYXJhdGlvbihmdW5jdGlvbk5hbWU6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLmxpbmtlcnNbZnVuY3Rpb25OYW1lXSAhPT0gdW5kZWZpbmVkO1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIGBQYXJ0aWFsTGlua2VyYCB0aGF0IGNhbiBoYW5kbGUgZnVuY3Rpb25zIHdpdGggdGhlIGdpdmVuIG5hbWUgYW5kIHZlcnNpb24uXG4gICAqIFRocm93cyBhbiBlcnJvciBpZiB0aGVyZSBpcyBub25lLlxuICAgKi9cbiAgZ2V0TGlua2VyKGZ1bmN0aW9uTmFtZTogc3RyaW5nLCB2ZXJzaW9uOiBzdHJpbmcpOiBQYXJ0aWFsTGlua2VyPFRFeHByZXNzaW9uPiB7XG4gICAgY29uc3QgdmVyc2lvbnMgPSB0aGlzLmxpbmtlcnNbZnVuY3Rpb25OYW1lXTtcbiAgICBpZiAodmVyc2lvbnMgPT09IHVuZGVmaW5lZCkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBVbmtub3duIHBhcnRpYWwgZGVjbGFyYXRpb24gZnVuY3Rpb24gJHtmdW5jdGlvbk5hbWV9LmApO1xuICAgIH1cbiAgICBmb3IgKGNvbnN0IHtyYW5nZSwgbGlua2VyfSBvZiB2ZXJzaW9ucykge1xuICAgICAgaWYgKHNhdGlzZmllcyh2ZXJzaW9uLCByYW5nZSwge2luY2x1ZGVQcmVyZWxlYXNlOiB0cnVlfSkpIHtcbiAgICAgICAgcmV0dXJuIGxpbmtlcjtcbiAgICAgIH1cbiAgICB9XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICBgVW5zdXBwb3J0ZWQgcGFydGlhbCBkZWNsYXJhdGlvbiB2ZXJzaW9uICR7dmVyc2lvbn0gZm9yICR7ZnVuY3Rpb25OYW1lfS5cXG5gICtcbiAgICAgICAgJ1ZhbGlkIHZlcnNpb24gcmFuZ2VzIGFyZTpcXG4nICsgdmVyc2lvbnMubWFwKHYgPT4gYCAtICR7di5yYW5nZX1gKS5qb2luKCdcXG4nKSk7XG4gIH1cblxuICBwcml2YXRlIGNyZWF0ZUxpbmtlck1hcChcbiAgICAgIGVudmlyb25tZW50OiBMaW5rZXJFbnZpcm9ubWVudDxUU3RhdGVtZW50LCBURXhwcmVzc2lvbj4sIHNvdXJjZVVybDogQWJzb2x1dGVGc1BhdGgsXG4gICAgICBjb2RlOiBzdHJpbmcpIHtcbiAgICBjb25zdCBwYXJ0aWFsRGlyZWN0aXZlTGlua2VyVmVyc2lvbjEgPSBuZXcgUGFydGlhbERpcmVjdGl2ZUxpbmtlclZlcnNpb24xKHNvdXJjZVVybCwgY29kZSk7XG4gICAgY29uc3QgcGFydGlhbENvbXBvbmVudExpbmtlclZlcnNpb24xID0gbmV3IFBhcnRpYWxDb21wb25lbnRMaW5rZXJWZXJzaW9uMShcbiAgICAgICAgZW52aXJvbm1lbnQsIGNyZWF0ZUdldFNvdXJjZUZpbGUoc291cmNlVXJsLCBjb2RlLCBlbnZpcm9ubWVudC5zb3VyY2VGaWxlTG9hZGVyKSwgc291cmNlVXJsLFxuICAgICAgICBjb2RlKTtcblxuICAgIHJldHVybiB7XG4gICAgICBbybXJtW5nRGVjbGFyZURpcmVjdGl2ZV06IFtcbiAgICAgICAge3JhbmdlOiAnMC4wLjAtUExBQ0VIT0xERVInLCBsaW5rZXI6IHBhcnRpYWxEaXJlY3RpdmVMaW5rZXJWZXJzaW9uMX0sXG4gICAgICAgIHtyYW5nZTogJz49MTEuMS4wLW5leHQuMScsIGxpbmtlcjogcGFydGlhbERpcmVjdGl2ZUxpbmtlclZlcnNpb24xfSxcbiAgICAgIF0sXG4gICAgICBbybXJtW5nRGVjbGFyZUNvbXBvbmVudF06IFtcbiAgICAgICAge3JhbmdlOiAnMC4wLjAtUExBQ0VIT0xERVInLCBsaW5rZXI6IHBhcnRpYWxDb21wb25lbnRMaW5rZXJWZXJzaW9uMX0sXG4gICAgICAgIHtyYW5nZTogJz49MTEuMS4wLW5leHQuMScsIGxpbmtlcjogcGFydGlhbENvbXBvbmVudExpbmtlclZlcnNpb24xfSxcbiAgICAgIF0sXG4gICAgfTtcbiAgfVxufVxuIl19
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"partial_linker_selector.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/linker/src/file_linker/partial_linkers/partial_linker_selector.ts"],"names":[],"mappings":";;;;;;;;;;;;;IAAA;;;;;;OAMG;IACH,iCAAiC;IAGjC,gGAAuD;IAGvD,sIAA4E;IAC5E,sIAA4E;IAG/D,QAAA,oBAAoB,GAAG,sBAAsB,CAAC;IAC9C,QAAA,oBAAoB,GAAG,sBAAsB,CAAC;IAC9C,QAAA,oBAAoB,GAAG,CAAC,4BAAoB,EAAE,4BAAoB,CAAC,CAAC;IAOjF;;;;;;;;;;;;;;OAcG;IACH;QAGE,+BACI,WAAuD,EAAE,SAAyB,EAClF,IAAY;YACd,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;QACpE,CAAC;QAED;;WAEG;QACH,mDAAmB,GAAnB,UAAoB,YAAoB;YACtC,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QACxC,CAAC;QAED;;;WAGG;QACH,yCAAS,GAAT,UAAU,YAAoB,EAAE,OAAe;;YAC7C,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE;gBACnC,MAAM,IAAI,KAAK,CAAC,0CAAwC,YAAY,MAAG,CAAC,CAAC;aAC1E;YACD,IAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAE,CAAC;;gBACjD,KAA8B,IAAA,aAAA,iBAAA,QAAQ,CAAA,kCAAA,wDAAE;oBAA7B,IAAA,uBAAe,EAAd,KAAK,WAAA,EAAE,MAAM,YAAA;oBACvB,IAAI,kBAAS,CAAC,OAAO,EAAE,KAAK,EAAE,EAAC,iBAAiB,EAAE,IAAI,EAAC,CAAC,EAAE;wBACxD,OAAO,MAAM,CAAC;qBACf;iBACF;;;;;;;;;YACD,MAAM,IAAI,KAAK,CACX,6CAA2C,OAAO,aAAQ,YAAY,QAAK;gBAC3E,6BAA6B,GAAG,QAAQ,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,QAAM,CAAC,CAAC,KAAO,EAAf,CAAe,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACrF,CAAC;QAEO,+CAAe,GAAvB,UACI,WAAuD,EAAE,SAAyB,EAClF,IAAY;YACd,IAAM,8BAA8B,GAAG,IAAI,2DAA8B,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;YAC3F,IAAM,8BAA8B,GAAG,IAAI,2DAA8B,CACrE,WAAW,EAAE,qCAAmB,CAAC,SAAS,EAAE,IAAI,EAAE,WAAW,CAAC,gBAAgB,CAAC,EAAE,SAAS,EAC1F,IAAI,CAAC,CAAC;YAEV,IAAM,OAAO,GAAG,IAAI,GAAG,EAAsC,CAAC;YAC9D,OAAO,CAAC,GAAG,CAAC,4BAAoB,EAAE;gBAChC,EAAC,KAAK,EAAE,mBAAmB,EAAE,MAAM,EAAE,8BAA8B,EAAC;gBACpE,EAAC,KAAK,EAAE,iBAAiB,EAAE,MAAM,EAAE,8BAA8B,EAAC;aACnE,CAAC,CAAC;YACH,OAAO,CAAC,GAAG,CAAC,4BAAoB,EAAE;gBAChC,EAAC,KAAK,EAAE,mBAAmB,EAAE,MAAM,EAAE,8BAA8B,EAAC;gBACpE,EAAC,KAAK,EAAE,iBAAiB,EAAE,MAAM,EAAE,8BAA8B,EAAC;aACnE,CAAC,CAAC;YACH,OAAO,OAAO,CAAC;QACjB,CAAC;QACH,4BAAC;IAAD,CAAC,AAtDD,IAsDC;IAtDY,sDAAqB","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 */\nimport {satisfies} from 'semver';\n\nimport {AbsoluteFsPath} from '../../../../src/ngtsc/file_system';\nimport {createGetSourceFile} from '../get_source_file';\nimport {LinkerEnvironment} from '../linker_environment';\n\nimport {PartialComponentLinkerVersion1} from './partial_component_linker_1';\nimport {PartialDirectiveLinkerVersion1} from './partial_directive_linker_1';\nimport {PartialLinker} from './partial_linker';\n\nexport const ɵɵngDeclareDirective = 'ɵɵngDeclareDirective';\nexport const ɵɵngDeclareComponent = 'ɵɵngDeclareComponent';\nexport const declarationFunctions = [ɵɵngDeclareDirective, ɵɵngDeclareComponent];\n\ninterface LinkerRange<TExpression> {\n  range: string;\n  linker: PartialLinker<TExpression>;\n}\n\n/**\n * A helper that selects the appropriate `PartialLinker` for a given declaration.\n *\n * The selection is made from a database of linker instances, chosen if their given semver range\n * satisfies the version found in the code to be linked.\n *\n * Note that the ranges are checked in order, and the first matching range will be selected, so\n * ranges should be most restrictive first.\n *\n * Also, ranges are matched to include \"pre-releases\", therefore if the range is `>=11.1.0-next.1`\n * then this includes `11.1.0-next.2` and also `12.0.0-next.1`.\n *\n * Finally, note that we always start with the current version (i.e. `0.0.0-PLACEHOLDER`). This\n * allows the linker to work on local builds effectively.\n */\nexport class PartialLinkerSelector<TStatement, TExpression> {\n  private readonly linkers: Map<string, LinkerRange<TExpression>[]>;\n\n  constructor(\n      environment: LinkerEnvironment<TStatement, TExpression>, sourceUrl: AbsoluteFsPath,\n      code: string) {\n    this.linkers = this.createLinkerMap(environment, sourceUrl, code);\n  }\n\n  /**\n   * Returns true if there are `PartialLinker` classes that can handle functions with this name.\n   */\n  supportsDeclaration(functionName: string): boolean {\n    return this.linkers.has(functionName);\n  }\n\n  /**\n   * Returns the `PartialLinker` that can handle functions with the given name and version.\n   * Throws an error if there is none.\n   */\n  getLinker(functionName: string, version: string): PartialLinker<TExpression> {\n    if (!this.linkers.has(functionName)) {\n      throw new Error(`Unknown partial declaration function ${functionName}.`);\n    }\n    const versions = this.linkers.get(functionName)!;\n    for (const {range, linker} of versions) {\n      if (satisfies(version, range, {includePrerelease: true})) {\n        return linker;\n      }\n    }\n    throw new Error(\n        `Unsupported partial declaration version ${version} for ${functionName}.\\n` +\n        'Valid version ranges are:\\n' + versions.map(v => ` - ${v.range}`).join('\\n'));\n  }\n\n  private createLinkerMap(\n      environment: LinkerEnvironment<TStatement, TExpression>, sourceUrl: AbsoluteFsPath,\n      code: string): Map<string, LinkerRange<TExpression>[]> {\n    const partialDirectiveLinkerVersion1 = new PartialDirectiveLinkerVersion1(sourceUrl, code);\n    const partialComponentLinkerVersion1 = new PartialComponentLinkerVersion1(\n        environment, createGetSourceFile(sourceUrl, code, environment.sourceFileLoader), sourceUrl,\n        code);\n\n    const linkers = new Map<string, LinkerRange<TExpression>[]>();\n    linkers.set(ɵɵngDeclareDirective, [\n      {range: '0.0.0-PLACEHOLDER', linker: partialDirectiveLinkerVersion1},\n      {range: '>=11.1.0-next.1', linker: partialDirectiveLinkerVersion1},\n    ]);\n    linkers.set(ɵɵngDeclareComponent, [\n      {range: '0.0.0-PLACEHOLDER', linker: partialComponentLinkerVersion1},\n      {range: '>=11.1.0-next.1', linker: partialComponentLinkerVersion1},\n    ]);\n    return linkers;\n  }\n}\n"]}
@@ -9,7 +9,7 @@
9
9
  import { AbsoluteFsPath } from '../../../src/ngtsc/file_system';
10
10
  import { PackageJsonUpdater } from '../writing/package_json_updater';
11
11
  import { EntryPointPackageJson, PackageJsonFormatProperties } from './entry_point';
12
- export declare const NGCC_VERSION = "11.1.0";
12
+ export declare const NGCC_VERSION = "11.1.1";
13
13
  /**
14
14
  * Returns true if there is a format in this entry-point that was compiled with an outdated version
15
15
  * of ngcc.
@@ -12,7 +12,7 @@
12
12
  exports.markAsProcessed = exports.hasBeenProcessed = exports.cleanPackageJson = exports.needsCleaning = exports.NGCC_VERSION = void 0;
13
13
  var tslib_1 = require("tslib");
14
14
  var new_entry_point_file_writer_1 = require("@angular/compiler-cli/ngcc/src/writing/new_entry_point_file_writer");
15
- exports.NGCC_VERSION = '11.1.0';
15
+ exports.NGCC_VERSION = '11.1.1';
16
16
  /**
17
17
  * Returns true if there is a format in this entry-point that was compiled with an outdated version
18
18
  * of ngcc.
@@ -25,18 +25,19 @@
25
25
  * with an appropriate source-map comment pointing to the merged source-map.
26
26
  */
27
27
  function renderSourceAndMap(logger, fs, sourceFile, generatedMagicString) {
28
- var generatedPath = file_system_1.absoluteFromSourceFile(sourceFile);
29
- var generatedMapPath = file_system_1.absoluteFrom(generatedPath + ".map");
28
+ var _a;
29
+ var sourceFilePath = file_system_1.absoluteFromSourceFile(sourceFile);
30
+ var sourceMapPath = file_system_1.absoluteFrom(sourceFilePath + ".map");
30
31
  var generatedContent = generatedMagicString.toString();
31
- var generatedMap = generatedMagicString.generateMap({ file: generatedPath, source: generatedPath, includeContent: true });
32
+ var generatedMap = generatedMagicString.generateMap({ file: sourceFilePath, source: sourceFilePath, includeContent: true });
32
33
  try {
33
34
  var loader = new sourcemaps_1.SourceFileLoader(fs, logger, {});
34
- var generatedFile = loader.loadSourceFile(generatedPath, generatedContent, { map: generatedMap, mapPath: generatedMapPath });
35
+ var generatedFile = loader.loadSourceFile(sourceFilePath, generatedContent, { map: generatedMap, mapPath: sourceMapPath });
35
36
  var rawMergedMap = generatedFile.renderFlattenedSourceMap();
36
37
  var mergedMap = convert_source_map_1.fromObject(rawMergedMap);
37
- var firstSource = generatedFile.sources[0];
38
- if (firstSource && (firstSource.rawMap !== null || !sourceFile.isDeclarationFile) &&
39
- firstSource.inline) {
38
+ var originalFile = loader.loadSourceFile(sourceFilePath, generatedMagicString.original);
39
+ if (originalFile.rawMap === null && !sourceFile.isDeclarationFile ||
40
+ ((_a = originalFile.rawMap) === null || _a === void 0 ? void 0 : _a.origin) === sourcemaps_1.ContentOrigin.Inline) {
40
41
  // We render an inline source map if one of:
41
42
  // * there was no input source map and this is not a typings file;
42
43
  // * the input source map exists and was inline.
@@ -45,25 +46,23 @@
45
46
  // the input file because these inline source maps can be very large and it impacts on the
46
47
  // performance of IDEs that need to read them to provide intellisense etc.
47
48
  return [
48
- { path: generatedPath, contents: generatedFile.contents + "\n" + mergedMap.toComment() }
49
- ];
50
- }
51
- else {
52
- var sourceMapComment = convert_source_map_1.generateMapFileComment(fs.basename(generatedPath) + ".map");
53
- return [
54
- { path: generatedPath, contents: generatedFile.contents + "\n" + sourceMapComment },
55
- { path: generatedMapPath, contents: mergedMap.toJSON() }
49
+ { path: sourceFilePath, contents: generatedFile.contents + "\n" + mergedMap.toComment() }
56
50
  ];
57
51
  }
52
+ var sourceMapComment = convert_source_map_1.generateMapFileComment(fs.basename(sourceFilePath) + ".map");
53
+ return [
54
+ { path: sourceFilePath, contents: generatedFile.contents + "\n" + sourceMapComment },
55
+ { path: sourceMapPath, contents: mergedMap.toJSON() }
56
+ ];
58
57
  }
59
58
  catch (e) {
60
- logger.error("Error when flattening the source-map \"" + generatedMapPath + "\" for \"" + generatedPath + "\": " + e.toString());
59
+ logger.error("Error when flattening the source-map \"" + sourceMapPath + "\" for \"" + sourceFilePath + "\": " + e.toString());
61
60
  return [
62
- { path: generatedPath, contents: generatedContent },
63
- { path: generatedMapPath, contents: convert_source_map_1.fromObject(generatedMap).toJSON() },
61
+ { path: sourceFilePath, contents: generatedContent },
62
+ { path: sourceMapPath, contents: convert_source_map_1.fromObject(generatedMap).toJSON() },
64
63
  ];
65
64
  }
66
65
  }
67
66
  exports.renderSourceAndMap = renderSourceAndMap;
68
67
  });
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic291cmNlX21hcHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci1jbGkvbmdjYy9zcmMvcmVuZGVyaW5nL3NvdXJjZV9tYXBzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztJQUFBOzs7Ozs7T0FNRztJQUNILHlEQUEwRjtJQUkxRiwyRUFBd0c7SUFFeEcseUVBQTZFO0lBVTdFOzs7T0FHRztJQUNILFNBQWdCLGtCQUFrQixDQUM5QixNQUFjLEVBQUUsRUFBc0IsRUFBRSxVQUF5QixFQUNqRSxvQkFBaUM7UUFDbkMsSUFBTSxhQUFhLEdBQUcsb0NBQXNCLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDekQsSUFBTSxnQkFBZ0IsR0FBRywwQkFBWSxDQUFJLGFBQWEsU0FBTSxDQUFDLENBQUM7UUFDOUQsSUFBTSxnQkFBZ0IsR0FBRyxvQkFBb0IsQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUN6RCxJQUFNLFlBQVksR0FBaUIsb0JBQW9CLENBQUMsV0FBVyxDQUMvRCxFQUFDLElBQUksRUFBRSxhQUFhLEVBQUUsTUFBTSxFQUFFLGFBQWEsRUFBRSxjQUFjLEVBQUUsSUFBSSxFQUFDLENBQUMsQ0FBQztRQUV4RSxJQUFJO1lBQ0YsSUFBTSxNQUFNLEdBQUcsSUFBSSw2QkFBZ0IsQ0FBQyxFQUFFLEVBQUUsTUFBTSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQ3BELElBQU0sYUFBYSxHQUFHLE1BQU0sQ0FBQyxjQUFjLENBQ3ZDLGFBQWEsRUFBRSxnQkFBZ0IsRUFBRSxFQUFDLEdBQUcsRUFBRSxZQUFZLEVBQUUsT0FBTyxFQUFFLGdCQUFnQixFQUFDLENBQUMsQ0FBQztZQUVyRixJQUFNLFlBQVksR0FBaUIsYUFBYSxDQUFDLHdCQUF3QixFQUFFLENBQUM7WUFDNUUsSUFBTSxTQUFTLEdBQUcsK0JBQVUsQ0FBQyxZQUFZLENBQUMsQ0FBQztZQUMzQyxJQUFNLFdBQVcsR0FBRyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQzdDLElBQUksV0FBVyxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sS0FBSyxJQUFJLElBQUksQ0FBQyxVQUFVLENBQUMsaUJBQWlCLENBQUM7Z0JBQzdFLFdBQVcsQ0FBQyxNQUFNLEVBQUU7Z0JBQ3RCLDRDQUE0QztnQkFDNUMsa0VBQWtFO2dCQUNsRSxnREFBZ0Q7Z0JBQ2hELEVBQUU7Z0JBQ0YsNkZBQTZGO2dCQUM3RiwwRkFBMEY7Z0JBQzFGLDBFQUEwRTtnQkFDMUUsT0FBTztvQkFDTCxFQUFDLElBQUksRUFBRSxhQUFhLEVBQUUsUUFBUSxFQUFLLGFBQWEsQ0FBQyxRQUFRLFVBQUssU0FBUyxDQUFDLFNBQVMsRUFBSSxFQUFDO2lCQUN2RixDQUFDO2FBQ0g7aUJBQU07Z0JBQ0wsSUFBTSxnQkFBZ0IsR0FBRywyQ0FBc0IsQ0FBSSxFQUFFLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxTQUFNLENBQUMsQ0FBQztnQkFDckYsT0FBTztvQkFDTCxFQUFDLElBQUksRUFBRSxhQUFhLEVBQUUsUUFBUSxFQUFLLGFBQWEsQ0FBQyxRQUFRLFVBQUssZ0JBQWtCLEVBQUM7b0JBQ2pGLEVBQUMsSUFBSSxFQUFFLGdCQUFnQixFQUFFLFFBQVEsRUFBRSxTQUFTLENBQUMsTUFBTSxFQUFFLEVBQUM7aUJBQ3ZELENBQUM7YUFDSDtTQUNGO1FBQUMsT0FBTyxDQUFDLEVBQUU7WUFDVixNQUFNLENBQUMsS0FBSyxDQUFDLDRDQUF5QyxnQkFBZ0IsaUJBQ2xFLGFBQWEsWUFBTSxDQUFDLENBQUMsUUFBUSxFQUFJLENBQUMsQ0FBQztZQUN2QyxPQUFPO2dCQUNMLEVBQUMsSUFBSSxFQUFFLGFBQWEsRUFBRSxRQUFRLEVBQUUsZ0JBQWdCLEVBQUM7Z0JBQ2pELEVBQUMsSUFBSSxFQUFFLGdCQUFnQixFQUFFLFFBQVEsRUFBRSwrQkFBVSxDQUFDLFlBQVksQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFDO2FBQ3RFLENBQUM7U0FDSDtJQUNILENBQUM7SUE1Q0QsZ0RBNENDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQge2Zyb21PYmplY3QsIGdlbmVyYXRlTWFwRmlsZUNvbW1lbnQsIFNvdXJjZU1hcENvbnZlcnRlcn0gZnJvbSAnY29udmVydC1zb3VyY2UtbWFwJztcbmltcG9ydCBNYWdpY1N0cmluZyBmcm9tICdtYWdpYy1zdHJpbmcnO1xuaW1wb3J0ICogYXMgdHMgZnJvbSAndHlwZXNjcmlwdCc7XG5cbmltcG9ydCB7YWJzb2x1dGVGcm9tLCBhYnNvbHV0ZUZyb21Tb3VyY2VGaWxlLCBSZWFkb25seUZpbGVTeXN0ZW19IGZyb20gJy4uLy4uLy4uL3NyYy9uZ3RzYy9maWxlX3N5c3RlbSc7XG5pbXBvcnQge0xvZ2dlcn0gZnJvbSAnLi4vLi4vLi4vc3JjL25ndHNjL2xvZ2dpbmcnO1xuaW1wb3J0IHtSYXdTb3VyY2VNYXAsIFNvdXJjZUZpbGVMb2FkZXJ9IGZyb20gJy4uLy4uLy4uL3NyYy9uZ3RzYy9zb3VyY2VtYXBzJztcblxuaW1wb3J0IHtGaWxlVG9Xcml0ZX0gZnJvbSAnLi91dGlscyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU291cmNlTWFwSW5mbyB7XG4gIHNvdXJjZTogc3RyaW5nO1xuICBtYXA6IFNvdXJjZU1hcENvbnZlcnRlcnxudWxsO1xuICBpc0lubGluZTogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBNZXJnZSB0aGUgaW5wdXQgYW5kIG91dHB1dCBzb3VyY2UtbWFwcywgcmVwbGFjaW5nIHRoZSBzb3VyY2UtbWFwIGNvbW1lbnQgaW4gdGhlIG91dHB1dCBmaWxlXG4gKiB3aXRoIGFuIGFwcHJvcHJpYXRlIHNvdXJjZS1tYXAgY29tbWVudCBwb2ludGluZyB0byB0aGUgbWVyZ2VkIHNvdXJjZS1tYXAuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiByZW5kZXJTb3VyY2VBbmRNYXAoXG4gICAgbG9nZ2VyOiBMb2dnZXIsIGZzOiBSZWFkb25seUZpbGVTeXN0ZW0sIHNvdXJjZUZpbGU6IHRzLlNvdXJjZUZpbGUsXG4gICAgZ2VuZXJhdGVkTWFnaWNTdHJpbmc6IE1hZ2ljU3RyaW5nKTogRmlsZVRvV3JpdGVbXSB7XG4gIGNvbnN0IGdlbmVyYXRlZFBhdGggPSBhYnNvbHV0ZUZyb21Tb3VyY2VGaWxlKHNvdXJjZUZpbGUpO1xuICBjb25zdCBnZW5lcmF0ZWRNYXBQYXRoID0gYWJzb2x1dGVGcm9tKGAke2dlbmVyYXRlZFBhdGh9Lm1hcGApO1xuICBjb25zdCBnZW5lcmF0ZWRDb250ZW50ID0gZ2VuZXJhdGVkTWFnaWNTdHJpbmcudG9TdHJpbmcoKTtcbiAgY29uc3QgZ2VuZXJhdGVkTWFwOiBSYXdTb3VyY2VNYXAgPSBnZW5lcmF0ZWRNYWdpY1N0cmluZy5nZW5lcmF0ZU1hcChcbiAgICAgIHtmaWxlOiBnZW5lcmF0ZWRQYXRoLCBzb3VyY2U6IGdlbmVyYXRlZFBhdGgsIGluY2x1ZGVDb250ZW50OiB0cnVlfSk7XG5cbiAgdHJ5IHtcbiAgICBjb25zdCBsb2FkZXIgPSBuZXcgU291cmNlRmlsZUxvYWRlcihmcywgbG9nZ2VyLCB7fSk7XG4gICAgY29uc3QgZ2VuZXJhdGVkRmlsZSA9IGxvYWRlci5sb2FkU291cmNlRmlsZShcbiAgICAgICAgZ2VuZXJhdGVkUGF0aCwgZ2VuZXJhdGVkQ29udGVudCwge21hcDogZ2VuZXJhdGVkTWFwLCBtYXBQYXRoOiBnZW5lcmF0ZWRNYXBQYXRofSk7XG5cbiAgICBjb25zdCByYXdNZXJnZWRNYXA6IFJhd1NvdXJjZU1hcCA9IGdlbmVyYXRlZEZpbGUucmVuZGVyRmxhdHRlbmVkU291cmNlTWFwKCk7XG4gICAgY29uc3QgbWVyZ2VkTWFwID0gZnJvbU9iamVjdChyYXdNZXJnZWRNYXApO1xuICAgIGNvbnN0IGZpcnN0U291cmNlID0gZ2VuZXJhdGVkRmlsZS5zb3VyY2VzWzBdO1xuICAgIGlmIChmaXJzdFNvdXJjZSAmJiAoZmlyc3RTb3VyY2UucmF3TWFwICE9PSBudWxsIHx8ICFzb3VyY2VGaWxlLmlzRGVjbGFyYXRpb25GaWxlKSAmJlxuICAgICAgICBmaXJzdFNvdXJjZS5pbmxpbmUpIHtcbiAgICAgIC8vIFdlIHJlbmRlciBhbiBpbmxpbmUgc291cmNlIG1hcCBpZiBvbmUgb2Y6XG4gICAgICAvLyAqIHRoZXJlIHdhcyBubyBpbnB1dCBzb3VyY2UgbWFwIGFuZCB0aGlzIGlzIG5vdCBhIHR5cGluZ3MgZmlsZTtcbiAgICAgIC8vICogdGhlIGlucHV0IHNvdXJjZSBtYXAgZXhpc3RzIGFuZCB3YXMgaW5saW5lLlxuICAgICAgLy9cbiAgICAgIC8vIFdlIGRvIG5vdCBnZW5lcmF0ZSBpbmxpbmUgc291cmNlIG1hcHMgZm9yIHR5cGluZ3MgZmlsZXMgdW5sZXNzIHRoZXJlIGV4cGxpY2l0bHkgd2FzIG9uZSBpblxuICAgICAgLy8gdGhlIGlucHV0IGZpbGUgYmVjYXVzZSB0aGVzZSBpbmxpbmUgc291cmNlIG1hcHMgY2FuIGJlIHZlcnkgbGFyZ2UgYW5kIGl0IGltcGFjdHMgb24gdGhlXG4gICAgICAvLyBwZXJmb3JtYW5jZSBvZiBJREVzIHRoYXQgbmVlZCB0byByZWFkIHRoZW0gdG8gcHJvdmlkZSBpbnRlbGxpc2Vuc2UgZXRjLlxuICAgICAgcmV0dXJuIFtcbiAgICAgICAge3BhdGg6IGdlbmVyYXRlZFBhdGgsIGNvbnRlbnRzOiBgJHtnZW5lcmF0ZWRGaWxlLmNvbnRlbnRzfVxcbiR7bWVyZ2VkTWFwLnRvQ29tbWVudCgpfWB9XG4gICAgICBdO1xuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCBzb3VyY2VNYXBDb21tZW50ID0gZ2VuZXJhdGVNYXBGaWxlQ29tbWVudChgJHtmcy5iYXNlbmFtZShnZW5lcmF0ZWRQYXRoKX0ubWFwYCk7XG4gICAgICByZXR1cm4gW1xuICAgICAgICB7cGF0aDogZ2VuZXJhdGVkUGF0aCwgY29udGVudHM6IGAke2dlbmVyYXRlZEZpbGUuY29udGVudHN9XFxuJHtzb3VyY2VNYXBDb21tZW50fWB9LFxuICAgICAgICB7cGF0aDogZ2VuZXJhdGVkTWFwUGF0aCwgY29udGVudHM6IG1lcmdlZE1hcC50b0pTT04oKX1cbiAgICAgIF07XG4gICAgfVxuICB9IGNhdGNoIChlKSB7XG4gICAgbG9nZ2VyLmVycm9yKGBFcnJvciB3aGVuIGZsYXR0ZW5pbmcgdGhlIHNvdXJjZS1tYXAgXCIke2dlbmVyYXRlZE1hcFBhdGh9XCIgZm9yIFwiJHtcbiAgICAgICAgZ2VuZXJhdGVkUGF0aH1cIjogJHtlLnRvU3RyaW5nKCl9YCk7XG4gICAgcmV0dXJuIFtcbiAgICAgIHtwYXRoOiBnZW5lcmF0ZWRQYXRoLCBjb250ZW50czogZ2VuZXJhdGVkQ29udGVudH0sXG4gICAgICB7cGF0aDogZ2VuZXJhdGVkTWFwUGF0aCwgY29udGVudHM6IGZyb21PYmplY3QoZ2VuZXJhdGVkTWFwKS50b0pTT04oKX0sXG4gICAgXTtcbiAgfVxufVxuIl19
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic291cmNlX21hcHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci1jbGkvbmdjYy9zcmMvcmVuZGVyaW5nL3NvdXJjZV9tYXBzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztJQUFBOzs7Ozs7T0FNRztJQUNILHlEQUEwRjtJQUkxRiwyRUFBd0c7SUFFeEcseUVBQTRGO0lBVTVGOzs7T0FHRztJQUNILFNBQWdCLGtCQUFrQixDQUM5QixNQUFjLEVBQUUsRUFBc0IsRUFBRSxVQUF5QixFQUNqRSxvQkFBaUM7O1FBQ25DLElBQU0sY0FBYyxHQUFHLG9DQUFzQixDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQzFELElBQU0sYUFBYSxHQUFHLDBCQUFZLENBQUksY0FBYyxTQUFNLENBQUMsQ0FBQztRQUM1RCxJQUFNLGdCQUFnQixHQUFHLG9CQUFvQixDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ3pELElBQU0sWUFBWSxHQUFpQixvQkFBb0IsQ0FBQyxXQUFXLENBQy9ELEVBQUMsSUFBSSxFQUFFLGNBQWMsRUFBRSxNQUFNLEVBQUUsY0FBYyxFQUFFLGNBQWMsRUFBRSxJQUFJLEVBQUMsQ0FBQyxDQUFDO1FBRTFFLElBQUk7WUFDRixJQUFNLE1BQU0sR0FBRyxJQUFJLDZCQUFnQixDQUFDLEVBQUUsRUFBRSxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFDcEQsSUFBTSxhQUFhLEdBQUcsTUFBTSxDQUFDLGNBQWMsQ0FDdkMsY0FBYyxFQUFFLGdCQUFnQixFQUFFLEVBQUMsR0FBRyxFQUFFLFlBQVksRUFBRSxPQUFPLEVBQUUsYUFBYSxFQUFDLENBQUMsQ0FBQztZQUVuRixJQUFNLFlBQVksR0FBaUIsYUFBYSxDQUFDLHdCQUF3QixFQUFFLENBQUM7WUFDNUUsSUFBTSxTQUFTLEdBQUcsK0JBQVUsQ0FBQyxZQUFZLENBQUMsQ0FBQztZQUMzQyxJQUFNLFlBQVksR0FBRyxNQUFNLENBQUMsY0FBYyxDQUFDLGNBQWMsRUFBRSxvQkFBb0IsQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUMxRixJQUFJLFlBQVksQ0FBQyxNQUFNLEtBQUssSUFBSSxJQUFJLENBQUMsVUFBVSxDQUFDLGlCQUFpQjtnQkFDN0QsT0FBQSxZQUFZLENBQUMsTUFBTSwwQ0FBRSxNQUFNLE1BQUssMEJBQWEsQ0FBQyxNQUFNLEVBQUU7Z0JBQ3hELDRDQUE0QztnQkFDNUMsa0VBQWtFO2dCQUNsRSxnREFBZ0Q7Z0JBQ2hELEVBQUU7Z0JBQ0YsNkZBQTZGO2dCQUM3RiwwRkFBMEY7Z0JBQzFGLDBFQUEwRTtnQkFDMUUsT0FBTztvQkFDTCxFQUFDLElBQUksRUFBRSxjQUFjLEVBQUUsUUFBUSxFQUFLLGFBQWEsQ0FBQyxRQUFRLFVBQUssU0FBUyxDQUFDLFNBQVMsRUFBSSxFQUFDO2lCQUN4RixDQUFDO2FBQ0g7WUFFRCxJQUFNLGdCQUFnQixHQUFHLDJDQUFzQixDQUFJLEVBQUUsQ0FBQyxRQUFRLENBQUMsY0FBYyxDQUFDLFNBQU0sQ0FBQyxDQUFDO1lBQ3RGLE9BQU87Z0JBQ0wsRUFBQyxJQUFJLEVBQUUsY0FBYyxFQUFFLFFBQVEsRUFBSyxhQUFhLENBQUMsUUFBUSxVQUFLLGdCQUFrQixFQUFDO2dCQUNsRixFQUFDLElBQUksRUFBRSxhQUFhLEVBQUUsUUFBUSxFQUFFLFNBQVMsQ0FBQyxNQUFNLEVBQUUsRUFBQzthQUNwRCxDQUFDO1NBQ0g7UUFBQyxPQUFPLENBQUMsRUFBRTtZQUNWLE1BQU0sQ0FBQyxLQUFLLENBQUMsNENBQXlDLGFBQWEsaUJBQy9ELGNBQWMsWUFBTSxDQUFDLENBQUMsUUFBUSxFQUFJLENBQUMsQ0FBQztZQUN4QyxPQUFPO2dCQUNMLEVBQUMsSUFBSSxFQUFFLGNBQWMsRUFBRSxRQUFRLEVBQUUsZ0JBQWdCLEVBQUM7Z0JBQ2xELEVBQUMsSUFBSSxFQUFFLGFBQWEsRUFBRSxRQUFRLEVBQUUsK0JBQVUsQ0FBQyxZQUFZLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBQzthQUNuRSxDQUFDO1NBQ0g7SUFDSCxDQUFDO0lBNUNELGdEQTRDQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHtmcm9tT2JqZWN0LCBnZW5lcmF0ZU1hcEZpbGVDb21tZW50LCBTb3VyY2VNYXBDb252ZXJ0ZXJ9IGZyb20gJ2NvbnZlcnQtc291cmNlLW1hcCc7XG5pbXBvcnQgTWFnaWNTdHJpbmcgZnJvbSAnbWFnaWMtc3RyaW5nJztcbmltcG9ydCAqIGFzIHRzIGZyb20gJ3R5cGVzY3JpcHQnO1xuXG5pbXBvcnQge2Fic29sdXRlRnJvbSwgYWJzb2x1dGVGcm9tU291cmNlRmlsZSwgUmVhZG9ubHlGaWxlU3lzdGVtfSBmcm9tICcuLi8uLi8uLi9zcmMvbmd0c2MvZmlsZV9zeXN0ZW0nO1xuaW1wb3J0IHtMb2dnZXJ9IGZyb20gJy4uLy4uLy4uL3NyYy9uZ3RzYy9sb2dnaW5nJztcbmltcG9ydCB7Q29udGVudE9yaWdpbiwgUmF3U291cmNlTWFwLCBTb3VyY2VGaWxlTG9hZGVyfSBmcm9tICcuLi8uLi8uLi9zcmMvbmd0c2Mvc291cmNlbWFwcyc7XG5cbmltcG9ydCB7RmlsZVRvV3JpdGV9IGZyb20gJy4vdXRpbHMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNvdXJjZU1hcEluZm8ge1xuICBzb3VyY2U6IHN0cmluZztcbiAgbWFwOiBTb3VyY2VNYXBDb252ZXJ0ZXJ8bnVsbDtcbiAgaXNJbmxpbmU6IGJvb2xlYW47XG59XG5cbi8qKlxuICogTWVyZ2UgdGhlIGlucHV0IGFuZCBvdXRwdXQgc291cmNlLW1hcHMsIHJlcGxhY2luZyB0aGUgc291cmNlLW1hcCBjb21tZW50IGluIHRoZSBvdXRwdXQgZmlsZVxuICogd2l0aCBhbiBhcHByb3ByaWF0ZSBzb3VyY2UtbWFwIGNvbW1lbnQgcG9pbnRpbmcgdG8gdGhlIG1lcmdlZCBzb3VyY2UtbWFwLlxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVuZGVyU291cmNlQW5kTWFwKFxuICAgIGxvZ2dlcjogTG9nZ2VyLCBmczogUmVhZG9ubHlGaWxlU3lzdGVtLCBzb3VyY2VGaWxlOiB0cy5Tb3VyY2VGaWxlLFxuICAgIGdlbmVyYXRlZE1hZ2ljU3RyaW5nOiBNYWdpY1N0cmluZyk6IEZpbGVUb1dyaXRlW10ge1xuICBjb25zdCBzb3VyY2VGaWxlUGF0aCA9IGFic29sdXRlRnJvbVNvdXJjZUZpbGUoc291cmNlRmlsZSk7XG4gIGNvbnN0IHNvdXJjZU1hcFBhdGggPSBhYnNvbHV0ZUZyb20oYCR7c291cmNlRmlsZVBhdGh9Lm1hcGApO1xuICBjb25zdCBnZW5lcmF0ZWRDb250ZW50ID0gZ2VuZXJhdGVkTWFnaWNTdHJpbmcudG9TdHJpbmcoKTtcbiAgY29uc3QgZ2VuZXJhdGVkTWFwOiBSYXdTb3VyY2VNYXAgPSBnZW5lcmF0ZWRNYWdpY1N0cmluZy5nZW5lcmF0ZU1hcChcbiAgICAgIHtmaWxlOiBzb3VyY2VGaWxlUGF0aCwgc291cmNlOiBzb3VyY2VGaWxlUGF0aCwgaW5jbHVkZUNvbnRlbnQ6IHRydWV9KTtcblxuICB0cnkge1xuICAgIGNvbnN0IGxvYWRlciA9IG5ldyBTb3VyY2VGaWxlTG9hZGVyKGZzLCBsb2dnZXIsIHt9KTtcbiAgICBjb25zdCBnZW5lcmF0ZWRGaWxlID0gbG9hZGVyLmxvYWRTb3VyY2VGaWxlKFxuICAgICAgICBzb3VyY2VGaWxlUGF0aCwgZ2VuZXJhdGVkQ29udGVudCwge21hcDogZ2VuZXJhdGVkTWFwLCBtYXBQYXRoOiBzb3VyY2VNYXBQYXRofSk7XG5cbiAgICBjb25zdCByYXdNZXJnZWRNYXA6IFJhd1NvdXJjZU1hcCA9IGdlbmVyYXRlZEZpbGUucmVuZGVyRmxhdHRlbmVkU291cmNlTWFwKCk7XG4gICAgY29uc3QgbWVyZ2VkTWFwID0gZnJvbU9iamVjdChyYXdNZXJnZWRNYXApO1xuICAgIGNvbnN0IG9yaWdpbmFsRmlsZSA9IGxvYWRlci5sb2FkU291cmNlRmlsZShzb3VyY2VGaWxlUGF0aCwgZ2VuZXJhdGVkTWFnaWNTdHJpbmcub3JpZ2luYWwpO1xuICAgIGlmIChvcmlnaW5hbEZpbGUucmF3TWFwID09PSBudWxsICYmICFzb3VyY2VGaWxlLmlzRGVjbGFyYXRpb25GaWxlIHx8XG4gICAgICAgIG9yaWdpbmFsRmlsZS5yYXdNYXA/Lm9yaWdpbiA9PT0gQ29udGVudE9yaWdpbi5JbmxpbmUpIHtcbiAgICAgIC8vIFdlIHJlbmRlciBhbiBpbmxpbmUgc291cmNlIG1hcCBpZiBvbmUgb2Y6XG4gICAgICAvLyAqIHRoZXJlIHdhcyBubyBpbnB1dCBzb3VyY2UgbWFwIGFuZCB0aGlzIGlzIG5vdCBhIHR5cGluZ3MgZmlsZTtcbiAgICAgIC8vICogdGhlIGlucHV0IHNvdXJjZSBtYXAgZXhpc3RzIGFuZCB3YXMgaW5saW5lLlxuICAgICAgLy9cbiAgICAgIC8vIFdlIGRvIG5vdCBnZW5lcmF0ZSBpbmxpbmUgc291cmNlIG1hcHMgZm9yIHR5cGluZ3MgZmlsZXMgdW5sZXNzIHRoZXJlIGV4cGxpY2l0bHkgd2FzIG9uZSBpblxuICAgICAgLy8gdGhlIGlucHV0IGZpbGUgYmVjYXVzZSB0aGVzZSBpbmxpbmUgc291cmNlIG1hcHMgY2FuIGJlIHZlcnkgbGFyZ2UgYW5kIGl0IGltcGFjdHMgb24gdGhlXG4gICAgICAvLyBwZXJmb3JtYW5jZSBvZiBJREVzIHRoYXQgbmVlZCB0byByZWFkIHRoZW0gdG8gcHJvdmlkZSBpbnRlbGxpc2Vuc2UgZXRjLlxuICAgICAgcmV0dXJuIFtcbiAgICAgICAge3BhdGg6IHNvdXJjZUZpbGVQYXRoLCBjb250ZW50czogYCR7Z2VuZXJhdGVkRmlsZS5jb250ZW50c31cXG4ke21lcmdlZE1hcC50b0NvbW1lbnQoKX1gfVxuICAgICAgXTtcbiAgICB9XG5cbiAgICBjb25zdCBzb3VyY2VNYXBDb21tZW50ID0gZ2VuZXJhdGVNYXBGaWxlQ29tbWVudChgJHtmcy5iYXNlbmFtZShzb3VyY2VGaWxlUGF0aCl9Lm1hcGApO1xuICAgIHJldHVybiBbXG4gICAgICB7cGF0aDogc291cmNlRmlsZVBhdGgsIGNvbnRlbnRzOiBgJHtnZW5lcmF0ZWRGaWxlLmNvbnRlbnRzfVxcbiR7c291cmNlTWFwQ29tbWVudH1gfSxcbiAgICAgIHtwYXRoOiBzb3VyY2VNYXBQYXRoLCBjb250ZW50czogbWVyZ2VkTWFwLnRvSlNPTigpfVxuICAgIF07XG4gIH0gY2F0Y2ggKGUpIHtcbiAgICBsb2dnZXIuZXJyb3IoYEVycm9yIHdoZW4gZmxhdHRlbmluZyB0aGUgc291cmNlLW1hcCBcIiR7c291cmNlTWFwUGF0aH1cIiBmb3IgXCIke1xuICAgICAgICBzb3VyY2VGaWxlUGF0aH1cIjogJHtlLnRvU3RyaW5nKCl9YCk7XG4gICAgcmV0dXJuIFtcbiAgICAgIHtwYXRoOiBzb3VyY2VGaWxlUGF0aCwgY29udGVudHM6IGdlbmVyYXRlZENvbnRlbnR9LFxuICAgICAge3BhdGg6IHNvdXJjZU1hcFBhdGgsIGNvbnRlbnRzOiBmcm9tT2JqZWN0KGdlbmVyYXRlZE1hcCkudG9KU09OKCl9LFxuICAgIF07XG4gIH1cbn1cbiJdfQ==
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@angular/compiler-cli",
3
- "version": "11.1.0",
3
+ "version": "11.1.1",
4
4
  "description": "Angular - the compiler CLI for Node.js",
5
5
  "main": "index.js",
6
6
  "typings": "index.d.ts",
@@ -28,7 +28,7 @@
28
28
  "yargs": "^16.1.1"
29
29
  },
30
30
  "peerDependencies": {
31
- "@angular/compiler": "11.1.0",
31
+ "@angular/compiler": "11.1.1",
32
32
  "typescript": ">=4.0 <4.2"
33
33
  },
34
34
  "engines": {
@@ -6,7 +6,8 @@
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
8
  /// <amd-module name="@angular/compiler-cli/src/ngtsc/annotations/src/component" />
9
- import { ConstantPool, ParsedTemplate, ParseSourceFile, R3ComponentMetadata, Statement, TmplAstNode } from '@angular/compiler';
9
+ import { ConstantPool, InterpolationConfig, ParsedTemplate, ParseSourceFile, R3ComponentMetadata, Statement, TmplAstNode } from '@angular/compiler';
10
+ import * as ts from 'typescript';
10
11
  import { CycleAnalyzer } from '../../cycles';
11
12
  import { DefaultImportRecorder, ModuleResolver, Reference, ReferenceEmitter } from '../../imports';
12
13
  import { DependencyTracker } from '../../incremental/api';
@@ -49,6 +50,14 @@ export interface ComponentAnalysisData {
49
50
  */
50
51
  viewProvidersRequiringFactory: Set<Reference<ClassDeclaration>> | null;
51
52
  resources: ComponentResources;
53
+ /**
54
+ * The literal `styleUrls` extracted from the decorator, if present.
55
+ */
56
+ styleUrls: string[] | null;
57
+ /**
58
+ * Inline stylesheets extracted from the decorator, if present.
59
+ */
60
+ inlineStyles: string[] | null;
52
61
  isPoisoned: boolean;
53
62
  }
54
63
  export declare type ComponentResolutionData = Pick<R3ComponentMetadata, ComponentMetadataResolvedFields>;
@@ -97,6 +106,7 @@ export declare class ComponentDecoratorHandler implements DecoratorHandler<Decor
97
106
  index(context: IndexingContext, node: ClassDeclaration, analysis: Readonly<ComponentAnalysisData>): null | undefined;
98
107
  typeCheck(ctx: TypeCheckContext, node: ClassDeclaration, meta: Readonly<ComponentAnalysisData>): void;
99
108
  resolve(node: ClassDeclaration, analysis: Readonly<ComponentAnalysisData>): ResolveResult<ComponentResolutionData>;
109
+ updateResources(node: ClassDeclaration, analysis: ComponentAnalysisData): void;
100
110
  compileFull(node: ClassDeclaration, analysis: Readonly<ComponentAnalysisData>, resolution: Readonly<ComponentResolutionData>, pool: ConstantPool): CompileResult[];
101
111
  compilePartial(node: ClassDeclaration, analysis: Readonly<ComponentAnalysisData>, resolution: Readonly<ComponentResolutionData>): CompileResult[];
102
112
  private compileComponent;
@@ -105,9 +115,9 @@ export declare class ComponentDecoratorHandler implements DecoratorHandler<Decor
105
115
  private _extractStyleUrls;
106
116
  private _extractStyleResources;
107
117
  private _preloadAndParseTemplate;
108
- private _extractExternalTemplate;
109
- private _extractInlineTemplate;
118
+ private extractTemplate;
110
119
  private _parseTemplate;
120
+ private parseTemplateDeclaration;
111
121
  private _expressionToImportedFile;
112
122
  private _isCyclicImport;
113
123
  private _recordSyntheticImport;
@@ -137,4 +147,39 @@ export interface ParsedComponentTemplate extends ParsedTemplate {
137
147
  }
138
148
  export interface ParsedTemplateWithSource extends ParsedComponentTemplate {
139
149
  sourceMapping: TemplateSourceMapping;
150
+ declaration: TemplateDeclaration;
151
+ }
152
+ /**
153
+ * Common fields extracted from the declaration of a template.
154
+ */
155
+ interface CommonTemplateDeclaration {
156
+ preserveWhitespaces: boolean;
157
+ interpolationConfig: InterpolationConfig;
158
+ templateUrl: string;
159
+ resolvedTemplateUrl: string;
160
+ sourceMapUrl: string;
161
+ }
162
+ /**
163
+ * Information extracted from the declaration of an inline template.
164
+ */
165
+ interface InlineTemplateDeclaration extends CommonTemplateDeclaration {
166
+ isInline: true;
167
+ expression: ts.Expression;
168
+ }
169
+ /**
170
+ * Information extracted from the declaration of an external template.
171
+ */
172
+ interface ExternalTemplateDeclaration extends CommonTemplateDeclaration {
173
+ isInline: false;
174
+ templateUrlExpression: ts.Expression;
140
175
  }
176
+ /**
177
+ * The declaration of a template extracted from a component decorator.
178
+ *
179
+ * This data is extracted and stored separately to faciliate re-interpreting the template
180
+ * declaration whenever the compiler is notified of a change to a template file. With this
181
+ * information, `ComponentDecoratorHandler` is able to re-read the template and update the component
182
+ * record without needing to parse the original decorator again.
183
+ */
184
+ declare type TemplateDeclaration = InlineTemplateDeclaration | ExternalTemplateDeclaration;
185
+ export {};