@angular/compiler-cli 7.2.4 → 7.2.8

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 (39) hide show
  1. package/index.js +1 -1
  2. package/package.json +4 -4
  3. package/src/diagnostics/expression_diagnostics.js +98 -151
  4. package/src/diagnostics/expression_type.js +122 -139
  5. package/src/diagnostics/translate_diagnostics.js +12 -12
  6. package/src/diagnostics/typescript_symbols.js +296 -514
  7. package/src/diagnostics/typescript_version.js +8 -8
  8. package/src/extract_i18n.js +11 -13
  9. package/src/main.js +80 -78
  10. package/src/metadata/bundle_index_host.js +39 -51
  11. package/src/metadata/bundler.js +214 -256
  12. package/src/metadata/collector.js +235 -317
  13. package/src/metadata/evaluator.js +146 -162
  14. package/src/metadata/index.js +1 -1
  15. package/src/metadata/index_writer.js +25 -47
  16. package/src/metadata/symbols.js +44 -62
  17. package/src/ngcc/src/packages/build_marker.d.ts +1 -1
  18. package/src/ngcc/src/packages/build_marker.js +1 -1
  19. package/src/ngtools_api.js +29 -44
  20. package/src/ngtools_api2.js +9 -11
  21. package/src/ngtsc/program.js +122 -162
  22. package/src/ngtsc/resource_loader.js +35 -50
  23. package/src/perform_compile.js +87 -93
  24. package/src/perform_watch.js +50 -51
  25. package/src/transformers/compiler_host.js +158 -171
  26. package/src/transformers/inline_resources.js +54 -57
  27. package/src/transformers/lower_expressions.js +87 -101
  28. package/src/transformers/metadata_cache.js +21 -50
  29. package/src/transformers/metadata_reader.js +17 -18
  30. package/src/transformers/nocollapse_hack.js +9 -9
  31. package/src/transformers/node_emitter.js +214 -237
  32. package/src/transformers/node_emitter_transform.js +25 -21
  33. package/src/transformers/program.js +336 -440
  34. package/src/transformers/r3_metadata_transform.js +21 -34
  35. package/src/transformers/r3_strip_decorators.js +29 -31
  36. package/src/transformers/r3_transform.js +7 -8
  37. package/src/transformers/tsc_pass_through.js +33 -37
  38. package/src/transformers/util.js +18 -30
  39. package/src/version.js +3 -3
@@ -37,22 +37,22 @@
37
37
  * arrays are equals
38
38
  */
