@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
@@ -11,32 +11,31 @@
11
11
  if (v !== undefined) module.exports = v;
12
12
  }
13
13
  else if (typeof define === "function" && define.amd) {
14
- define("@angular/compiler-cli/src/metadata/bundle_index_host", ["require", "exports", "tslib", "path", "typescript", "@angular/compiler-cli/src/metadata/bundler", "@angular/compiler-cli/src/metadata/index_writer"], factory);
14
+ define("@angular/compiler-cli/src/metadata/bundle_index_host", ["require", "exports", "path", "typescript", "@angular/compiler-cli/src/metadata/bundler", "@angular/compiler-cli/src/metadata/index_writer"], factory);
15
15
  }
16
16
  })(function (require, exports) {
17
17
  "use strict";
18
18
  Object.defineProperty(exports, "__esModule", { value: true });
19
- var tslib_1 = require("tslib");
20
- var path = require("path");
21
- var ts = require("typescript");
22
- var bundler_1 = require("@angular/compiler-cli/src/metadata/bundler");
23
- var index_writer_1 = require("@angular/compiler-cli/src/metadata/index_writer");
24
- var DTS = /\.d\.ts$/;
25
- var JS_EXT = /(\.js|)$/;
19
+ const path = require("path");
20
+ const ts = require("typescript");
21
+ const bundler_1 = require("@angular/compiler-cli/src/metadata/bundler");
22
+ const index_writer_1 = require("@angular/compiler-cli/src/metadata/index_writer");
23
+ const DTS = /\.d\.ts$/;
24
+ const JS_EXT = /(\.js|)$/;
26
25
  function createSyntheticIndexHost(delegate, syntheticIndex) {
27
- var normalSyntheticIndexName = path.normalize(syntheticIndex.name);
28
- var newHost = Object.create(delegate);
29
- newHost.fileExists = function (fileName) {
26
+ const normalSyntheticIndexName = path.normalize(syntheticIndex.name);
27
+ const newHost = Object.create(delegate);
28
+ newHost.fileExists = (fileName) => {
30
29
  return path.normalize(fileName) == normalSyntheticIndexName || delegate.fileExists(fileName);
31
30
  };
32
- newHost.readFile = function (fileName) {
31
+ newHost.readFile = (fileName) => {
33
32
  return path.normalize(fileName) == normalSyntheticIndexName ? syntheticIndex.content :
34
33
  delegate.readFile(fileName);
35
34
  };
36
35
  newHost.getSourceFile =
37
- function (fileName, languageVersion, onError) {
36
+ (fileName, languageVersion, onError) => {
38
37
  if (path.normalize(fileName) == normalSyntheticIndexName) {
39
- var sf = ts.createSourceFile(fileName, syntheticIndex.content, languageVersion, true);
38
+ const sf = ts.createSourceFile(fileName, syntheticIndex.content, languageVersion, true);
40
39
  if (delegate.fileNameToModuleName) {
41
40
  sf.moduleName = delegate.fileNameToModuleName(fileName);
42
41
  }
@@ -45,50 +44,39 @@
45
44
  return delegate.getSourceFile(fileName, languageVersion, onError);
46
45
  };
47
46
  newHost.writeFile =
48
- function (fileName, data, writeByteOrderMark, onError, sourceFiles) {
47
+ (fileName, data, writeByteOrderMark, onError, sourceFiles) => {
49
48
  delegate.writeFile(fileName, data, writeByteOrderMark, onError, sourceFiles);
50
49
  if (fileName.match(DTS) && sourceFiles && sourceFiles.length == 1 &&
51
50
  path.normalize(sourceFiles[0].fileName) === normalSyntheticIndexName) {
52
51
  // If we are writing the synthetic index, write the metadata along side.
53
- var metadataName = fileName.replace(DTS, '.metadata.json');
54
- var indexMetadata = syntheticIndex.getMetadata();
52
+ const metadataName = fileName.replace(DTS, '.metadata.json');
53
+ const indexMetadata = syntheticIndex.getMetadata();
55
54
  delegate.writeFile(metadataName, indexMetadata, writeByteOrderMark, onError, []);
56
55
  }
57
56
  };
58
57
  return newHost;
59
58
  }
60
59
  function createBundleIndexHost(ngOptions, rootFiles, host, getMetadataCache) {
61
- var e_1, _a;
62
- var files = rootFiles.filter(function (f) { return !DTS.test(f); });
63
- var indexFile;
60
+ const files = rootFiles.filter(f => !DTS.test(f));
61
+ let indexFile;
64
62
  if (files.length === 1) {
65
63
  indexFile = files[0];
66
64
  }
67
65
  else {
68
- try {
69
- for (var files_1 = tslib_1.__values(files), files_1_1 = files_1.next(); !files_1_1.done; files_1_1 = files_1.next()) {
70
- var f = files_1_1.value;
71
- // Assume the shortest file path called index.ts is the entry point. Note that we
72
- // need to use the posix path delimiter here because TypeScript internally only
73
- // passes posix paths.
74
- if (f.endsWith('/index.ts')) {
75
- if (!indexFile || indexFile.length > f.length) {
76
- indexFile = f;
77
- }
66
+ for (const f of files) {
67
+ // Assume the shortest file path called index.ts is the entry point. Note that we
68
+ // need to use the posix path delimiter here because TypeScript internally only
69
+ // passes posix paths.
70
+ if (f.endsWith('/index.ts')) {
71
+ if (!indexFile || indexFile.length > f.length) {
72
+ indexFile = f;
78
73
  }
79
74
  }
80
75
  }
81
- catch (e_1_1) { e_1 = { error: e_1_1 }; }
82
- finally {
83
- try {
84
- if (files_1_1 && !files_1_1.done && (_a = files_1.return)) _a.call(files_1);
85
- }
86
- finally { if (e_1) throw e_1.error; }
87
- }
88
76
  }
89
77
  if (!indexFile) {
90
78
  return {
91
- host: host,
79
+ host,
92
80
  errors: [{
93
81
  file: null,
94
82
  start: null,
@@ -99,34 +87,34 @@
99
87
  }]
100
88
  };
101
89
  }
102
- var indexModule = indexFile.replace(/\.ts$/, '');
90
+ const indexModule = indexFile.replace(/\.ts$/, '');
103
91
  // The operation of producing a metadata bundle happens twice - once during setup and once during
104
92
  // the emit phase. The first time, the bundle is produced without a metadata cache, to compute the
105
93
  // contents of the flat module index. The bundle produced during emit does use the metadata cache
106
94
  // with associated transforms, so the metadata will have lowered expressions, resource inlining,
107
95
  // etc.
108
- var getMetadataBundle = function (cache) {
109
- var bundler = new bundler_1.MetadataBundler(indexModule, ngOptions.flatModuleId, new bundler_1.CompilerHostAdapter(host, cache, ngOptions), ngOptions.flatModulePrivateSymbolPrefix);
96
+ const getMetadataBundle = (cache) => {
97
+ const bundler = new bundler_1.MetadataBundler(indexModule, ngOptions.flatModuleId, new bundler_1.CompilerHostAdapter(host, cache, ngOptions), ngOptions.flatModulePrivateSymbolPrefix);
110
98
  return bundler.getMetadataBundle();
111
99
  };
112
100
  // First, produce the bundle with no MetadataCache.
113
- var metadataBundle = getMetadataBundle(/* MetadataCache */ null);
114
- var name = path.join(path.dirname(indexModule), ngOptions.flatModuleOutFile.replace(JS_EXT, '.ts'));
115
- var libraryIndex = "./" + path.basename(indexModule);
116
- var content = index_writer_1.privateEntriesToIndex(libraryIndex, metadataBundle.privates);
101
+ const metadataBundle = getMetadataBundle(/* MetadataCache */ null);
102
+ const name = path.join(path.dirname(indexModule), ngOptions.flatModuleOutFile.replace(JS_EXT, '.ts'));
103
+ const libraryIndex = `./${path.basename(indexModule)}`;
104
+ const content = index_writer_1.privateEntriesToIndex(libraryIndex, metadataBundle.privates);
117
105
  host = createSyntheticIndexHost(host, {
118
- name: name,
119
- content: content,
120
- getMetadata: function () {
106
+ name,
107
+ content,
108
+ getMetadata: () => {
121
109
  // The second metadata bundle production happens on-demand, and uses the getMetadataCache
122
110
  // closure to retrieve an up-to-date MetadataCache which is configured with whatever metadata
123
111
  // transforms were used to produce the JS output.
124
- var metadataBundle = getMetadataBundle(getMetadataCache());
112
+ const metadataBundle = getMetadataBundle(getMetadataCache());
125
113
  return JSON.stringify(metadataBundle.metadata);
126
114
  }
127
115
  });
128
- return { host: host, indexName: name };
116
+ return { host, indexName: name };
129
117
  }
130
118
  exports.createBundleIndexHost = createBundleIndexHost;
131
119
  });
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundle_index_host.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/metadata/bundle_index_host.ts"],"names":[],"mappings":"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","sourcesContent":["/**\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\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as ts from 'typescript';\n\nimport {CompilerOptions} from '../transformers/api';\nimport {MetadataCache} from '../transformers/metadata_cache';\n\nimport {CompilerHostAdapter, MetadataBundler} from './bundler';\nimport {privateEntriesToIndex} from './index_writer';\n\nconst DTS = /\\.d\\.ts$/;\nconst JS_EXT = /(\\.js|)$/;\n\nfunction createSyntheticIndexHost<H extends ts.CompilerHost>(\n    delegate: H, syntheticIndex: {name: string, content: string, getMetadata: () => string}): H {\n  const normalSyntheticIndexName = path.normalize(syntheticIndex.name);\n\n  const newHost = Object.create(delegate);\n  newHost.fileExists = (fileName: string): boolean => {\n    return path.normalize(fileName) == normalSyntheticIndexName || delegate.fileExists(fileName);\n  };\n\n  newHost.readFile = (fileName: string) => {\n    return path.normalize(fileName) == normalSyntheticIndexName ? syntheticIndex.content :\n                                                                  delegate.readFile(fileName);\n  };\n\n  newHost.getSourceFile =\n      (fileName: string, languageVersion: ts.ScriptTarget, onError?: (message: string) => void) => {\n        if (path.normalize(fileName) == normalSyntheticIndexName) {\n          const sf = ts.createSourceFile(fileName, syntheticIndex.content, languageVersion, true);\n          if ((delegate as any).fileNameToModuleName) {\n            sf.moduleName = (delegate as any).fileNameToModuleName(fileName);\n          }\n          return sf;\n        }\n        return delegate.getSourceFile(fileName, languageVersion, onError);\n      };\n\n  newHost.writeFile =\n      (fileName: string, data: string, writeByteOrderMark: boolean,\n       onError: ((message: string) => void) | undefined,\n       sourceFiles: Readonly<ts.SourceFile>[]) => {\n        delegate.writeFile(fileName, data, writeByteOrderMark, onError, sourceFiles);\n        if (fileName.match(DTS) && sourceFiles && sourceFiles.length == 1 &&\n            path.normalize(sourceFiles[0].fileName) === normalSyntheticIndexName) {\n          // If we are writing the synthetic index, write the metadata along side.\n          const metadataName = fileName.replace(DTS, '.metadata.json');\n          const indexMetadata = syntheticIndex.getMetadata();\n          delegate.writeFile(metadataName, indexMetadata, writeByteOrderMark, onError, []);\n        }\n      };\n  return newHost;\n}\n\nexport function createBundleIndexHost<H extends ts.CompilerHost>(\n    ngOptions: CompilerOptions, rootFiles: ReadonlyArray<string>, host: H,\n    getMetadataCache: () =>\n        MetadataCache): {host: H, indexName?: string, errors?: ts.Diagnostic[]} {\n  const files = rootFiles.filter(f => !DTS.test(f));\n  let indexFile: string|undefined;\n  if (files.length === 1) {\n    indexFile = files[0];\n  } else {\n    for (const f of files) {\n      // Assume the shortest file path called index.ts is the entry point. Note that we\n      // need to use the posix path delimiter here because TypeScript internally only\n      // passes posix paths.\n      if (f.endsWith('/index.ts')) {\n        if (!indexFile || indexFile.length > f.length) {\n          indexFile = f;\n        }\n      }\n    }\n  }\n  if (!indexFile) {\n    return {\n      host,\n      errors: [{\n        file: null as any as ts.SourceFile,\n        start: null as any as number,\n        length: null as any as number,\n        messageText:\n            'Angular compiler option \"flatModuleIndex\" requires one and only one .ts file in the \"files\" field.',\n        category: ts.DiagnosticCategory.Error,\n        code: 0\n      }]\n    };\n  }\n\n  const indexModule = indexFile.replace(/\\.ts$/, '');\n\n  // The operation of producing a metadata bundle happens twice - once during setup and once during\n  // the emit phase. The first time, the bundle is produced without a metadata cache, to compute the\n  // contents of the flat module index. The bundle produced during emit does use the metadata cache\n  // with associated transforms, so the metadata will have lowered expressions, resource inlining,\n  // etc.\n  const getMetadataBundle = (cache: MetadataCache | null) => {\n    const bundler = new MetadataBundler(\n        indexModule, ngOptions.flatModuleId, new CompilerHostAdapter(host, cache, ngOptions),\n        ngOptions.flatModulePrivateSymbolPrefix);\n    return bundler.getMetadataBundle();\n  };\n\n  // First, produce the bundle with no MetadataCache.\n  const metadataBundle = getMetadataBundle(/* MetadataCache */ null);\n  const name =\n      path.join(path.dirname(indexModule), ngOptions.flatModuleOutFile !.replace(JS_EXT, '.ts'));\n  const libraryIndex = `./${path.basename(indexModule)}`;\n  const content = privateEntriesToIndex(libraryIndex, metadataBundle.privates);\n\n  host = createSyntheticIndexHost(host, {\n    name,\n    content,\n    getMetadata: () => {\n      // The second metadata bundle production happens on-demand, and uses the getMetadataCache\n      // closure to retrieve an up-to-date MetadataCache which is configured with whatever metadata\n      // transforms were used to produce the JS output.\n      const metadataBundle = getMetadataBundle(getMetadataCache());\n      return JSON.stringify(metadataBundle.metadata);\n    }\n  });\n  return {host, indexName: name};\n}\n"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundle_index_host.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/metadata/bundle_index_host.ts"],"names":[],"mappings":"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","sourcesContent":["/**\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\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as ts from 'typescript';\n\nimport {CompilerOptions} from '../transformers/api';\nimport {MetadataCache} from '../transformers/metadata_cache';\n\nimport {CompilerHostAdapter, MetadataBundler} from './bundler';\nimport {privateEntriesToIndex} from './index_writer';\n\nconst DTS = /\\.d\\.ts$/;\nconst JS_EXT = /(\\.js|)$/;\n\nfunction createSyntheticIndexHost<H extends ts.CompilerHost>(\n    delegate: H, syntheticIndex: {name: string, content: string, getMetadata: () => string}): H {\n  const normalSyntheticIndexName = path.normalize(syntheticIndex.name);\n\n  const newHost = Object.create(delegate);\n  newHost.fileExists = (fileName: string): boolean => {\n    return path.normalize(fileName) == normalSyntheticIndexName || delegate.fileExists(fileName);\n  };\n\n  newHost.readFile = (fileName: string) => {\n    return path.normalize(fileName) == normalSyntheticIndexName ? syntheticIndex.content :\n                                                                  delegate.readFile(fileName);\n  };\n\n  newHost.getSourceFile =\n      (fileName: string, languageVersion: ts.ScriptTarget, onError?: (message: string) => void) => {\n        if (path.normalize(fileName) == normalSyntheticIndexName) {\n          const sf = ts.createSourceFile(fileName, syntheticIndex.content, languageVersion, true);\n          if ((delegate as any).fileNameToModuleName) {\n            sf.moduleName = (delegate as any).fileNameToModuleName(fileName);\n          }\n          return sf;\n        }\n        return delegate.getSourceFile(fileName, languageVersion, onError);\n      };\n\n  newHost.writeFile =\n      (fileName: string, data: string, writeByteOrderMark: boolean,\n       onError: ((message: string) => void) | undefined,\n       sourceFiles: Readonly<ts.SourceFile>[]) => {\n        delegate.writeFile(fileName, data, writeByteOrderMark, onError, sourceFiles);\n        if (fileName.match(DTS) && sourceFiles && sourceFiles.length == 1 &&\n            path.normalize(sourceFiles[0].fileName) === normalSyntheticIndexName) {\n          // If we are writing the synthetic index, write the metadata along side.\n          const metadataName = fileName.replace(DTS, '.metadata.json');\n          const indexMetadata = syntheticIndex.getMetadata();\n          delegate.writeFile(metadataName, indexMetadata, writeByteOrderMark, onError, []);\n        }\n      };\n  return newHost;\n}\n\nexport function createBundleIndexHost<H extends ts.CompilerHost>(\n    ngOptions: CompilerOptions, rootFiles: ReadonlyArray<string>, host: H,\n    getMetadataCache: () =>\n        MetadataCache): {host: H, indexName?: string, errors?: ts.Diagnostic[]} {\n  const files = rootFiles.filter(f => !DTS.test(f));\n  let indexFile: string|undefined;\n  if (files.length === 1) {\n    indexFile = files[0];\n  } else {\n    for (const f of files) {\n      // Assume the shortest file path called index.ts is the entry point. Note that we\n      // need to use the posix path delimiter here because TypeScript internally only\n      // passes posix paths.\n      if (f.endsWith('/index.ts')) {\n        if (!indexFile || indexFile.length > f.length) {\n          indexFile = f;\n        }\n      }\n    }\n  }\n  if (!indexFile) {\n    return {\n      host,\n      errors: [{\n        file: null as any as ts.SourceFile,\n        start: null as any as number,\n        length: null as any as number,\n        messageText:\n            'Angular compiler option \"flatModuleIndex\" requires one and only one .ts file in the \"files\" field.',\n        category: ts.DiagnosticCategory.Error,\n        code: 0\n      }]\n    };\n  }\n\n  const indexModule = indexFile.replace(/\\.ts$/, '');\n\n  // The operation of producing a metadata bundle happens twice - once during setup and once during\n  // the emit phase. The first time, the bundle is produced without a metadata cache, to compute the\n  // contents of the flat module index. The bundle produced during emit does use the metadata cache\n  // with associated transforms, so the metadata will have lowered expressions, resource inlining,\n  // etc.\n  const getMetadataBundle = (cache: MetadataCache | null) => {\n    const bundler = new MetadataBundler(\n        indexModule, ngOptions.flatModuleId, new CompilerHostAdapter(host, cache, ngOptions),\n        ngOptions.flatModulePrivateSymbolPrefix);\n    return bundler.getMetadataBundle();\n  };\n\n  // First, produce the bundle with no MetadataCache.\n  const metadataBundle = getMetadataBundle(/* MetadataCache */ null);\n  const name =\n      path.join(path.dirname(indexModule), ngOptions.flatModuleOutFile !.replace(JS_EXT, '.ts'));\n  const libraryIndex = `./${path.basename(indexModule)}`;\n  const content = privateEntriesToIndex(libraryIndex, metadataBundle.privates);\n\n  host = createSyntheticIndexHost(host, {\n    name,\n    content,\n    getMetadata: () => {\n      // The second metadata bundle production happens on-demand, and uses the getMetadataCache\n      // closure to retrieve an up-to-date MetadataCache which is configured with whatever metadata\n      // transforms were used to produce the JS output.\n      const metadataBundle = getMetadataBundle(getMetadataCache());\n      return JSON.stringify(metadataBundle.metadata);\n    }\n  });\n  return {host, indexName: name};\n}\n"]}