39
39
  function compareNumbers(a, b) {
40
- var max = Math.max(a.length, b.length);
41
- var min = Math.min(a.length, b.length);
42
- for (var i = 0; i < min; i++) {
40
+ const max = Math.max(a.length, b.length);
41
+ const min = Math.min(a.length, b.length);
42
+ for (let i = 0; i < min; i++) {
43
43
  if (a[i] > b[i])
44
44
  return 1;
45
45
  if (a[i] < b[i])
46
46
  return -1;
47
47
  }
48
48
  if (min !== max) {
49
- var longestArray = a.length === max ? a : b;
49
+ const longestArray = a.length === max ? a : b;
50
50
  // The result to return in case the to arrays are considered different (1 if a is greater,
51
51
  // -1 if b is greater)
52
- var comparisonResult = a.length === max ? 1 : -1;
52
+ const comparisonResult = a.length === max ? 1 : -1;
53
53
  // Check that at least one of the remaining elements is greater than 0 to consider that the two
54
54
  // arrays are different (e.g. [1, 0] and [1] are considered the same but not [1, 0, 1] and [1])
55
- for (var i = min; i < max; i++) {
55
+ for (let i = min; i < max; i++) {
56
56
  if (longestArray[i] > 0) {
57
57
  return comparisonResult;
58
58
  }
@@ -71,7 +71,7 @@
71
71
  * @param high The maximum version
72
72
  */
73
73
  function isVersionBetween(version, low, high) {
74
- var tsNumbers = toNumbers(version);
74
+ const tsNumbers = toNumbers(version);
75
75
  if (high !== undefined) {
76
76
  return compareNumbers(toNumbers(low), tsNumbers) <= 0 &&
77
77
  compareNumbers(toNumbers(high), tsNumbers) >= 0;
@@ -92,4 +92,4 @@
92
92
  }
93
93
  exports.compareVersions = compareVersions;
94
94
  });
95
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXNjcmlwdF92ZXJzaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcGlsZXItY2xpL3NyYy9kaWFnbm9zdGljcy90eXBlc2NyaXB0X3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HOzs7Ozs7Ozs7Ozs7SUFFSDs7OztPQUlHO0lBQ0gsU0FBZ0IsU0FBUyxDQUFDLEtBQWE7UUFDckMsT0FBTyxLQUFLLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN0QyxDQUFDO0lBRkQsOEJBRUM7SUFFRDs7Ozs7Ozs7OztPQVVHO0lBQ0gsU0FBZ0IsY0FBYyxDQUFDLENBQVcsRUFBRSxDQUFXO1FBQ3JELElBQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDekMsSUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUV6QyxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsR0FBRyxFQUFFLENBQUMsRUFBRSxFQUFFO1lBQzVCLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQUUsT0FBTyxDQUFDLENBQUM7WUFDMUIsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDO1NBQzVCO1FBRUQsSUFBSSxHQUFHLEtBQUssR0FBRyxFQUFFO1lBQ2YsSUFBTSxZQUFZLEdBQUcsQ0FBQyxDQUFDLE1BQU0sS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBRTlDLDBGQUEwRjtZQUMxRixzQkFBc0I7WUFDdEIsSUFBTSxnQkFBZ0IsR0FBRyxDQUFDLENBQUMsTUFBTSxLQUFLLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUVuRCwrRkFBK0Y7WUFDL0YsK0ZBQStGO1lBQy9GLEtBQUssSUFBSSxDQUFDLEdBQUcsR0FBRyxFQUFFLENBQUMsR0FBRyxHQUFHLEVBQUUsQ0FBQyxFQUFFLEVBQUU7Z0JBQzlCLElBQUksWUFBWSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRTtvQkFDdkIsT0FBTyxnQkFBZ0IsQ0FBQztpQkFDekI7YUFDRjtTQUNGO1FBRUQsT0FBTyxDQUFDLENBQUM7SUFDWCxDQUFDO0lBMUJELHdDQTBCQztJQUVEOzs7Ozs7OztPQVFHO0lBQ0gsU0FBZ0IsZ0JBQWdCLENBQUMsT0FBZSxFQUFFLEdBQVcsRUFBRSxJQUFhO1FBQzFFLElBQU0sU0FBUyxHQUFHLFNBQVMsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNyQyxJQUFJLElBQUksS0FBSyxTQUFTLEVBQUU7WUFDdEIsT0FBTyxjQUFjLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFLFNBQVMsQ0FBQyxJQUFJLENBQUM7Z0JBQ2pELGNBQWMsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUUsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQ3JEO1FBQ0QsT0FBTyxjQUFjLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN4RCxDQUFDO0lBUEQsNENBT0M7SUFFRDs7Ozs7OztPQU9HO0lBQ0gsU0FBZ0IsZUFBZSxDQUFDLEVBQVUsRUFBRSxFQUFVO1FBQ3BELE9BQU8sY0FBYyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsRUFBRSxTQUFTLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUN0RCxDQUFDO0lBRkQsMENBRUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbi8qKlxuICogQ29udmVydHMgYSBgc3RyaW5nYCB2ZXJzaW9uIGludG8gYW4gYXJyYXkgb2YgbnVtYmVyc1xuICogQGV4YW1wbGVcbiAqIHRvTnVtYmVycygnMi4wLjEnKTsgLy8gcmV0dXJucyBbMiwgMCwgMV1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHRvTnVtYmVycyh2YWx1ZTogc3RyaW5nKTogbnVtYmVyW10ge1xuICByZXR1cm4gdmFsdWUuc3BsaXQoJy4nKS5tYXAoTnVtYmVyKTtcbn1cblxuLyoqXG4gKiBDb21wYXJlcyB0d28gYXJyYXlzIG9mIHBvc2l0aXZlIG51bWJlcnMgd2l0aCBsZXhpY29ncmFwaGljYWwgb3JkZXIgaW4gbWluZC5cbiAqXG4gKiBIb3dldmVyIC0gdW5saWtlIGxleGljb2dyYXBoaWNhbCBvcmRlciAtIGZvciBhcnJheXMgb2YgZGlmZmVyZW50IGxlbmd0aCB3ZSBjb25zaWRlcjpcbiAqIFsxLCAyLCAzXSA9IFsxLCAyLCAzLCAwXSBpbnN0ZWFkIG9mIFsxLCAyLCAzXSA8IFsxLCAyLCAzLCAwXVxuICpcbiAqIEBwYXJhbSBhIFRoZSAnbGVmdCBoYW5kJyBhcnJheSBpbiB0aGUgY29tcGFyaXNvbiB0ZXN0XG4gKiBAcGFyYW0gYiBUaGUgJ3JpZ2h0IGhhbmQnIGluIHRoZSBjb21wYXJpc29uIHRlc3RcbiAqIEByZXR1cm5zIHstMXwwfDF9IFRoZSBjb21wYXJpc29uIHJlc3VsdDogMSBpZiBhIGlzIGdyZWF0ZXIsIC0xIGlmIGIgaXMgZ3JlYXRlciwgMCBpcyB0aGUgdHdvXG4gKiBhcnJheXMgYXJlIGVxdWFsc1xuICovXG5leHBvcnQgZnVuY3Rpb24gY29tcGFyZU51bWJlcnMoYTogbnVtYmVyW10sIGI6IG51bWJlcltdKTogLTF8MHwxIHtcbiAgY29uc3QgbWF4ID0gTWF0aC5tYXgoYS5sZW5ndGgsIGIubGVuZ3RoKTtcbiAgY29uc3QgbWluID0gTWF0aC5taW4oYS5sZW5ndGgsIGIubGVuZ3RoKTtcblxuICBmb3IgKGxldCBpID0gMDsgaSA8IG1pbjsgaSsrKSB7XG4gICAgaWYgKGFbaV0gPiBiW2ldKSByZXR1cm4gMTtcbiAgICBpZiAoYVtpXSA8IGJbaV0pIHJldHVybiAtMTtcbiAgfVxuXG4gIGlmIChtaW4gIT09IG1heCkge1xuICAgIGNvbnN0IGxvbmdlc3RBcnJheSA9IGEubGVuZ3RoID09PSBtYXggPyBhIDogYjtcblxuICAgIC8vIFRoZSByZXN1bHQgdG8gcmV0dXJuIGluIGNhc2UgdGhlIHRvIGFycmF5cyBhcmUgY29uc2lkZXJlZCBkaWZmZXJlbnQgKDEgaWYgYSBpcyBncmVhdGVyLFxuICAgIC8vIC0xIGlmIGIgaXMgZ3JlYXRlcilcbiAgICBjb25zdCBjb21wYXJpc29uUmVzdWx0ID0gYS5sZW5ndGggPT09IG1heCA/IDEgOiAtMTtcblxuICAgIC8vIENoZWNrIHRoYXQgYXQgbGVhc3Qgb25lIG9mIHRoZSByZW1haW5pbmcgZWxlbWVudHMgaXMgZ3JlYXRlciB0aGFuIDAgdG8gY29uc2lkZXIgdGhhdCB0aGUgdHdvXG4gICAgLy8gYXJyYXlzIGFyZSBkaWZmZXJlbnQgKGUuZy4gWzEsIDBdIGFuZCBbMV0gYXJlIGNvbnNpZGVyZWQgdGhlIHNhbWUgYnV0IG5vdCBbMSwgMCwgMV0gYW5kIFsxXSlcbiAgICBmb3IgKGxldCBpID0gbWluOyBpIDwgbWF4OyBpKyspIHtcbiAgICAgIGlmIChsb25nZXN0QXJyYXlbaV0gPiAwKSB7XG4gICAgICAgIHJldHVybiBjb21wYXJpc29uUmVzdWx0O1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiAwO1xufVxuXG4vKipcbiAqIENoZWNrcyBpZiBhIFR5cGVTY3JpcHQgdmVyc2lvbiBpczpcbiAqIC0gZ3JlYXRlciBvciBlcXVhbCB0aGFuIHRoZSBwcm92aWRlZCBgbG93YCB2ZXJzaW9uLFxuICogLSBsb3dlciBvciBlcXVhbCB0aGFuIGFuIG9wdGlvbmFsIGBoaWdoYCB2ZXJzaW9uLlxuICpcbiAqIEBwYXJhbSB2ZXJzaW9uIFRoZSBUeXBlU2NyaXB0IHZlcnNpb25cbiAqIEBwYXJhbSBsb3cgVGhlIG1pbmltdW0gdmVyc2lvblxuICogQHBhcmFtIGhpZ2ggVGhlIG1heGltdW0gdmVyc2lvblxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNWZXJzaW9uQmV0d2Vlbih2ZXJzaW9uOiBzdHJpbmcsIGxvdzogc3RyaW5nLCBoaWdoPzogc3RyaW5nKTogYm9vbGVhbiB7XG4gIGNvbnN0IHRzTnVtYmVycyA9IHRvTnVtYmVycyh2ZXJzaW9uKTtcbiAgaWYgKGhpZ2ggIT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiBjb21wYXJlTnVtYmVycyh0b051bWJlcnMobG93KSwgdHNOdW1iZXJzKSA8PSAwICYmXG4gICAgICAgIGNvbXBhcmVOdW1iZXJzKHRvTnVtYmVycyhoaWdoKSwgdHNOdW1iZXJzKSA+PSAwO1xuICB9XG4gIHJldHVybiBjb21wYXJlTnVtYmVycyh0b051bWJlcnMobG93KSwgdHNOdW1iZXJzKSA8PSAwO1xufVxuXG4vKipcbiAqIENvbXBhcmVzIHR3byB2ZXJzaW9uc1xuICpcbiAqIEBwYXJhbSB2MSBUaGUgJ2xlZnQgaGFuZCcgdmVyc2lvbiBpbiB0aGUgY29tcGFyaXNvbiB0ZXN0XG4gKiBAcGFyYW0gdjIgVGhlICdyaWdodCBoYW5kJyB2ZXJzaW9uIGluIHRoZSBjb21wYXJpc29uIHRlc3RcbiAqIEByZXR1cm5zIHstMXwwfDF9IFRoZSBjb21wYXJpc29uIHJlc3VsdDogMSBpZiB2MSBpcyBncmVhdGVyLCAtMSBpZiB2MiBpcyBncmVhdGVyLCAwIGlzIHRoZSB0d29cbiAqIHZlcnNpb25zIGFyZSBlcXVhbHNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNvbXBhcmVWZXJzaW9ucyh2MTogc3RyaW5nLCB2Mjogc3RyaW5nKTogLTF8MHwxIHtcbiAgcmV0dXJuIGNvbXBhcmVOdW1iZXJzKHRvTnVtYmVycyh2MSksIHRvTnVtYmVycyh2MikpO1xufVxuIl19
95
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXNjcmlwdF92ZXJzaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcGlsZXItY2xpL3NyYy9kaWFnbm9zdGljcy90eXBlc2NyaXB0X3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HOzs7Ozs7Ozs7Ozs7SUFFSDs7OztPQUlHO0lBQ0gsU0FBZ0IsU0FBUyxDQUFDLEtBQWE7UUFDckMsT0FBTyxLQUFLLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN0QyxDQUFDO0lBRkQsOEJBRUM7SUFFRDs7Ozs7Ozs7OztPQVVHO0lBQ0gsU0FBZ0IsY0FBYyxDQUFDLENBQVcsRUFBRSxDQUFXO1FBQ3JELE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDekMsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUV6QyxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsR0FBRyxFQUFFLENBQUMsRUFBRSxFQUFFO1lBQzVCLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQUUsT0FBTyxDQUFDLENBQUM7WUFDMUIsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDO1NBQzVCO1FBRUQsSUFBSSxHQUFHLEtBQUssR0FBRyxFQUFFO1lBQ2YsTUFBTSxZQUFZLEdBQUcsQ0FBQyxDQUFDLE1BQU0sS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBRTlDLDBGQUEwRjtZQUMxRixzQkFBc0I7WUFDdEIsTUFBTSxnQkFBZ0IsR0FBRyxDQUFDLENBQUMsTUFBTSxLQUFLLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUVuRCwrRkFBK0Y7WUFDL0YsK0ZBQStGO1lBQy9GLEtBQUssSUFBSSxDQUFDLEdBQUcsR0FBRyxFQUFFLENBQUMsR0FBRyxHQUFHLEVBQUUsQ0FBQyxFQUFFLEVBQUU7Z0JBQzlCLElBQUksWUFBWSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRTtvQkFDdkIsT0FBTyxnQkFBZ0IsQ0FBQztpQkFDekI7YUFDRjtTQUNGO1FBRUQsT0FBTyxDQUFDLENBQUM7SUFDWCxDQUFDO0lBMUJELHdDQTBCQztJQUVEOzs7Ozs7OztPQVFHO0lBQ0gsU0FBZ0IsZ0JBQWdCLENBQUMsT0FBZSxFQUFFLEdBQVcsRUFBRSxJQUFhO1FBQzFFLE1BQU0sU0FBUyxHQUFHLFNBQVMsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNyQyxJQUFJLElBQUksS0FBSyxTQUFTLEVBQUU7WUFDdEIsT0FBTyxjQUFjLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFLFNBQVMsQ0FBQyxJQUFJLENBQUM7Z0JBQ2pELGNBQWMsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUUsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQ3JEO1FBQ0QsT0FBTyxjQUFjLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN4RCxDQUFDO0lBUEQsNENBT0M7SUFFRDs7Ozs7OztPQU9HO0lBQ0gsU0FBZ0IsZUFBZSxDQUFDLEVBQVUsRUFBRSxFQUFVO1FBQ3BELE9BQU8sY0FBYyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsRUFBRSxTQUFTLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUN0RCxDQUFDO0lBRkQsMENBRUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbi8qKlxuICogQ29udmVydHMgYSBgc3RyaW5nYCB2ZXJzaW9uIGludG8gYW4gYXJyYXkgb2YgbnVtYmVyc1xuICogQGV4YW1wbGVcbiAqIHRvTnVtYmVycygnMi4wLjEnKTsgLy8gcmV0dXJucyBbMiwgMCwgMV1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHRvTnVtYmVycyh2YWx1ZTogc3RyaW5nKTogbnVtYmVyW10ge1xuICByZXR1cm4gdmFsdWUuc3BsaXQoJy4nKS5tYXAoTnVtYmVyKTtcbn1cblxuLyoqXG4gKiBDb21wYXJlcyB0d28gYXJyYXlzIG9mIHBvc2l0aXZlIG51bWJlcnMgd2l0aCBsZXhpY29ncmFwaGljYWwgb3JkZXIgaW4gbWluZC5cbiAqXG4gKiBIb3dldmVyIC0gdW5saWtlIGxleGljb2dyYXBoaWNhbCBvcmRlciAtIGZvciBhcnJheXMgb2YgZGlmZmVyZW50IGxlbmd0aCB3ZSBjb25zaWRlcjpcbiAqIFsxLCAyLCAzXSA9IFsxLCAyLCAzLCAwXSBpbnN0ZWFkIG9mIFsxLCAyLCAzXSA8IFsxLCAyLCAzLCAwXVxuICpcbiAqIEBwYXJhbSBhIFRoZSAnbGVmdCBoYW5kJyBhcnJheSBpbiB0aGUgY29tcGFyaXNvbiB0ZXN0XG4gKiBAcGFyYW0gYiBUaGUgJ3JpZ2h0IGhhbmQnIGluIHRoZSBjb21wYXJpc29uIHRlc3RcbiAqIEByZXR1cm5zIHstMXwwfDF9IFRoZSBjb21wYXJpc29uIHJlc3VsdDogMSBpZiBhIGlzIGdyZWF0ZXIsIC0xIGlmIGIgaXMgZ3JlYXRlciwgMCBpcyB0aGUgdHdvXG4gKiBhcnJheXMgYXJlIGVxdWFsc1xuICovXG5leHBvcnQgZnVuY3Rpb24gY29tcGFyZU51bWJlcnMoYTogbnVtYmVyW10sIGI6IG51bWJlcltdKTogLTF8MHwxIHtcbiAgY29uc3QgbWF4ID0gTWF0aC5tYXgoYS5sZW5ndGgsIGIubGVuZ3RoKTtcbiAgY29uc3QgbWluID0gTWF0aC5taW4oYS5sZW5ndGgsIGIubGVuZ3RoKTtcblxuICBmb3IgKGxldCBpID0gMDsgaSA8IG1pbjsgaSsrKSB7XG4gICAgaWYgKGFbaV0gPiBiW2ldKSByZXR1cm4gMTtcbiAgICBpZiAoYVtpXSA8IGJbaV0pIHJldHVybiAtMTtcbiAgfVxuXG4gIGlmIChtaW4gIT09IG1heCkge1xuICAgIGNvbnN0IGxvbmdlc3RBcnJheSA9IGEubGVuZ3RoID09PSBtYXggPyBhIDogYjtcblxuICAgIC8vIFRoZSByZXN1bHQgdG8gcmV0dXJuIGluIGNhc2UgdGhlIHRvIGFycmF5cyBhcmUgY29uc2lkZXJlZCBkaWZmZXJlbnQgKDEgaWYgYSBpcyBncmVhdGVyLFxuICAgIC8vIC0xIGlmIGIgaXMgZ3JlYXRlcilcbiAgICBjb25zdCBjb21wYXJpc29uUmVzdWx0ID0gYS5sZW5ndGggPT09IG1heCA/IDEgOiAtMTtcblxuICAgIC8vIENoZWNrIHRoYXQgYXQgbGVhc3Qgb25lIG9mIHRoZSByZW1haW5pbmcgZWxlbWVudHMgaXMgZ3JlYXRlciB0aGFuIDAgdG8gY29uc2lkZXIgdGhhdCB0aGUgdHdvXG4gICAgLy8gYXJyYXlzIGFyZSBkaWZmZXJlbnQgKGUuZy4gWzEsIDBdIGFuZCBbMV0gYXJlIGNvbnNpZGVyZWQgdGhlIHNhbWUgYnV0IG5vdCBbMSwgMCwgMV0gYW5kIFsxXSlcbiAgICBmb3IgKGxldCBpID0gbWluOyBpIDwgbWF4OyBpKyspIHtcbiAgICAgIGlmIChsb25nZXN0QXJyYXlbaV0gPiAwKSB7XG4gICAgICAgIHJldHVybiBjb21wYXJpc29uUmVzdWx0O1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiAwO1xufVxuXG4vKipcbiAqIENoZWNrcyBpZiBhIFR5cGVTY3JpcHQgdmVyc2lvbiBpczpcbiAqIC0gZ3JlYXRlciBvciBlcXVhbCB0aGFuIHRoZSBwcm92aWRlZCBgbG93YCB2ZXJzaW9uLFxuICogLSBsb3dlciBvciBlcXVhbCB0aGFuIGFuIG9wdGlvbmFsIGBoaWdoYCB2ZXJzaW9uLlxuICpcbiAqIEBwYXJhbSB2ZXJzaW9uIFRoZSBUeXBlU2NyaXB0IHZlcnNpb25cbiAqIEBwYXJhbSBsb3cgVGhlIG1pbmltdW0gdmVyc2lvblxuICogQHBhcmFtIGhpZ2ggVGhlIG1heGltdW0gdmVyc2lvblxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNWZXJzaW9uQmV0d2Vlbih2ZXJzaW9uOiBzdHJpbmcsIGxvdzogc3RyaW5nLCBoaWdoPzogc3RyaW5nKTogYm9vbGVhbiB7XG4gIGNvbnN0IHRzTnVtYmVycyA9IHRvTnVtYmVycyh2ZXJzaW9uKTtcbiAgaWYgKGhpZ2ggIT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiBjb21wYXJlTnVtYmVycyh0b051bWJlcnMobG93KSwgdHNOdW1iZXJzKSA8PSAwICYmXG4gICAgICAgIGNvbXBhcmVOdW1iZXJzKHRvTnVtYmVycyhoaWdoKSwgdHNOdW1iZXJzKSA+PSAwO1xuICB9XG4gIHJldHVybiBjb21wYXJlTnVtYmVycyh0b051bWJlcnMobG93KSwgdHNOdW1iZXJzKSA8PSAwO1xufVxuXG4vKipcbiAqIENvbXBhcmVzIHR3byB2ZXJzaW9uc1xuICpcbiAqIEBwYXJhbSB2MSBUaGUgJ2xlZnQgaGFuZCcgdmVyc2lvbiBpbiB0aGUgY29tcGFyaXNvbiB0ZXN0XG4gKiBAcGFyYW0gdjIgVGhlICdyaWdodCBoYW5kJyB2ZXJzaW9uIGluIHRoZSBjb21wYXJpc29uIHRlc3RcbiAqIEByZXR1cm5zIHstMXwwfDF9IFRoZSBjb21wYXJpc29uIHJlc3VsdDogMSBpZiB2MSBpcyBncmVhdGVyLCAtMSBpZiB2MiBpcyBncmVhdGVyLCAwIGlzIHRoZSB0d29cbiAqIHZlcnNpb25zIGFyZSBlcXVhbHNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNvbXBhcmVWZXJzaW9ucyh2MTogc3RyaW5nLCB2Mjogc3RyaW5nKTogLTF8MHwxIHtcbiAgcmV0dXJuIGNvbXBhcmVOdW1iZXJzKHRvTnVtYmVycyh2MSksIHRvTnVtYmVycyh2MikpO1xufVxuIl19
@@ -5,42 +5,40 @@
5
5
  if (v !== undefined) module.exports = v;
6
6
  }
7
7
  else if (typeof define === "function" && define.amd) {
8
- define("@angular/compiler-cli/src/extract_i18n", ["require", "exports", "tslib", "reflect-metadata", "@angular/compiler-cli/src/transformers/api", "@angular/compiler-cli/src/main"], factory);
8
+ define("@angular/compiler-cli/src/extract_i18n", ["require", "exports", "reflect-metadata", "@angular/compiler-cli/src/transformers/api", "@angular/compiler-cli/src/main"], factory);
9
9
  }
10
10
  })(function (require, exports) {
11
11
  "use strict";
12
12
  Object.defineProperty(exports, "__esModule", { value: true });
13
- var tslib_1 = require("tslib");
14
13
  require("reflect-metadata");
15
- var api = require("@angular/compiler-cli/src/transformers/api");
16
- var main_1 = require("@angular/compiler-cli/src/main");
17
- function mainXi18n(args, consoleError) {
18
- if (consoleError === void 0) { consoleError = console.error; }
19
- var config = readXi18nCommandLineAndConfiguration(args);
14
+ const api = require("@angular/compiler-cli/src/transformers/api");
15
+ const main_1 = require("@angular/compiler-cli/src/main");
16
+ function mainXi18n(args, consoleError = console.error) {
17
+ const config = readXi18nCommandLineAndConfiguration(args);
20
18
  return main_1.main(args, consoleError, config);
21
19
  }
22
20
  exports.mainXi18n = mainXi18n;
23
21
  function readXi18nCommandLineAndConfiguration(args) {
24
- var options = {};
25
- var parsedArgs = require('minimist')(args);
22
+ const options = {};
23
+ const parsedArgs = require('minimist')(args);
26
24
  if (parsedArgs.outFile)
27
25
  options.i18nOutFile = parsedArgs.outFile;
28
26
  if (parsedArgs.i18nFormat)
29
27
  options.i18nOutFormat = parsedArgs.i18nFormat;
30
28
  if (parsedArgs.locale)
31
29
  options.i18nOutLocale = parsedArgs.locale;
32
- var config = main_1.readCommandLineAndConfiguration(args, options, [
30
+ const config = main_1.readCommandLineAndConfiguration(args, options, [
33
31
  'outFile',
34
32
  'i18nFormat',
35
33
  'locale',
36
34
  ]);
37
35
  // only emit the i18nBundle but nothing else.
38
- return tslib_1.__assign({}, config, { emitFlags: api.EmitFlags.I18nBundle });
36
+ return Object.assign({}, config, { emitFlags: api.EmitFlags.I18nBundle });
39
37
  }
40
38
  // Entry point
41
39
  if (require.main === module) {
42
- var args = process.argv.slice(2);
40
+ const args = process.argv.slice(2);
43
41
  process.exitCode = mainXi18n(args);
44
42
  }
45
43
  });
46
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXh0cmFjdF9pMThuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcGlsZXItY2xpL3NyYy9leHRyYWN0X2kxOG4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztJQWNBLDRCQUEwQjtJQUMxQixnRUFBMEM7SUFFMUMsdURBQTZEO0lBRTdELFNBQWdCLFNBQVMsQ0FDckIsSUFBYyxFQUFFLFlBQW1EO1FBQW5ELDZCQUFBLEVBQUEsZUFBc0MsT0FBTyxDQUFDLEtBQUs7UUFDckUsSUFBTSxNQUFNLEdBQUcsb0NBQW9DLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDMUQsT0FBTyxXQUFJLENBQUMsSUFBSSxFQUFFLFlBQVksRUFBRSxNQUFNLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBSkQsOEJBSUM7SUFFRCxTQUFTLG9DQUFvQyxDQUFDLElBQWM7UUFDMUQsSUFBTSxPQUFPLEdBQXdCLEVBQUUsQ0FBQztRQUN4QyxJQUFNLFVBQVUsR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDN0MsSUFBSSxVQUFVLENBQUMsT0FBTztZQUFFLE9BQU8sQ0FBQyxXQUFXLEdBQUcsVUFBVSxDQUFDLE9BQU8sQ0FBQztRQUNqRSxJQUFJLFVBQVUsQ0FBQyxVQUFVO1lBQUUsT0FBTyxDQUFDLGFBQWEsR0FBRyxVQUFVLENBQUMsVUFBVSxDQUFDO1FBQ3pFLElBQUksVUFBVSxDQUFDLE1BQU07WUFBRSxPQUFPLENBQUMsYUFBYSxHQUFHLFVBQVUsQ0FBQyxNQUFNLENBQUM7UUFFakUsSUFBTSxNQUFNLEdBQUcsc0NBQStCLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRTtZQUM1RCxTQUFTO1lBQ1QsWUFBWTtZQUNaLFFBQVE7U0FDVCxDQUFDLENBQUM7UUFDSCw2Q0FBNkM7UUFDN0MsNEJBQVcsTUFBTSxJQUFFLFNBQVMsRUFBRSxHQUFHLENBQUMsU0FBUyxDQUFDLFVBQVUsSUFBRTtJQUMxRCxDQUFDO0lBRUQsY0FBYztJQUNkLElBQUksT0FBTyxDQUFDLElBQUksS0FBSyxNQUFNLEVBQUU7UUFDM0IsSUFBTSxJQUFJLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDbkMsT0FBTyxDQUFDLFFBQVEsR0FBRyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUM7S0FDcEMiLCJzb3VyY2VzQ29udGVudCI6WyIjIS91c3IvYmluL2VudiBub2RlXG4vKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cblxuLyoqXG4gKiBFeHRyYWN0IGkxOG4gbWVzc2FnZXMgZnJvbSBzb3VyY2UgY29kZVxuICovXG4vLyBNdXN0IGJlIGltcG9ydGVkIGZpcnN0LCBiZWNhdXNlIEFuZ3VsYXIgZGVjb3JhdG9ycyB0aHJvdyBvbiBsb2FkLlxuaW1wb3J0ICdyZWZsZWN0LW1ldGFkYXRhJztcbmltcG9ydCAqIGFzIGFwaSBmcm9tICcuL3RyYW5zZm9ybWVycy9hcGknO1xuaW1wb3J0IHtQYXJzZWRDb25maWd1cmF0aW9ufSBmcm9tICcuL3BlcmZvcm1fY29tcGlsZSc7XG5pbXBvcnQge21haW4sIHJlYWRDb21tYW5kTGluZUFuZENvbmZpZ3VyYXRpb259IGZyb20gJy4vbWFpbic7XG5cbmV4cG9ydCBmdW5jdGlvbiBtYWluWGkxOG4oXG4gICAgYXJnczogc3RyaW5nW10sIGNvbnNvbGVFcnJvcjogKG1zZzogc3RyaW5nKSA9PiB2b2lkID0gY29uc29sZS5lcnJvcik6IG51bWJlciB7XG4gIGNvbnN0IGNvbmZpZyA9IHJlYWRYaTE4bkNvbW1hbmRMaW5lQW5kQ29uZmlndXJhdGlvbihhcmdzKTtcbiAgcmV0dXJuIG1haW4oYXJncywgY29uc29sZUVycm9yLCBjb25maWcpO1xufVxuXG5mdW5jdGlvbiByZWFkWGkxOG5Db21tYW5kTGluZUFuZENvbmZpZ3VyYXRpb24oYXJnczogc3RyaW5nW10pOiBQYXJzZWRDb25maWd1cmF0aW9uIHtcbiAgY29uc3Qgb3B0aW9uczogYXBpLkNvbXBpbGVyT3B0aW9ucyA9IHt9O1xuICBjb25zdCBwYXJzZWRBcmdzID0gcmVxdWlyZSgnbWluaW1pc3QnKShhcmdzKTtcbiAgaWYgKHBhcnNlZEFyZ3Mub3V0RmlsZSkgb3B0aW9ucy5pMThuT3V0RmlsZSA9IHBhcnNlZEFyZ3Mub3V0RmlsZTtcbiAgaWYgKHBhcnNlZEFyZ3MuaTE4bkZvcm1hdCkgb3B0aW9ucy5pMThuT3V0Rm9ybWF0ID0gcGFyc2VkQXJncy5pMThuRm9ybWF0O1xuICBpZiAocGFyc2VkQXJncy5sb2NhbGUpIG9wdGlvbnMuaTE4bk91dExvY2FsZSA9IHBhcnNlZEFyZ3MubG9jYWxlO1xuXG4gIGNvbnN0IGNvbmZpZyA9IHJlYWRDb21tYW5kTGluZUFuZENvbmZpZ3VyYXRpb24oYXJncywgb3B0aW9ucywgW1xuICAgICdvdXRGaWxlJyxcbiAgICAnaTE4bkZvcm1hdCcsXG4gICAgJ2xvY2FsZScsXG4gIF0pO1xuICAvLyBvbmx5IGVtaXQgdGhlIGkxOG5CdW5kbGUgYnV0IG5vdGhpbmcgZWxzZS5cbiAgcmV0dXJuIHsuLi5jb25maWcsIGVtaXRGbGFnczogYXBpLkVtaXRGbGFncy5JMThuQnVuZGxlfTtcbn1cblxuLy8gRW50cnkgcG9pbnRcbmlmIChyZXF1aXJlLm1haW4gPT09IG1vZHVsZSkge1xuICBjb25zdCBhcmdzID0gcHJvY2Vzcy5hcmd2LnNsaWNlKDIpO1xuICBwcm9jZXNzLmV4aXRDb2RlID0gbWFpblhpMThuKGFyZ3MpO1xufVxuIl19
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXh0cmFjdF9pMThuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcGlsZXItY2xpL3NyYy9leHRyYWN0X2kxOG4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0lBY0EsNEJBQTBCO0lBQzFCLGtFQUEwQztJQUUxQyx5REFBNkQ7SUFFN0QsU0FBZ0IsU0FBUyxDQUNyQixJQUFjLEVBQUUsZUFBc0MsT0FBTyxDQUFDLEtBQUs7UUFDckUsTUFBTSxNQUFNLEdBQUcsb0NBQW9DLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDMUQsT0FBTyxXQUFJLENBQUMsSUFBSSxFQUFFLFlBQVksRUFBRSxNQUFNLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBSkQsOEJBSUM7SUFFRCxTQUFTLG9DQUFvQyxDQUFDLElBQWM7UUFDMUQsTUFBTSxPQUFPLEdBQXdCLEVBQUUsQ0FBQztRQUN4QyxNQUFNLFVBQVUsR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDN0MsSUFBSSxVQUFVLENBQUMsT0FBTztZQUFFLE9BQU8sQ0FBQyxXQUFXLEdBQUcsVUFBVSxDQUFDLE9BQU8sQ0FBQztRQUNqRSxJQUFJLFVBQVUsQ0FBQyxVQUFVO1lBQUUsT0FBTyxDQUFDLGFBQWEsR0FBRyxVQUFVLENBQUMsVUFBVSxDQUFDO1FBQ3pFLElBQUksVUFBVSxDQUFDLE1BQU07WUFBRSxPQUFPLENBQUMsYUFBYSxHQUFHLFVBQVUsQ0FBQyxNQUFNLENBQUM7UUFFakUsTUFBTSxNQUFNLEdBQUcsc0NBQStCLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRTtZQUM1RCxTQUFTO1lBQ1QsWUFBWTtZQUNaLFFBQVE7U0FDVCxDQUFDLENBQUM7UUFDSCw2Q0FBNkM7UUFDN0MseUJBQVcsTUFBTSxJQUFFLFNBQVMsRUFBRSxHQUFHLENBQUMsU0FBUyxDQUFDLFVBQVUsSUFBRTtJQUMxRCxDQUFDO0lBRUQsY0FBYztJQUNkLElBQUksT0FBTyxDQUFDLElBQUksS0FBSyxNQUFNLEVBQUU7UUFDM0IsTUFBTSxJQUFJLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDbkMsT0FBTyxDQUFDLFFBQVEsR0FBRyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUM7S0FDcEMiLCJzb3VyY2VzQ29udGVudCI6WyIjIS91c3IvYmluL2VudiBub2RlXG4vKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cblxuLyoqXG4gKiBFeHRyYWN0IGkxOG4gbWVzc2FnZXMgZnJvbSBzb3VyY2UgY29kZVxuICovXG4vLyBNdXN0IGJlIGltcG9ydGVkIGZpcnN0LCBiZWNhdXNlIEFuZ3VsYXIgZGVjb3JhdG9ycyB0aHJvdyBvbiBsb2FkLlxuaW1wb3J0ICdyZWZsZWN0LW1ldGFkYXRhJztcbmltcG9ydCAqIGFzIGFwaSBmcm9tICcuL3RyYW5zZm9ybWVycy9hcGknO1xuaW1wb3J0IHtQYXJzZWRDb25maWd1cmF0aW9ufSBmcm9tICcuL3BlcmZvcm1fY29tcGlsZSc7XG5pbXBvcnQge21haW4sIHJlYWRDb21tYW5kTGluZUFuZENvbmZpZ3VyYXRpb259IGZyb20gJy4vbWFpbic7XG5cbmV4cG9ydCBmdW5jdGlvbiBtYWluWGkxOG4oXG4gICAgYXJnczogc3RyaW5nW10sIGNvbnNvbGVFcnJvcjogKG1zZzogc3RyaW5nKSA9PiB2b2lkID0gY29uc29sZS5lcnJvcik6IG51bWJlciB7XG4gIGNvbnN0IGNvbmZpZyA9IHJlYWRYaTE4bkNvbW1hbmRMaW5lQW5kQ29uZmlndXJhdGlvbihhcmdzKTtcbiAgcmV0dXJuIG1haW4oYXJncywgY29uc29sZUVycm9yLCBjb25maWcpO1xufVxuXG5mdW5jdGlvbiByZWFkWGkxOG5Db21tYW5kTGluZUFuZENvbmZpZ3VyYXRpb24oYXJnczogc3RyaW5nW10pOiBQYXJzZWRDb25maWd1cmF0aW9uIHtcbiAgY29uc3Qgb3B0aW9uczogYXBpLkNvbXBpbGVyT3B0aW9ucyA9IHt9O1xuICBjb25zdCBwYXJzZWRBcmdzID0gcmVxdWlyZSgnbWluaW1pc3QnKShhcmdzKTtcbiAgaWYgKHBhcnNlZEFyZ3Mub3V0RmlsZSkgb3B0aW9ucy5pMThuT3V0RmlsZSA9IHBhcnNlZEFyZ3Mub3V0RmlsZTtcbiAgaWYgKHBhcnNlZEFyZ3MuaTE4bkZvcm1hdCkgb3B0aW9ucy5pMThuT3V0Rm9ybWF0ID0gcGFyc2VkQXJncy5pMThuRm9ybWF0O1xuICBpZiAocGFyc2VkQXJncy5sb2NhbGUpIG9wdGlvbnMuaTE4bk91dExvY2FsZSA9IHBhcnNlZEFyZ3MubG9jYWxlO1xuXG4gIGNvbnN0IGNvbmZpZyA9IHJlYWRDb21tYW5kTGluZUFuZENvbmZpZ3VyYXRpb24oYXJncywgb3B0aW9ucywgW1xuICAgICdvdXRGaWxlJyxcbiAgICAnaTE4bkZvcm1hdCcsXG4gICAgJ2xvY2FsZScsXG4gIF0pO1xuICAvLyBvbmx5IGVtaXQgdGhlIGkxOG5CdW5kbGUgYnV0IG5vdGhpbmcgZWxzZS5cbiAgcmV0dXJuIHsuLi5jb25maWcsIGVtaXRGbGFnczogYXBpLkVtaXRGbGFncy5JMThuQnVuZGxlfTtcbn1cblxuLy8gRW50cnkgcG9pbnRcbmlmIChyZXF1aXJlLm1haW4gPT09IG1vZHVsZSkge1xuICBjb25zdCBhcmdzID0gcHJvY2Vzcy5hcmd2LnNsaWNlKDIpO1xuICBwcm9jZXNzLmV4aXRDb2RlID0gbWFpblhpMThuKGFyZ3MpO1xufVxuIl19
package/src/main.js CHANGED
@@ -5,51 +5,49 @@
5
5
  if (v !== undefined) module.exports = v;
6
6
  }
7
7
  else if (typeof define === "function" && define.amd) {
8
- define("@angular/compiler-cli/src/main", ["require", "exports", "tslib", "reflect-metadata", "typescript", "@angular/compiler-cli/src/ngtsc/diagnostics", "@angular/compiler-cli/src/transformers/api", "@angular/compiler-cli/src/transformers/util", "@angular/compiler-cli/src/perform_compile", "@angular/compiler-cli/src/perform_watch"], factory);
8
+ define("@angular/compiler-cli/src/main", ["require", "exports", "reflect-metadata", "typescript", "@angular/compiler-cli/src/ngtsc/diagnostics", "@angular/compiler-cli/src/transformers/api", "@angular/compiler-cli/src/transformers/util", "@angular/compiler-cli/src/perform_compile", "@angular/compiler-cli/src/perform_watch"], factory);
9
9
  }
10
10
  })(function (require, exports) {
11
11
  "use strict";
12
12
  Object.defineProperty(exports, "__esModule", { value: true });
13
- var tslib_1 = require("tslib");
14
13
  require("reflect-metadata");
15
- var ts = require("typescript");
16
- var diagnostics_1 = require("@angular/compiler-cli/src/ngtsc/diagnostics");
17
- var api = require("@angular/compiler-cli/src/transformers/api");
18
- var util_1 = require("@angular/compiler-cli/src/transformers/util");
19
- var perform_compile_1 = require("@angular/compiler-cli/src/perform_compile");
20
- var perform_watch_1 = require("@angular/compiler-cli/src/perform_watch");
21
- function main(args, consoleError, config, customTransformers) {
22
- if (consoleError === void 0) { consoleError = console.error; }
23
- var _a = config || readNgcCommandLineAndConfiguration(args), project = _a.project, rootNames = _a.rootNames, options = _a.options, configErrors = _a.errors, watch = _a.watch, emitFlags = _a.emitFlags;
14
+ const ts = require("typescript");
15
+ const diagnostics_1 = require("@angular/compiler-cli/src/ngtsc/diagnostics");
16
+ const api = require("@angular/compiler-cli/src/transformers/api");
17
+ const util_1 = require("@angular/compiler-cli/src/transformers/util");
18
+ const perform_compile_1 = require("@angular/compiler-cli/src/perform_compile");
19
+ const perform_watch_1 = require("@angular/compiler-cli/src/perform_watch");
20
+ function main(args, consoleError = console.error, config, customTransformers) {
21
+ let { project, rootNames, options, errors: configErrors, watch, emitFlags } = config || readNgcCommandLineAndConfiguration(args);
24
22
  if (configErrors.length) {
25
23
  return reportErrorsAndExit(configErrors, /*options*/ undefined, consoleError);
26
24
  }
27
25
  if (watch) {
28
- var result = watchMode(project, options, consoleError);
26
+ const result = watchMode(project, options, consoleError);
29
27
  return reportErrorsAndExit(result.firstCompileResult, options, consoleError);
30
28
  }
31
- var compileDiags = perform_compile_1.performCompilation({
32
- rootNames: rootNames,
33
- options: options,
34
- emitFlags: emitFlags,
35
- emitCallback: createEmitCallback(options), customTransformers: customTransformers
36
- }).diagnostics;
29
+ const { diagnostics: compileDiags } = perform_compile_1.performCompilation({
30
+ rootNames,
31
+ options,
32
+ emitFlags,
33
+ emitCallback: createEmitCallback(options), customTransformers
34
+ });
37
35
  return reportErrorsAndExit(compileDiags, options, consoleError);
38
36
  }
39
37
  exports.main = main;
40
38
  function mainDiagnosticsForTest(args, config) {
41
- var _a = config || readNgcCommandLineAndConfiguration(args), project = _a.project, rootNames = _a.rootNames, options = _a.options, configErrors = _a.errors, watch = _a.watch, emitFlags = _a.emitFlags;
39
+ let { project, rootNames, options, errors: configErrors, watch, emitFlags } = config || readNgcCommandLineAndConfiguration(args);
42
40
  if (configErrors.length) {
43
41
  return configErrors;
44
42
  }
45
- var compileDiags = perform_compile_1.performCompilation({ rootNames: rootNames, options: options, emitFlags: emitFlags, emitCallback: createEmitCallback(options) }).diagnostics;
43
+ const { diagnostics: compileDiags } = perform_compile_1.performCompilation({ rootNames, options, emitFlags, emitCallback: createEmitCallback(options) });
46
44
  return compileDiags;
47
45
  }
48
46
  exports.mainDiagnosticsForTest = mainDiagnosticsForTest;
49
47
  function createEmitCallback(options) {
50
- var transformDecorators = options.enableIvy !== 'ngtsc' && options.enableIvy !== 'tsc' &&
48
+ const transformDecorators = options.enableIvy !== 'ngtsc' && options.enableIvy !== 'tsc' &&
51
49
  options.annotationsAs !== 'decorators';
52
- var transformTypesToClosure = options.annotateForClosureCompiler;
50
+ const transformTypesToClosure = options.annotateForClosureCompiler;
53
51
  if (!transformDecorators && !transformTypesToClosure) {
54
52
  return undefined;
55
53
  }
@@ -59,99 +57,103 @@
59
57
  // as TypeScript elided the import.
60
58
  options.emitDecoratorMetadata = true;
61
59
  }
62
- var tsickleHost = {
63
- shouldSkipTsickleProcessing: function (fileName) {
64
- return /\.d\.ts$/.test(fileName) || util_1.GENERATED_FILES.test(fileName);
65
- },
66
- pathToModuleName: function (context, importPath) { return ''; },
67
- shouldIgnoreWarningsForPath: function (filePath) { return false; },
68
- fileNameToModuleId: function (fileName) { return fileName; },
60
+ const tsickleHost = {
61
+ shouldSkipTsickleProcessing: (fileName) => /\.d\.ts$/.test(fileName) || util_1.GENERATED_FILES.test(fileName),
62
+ pathToModuleName: (context, importPath) => '',
63
+ shouldIgnoreWarningsForPath: (filePath) => false,
64
+ fileNameToModuleId: (fileName) => fileName,
69
65
  googmodule: false,
70
66
  untyped: true,
71
- convertIndexImportShorthand: false, transformDecorators: transformDecorators, transformTypesToClosure: transformTypesToClosure,
67
+ convertIndexImportShorthand: false, transformDecorators, transformTypesToClosure,
72
68
  };
73
69
  if (options.annotateForClosureCompiler || options.annotationsAs === 'static fields') {
74
- return function (_a) {
75
- var program = _a.program, targetSourceFile = _a.targetSourceFile, writeFile = _a.writeFile, cancellationToken = _a.cancellationToken, emitOnlyDtsFiles = _a.emitOnlyDtsFiles, _b = _a.customTransformers, customTransformers = _b === void 0 ? {} : _b, host = _a.host, options = _a.options;
76
- // tslint:disable-next-line:no-require-imports only depend on tsickle if requested
77
- return require('tsickle').emitWithTsickle(program, tslib_1.__assign({}, tsickleHost, { options: options, host: host }), host, options, targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, {
78
- beforeTs: customTransformers.before,
79
- afterTs: customTransformers.after,
80
- });
81
- };
70
+ return ({ program, targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, customTransformers = {}, host, options }) =>
71
+ // tslint:disable-next-line:no-require-imports only depend on tsickle if requested
72
+ require('tsickle').emitWithTsickle(program, Object.assign({}, tsickleHost, { options, host }), host, options, targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, {
73
+ beforeTs: customTransformers.before,
74
+ afterTs: customTransformers.after,
75
+ });
82
76
  }
83
77
  else {
84
- return function (_a) {
85
- var program = _a.program, targetSourceFile = _a.targetSourceFile, writeFile = _a.writeFile, cancellationToken = _a.cancellationToken, emitOnlyDtsFiles = _a.emitOnlyDtsFiles, _b = _a.customTransformers, customTransformers = _b === void 0 ? {} : _b;
86
- return program.emit(targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, { after: customTransformers.after, before: customTransformers.before });
87
- };
78
+ return ({ program, targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, customTransformers = {}, }) => program.emit(targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, { after: customTransformers.after, before: customTransformers.before });
88
79
  }
89
80
  }
90
81
  function readNgcCommandLineAndConfiguration(args) {
91
- var options = {};
92
- var parsedArgs = require('minimist')(args);
82
+ const options = {};
83
+ const parsedArgs = require('minimist')(args);
93
84
  if (parsedArgs.i18nFile)
94
85
  options.i18nInFile = parsedArgs.i18nFile;
95
86
  if (parsedArgs.i18nFormat)
96
87
  options.i18nInFormat = parsedArgs.i18nFormat;
97
88
  if (parsedArgs.locale)
98
89
  options.i18nInLocale = parsedArgs.locale;
99
- var mt = parsedArgs.missingTranslation;
90
+ const mt = parsedArgs.missingTranslation;
100
91
  if (mt === 'error' || mt === 'warning' || mt === 'ignore') {
101
92
  options.i18nInMissingTranslations = mt;
102
93
  }
103
- var config = readCommandLineAndConfiguration(args, options, ['i18nFile', 'i18nFormat', 'locale', 'missingTranslation', 'watch']);
104
- var watch = parsedArgs.w || parsedArgs.watch;
105
- return tslib_1.__assign({}, config, { watch: watch });
94
+ const config = readCommandLineAndConfiguration(args, options, ['i18nFile', 'i18nFormat', 'locale', 'missingTranslation', 'watch']);
95
+ const watch = parsedArgs.w || parsedArgs.watch;
96
+ return Object.assign({}, config, { watch });
106
97
  }
107
- function readCommandLineAndConfiguration(args, existingOptions, ngCmdLineOptions) {
108
- if (existingOptions === void 0) { existingOptions = {}; }
109
- if (ngCmdLineOptions === void 0) { ngCmdLineOptions = []; }
110
- var cmdConfig = ts.parseCommandLine(args);
111
- var project = cmdConfig.options.project || '.';
112
- var cmdErrors = cmdConfig.errors.filter(function (e) {
98
+ function readCommandLineAndConfiguration(args, existingOptions = {}, ngCmdLineOptions = []) {
99
+ let cmdConfig = ts.parseCommandLine(args);
100
+ const project = cmdConfig.options.project || '.';
101
+ const cmdErrors = cmdConfig.errors.filter(e => {
113
102
  if (typeof e.messageText === 'string') {
114
- var msg_1 = e.messageText;
115
- return !ngCmdLineOptions.some(function (o) { return msg_1.indexOf(o) >= 0; });
103
+ const msg = e.messageText;
104
+ return !ngCmdLineOptions.some(o => msg.indexOf(o) >= 0);
116
105
  }
117
106
  return true;
118
107
  });
119
108
  if (cmdErrors.length) {
120
109
  return {
121
- project: project,
110
+ project,
122
111
  rootNames: [],
123
112
  options: cmdConfig.options,
124
113
  errors: cmdErrors,
125
114
  emitFlags: api.EmitFlags.Default
126
115
  };
127
116
  }
128
- var allDiagnostics = [];
129
- var config = perform_compile_1.readConfiguration(project, cmdConfig.options);
130
- var options = tslib_1.__assign({}, config.options, existingOptions);
117
+ const allDiagnostics = [];
118
+ const config = perform_compile_1.readConfiguration(project, cmdConfig.options);
119
+ const options = Object.assign({}, config.options, existingOptions);
131
120
  if (options.locale) {
132
121
  options.i18nInLocale = options.locale;
133
122
  }
134
123
  return {
135
- project: project,
136
- rootNames: config.rootNames, options: options,
124
+ project,
125
+ rootNames: config.rootNames, options,
137
126
  errors: config.errors,
138
127
  emitFlags: config.emitFlags
139
128
  };
140
129
  }
141
130
  exports.readCommandLineAndConfiguration = readCommandLineAndConfiguration;
142
- function reportErrorsAndExit(allDiagnostics, options, consoleError) {
143
- if (consoleError === void 0) { consoleError = console.error; }
144
- var errorsAndWarnings = perform_compile_1.filterErrorsAndWarnings(allDiagnostics);
131
+ function getFormatDiagnosticsHost(options) {
132
+ const basePath = options ? options.basePath : undefined;
133
+ return {
134
+ getCurrentDirectory: () => basePath || ts.sys.getCurrentDirectory(),
135
+ // We need to normalize the path separators here because by default, TypeScript
136
+ // compiler hosts use posix canonical paths. In order to print consistent diagnostics,
137
+ // we also normalize the paths.
138
+ getCanonicalFileName: fileName => fileName.replace(/\\/g, '/'),
139
+ getNewLine: () => {
140
+ // Manually determine the proper new line string based on the passed compiler
141
+ // options. There is no public TypeScript function that returns the corresponding
142
+ // new line string. see: https://github.com/Microsoft/TypeScript/issues/29581
143
+ if (options && options.newLine !== undefined) {
144
+ return options.newLine === ts.NewLineKind.LineFeed ? '\n' : '\r\n';
145
+ }
146
+ return ts.sys.newLine;
147
+ },
148
+ };
149
+ }
150
+ function reportErrorsAndExit(allDiagnostics, options, consoleError = console.error) {
151
+ const errorsAndWarnings = perform_compile_1.filterErrorsAndWarnings(allDiagnostics);
145
152
  if (errorsAndWarnings.length) {
146
- var currentDir_1 = options ? options.basePath : undefined;
147
- var formatHost = {
148
- getCurrentDirectory: function () { return currentDir_1 || ts.sys.getCurrentDirectory(); },
149
- getCanonicalFileName: function (fileName) { return fileName; },
150
- getNewLine: function () { return ts.sys.newLine; }
151
- };
153
+ const formatHost = getFormatDiagnosticsHost(options);
152
154
  if (options && (options.enableIvy === true || options.enableIvy === 'ngtsc')) {
153
- var ngDiagnostics = errorsAndWarnings.filter(api.isNgDiagnostic);
154
- var tsDiagnostics = errorsAndWarnings.filter(api.isTsDiagnostic);
155
+ const ngDiagnostics = errorsAndWarnings.filter(api.isNgDiagnostic);
156
+ const tsDiagnostics = errorsAndWarnings.filter(api.isTsDiagnostic);
155
157
  consoleError(diagnostics_1.replaceTsWithNgInErrors(ts.formatDiagnosticsWithColorAndContext(tsDiagnostics, formatHost)));
156
158
  consoleError(perform_compile_1.formatDiagnostics(ngDiagnostics, formatHost));
157
159
  }
@@ -162,15 +164,15 @@
162
164
  return perform_compile_1.exitCodeFromResult(allDiagnostics);
163
165
  }
164
166
  function watchMode(project, options, consoleError) {
165
- return perform_watch_1.performWatchCompilation(perform_watch_1.createPerformWatchHost(project, function (diagnostics) {
166
- consoleError(perform_compile_1.formatDiagnostics(diagnostics));
167
- }, options, function (options) { return createEmitCallback(options); }));
167
+ return perform_watch_1.performWatchCompilation(perform_watch_1.createPerformWatchHost(project, diagnostics => {
168
+ consoleError(perform_compile_1.formatDiagnostics(diagnostics, getFormatDiagnosticsHost(options)));
169
+ }, options, options => createEmitCallback(options)));
168
170
  }
169
171
  exports.watchMode = watchMode;
170
172
  // CLI entry point
171
173
  if (require.main === module) {
172
- var args = process.argv.slice(2);
174
+ const args = process.argv.slice(2);
173
175
  process.exitCode = main(args);
174
176
  }
175
177
  });
176
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main.js","sourceRoot":"","sources":["../../../../../../packages/compiler-cli/src/main.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n/**\n * @license\n * Copyright Google Inc. 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\n// Must be imported first, because Angular decorators throw on load.\nimport 'reflect-metadata';\n\nimport * as ts from 'typescript';\nimport * as tsickle from 'tsickle';\n\nimport {replaceTsWithNgInErrors} from './ngtsc/diagnostics';\nimport * as api from './transformers/api';\nimport {GENERATED_FILES} from './transformers/util';\n\nimport {exitCodeFromResult, performCompilation, readConfiguration, formatDiagnostics, Diagnostics, ParsedConfiguration, PerformCompilationResult, filterErrorsAndWarnings} from './perform_compile';\nimport {performWatchCompilation, createPerformWatchHost} from './perform_watch';\n\nexport function main(\n    args: string[], consoleError: (s: string) => void = console.error,\n    config?: NgcParsedConfiguration, customTransformers?: api.CustomTransformers): number {\n  let {project, rootNames, options, errors: configErrors, watch, emitFlags} =\n      config || readNgcCommandLineAndConfiguration(args);\n  if (configErrors.length) {\n    return reportErrorsAndExit(configErrors, /*options*/ undefined, consoleError);\n  }\n  if (watch) {\n    const result = watchMode(project, options, consoleError);\n    return reportErrorsAndExit(result.firstCompileResult, options, consoleError);\n  }\n  const {diagnostics: compileDiags} = performCompilation({\n    rootNames,\n    options,\n    emitFlags,\n    emitCallback: createEmitCallback(options), customTransformers\n  });\n  return reportErrorsAndExit(compileDiags, options, consoleError);\n}\n\nexport function mainDiagnosticsForTest(\n    args: string[], config?: NgcParsedConfiguration): ReadonlyArray<ts.Diagnostic|api.Diagnostic> {\n  let {project, rootNames, options, errors: configErrors, watch, emitFlags} =\n      config || readNgcCommandLineAndConfiguration(args);\n  if (configErrors.length) {\n    return configErrors;\n  }\n  const {diagnostics: compileDiags} = performCompilation(\n      {rootNames, options, emitFlags, emitCallback: createEmitCallback(options)});\n  return compileDiags;\n}\n\nfunction createEmitCallback(options: api.CompilerOptions): api.TsEmitCallback|undefined {\n  const transformDecorators = options.enableIvy !== 'ngtsc' && options.enableIvy !== 'tsc' &&\n      options.annotationsAs !== 'decorators';\n  const transformTypesToClosure = options.annotateForClosureCompiler;\n  if (!transformDecorators && !transformTypesToClosure) {\n    return undefined;\n  }\n  if (transformDecorators) {\n    // This is needed as a workaround for https://github.com/angular/tsickle/issues/635\n    // Otherwise tsickle might emit references to non imported values\n    // as TypeScript elided the import.\n    options.emitDecoratorMetadata = true;\n  }\n  const tsickleHost: Pick<\n      tsickle.TsickleHost, 'shouldSkipTsickleProcessing'|'pathToModuleName'|\n      'shouldIgnoreWarningsForPath'|'fileNameToModuleId'|'googmodule'|'untyped'|\n      'convertIndexImportShorthand'|'transformDecorators'|'transformTypesToClosure'> = {\n    shouldSkipTsickleProcessing: (fileName) =>\n                                     /\\.d\\.ts$/.test(fileName) || GENERATED_FILES.test(fileName),\n    pathToModuleName: (context, importPath) => '',\n    shouldIgnoreWarningsForPath: (filePath) => false,\n    fileNameToModuleId: (fileName) => fileName,\n    googmodule: false,\n    untyped: true,\n    convertIndexImportShorthand: false, transformDecorators, transformTypesToClosure,\n  };\n\n  if (options.annotateForClosureCompiler || options.annotationsAs === 'static fields') {\n    return ({\n             program,\n             targetSourceFile,\n             writeFile,\n             cancellationToken,\n             emitOnlyDtsFiles,\n             customTransformers = {},\n             host,\n             options\n           }) =>\n               // tslint:disable-next-line:no-require-imports only depend on tsickle if requested\n        require('tsickle').emitWithTsickle(\n            program, {...tsickleHost, options, host}, host, options, targetSourceFile, writeFile,\n            cancellationToken, emitOnlyDtsFiles, {\n              beforeTs: customTransformers.before,\n              afterTs: customTransformers.after,\n            });\n  } else {\n    return ({\n             program,\n             targetSourceFile,\n             writeFile,\n             cancellationToken,\n             emitOnlyDtsFiles,\n             customTransformers = {},\n           }) =>\n               program.emit(\n                   targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles,\n                   {after: customTransformers.after, before: customTransformers.before});\n  }\n}\n\nexport interface NgcParsedConfiguration extends ParsedConfiguration { watch?: boolean; }\n\nfunction readNgcCommandLineAndConfiguration(args: string[]): NgcParsedConfiguration {\n  const options: api.CompilerOptions = {};\n  const parsedArgs = require('minimist')(args);\n  if (parsedArgs.i18nFile) options.i18nInFile = parsedArgs.i18nFile;\n  if (parsedArgs.i18nFormat) options.i18nInFormat = parsedArgs.i18nFormat;\n  if (parsedArgs.locale) options.i18nInLocale = parsedArgs.locale;\n  const mt = parsedArgs.missingTranslation;\n  if (mt === 'error' || mt === 'warning' || mt === 'ignore') {\n    options.i18nInMissingTranslations = mt;\n  }\n  const config = readCommandLineAndConfiguration(\n      args, options, ['i18nFile', 'i18nFormat', 'locale', 'missingTranslation', 'watch']);\n  const watch = parsedArgs.w || parsedArgs.watch;\n  return {...config, watch};\n}\n\nexport function readCommandLineAndConfiguration(\n    args: string[], existingOptions: api.CompilerOptions = {},\n    ngCmdLineOptions: string[] = []): ParsedConfiguration {\n  let cmdConfig = ts.parseCommandLine(args);\n  const project = cmdConfig.options.project || '.';\n  const cmdErrors = cmdConfig.errors.filter(e => {\n    if (typeof e.messageText === 'string') {\n      const msg = e.messageText;\n      return !ngCmdLineOptions.some(o => msg.indexOf(o) >= 0);\n    }\n    return true;\n  });\n  if (cmdErrors.length) {\n    return {\n      project,\n      rootNames: [],\n      options: cmdConfig.options,\n      errors: cmdErrors,\n      emitFlags: api.EmitFlags.Default\n    };\n  }\n  const allDiagnostics: Diagnostics = [];\n  const config = readConfiguration(project, cmdConfig.options);\n  const options = {...config.options, ...existingOptions};\n  if (options.locale) {\n    options.i18nInLocale = options.locale;\n  }\n  return {\n    project,\n    rootNames: config.rootNames, options,\n    errors: config.errors,\n    emitFlags: config.emitFlags\n  };\n}\n\nfunction reportErrorsAndExit(\n    allDiagnostics: Diagnostics, options?: api.CompilerOptions,\n    consoleError: (s: string) => void = console.error): number {\n  const errorsAndWarnings = filterErrorsAndWarnings(allDiagnostics);\n  if (errorsAndWarnings.length) {\n    let currentDir = options ? options.basePath : undefined;\n    const formatHost: ts.FormatDiagnosticsHost = {\n      getCurrentDirectory: () => currentDir || ts.sys.getCurrentDirectory(),\n      getCanonicalFileName: fileName => fileName,\n      getNewLine: () => ts.sys.newLine\n    };\n    if (options && (options.enableIvy === true || options.enableIvy === 'ngtsc')) {\n      const ngDiagnostics = errorsAndWarnings.filter(api.isNgDiagnostic);\n      const tsDiagnostics = errorsAndWarnings.filter(api.isTsDiagnostic);\n      consoleError(replaceTsWithNgInErrors(\n          ts.formatDiagnosticsWithColorAndContext(tsDiagnostics, formatHost)));\n      consoleError(formatDiagnostics(ngDiagnostics, formatHost));\n    } else {\n      consoleError(formatDiagnostics(errorsAndWarnings, formatHost));\n    }\n  }\n  return exitCodeFromResult(allDiagnostics);\n}\n\nexport function watchMode(\n    project: string, options: api.CompilerOptions, consoleError: (s: string) => void) {\n  return performWatchCompilation(createPerformWatchHost(project, diagnostics => {\n    consoleError(formatDiagnostics(diagnostics));\n  }, options, options => createEmitCallback(options)));\n}\n\n// CLI entry point\nif (require.main === module) {\n  const args = process.argv.slice(2);\n  process.exitCode = main(args);\n}\n"]}
178
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main.js","sourceRoot":"","sources":["../../../../../../packages/compiler-cli/src/main.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n/**\n * @license\n * Copyright Google Inc. 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\n// Must be imported first, because Angular decorators throw on load.\nimport 'reflect-metadata';\n\nimport * as ts from 'typescript';\nimport * as tsickle from 'tsickle';\n\nimport {replaceTsWithNgInErrors} from './ngtsc/diagnostics';\nimport * as api from './transformers/api';\nimport {GENERATED_FILES} from './transformers/util';\n\nimport {exitCodeFromResult, performCompilation, readConfiguration, formatDiagnostics, Diagnostics, ParsedConfiguration, PerformCompilationResult, filterErrorsAndWarnings} from './perform_compile';\nimport {performWatchCompilation, createPerformWatchHost} from './perform_watch';\n\nexport function main(\n    args: string[], consoleError: (s: string) => void = console.error,\n    config?: NgcParsedConfiguration, customTransformers?: api.CustomTransformers): number {\n  let {project, rootNames, options, errors: configErrors, watch, emitFlags} =\n      config || readNgcCommandLineAndConfiguration(args);\n  if (configErrors.length) {\n    return reportErrorsAndExit(configErrors, /*options*/ undefined, consoleError);\n  }\n  if (watch) {\n    const result = watchMode(project, options, consoleError);\n    return reportErrorsAndExit(result.firstCompileResult, options, consoleError);\n  }\n  const {diagnostics: compileDiags} = performCompilation({\n    rootNames,\n    options,\n    emitFlags,\n    emitCallback: createEmitCallback(options), customTransformers\n  });\n  return reportErrorsAndExit(compileDiags, options, consoleError);\n}\n\nexport function mainDiagnosticsForTest(\n    args: string[], config?: NgcParsedConfiguration): ReadonlyArray<ts.Diagnostic|api.Diagnostic> {\n  let {project, rootNames, options, errors: configErrors, watch, emitFlags} =\n      config || readNgcCommandLineAndConfiguration(args);\n  if (configErrors.length) {\n    return configErrors;\n  }\n  const {diagnostics: compileDiags} = performCompilation(\n      {rootNames, options, emitFlags, emitCallback: createEmitCallback(options)});\n  return compileDiags;\n}\n\nfunction createEmitCallback(options: api.CompilerOptions): api.TsEmitCallback|undefined {\n  const transformDecorators = options.enableIvy !== 'ngtsc' && options.enableIvy !== 'tsc' &&\n      options.annotationsAs !== 'decorators';\n  const transformTypesToClosure = options.annotateForClosureCompiler;\n  if (!transformDecorators && !transformTypesToClosure) {\n    return undefined;\n  }\n  if (transformDecorators) {\n    // This is needed as a workaround for https://github.com/angular/tsickle/issues/635\n    // Otherwise tsickle might emit references to non imported values\n    // as TypeScript elided the import.\n    options.emitDecoratorMetadata = true;\n  }\n  const tsickleHost: Pick<\n      tsickle.TsickleHost, 'shouldSkipTsickleProcessing'|'pathToModuleName'|\n      'shouldIgnoreWarningsForPath'|'fileNameToModuleId'|'googmodule'|'untyped'|\n      'convertIndexImportShorthand'|'transformDecorators'|'transformTypesToClosure'> = {\n    shouldSkipTsickleProcessing: (fileName) =>\n                                     /\\.d\\.ts$/.test(fileName) || GENERATED_FILES.test(fileName),\n    pathToModuleName: (context, importPath) => '',\n    shouldIgnoreWarningsForPath: (filePath) => false,\n    fileNameToModuleId: (fileName) => fileName,\n    googmodule: false,\n    untyped: true,\n    convertIndexImportShorthand: false, transformDecorators, transformTypesToClosure,\n  };\n\n  if (options.annotateForClosureCompiler || options.annotationsAs === 'static fields') {\n    return ({\n             program,\n             targetSourceFile,\n             writeFile,\n             cancellationToken,\n             emitOnlyDtsFiles,\n             customTransformers = {},\n             host,\n             options\n           }) =>\n               // tslint:disable-next-line:no-require-imports only depend on tsickle if requested\n        require('tsickle').emitWithTsickle(\n            program, {...tsickleHost, options, host}, host, options, targetSourceFile, writeFile,\n            cancellationToken, emitOnlyDtsFiles, {\n              beforeTs: customTransformers.before,\n              afterTs: customTransformers.after,\n            });\n  } else {\n    return ({\n             program,\n             targetSourceFile,\n             writeFile,\n             cancellationToken,\n             emitOnlyDtsFiles,\n             customTransformers = {},\n           }) =>\n               program.emit(\n                   targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles,\n                   {after: customTransformers.after, before: customTransformers.before});\n  }\n}\n\nexport interface NgcParsedConfiguration extends ParsedConfiguration { watch?: boolean; }\n\nfunction readNgcCommandLineAndConfiguration(args: string[]): NgcParsedConfiguration {\n  const options: api.CompilerOptions = {};\n  const parsedArgs = require('minimist')(args);\n  if (parsedArgs.i18nFile) options.i18nInFile = parsedArgs.i18nFile;\n  if (parsedArgs.i18nFormat) options.i18nInFormat = parsedArgs.i18nFormat;\n  if (parsedArgs.locale) options.i18nInLocale = parsedArgs.locale;\n  const mt = parsedArgs.missingTranslation;\n  if (mt === 'error' || mt === 'warning' || mt === 'ignore') {\n    options.i18nInMissingTranslations = mt;\n  }\n  const config = readCommandLineAndConfiguration(\n      args, options, ['i18nFile', 'i18nFormat', 'locale', 'missingTranslation', 'watch']);\n  const watch = parsedArgs.w || parsedArgs.watch;\n  return {...config, watch};\n}\n\nexport function readCommandLineAndConfiguration(\n    args: string[], existingOptions: api.CompilerOptions = {},\n    ngCmdLineOptions: string[] = []): ParsedConfiguration {\n  let cmdConfig = ts.parseCommandLine(args);\n  const project = cmdConfig.options.project || '.';\n  const cmdErrors = cmdConfig.errors.filter(e => {\n    if (typeof e.messageText === 'string') {\n      const msg = e.messageText;\n      return !ngCmdLineOptions.some(o => msg.indexOf(o) >= 0);\n    }\n    return true;\n  });\n  if (cmdErrors.length) {\n    return {\n      project,\n      rootNames: [],\n      options: cmdConfig.options,\n      errors: cmdErrors,\n      emitFlags: api.EmitFlags.Default\n    };\n  }\n  const allDiagnostics: Diagnostics = [];\n  const config = readConfiguration(project, cmdConfig.options);\n  const options = {...config.options, ...existingOptions};\n  if (options.locale) {\n    options.i18nInLocale = options.locale;\n  }\n  return {\n    project,\n    rootNames: config.rootNames, options,\n    errors: config.errors,\n    emitFlags: config.emitFlags\n  };\n}\n\nfunction getFormatDiagnosticsHost(options?: api.CompilerOptions): ts.FormatDiagnosticsHost {\n  const basePath = options ? options.basePath : undefined;\n  return {\n    getCurrentDirectory: () => basePath || ts.sys.getCurrentDirectory(),\n    // We need to normalize the path separators here because by default, TypeScript\n    // compiler hosts use posix canonical paths. In order to print consistent diagnostics,\n    // we also normalize the paths.\n    getCanonicalFileName: fileName => fileName.replace(/\\\\/g, '/'),\n    getNewLine: () => {\n      // Manually determine the proper new line string based on the passed compiler\n      // options. There is no public TypeScript function that returns the corresponding\n      // new line string. see: https://github.com/Microsoft/TypeScript/issues/29581\n      if (options && options.newLine !== undefined) {\n        return options.newLine === ts.NewLineKind.LineFeed ? '\\n' : '\\r\\n';\n      }\n      return ts.sys.newLine;\n    },\n  };\n}\n\nfunction reportErrorsAndExit(\n    allDiagnostics: Diagnostics, options?: api.CompilerOptions,\n    consoleError: (s: string) => void = console.error): number {\n  const errorsAndWarnings = filterErrorsAndWarnings(allDiagnostics);\n  if (errorsAndWarnings.length) {\n    const formatHost = getFormatDiagnosticsHost(options);\n    if (options && (options.enableIvy === true || options.enableIvy === 'ngtsc')) {\n      const ngDiagnostics = errorsAndWarnings.filter(api.isNgDiagnostic);\n      const tsDiagnostics = errorsAndWarnings.filter(api.isTsDiagnostic);\n      consoleError(replaceTsWithNgInErrors(\n          ts.formatDiagnosticsWithColorAndContext(tsDiagnostics, formatHost)));\n      consoleError(formatDiagnostics(ngDiagnostics, formatHost));\n    } else {\n      consoleError(formatDiagnostics(errorsAndWarnings, formatHost));\n    }\n  }\n  return exitCodeFromResult(allDiagnostics);\n}\n\nexport function watchMode(\n    project: string, options: api.CompilerOptions, consoleError: (s: string) => void) {\n  return performWatchCompilation(createPerformWatchHost(project, diagnostics => {\n    consoleError(formatDiagnostics(diagnostics, getFormatDiagnosticsHost(options)));\n  }, options, options => createEmitCallback(options)));\n}\n\n// CLI entry point\nif (require.main === module) {\n  const args = process.argv.slice(2);\n  process.exitCode = main(args);\n}\n"]}