@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.
- package/index.js +1 -1
- package/package.json +4 -4
- package/src/diagnostics/expression_diagnostics.js +98 -151
- package/src/diagnostics/expression_type.js +122 -139
- package/src/diagnostics/translate_diagnostics.js +12 -12
- package/src/diagnostics/typescript_symbols.js +296 -514
- package/src/diagnostics/typescript_version.js +8 -8
- package/src/extract_i18n.js +11 -13
- package/src/main.js +80 -78
- package/src/metadata/bundle_index_host.js +39 -51
- package/src/metadata/bundler.js +214 -256
- package/src/metadata/collector.js +235 -317
- package/src/metadata/evaluator.js +146 -162
- package/src/metadata/index.js +1 -1
- package/src/metadata/index_writer.js +25 -47
- package/src/metadata/symbols.js +44 -62
- package/src/ngcc/src/packages/build_marker.d.ts +1 -1
- package/src/ngcc/src/packages/build_marker.js +1 -1
- package/src/ngtools_api.js +29 -44
- package/src/ngtools_api2.js +9 -11
- package/src/ngtsc/program.js +122 -162
- package/src/ngtsc/resource_loader.js +35 -50
- package/src/perform_compile.js +87 -93
- package/src/perform_watch.js +50 -51
- package/src/transformers/compiler_host.js +158 -171
- package/src/transformers/inline_resources.js +54 -57
- package/src/transformers/lower_expressions.js +87 -101
- package/src/transformers/metadata_cache.js +21 -50
- package/src/transformers/metadata_reader.js +17 -18
- package/src/transformers/nocollapse_hack.js +9 -9
- package/src/transformers/node_emitter.js +214 -237
- package/src/transformers/node_emitter_transform.js +25 -21
- package/src/transformers/program.js +336 -440
- package/src/transformers/r3_metadata_transform.js +21 -34
- package/src/transformers/r3_strip_decorators.js +29 -31
- package/src/transformers/r3_transform.js +7 -8
- package/src/transformers/tsc_pass_through.js +33 -37
- package/src/transformers/util.js +18 -30
- package/src/version.js +3 -3
|
@@ -11,22 +11,20 @@
|
|
|
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/transformers/compiler_host", ["require", "exports", "
|
|
14
|
+
define("@angular/compiler-cli/src/transformers/compiler_host", ["require", "exports", "@angular/compiler", "path", "typescript", "@angular/compiler-cli/src/transformers/metadata_reader", "@angular/compiler-cli/src/transformers/util"], factory);
|
|
15
15
|
}
|
|
16
16
|
})(function (require, exports) {
|
|
17
17
|
"use strict";
|
|
18
18
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
function createCompilerHost(_a) {
|
|
29
|
-
var options = _a.options, _b = _a.tsHost, tsHost = _b === void 0 ? ts.createCompilerHost(options, true) : _b;
|
|
19
|
+
const compiler_1 = require("@angular/compiler");
|
|
20
|
+
const path = require("path");
|
|
21
|
+
const ts = require("typescript");
|
|
22
|
+
const metadata_reader_1 = require("@angular/compiler-cli/src/transformers/metadata_reader");
|
|
23
|
+
const util_1 = require("@angular/compiler-cli/src/transformers/util");
|
|
24
|
+
const NODE_MODULES_PACKAGE_NAME = /node_modules\/((\w|-|\.)+|(@(\w|-|\.)+\/(\w|-|\.)+))/;
|
|
25
|
+
const EXT = /(\.ts|\.d\.ts|\.js|\.jsx|\.tsx)$/;
|
|
26
|
+
const CSS_PREPROCESSOR_EXT = /(\.scss|\.less|\.styl)$/;
|
|
27
|
+
function createCompilerHost({ options, tsHost = ts.createCompilerHost(options, true) }) {
|
|
30
28
|
return tsHost;
|
|
31
29
|
}
|
|
32
30
|
exports.createCompilerHost = createCompilerHost;
|
|
@@ -42,10 +40,8 @@
|
|
|
42
40
|
* - AotCompilerHost for @angular/compiler
|
|
43
41
|
* - TypeCheckHost for mapping ts errors to ng errors (via translateDiagnostics)
|
|
44
42
|
*/
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
if (librarySummaries === void 0) { librarySummaries = new Map(); }
|
|
48
|
-
var _this = this;
|
|
43
|
+
class TsCompilerAotCompilerTypeCheckHostAdapter {
|
|
44
|
+
constructor(rootFiles, options, context, metadataProvider, codeGenerator, librarySummaries = new Map()) {
|
|
49
45
|
this.rootFiles = rootFiles;
|
|
50
46
|
this.options = options;
|
|
51
47
|
this.context = context;
|
|
@@ -62,40 +58,36 @@
|
|
|
62
58
|
this.generatedSourceFiles = new Map();
|
|
63
59
|
this.generatedCodeFor = new Map();
|
|
64
60
|
this.emitter = new compiler_1.TypeScriptEmitter();
|
|
65
|
-
this.getDefaultLibFileName =
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
this.
|
|
69
|
-
this.
|
|
70
|
-
this.useCaseSensitiveFileNames = function () { return _this.context.useCaseSensitiveFileNames(); };
|
|
71
|
-
this.getNewLine = function () { return _this.context.getNewLine(); };
|
|
61
|
+
this.getDefaultLibFileName = (options) => this.context.getDefaultLibFileName(options);
|
|
62
|
+
this.getCurrentDirectory = () => this.context.getCurrentDirectory();
|
|
63
|
+
this.getCanonicalFileName = (fileName) => this.context.getCanonicalFileName(fileName);
|
|
64
|
+
this.useCaseSensitiveFileNames = () => this.context.useCaseSensitiveFileNames();
|
|
65
|
+
this.getNewLine = () => this.context.getNewLine();
|
|
72
66
|
// Make sure we do not `host.realpath()` from TS as we do not want to resolve symlinks.
|
|
73
67
|
// https://github.com/Microsoft/TypeScript/issues/9552
|
|
74
|
-
this.realpath =
|
|
68
|
+
this.realpath = (p) => p;
|
|
75
69
|
this.writeFile = this.context.writeFile.bind(this.context);
|
|
76
70
|
this.moduleResolutionCache = ts.createModuleResolutionCache(this.context.getCurrentDirectory(), this.context.getCanonicalFileName.bind(this.context));
|
|
77
|
-
|
|
71
|
+
const basePath = this.options.basePath;
|
|
78
72
|
this.rootDirs =
|
|
79
|
-
(this.options.rootDirs || [this.options.basePath]).map(
|
|
73
|
+
(this.options.rootDirs || [this.options.basePath]).map(p => path.resolve(basePath, p));
|
|
80
74
|
if (context.getDirectories) {
|
|
81
|
-
this.getDirectories =
|
|
75
|
+
this.getDirectories = path => context.getDirectories(path);
|
|
82
76
|
}
|
|
83
77
|
if (context.directoryExists) {
|
|
84
|
-
this.directoryExists =
|
|
78
|
+
this.directoryExists = directoryName => context.directoryExists(directoryName);
|
|
85
79
|
}
|
|
86
80
|
if (context.getCancellationToken) {
|
|
87
|
-
this.getCancellationToken =
|
|
81
|
+
this.getCancellationToken = () => context.getCancellationToken();
|
|
88
82
|
}
|
|
89
83
|
if (context.getDefaultLibLocation) {
|
|
90
|
-
this.getDefaultLibLocation =
|
|
84
|
+
this.getDefaultLibLocation = () => context.getDefaultLibLocation();
|
|
91
85
|
}
|
|
92
86
|
if (context.resolveTypeReferenceDirectives) {
|
|
93
|
-
this.resolveTypeReferenceDirectives =
|
|
94
|
-
return context.resolveTypeReferenceDirectives(names, containingFile);
|
|
95
|
-
};
|
|
87
|
+
this.resolveTypeReferenceDirectives = (names, containingFile) => context.resolveTypeReferenceDirectives(names, containingFile);
|
|
96
88
|
}
|
|
97
89
|
if (context.trace) {
|
|
98
|
-
this.trace =
|
|
90
|
+
this.trace = s => context.trace(s);
|
|
99
91
|
}
|
|
100
92
|
if (context.fileNameToModuleName) {
|
|
101
93
|
this.fileNameToModuleName = context.fileNameToModuleName.bind(context);
|
|
@@ -112,17 +104,17 @@
|
|
|
112
104
|
this.fromSummaryFileName = context.fromSummaryFileName.bind(context);
|
|
113
105
|
}
|
|
114
106
|
this.metadataReaderHost = {
|
|
115
|
-
cacheMetadata:
|
|
116
|
-
getSourceFileMetadata:
|
|
117
|
-
|
|
118
|
-
return sf ?
|
|
107
|
+
cacheMetadata: () => true,
|
|
108
|
+
getSourceFileMetadata: (filePath) => {
|
|
109
|
+
const sf = this.getOriginalSourceFile(filePath);
|
|
110
|
+
return sf ? this.metadataProvider.getMetadata(sf) : undefined;
|
|
119
111
|
},
|
|
120
|
-
fileExists:
|
|
121
|
-
readFile:
|
|
112
|
+
fileExists: (filePath) => this.originalFileExists(filePath),
|
|
113
|
+
readFile: (filePath) => assert(this.context.readFile(filePath)),
|
|
122
114
|
};
|
|
123
115
|
}
|
|
124
|
-
|
|
125
|
-
|
|
116
|
+
resolveModuleName(moduleName, containingFile) {
|
|
117
|
+
const rm = ts.resolveModuleName(moduleName, containingFile.replace(/\\/g, '/'), this.options, this, this.moduleResolutionCache)
|
|
126
118
|
.resolvedModule;
|
|
127
119
|
if (rm && this.isSourceFile(rm.resolvedFileName) && util_1.DTS.test(rm.resolvedFileName)) {
|
|
128
120
|
// Case: generateCodeForLibraries = true and moduleName is
|
|
@@ -132,20 +124,19 @@
|
|
|
132
124
|
rm.isExternalLibraryImport = false;
|
|
133
125
|
}
|
|
134
126
|
return rm;
|
|
135
|
-
}
|
|
127
|
+
}
|
|
136
128
|
// Note: We implement this method so that TypeScript and Angular share the same
|
|
137
129
|
// ts.ModuleResolutionCache
|
|
138
130
|
// and that we can tell ts.Program about our different opinion about
|
|
139
131
|
// ResolvedModule.isExternalLibraryImport
|
|
140
132
|
// (see our isSourceFile method).
|
|
141
|
-
|
|
142
|
-
var _this = this;
|
|
133
|
+
resolveModuleNames(moduleNames, containingFile) {
|
|
143
134
|
// TODO(tbosch): this seems to be a typing error in TypeScript,
|
|
144
135
|
// as it contains assertions that the result contains the same number of entries
|
|
145
136
|
// as the given module names.
|
|
146
|
-
return moduleNames.map(
|
|
147
|
-
}
|
|
148
|
-
|
|
137
|
+
return moduleNames.map(moduleName => this.resolveModuleName(moduleName, containingFile));
|
|
138
|
+
}
|
|
139
|
+
moduleNameToFileName(m, containingFile) {
|
|
149
140
|
if (!containingFile) {
|
|
150
141
|
if (m.indexOf('.') === 0) {
|
|
151
142
|
throw new Error('Resolution of relative paths requires a containing file.');
|
|
@@ -156,9 +147,9 @@
|
|
|
156
147
|
if (this.context.moduleNameToFileName) {
|
|
157
148
|
return this.context.moduleNameToFileName(m, containingFile);
|
|
158
149
|
}
|
|
159
|
-
|
|
150
|
+
const resolved = this.resolveModuleName(m, containingFile);
|
|
160
151
|
return resolved ? resolved.resolvedFileName : null;
|
|
161
|
-
}
|
|
152
|
+
}
|
|
162
153
|
/**
|
|
163
154
|
* We want a moduleId that will appear in import statements in the generated code
|
|
164
155
|
* which will be written to `containingFile`.
|
|
@@ -176,24 +167,24 @@
|
|
|
176
167
|
* as that is a violation of the principle that node_modules packages cannot
|
|
177
168
|
* import project sources.
|
|
178
169
|
*/
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
170
|
+
fileNameToModuleName(importedFile, containingFile) {
|
|
171
|
+
const cacheKey = `${importedFile}:${containingFile}`;
|
|
172
|
+
let moduleName = this.fileNameToModuleNameCache.get(cacheKey);
|
|
182
173
|
if (moduleName != null) {
|
|
183
174
|
return moduleName;
|
|
184
175
|
}
|
|
185
|
-
|
|
176
|
+
const originalImportedFile = importedFile;
|
|
186
177
|
if (this.options.traceResolution) {
|
|
187
178
|
console.error('fileNameToModuleName from containingFile', containingFile, 'to importedFile', importedFile);
|
|
188
179
|
}
|
|
189
180
|
// drop extension
|
|
190
181
|
importedFile = importedFile.replace(EXT, '');
|
|
191
|
-
|
|
192
|
-
|
|
182
|
+
const importedFilePackageName = getPackageName(importedFile);
|
|
183
|
+
const containingFilePackageName = getPackageName(containingFile);
|
|
193
184
|
if (importedFilePackageName === containingFilePackageName ||
|
|
194
185
|
util_1.GENERATED_FILES.test(originalImportedFile)) {
|
|
195
|
-
|
|
196
|
-
|
|
186
|
+
const rootedContainingFile = util_1.relativeToRootDirs(containingFile, this.rootDirs);
|
|
187
|
+
const rootedImportedFile = util_1.relativeToRootDirs(importedFile, this.rootDirs);
|
|
197
188
|
if (rootedContainingFile !== containingFile && rootedImportedFile !== importedFile) {
|
|
198
189
|
// if both files are contained in the `rootDirs`, then strip the rootDirs
|
|
199
190
|
containingFile = rootedContainingFile;
|
|
@@ -207,10 +198,10 @@
|
|
|
207
198
|
// the moduleName for these typings could be shortented to the npm package name
|
|
208
199
|
// if the npm package typings matches the importedFile
|
|
209
200
|
try {
|
|
210
|
-
|
|
201
|
+
const modulePath = importedFile.substring(0, importedFile.length - moduleName.length) +
|
|
211
202
|
importedFilePackageName;
|
|
212
|
-
|
|
213
|
-
|
|
203
|
+
const packageJson = require(modulePath + '/package.json');
|
|
204
|
+
const packageTypings = path.posix.join(modulePath, packageJson.typings);
|
|
214
205
|
if (packageTypings === originalImportedFile) {
|
|
215
206
|
moduleName = importedFilePackageName;
|
|
216
207
|
}
|
|
@@ -223,54 +214,54 @@
|
|
|
223
214
|
}
|
|
224
215
|
}
|
|
225
216
|
else {
|
|
226
|
-
throw new Error(
|
|
217
|
+
throw new Error(`Trying to import a source file from a node_modules package: import ${originalImportedFile} from ${containingFile}`);
|
|
227
218
|
}
|
|
228
219
|
this.fileNameToModuleNameCache.set(cacheKey, moduleName);
|
|
229
220
|
return moduleName;
|
|
230
|
-
}
|
|
231
|
-
|
|
221
|
+
}
|
|
222
|
+
resourceNameToFileName(resourceName, containingFile) {
|
|
232
223
|
// Note: we convert package paths into relative paths to be compatible with the the
|
|
233
224
|
// previous implementation of UrlResolver.
|
|
234
|
-
|
|
225
|
+
const firstChar = resourceName[0];
|
|
235
226
|
if (firstChar === '/') {
|
|
236
227
|
resourceName = resourceName.slice(1);
|
|
237
228
|
}
|
|
238
229
|
else if (firstChar !== '.') {
|
|
239
|
-
resourceName =
|
|
230
|
+
resourceName = `./${resourceName}`;
|
|
240
231
|
}
|
|
241
|
-
|
|
232
|
+
let filePathWithNgResource = this.moduleNameToFileName(addNgResourceSuffix(resourceName), containingFile);
|
|
242
233
|
// If the user specified styleUrl pointing to *.scss, but the Sass compiler was run before
|
|
243
234
|
// Angular, then the resource may have been generated as *.css. Simply try the resolution again.
|
|
244
235
|
if (!filePathWithNgResource && CSS_PREPROCESSOR_EXT.test(resourceName)) {
|
|
245
|
-
|
|
236
|
+
const fallbackResourceName = resourceName.replace(CSS_PREPROCESSOR_EXT, '.css');
|
|
246
237
|
filePathWithNgResource =
|
|
247
238
|
this.moduleNameToFileName(addNgResourceSuffix(fallbackResourceName), containingFile);
|
|
248
239
|
}
|
|
249
|
-
|
|
240
|
+
const result = filePathWithNgResource ? stripNgResourceSuffix(filePathWithNgResource) : null;
|
|
250
241
|
// Used under Bazel to report more specific error with remediation advice
|
|
251
242
|
if (!result && this.context.reportMissingResource) {
|
|
252
243
|
this.context.reportMissingResource(resourceName);
|
|
253
244
|
}
|
|
254
245
|
return result;
|
|
255
|
-
}
|
|
256
|
-
|
|
246
|
+
}
|
|
247
|
+
toSummaryFileName(fileName, referringSrcFileName) {
|
|
257
248
|
return this.fileNameToModuleName(fileName, referringSrcFileName);
|
|
258
|
-
}
|
|
259
|
-
|
|
260
|
-
|
|
249
|
+
}
|
|
250
|
+
fromSummaryFileName(fileName, referringLibFileName) {
|
|
251
|
+
const resolved = this.moduleNameToFileName(fileName, referringLibFileName);
|
|
261
252
|
if (!resolved) {
|
|
262
|
-
throw new Error(
|
|
253
|
+
throw new Error(`Could not resolve ${fileName} from ${referringLibFileName}`);
|
|
263
254
|
}
|
|
264
255
|
return resolved;
|
|
265
|
-
}
|
|
266
|
-
|
|
267
|
-
|
|
256
|
+
}
|
|
257
|
+
parseSourceSpanOf(fileName, line, character) {
|
|
258
|
+
const data = this.generatedSourceFiles.get(fileName);
|
|
268
259
|
if (data && data.emitCtx) {
|
|
269
260
|
return data.emitCtx.spanOf(line, character);
|
|
270
261
|
}
|
|
271
262
|
return null;
|
|
272
|
-
}
|
|
273
|
-
|
|
263
|
+
}
|
|
264
|
+
getOriginalSourceFile(filePath, languageVersion, onError) {
|
|
274
265
|
// Note: we need the explicit check via `has` as we also cache results
|
|
275
266
|
// that were null / undefined.
|
|
276
267
|
if (this.originalSourceFiles.has(filePath)) {
|
|
@@ -281,64 +272,63 @@
|
|
|
281
272
|
}
|
|
282
273
|
// Note: This can also return undefined,
|
|
283
274
|
// as the TS typings are not correct!
|
|
284
|
-
|
|
275
|
+
const sf = this.context.getSourceFile(filePath, languageVersion, onError) || null;
|
|
285
276
|
this.originalSourceFiles.set(filePath, sf);
|
|
286
277
|
return sf;
|
|
287
|
-
}
|
|
288
|
-
|
|
278
|
+
}
|
|
279
|
+
updateGeneratedFile(genFile) {
|
|
289
280
|
if (!genFile.stmts) {
|
|
290
|
-
throw new Error(
|
|
281
|
+
throw new Error(`Invalid Argument: Expected a GenerateFile with statements. ${genFile.genFileUrl}`);
|
|
291
282
|
}
|
|
292
|
-
|
|
283
|
+
const oldGenFile = this.generatedSourceFiles.get(genFile.genFileUrl);
|
|
293
284
|
if (!oldGenFile) {
|
|
294
|
-
throw new Error(
|
|
285
|
+
throw new Error(`Illegal State: previous GeneratedFile not found for ${genFile.genFileUrl}.`);
|
|
295
286
|
}
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
287
|
+
const newRefs = genFileExternalReferences(genFile);
|
|
288
|
+
const oldRefs = oldGenFile.externalReferences;
|
|
289
|
+
let refsAreEqual = oldRefs.size === newRefs.size;
|
|
299
290
|
if (refsAreEqual) {
|
|
300
|
-
newRefs.forEach(
|
|
291
|
+
newRefs.forEach(r => refsAreEqual = refsAreEqual && oldRefs.has(r));
|
|
301
292
|
}
|
|
302
293
|
if (!refsAreEqual) {
|
|
303
|
-
throw new Error(
|
|
294
|
+
throw new Error(`Illegal State: external references changed in ${genFile.genFileUrl}.\nOld: ${Array.from(oldRefs)}.\nNew: ${Array.from(newRefs)}`);
|
|
304
295
|
}
|
|
305
296
|
return this.addGeneratedFile(genFile, newRefs);
|
|
306
|
-
}
|
|
307
|
-
|
|
297
|
+
}
|
|
298
|
+
addGeneratedFile(genFile, externalReferences) {
|
|
308
299
|
if (!genFile.stmts) {
|
|
309
|
-
throw new Error(
|
|
300
|
+
throw new Error(`Invalid Argument: Expected a GenerateFile with statements. ${genFile.genFileUrl}`);
|
|
310
301
|
}
|
|
311
|
-
|
|
312
|
-
/* emitSourceMaps */ false)
|
|
313
|
-
|
|
302
|
+
const { sourceText, context } = this.emitter.emitStatementsAndContext(genFile.genFileUrl, genFile.stmts, /* preamble */ '',
|
|
303
|
+
/* emitSourceMaps */ false);
|
|
304
|
+
const sf = ts.createSourceFile(genFile.genFileUrl, sourceText, this.options.target || ts.ScriptTarget.Latest);
|
|
314
305
|
if ((this.options.module === ts.ModuleKind.AMD || this.options.module === ts.ModuleKind.UMD) &&
|
|
315
306
|
this.context.amdModuleName) {
|
|
316
|
-
|
|
307
|
+
const moduleName = this.context.amdModuleName(sf);
|
|
317
308
|
if (moduleName)
|
|
318
309
|
sf.moduleName = moduleName;
|
|
319
310
|
}
|
|
320
311
|
this.generatedSourceFiles.set(genFile.genFileUrl, {
|
|
321
312
|
sourceFile: sf,
|
|
322
|
-
emitCtx: context, externalReferences
|
|
313
|
+
emitCtx: context, externalReferences,
|
|
323
314
|
});
|
|
324
315
|
return sf;
|
|
325
|
-
}
|
|
326
|
-
|
|
327
|
-
var _this = this;
|
|
316
|
+
}
|
|
317
|
+
shouldGenerateFile(fileName) {
|
|
328
318
|
// TODO(tbosch): allow generating files that are not in the rootDir
|
|
329
319
|
// See https://github.com/angular/angular/issues/19337
|
|
330
320
|
if (!util_1.isInRootDir(fileName, this.options)) {
|
|
331
321
|
return { generate: false };
|
|
332
322
|
}
|
|
333
|
-
|
|
323
|
+
const genMatch = util_1.GENERATED_FILES.exec(fileName);
|
|
334
324
|
if (!genMatch) {
|
|
335
325
|
return { generate: false };
|
|
336
326
|
}
|
|
337
|
-
|
|
327
|
+
const [, base, genSuffix, suffix] = genMatch;
|
|
338
328
|
if (suffix !== 'ts' && suffix !== 'tsx') {
|
|
339
329
|
return { generate: false };
|
|
340
330
|
}
|
|
341
|
-
|
|
331
|
+
let baseFileName;
|
|
342
332
|
if (genSuffix.indexOf('ngstyle') >= 0) {
|
|
343
333
|
// Note: ngstyle files have names like `afile.css.ngstyle.ts`
|
|
344
334
|
if (!this.originalFileExists(base)) {
|
|
@@ -349,27 +339,26 @@
|
|
|
349
339
|
// Note: on-the-fly generated files always have a `.ts` suffix,
|
|
350
340
|
// but the file from which we generated it can be a `.ts`/ `.tsx`/ `.d.ts`
|
|
351
341
|
// (see options.generateCodeForLibraries).
|
|
352
|
-
baseFileName = [base
|
|
342
|
+
baseFileName = [`${base}.ts`, `${base}.tsx`, `${base}.d.ts`].find(baseFileName => this.isSourceFile(baseFileName) && this.originalFileExists(baseFileName));
|
|
353
343
|
if (!baseFileName) {
|
|
354
344
|
return { generate: false };
|
|
355
345
|
}
|
|
356
346
|
}
|
|
357
|
-
return { generate: true, baseFileName
|
|
358
|
-
}
|
|
359
|
-
|
|
347
|
+
return { generate: true, baseFileName };
|
|
348
|
+
}
|
|
349
|
+
shouldGenerateFilesFor(fileName) {
|
|
360
350
|
// TODO(tbosch): allow generating files that are not in the rootDir
|
|
361
351
|
// See https://github.com/angular/angular/issues/19337
|
|
362
352
|
return !util_1.GENERATED_FILES.test(fileName) && this.isSourceFile(fileName) &&
|
|
363
353
|
util_1.isInRootDir(fileName, this.options);
|
|
364
|
-
}
|
|
365
|
-
|
|
366
|
-
var _this = this;
|
|
354
|
+
}
|
|
355
|
+
getSourceFile(fileName, languageVersion, onError) {
|
|
367
356
|
// Note: Don't exit early in this method to make sure
|
|
368
357
|
// we always have up to date references on the file!
|
|
369
|
-
|
|
370
|
-
|
|
358
|
+
let genFileNames = [];
|
|
359
|
+
let sf = this.getGeneratedFile(fileName);
|
|
371
360
|
if (!sf) {
|
|
372
|
-
|
|
361
|
+
const summary = this.librarySummaries.get(fileName);
|
|
373
362
|
if (summary) {
|
|
374
363
|
if (!summary.sourceFile) {
|
|
375
364
|
summary.sourceFile = ts.createSourceFile(fileName, summary.text, this.options.target || ts.ScriptTarget.Latest);
|
|
@@ -380,13 +369,13 @@
|
|
|
380
369
|
}
|
|
381
370
|
if (!sf) {
|
|
382
371
|
sf = this.getOriginalSourceFile(fileName);
|
|
383
|
-
|
|
372
|
+
const cachedGenFiles = this.generatedCodeFor.get(fileName);
|
|
384
373
|
if (cachedGenFiles) {
|
|
385
374
|
genFileNames = cachedGenFiles;
|
|
386
375
|
}
|
|
387
376
|
else {
|
|
388
377
|
if (!this.options.noResolve && this.shouldGenerateFilesFor(fileName)) {
|
|
389
|
-
genFileNames = this.codeGenerator.findGeneratedFileNames(fileName).filter(
|
|
378
|
+
genFileNames = this.codeGenerator.findGeneratedFileNames(fileName).filter(fileName => this.shouldGenerateFile(fileName).generate);
|
|
390
379
|
}
|
|
391
380
|
this.generatedCodeFor.set(fileName, genFileNames);
|
|
392
381
|
}
|
|
@@ -397,28 +386,28 @@
|
|
|
397
386
|
// TODO(tbosch): TypeScript's typings for getSourceFile are incorrect,
|
|
398
387
|
// as it can very well return undefined.
|
|
399
388
|
return sf;
|
|
400
|
-
}
|
|
401
|
-
|
|
402
|
-
|
|
389
|
+
}
|
|
390
|
+
getGeneratedFile(fileName) {
|
|
391
|
+
const genSrcFile = this.generatedSourceFiles.get(fileName);
|
|
403
392
|
if (genSrcFile) {
|
|
404
393
|
return genSrcFile.sourceFile;
|
|
405
394
|
}
|
|
406
|
-
|
|
395
|
+
const { generate, baseFileName } = this.shouldGenerateFile(fileName);
|
|
407
396
|
if (generate) {
|
|
408
|
-
|
|
397
|
+
const genFile = this.codeGenerator.generateFile(fileName, baseFileName);
|
|
409
398
|
return this.addGeneratedFile(genFile, genFileExternalReferences(genFile));
|
|
410
399
|
}
|
|
411
400
|
return null;
|
|
412
|
-
}
|
|
413
|
-
|
|
414
|
-
|
|
401
|
+
}
|
|
402
|
+
originalFileExists(fileName) {
|
|
403
|
+
let fileExists = this.originalFileExistsCache.get(fileName);
|
|
415
404
|
if (fileExists == null) {
|
|
416
405
|
fileExists = this.context.fileExists(fileName);
|
|
417
406
|
this.originalFileExistsCache.set(fileName, fileExists);
|
|
418
407
|
}
|
|
419
408
|
return fileExists;
|
|
420
|
-
}
|
|
421
|
-
|
|
409
|
+
}
|
|
410
|
+
fileExists(fileName) {
|
|
422
411
|
fileName = stripNgResourceSuffix(fileName);
|
|
423
412
|
if (this.librarySummaries.has(fileName) || this.generatedSourceFiles.has(fileName)) {
|
|
424
413
|
return true;
|
|
@@ -427,9 +416,9 @@
|
|
|
427
416
|
return true;
|
|
428
417
|
}
|
|
429
418
|
return this.originalFileExists(fileName);
|
|
430
|
-
}
|
|
431
|
-
|
|
432
|
-
|
|
419
|
+
}
|
|
420
|
+
loadSummary(filePath) {
|
|
421
|
+
const summary = this.librarySummaries.get(filePath);
|
|
433
422
|
if (summary) {
|
|
434
423
|
return summary.text;
|
|
435
424
|
}
|
|
@@ -437,8 +426,8 @@
|
|
|
437
426
|
return assert(this.context.readFile(filePath));
|
|
438
427
|
}
|
|
439
428
|
return null;
|
|
440
|
-
}
|
|
441
|
-
|
|
429
|
+
}
|
|
430
|
+
isSourceFile(filePath) {
|
|
442
431
|
// Don't generate any files nor typecheck them
|
|
443
432
|
// if skipTemplateCodegen is set and fullTemplateTypeCheck is not yet set,
|
|
444
433
|
// for backwards compatibility.
|
|
@@ -459,38 +448,37 @@
|
|
|
459
448
|
if (util_1.DTS.test(filePath)) {
|
|
460
449
|
// Check for a bundle index.
|
|
461
450
|
if (this.hasBundleIndex(filePath)) {
|
|
462
|
-
|
|
451
|
+
const normalFilePath = path.normalize(filePath);
|
|
463
452
|
return this.flatModuleIndexNames.has(normalFilePath) ||
|
|
464
453
|
this.flatModuleIndexRedirectNames.has(normalFilePath);
|
|
465
454
|
}
|
|
466
455
|
}
|
|
467
456
|
return true;
|
|
468
|
-
}
|
|
469
|
-
|
|
470
|
-
|
|
457
|
+
}
|
|
458
|
+
readFile(fileName) {
|
|
459
|
+
const summary = this.librarySummaries.get(fileName);
|
|
471
460
|
if (summary) {
|
|
472
461
|
return summary.text;
|
|
473
462
|
}
|
|
474
463
|
return this.context.readFile(fileName);
|
|
475
|
-
}
|
|
476
|
-
|
|
464
|
+
}
|
|
465
|
+
getMetadataFor(filePath) {
|
|
477
466
|
return metadata_reader_1.readMetadata(filePath, this.metadataReaderHost, this.metadataReaderCache);
|
|
478
|
-
}
|
|
479
|
-
|
|
467
|
+
}
|
|
468
|
+
loadResource(filePath) {
|
|
480
469
|
if (this.context.readResource)
|
|
481
470
|
return this.context.readResource(filePath);
|
|
482
471
|
if (!this.originalFileExists(filePath)) {
|
|
483
|
-
throw compiler_1.syntaxError(
|
|
472
|
+
throw compiler_1.syntaxError(`Error: Resource file not found: ${filePath}`);
|
|
484
473
|
}
|
|
485
474
|
return assert(this.context.readFile(filePath));
|
|
486
|
-
}
|
|
487
|
-
|
|
475
|
+
}
|
|
476
|
+
getOutputName(filePath) {
|
|
488
477
|
return path.relative(this.getCurrentDirectory(), filePath);
|
|
489
|
-
}
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
var result = _this.flatModuleIndexCache.get(directory);
|
|
478
|
+
}
|
|
479
|
+
hasBundleIndex(filePath) {
|
|
480
|
+
const checkBundleIndex = (directory) => {
|
|
481
|
+
let result = this.flatModuleIndexCache.get(directory);
|
|
494
482
|
if (result == null) {
|
|
495
483
|
if (path.basename(directory) == 'node_module') {
|
|
496
484
|
// Don't look outside the node_modules this package is installed in.
|
|
@@ -500,26 +488,26 @@
|
|
|
500
488
|
// A bundle index exists if the typings .d.ts file has a metadata.json that has an
|
|
501
489
|
// importAs.
|
|
502
490
|
try {
|
|
503
|
-
|
|
504
|
-
if (
|
|
491
|
+
const packageFile = path.join(directory, 'package.json');
|
|
492
|
+
if (this.originalFileExists(packageFile)) {
|
|
505
493
|
// Once we see a package.json file, assume false until it we find the bundle index.
|
|
506
494
|
result = false;
|
|
507
|
-
|
|
495
|
+
const packageContent = JSON.parse(assert(this.context.readFile(packageFile)));
|
|
508
496
|
if (packageContent.typings) {
|
|
509
|
-
|
|
497
|
+
const typings = path.normalize(path.join(directory, packageContent.typings));
|
|
510
498
|
if (util_1.DTS.test(typings)) {
|
|
511
|
-
|
|
512
|
-
if (
|
|
513
|
-
|
|
499
|
+
const metadataFile = typings.replace(util_1.DTS, '.metadata.json');
|
|
500
|
+
if (this.originalFileExists(metadataFile)) {
|
|
501
|
+
const metadata = JSON.parse(assert(this.context.readFile(metadataFile)));
|
|
514
502
|
if (metadata.flatModuleIndexRedirect) {
|
|
515
|
-
|
|
503
|
+
this.flatModuleIndexRedirectNames.add(typings);
|
|
516
504
|
// Note: don't set result = true,
|
|
517
505
|
// as this would mark this folder
|
|
518
506
|
// as having a bundleIndex too early without
|
|
519
507
|
// filling the bundleIndexNames.
|
|
520
508
|
}
|
|
521
509
|
else if (metadata.importAs) {
|
|
522
|
-
|
|
510
|
+
this.flatModuleIndexNames.add(typings);
|
|
523
511
|
result = true;
|
|
524
512
|
}
|
|
525
513
|
}
|
|
@@ -527,7 +515,7 @@
|
|
|
527
515
|
}
|
|
528
516
|
}
|
|
529
517
|
else {
|
|
530
|
-
|
|
518
|
+
const parent = path.dirname(directory);
|
|
531
519
|
if (parent != directory) {
|
|
532
520
|
// Try the parent directory.
|
|
533
521
|
result = checkBundleIndex(parent);
|
|
@@ -542,30 +530,29 @@
|
|
|
542
530
|
result = false;
|
|
543
531
|
}
|
|
544
532
|
}
|
|
545
|
-
|
|
533
|
+
this.flatModuleIndexCache.set(directory, result);
|
|
546
534
|
}
|
|
547
535
|
return result;
|
|
548
536
|
};
|
|
549
537
|
return checkBundleIndex(path.dirname(filePath));
|
|
550
|
-
}
|
|
551
|
-
|
|
552
|
-
}());
|
|
538
|
+
}
|
|
539
|
+
}
|
|
553
540
|
exports.TsCompilerAotCompilerTypeCheckHostAdapter = TsCompilerAotCompilerTypeCheckHostAdapter;
|
|
554
541
|
function genFileExternalReferences(genFile) {
|
|
555
|
-
return new Set(compiler_1.collectExternalReferences(genFile.stmts).map(
|
|
542
|
+
return new Set(compiler_1.collectExternalReferences(genFile.stmts).map(er => er.moduleName));
|
|
556
543
|
}
|
|
557
544
|
function addReferencesToSourceFile(sf, genFileNames) {
|
|
558
545
|
// Note: as we modify ts.SourceFiles we need to keep the original
|
|
559
546
|
// value for `referencedFiles` around in cache the original host is caching ts.SourceFiles.
|
|
560
547
|
// Note: cloning the ts.SourceFile is expensive as the nodes in have parent pointers,
|
|
561
548
|
// i.e. we would also need to clone and adjust all nodes.
|
|
562
|
-
|
|
549
|
+
let originalReferencedFiles = sf.originalReferencedFiles;
|
|
563
550
|
if (!originalReferencedFiles) {
|
|
564
551
|
originalReferencedFiles = sf.referencedFiles;
|
|
565
552
|
sf.originalReferencedFiles = originalReferencedFiles;
|
|
566
553
|
}
|
|
567
|
-
|
|
568
|
-
genFileNames.forEach(
|
|
554
|
+
const newReferencedFiles = [...originalReferencedFiles];
|
|
555
|
+
genFileNames.forEach(gf => newReferencedFiles.push({ fileName: gf, pos: 0, end: 0 }));
|
|
569
556
|
sf.referencedFiles = newReferencedFiles;
|
|
570
557
|
}
|
|
571
558
|
function getOriginalReferences(sourceFile) {
|
|
@@ -573,28 +560,28 @@
|
|
|
573
560
|
}
|
|
574
561
|
exports.getOriginalReferences = getOriginalReferences;
|
|
575
562
|
function dotRelative(from, to) {
|
|
576
|
-
|
|
563
|
+
const rPath = path.relative(from, to).replace(/\\/g, '/');
|
|
577
564
|
return rPath.startsWith('.') ? rPath : './' + rPath;
|
|
578
565
|
}
|
|
579
566
|
/**
|
|
580
567
|
* Moves the path into `genDir` folder while preserving the `node_modules` directory.
|
|
581
568
|
*/
|
|
582
569
|
function getPackageName(filePath) {
|
|
583
|
-
|
|
570
|
+
const match = NODE_MODULES_PACKAGE_NAME.exec(filePath);
|
|
584
571
|
return match ? match[1] : null;
|
|
585
572
|
}
|
|
586
573
|
function stripNodeModulesPrefix(filePath) {
|
|
587
574
|
return filePath.replace(/.*node_modules\//, '');
|
|
588
575
|
}
|
|
589
576
|
function getNodeModulesPrefix(filePath) {
|
|
590
|
-
|
|
577
|
+
const match = /.*node_modules\//.exec(filePath);
|
|
591
578
|
return match ? match[1] : null;
|
|
592
579
|
}
|
|
593
580
|
function stripNgResourceSuffix(fileName) {
|
|
594
581
|
return fileName.replace(/\.\$ngresource\$.*/, '');
|
|
595
582
|
}
|
|
596
583
|
function addNgResourceSuffix(fileName) {
|
|
597
|
-
return fileName
|
|
584
|
+
return `${fileName}.$ngresource$`;
|
|
598
585
|
}
|
|
599
586
|
});
|
|
600
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compiler_host.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/transformers/compiler_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 {AotCompilerHost, EmitterVisitorContext, ExternalReference, GeneratedFile, ParseSourceSpan, TypeScriptEmitter, collectExternalReferences, syntaxError} from '@angular/compiler';\nimport * as path from 'path';\nimport * as ts from 'typescript';\n\nimport {TypeCheckHost} from '../diagnostics/translate_diagnostics';\nimport {METADATA_VERSION, ModuleMetadata} from '../metadata/index';\n\nimport {CompilerHost, CompilerOptions, LibrarySummary} from './api';\nimport {MetadataReaderHost, createMetadataReaderCache, readMetadata} from './metadata_reader';\nimport {DTS, GENERATED_FILES, isInRootDir, relativeToRootDirs} from './util';\n\nconst NODE_MODULES_PACKAGE_NAME = /node_modules\\/((\\w|-|\\.)+|(@(\\w|-|\\.)+\\/(\\w|-|\\.)+))/;\nconst EXT = /(\\.ts|\\.d\\.ts|\\.js|\\.jsx|\\.tsx)$/;\nconst CSS_PREPROCESSOR_EXT = /(\\.scss|\\.less|\\.styl)$/;\n\nexport function createCompilerHost(\n    {options, tsHost = ts.createCompilerHost(options, true)}:\n        {options: CompilerOptions, tsHost?: ts.CompilerHost}): CompilerHost {\n  return tsHost;\n}\n\nexport interface MetadataProvider {\n  getMetadata(sourceFile: ts.SourceFile): ModuleMetadata|undefined;\n}\n\ninterface GenSourceFile {\n  externalReferences: Set<string>;\n  sourceFile: ts.SourceFile;\n  emitCtx: EmitterVisitorContext;\n}\n\nexport interface CodeGenerator {\n  generateFile(genFileName: string, baseFileName?: string): GeneratedFile;\n  findGeneratedFileNames(fileName: string): string[];\n}\n\nfunction assert<T>(condition: T | null | undefined) {\n  if (!condition) {\n    // TODO(chuckjaz): do the right thing\n  }\n  return condition !;\n}\n\n/**\n * Implements the following hosts based on an api.CompilerHost:\n * - ts.CompilerHost to be consumed by a ts.Program\n * - AotCompilerHost for @angular/compiler\n * - TypeCheckHost for mapping ts errors to ng errors (via translateDiagnostics)\n */\nexport class TsCompilerAotCompilerTypeCheckHostAdapter implements ts.CompilerHost, AotCompilerHost,\n    TypeCheckHost {\n  private metadataReaderCache = createMetadataReaderCache();\n  private fileNameToModuleNameCache = new Map<string, string>();\n  private flatModuleIndexCache = new Map<string, boolean>();\n  private flatModuleIndexNames = new Set<string>();\n  private flatModuleIndexRedirectNames = new Set<string>();\n  private rootDirs: string[];\n  private moduleResolutionCache: ts.ModuleResolutionCache;\n  private originalSourceFiles = new Map<string, ts.SourceFile|null>();\n  private originalFileExistsCache = new Map<string, boolean>();\n  private generatedSourceFiles = new Map<string, GenSourceFile>();\n  private generatedCodeFor = new Map<string, string[]>();\n  private emitter = new TypeScriptEmitter();\n  private metadataReaderHost: MetadataReaderHost;\n\n  // TODO(issue/24571): remove '!'.\n  getCancellationToken !: () => ts.CancellationToken;\n  // TODO(issue/24571): remove '!'.\n  getDefaultLibLocation !: () => string;\n  // TODO(issue/24571): remove '!'.\n  trace !: (s: string) => void;\n  // TODO(issue/24571): remove '!'.\n  getDirectories !: (path: string) => string[];\n  resolveTypeReferenceDirectives?:\n      (names: string[], containingFile: string) => ts.ResolvedTypeReferenceDirective[];\n  directoryExists?: (directoryName: string) => boolean;\n\n  constructor(\n      private rootFiles: ReadonlyArray<string>, private options: CompilerOptions,\n      private context: CompilerHost, private metadataProvider: MetadataProvider,\n      private codeGenerator: CodeGenerator,\n      private librarySummaries = new Map<string, LibrarySummary>()) {\n    this.moduleResolutionCache = ts.createModuleResolutionCache(\n        this.context.getCurrentDirectory !(), this.context.getCanonicalFileName.bind(this.context));\n    const basePath = this.options.basePath !;\n    this.rootDirs =\n        (this.options.rootDirs || [this.options.basePath !]).map(p => path.resolve(basePath, p));\n    if (context.getDirectories) {\n      this.getDirectories = path => context.getDirectories !(path);\n    }\n    if (context.directoryExists) {\n      this.directoryExists = directoryName => context.directoryExists !(directoryName);\n    }\n    if (context.getCancellationToken) {\n      this.getCancellationToken = () => context.getCancellationToken !();\n    }\n    if (context.getDefaultLibLocation) {\n      this.getDefaultLibLocation = () => context.getDefaultLibLocation !();\n    }\n    if (context.resolveTypeReferenceDirectives) {\n      // Backward compatibility with TypeScript 2.9 and older since return\n      // type has changed from (ts.ResolvedTypeReferenceDirective | undefined)[]\n      // to ts.ResolvedTypeReferenceDirective[] in Typescript 3.0\n      type ts3ResolveTypeReferenceDirectives = (names: string[], containingFile: string) =>\n          ts.ResolvedTypeReferenceDirective[];\n      this.resolveTypeReferenceDirectives = (names: string[], containingFile: string) =>\n          (context.resolveTypeReferenceDirectives as ts3ResolveTypeReferenceDirectives) !(\n              names, containingFile);\n    }\n    if (context.trace) {\n      this.trace = s => context.trace !(s);\n    }\n    if (context.fileNameToModuleName) {\n      this.fileNameToModuleName = context.fileNameToModuleName.bind(context);\n    }\n    // Note: don't copy over context.moduleNameToFileName as we first\n    // normalize undefined containingFile to a filled containingFile.\n    if (context.resourceNameToFileName) {\n      this.resourceNameToFileName = context.resourceNameToFileName.bind(context);\n    }\n    if (context.toSummaryFileName) {\n      this.toSummaryFileName = context.toSummaryFileName.bind(context);\n    }\n    if (context.fromSummaryFileName) {\n      this.fromSummaryFileName = context.fromSummaryFileName.bind(context);\n    }\n    this.metadataReaderHost = {\n      cacheMetadata: () => true,\n      getSourceFileMetadata: (filePath) => {\n        const sf = this.getOriginalSourceFile(filePath);\n        return sf ? this.metadataProvider.getMetadata(sf) : undefined;\n      },\n      fileExists: (filePath) => this.originalFileExists(filePath),\n      readFile: (filePath) => assert(this.context.readFile(filePath)),\n    };\n  }\n\n  private resolveModuleName(moduleName: string, containingFile: string): ts.ResolvedModule\n      |undefined {\n    const rm = ts.resolveModuleName(\n                     moduleName, containingFile.replace(/\\\\/g, '/'), this.options, this,\n                     this.moduleResolutionCache)\n                   .resolvedModule;\n    if (rm && this.isSourceFile(rm.resolvedFileName) && DTS.test(rm.resolvedFileName)) {\n      // Case: generateCodeForLibraries = true and moduleName is\n      // a .d.ts file in a node_modules folder.\n      // Need to set isExternalLibraryImport to false so that generated files for that file\n      // are emitted.\n      rm.isExternalLibraryImport = false;\n    }\n    return rm;\n  }\n\n  // Note: We implement this method so that TypeScript and Angular share the same\n  // ts.ModuleResolutionCache\n  // and that we can tell ts.Program about our different opinion about\n  // ResolvedModule.isExternalLibraryImport\n  // (see our isSourceFile method).\n  resolveModuleNames(moduleNames: string[], containingFile: string): ts.ResolvedModule[] {\n    // TODO(tbosch): this seems to be a typing error in TypeScript,\n    // as it contains assertions that the result contains the same number of entries\n    // as the given module names.\n    return <ts.ResolvedModule[]>moduleNames.map(\n        moduleName => this.resolveModuleName(moduleName, containingFile));\n  }\n\n  moduleNameToFileName(m: string, containingFile?: string): string|null {\n    if (!containingFile) {\n      if (m.indexOf('.') === 0) {\n        throw new Error('Resolution of relative paths requires a containing file.');\n      }\n      // Any containing file gives the same result for absolute imports\n      containingFile = this.rootFiles[0];\n    }\n    if (this.context.moduleNameToFileName) {\n      return this.context.moduleNameToFileName(m, containingFile);\n    }\n    const resolved = this.resolveModuleName(m, containingFile);\n    return resolved ? resolved.resolvedFileName : null;\n  }\n\n  /**\n   * We want a moduleId that will appear in import statements in the generated code\n   * which will be written to `containingFile`.\n   *\n   * Note that we also generate files for files in node_modules, as libraries\n   * only ship .metadata.json files but not the generated code.\n   *\n   * Logic:\n   * 1. if the importedFile and the containingFile are from the project sources\n   *    or from the same node_modules package, use a relative path\n   * 2. if the importedFile is in a node_modules package,\n   *    use a path that starts with the package name.\n   * 3. Error if the containingFile is in the node_modules package\n   *    and the importedFile is in the project soures,\n   *    as that is a violation of the principle that node_modules packages cannot\n   *    import project sources.\n   */\n  fileNameToModuleName(importedFile: string, containingFile: string): string {\n    const cacheKey = `${importedFile}:${containingFile}`;\n    let moduleName = this.fileNameToModuleNameCache.get(cacheKey);\n    if (moduleName != null) {\n      return moduleName;\n    }\n\n    const originalImportedFile = importedFile;\n    if (this.options.traceResolution) {\n      console.error(\n          'fileNameToModuleName from containingFile', containingFile, 'to importedFile',\n          importedFile);\n    }\n\n    // drop extension\n    importedFile = importedFile.replace(EXT, '');\n    const importedFilePackageName = getPackageName(importedFile);\n    const containingFilePackageName = getPackageName(containingFile);\n\n    if (importedFilePackageName === containingFilePackageName ||\n        GENERATED_FILES.test(originalImportedFile)) {\n      const rootedContainingFile = relativeToRootDirs(containingFile, this.rootDirs);\n      const rootedImportedFile = relativeToRootDirs(importedFile, this.rootDirs);\n\n      if (rootedContainingFile !== containingFile && rootedImportedFile !== importedFile) {\n        // if both files are contained in the `rootDirs`, then strip the rootDirs\n        containingFile = rootedContainingFile;\n        importedFile = rootedImportedFile;\n      }\n      moduleName = dotRelative(path.dirname(containingFile), importedFile);\n    } else if (importedFilePackageName) {\n      moduleName = stripNodeModulesPrefix(importedFile);\n      if (originalImportedFile.endsWith('.d.ts')) {\n        // the moduleName for these typings could be shortented to the npm package name\n        // if the npm package typings matches the importedFile\n        try {\n          const modulePath = importedFile.substring(0, importedFile.length - moduleName.length) +\n              importedFilePackageName;\n          const packageJson = require(modulePath + '/package.json');\n          const packageTypings = path.posix.join(modulePath, packageJson.typings);\n          if (packageTypings === originalImportedFile) {\n            moduleName = importedFilePackageName;\n          }\n        } catch {\n          // the above require() will throw if there is no package.json file\n          // and this is safe to ignore and correct to keep the longer\n          // moduleName in this case\n        }\n      }\n    } else {\n      throw new Error(\n          `Trying to import a source file from a node_modules package: import ${originalImportedFile} from ${containingFile}`);\n    }\n\n    this.fileNameToModuleNameCache.set(cacheKey, moduleName);\n    return moduleName;\n  }\n\n  resourceNameToFileName(resourceName: string, containingFile: string): string|null {\n    // Note: we convert package paths into relative paths to be compatible with the the\n    // previous implementation of UrlResolver.\n    const firstChar = resourceName[0];\n    if (firstChar === '/') {\n      resourceName = resourceName.slice(1);\n    } else if (firstChar !== '.') {\n      resourceName = `./${resourceName}`;\n    }\n    let filePathWithNgResource =\n        this.moduleNameToFileName(addNgResourceSuffix(resourceName), containingFile);\n    // If the user specified styleUrl pointing to *.scss, but the Sass compiler was run before\n    // Angular, then the resource may have been generated as *.css. Simply try the resolution again.\n    if (!filePathWithNgResource && CSS_PREPROCESSOR_EXT.test(resourceName)) {\n      const fallbackResourceName = resourceName.replace(CSS_PREPROCESSOR_EXT, '.css');\n      filePathWithNgResource =\n          this.moduleNameToFileName(addNgResourceSuffix(fallbackResourceName), containingFile);\n    }\n    const result = filePathWithNgResource ? stripNgResourceSuffix(filePathWithNgResource) : null;\n    // Used under Bazel to report more specific error with remediation advice\n    if (!result && (this.context as any).reportMissingResource) {\n      (this.context as any).reportMissingResource(resourceName);\n    }\n    return result;\n  }\n\n  toSummaryFileName(fileName: string, referringSrcFileName: string): string {\n    return this.fileNameToModuleName(fileName, referringSrcFileName);\n  }\n\n  fromSummaryFileName(fileName: string, referringLibFileName: string): string {\n    const resolved = this.moduleNameToFileName(fileName, referringLibFileName);\n    if (!resolved) {\n      throw new Error(`Could not resolve ${fileName} from ${referringLibFileName}`);\n    }\n    return resolved;\n  }\n\n  parseSourceSpanOf(fileName: string, line: number, character: number): ParseSourceSpan|null {\n    const data = this.generatedSourceFiles.get(fileName);\n    if (data && data.emitCtx) {\n      return data.emitCtx.spanOf(line, character);\n    }\n    return null;\n  }\n\n  private getOriginalSourceFile(\n      filePath: string, languageVersion?: ts.ScriptTarget,\n      onError?: ((message: string) => void)|undefined): ts.SourceFile|null {\n    // Note: we need the explicit check via `has` as we also cache results\n    // that were null / undefined.\n    if (this.originalSourceFiles.has(filePath)) {\n      return this.originalSourceFiles.get(filePath) !;\n    }\n    if (!languageVersion) {\n      languageVersion = this.options.target || ts.ScriptTarget.Latest;\n    }\n    // Note: This can also return undefined,\n    // as the TS typings are not correct!\n    const sf = this.context.getSourceFile(filePath, languageVersion, onError) || null;\n    this.originalSourceFiles.set(filePath, sf);\n    return sf;\n  }\n\n  updateGeneratedFile(genFile: GeneratedFile): ts.SourceFile {\n    if (!genFile.stmts) {\n      throw new Error(\n          `Invalid Argument: Expected a GenerateFile with statements. ${genFile.genFileUrl}`);\n    }\n    const oldGenFile = this.generatedSourceFiles.get(genFile.genFileUrl);\n    if (!oldGenFile) {\n      throw new Error(`Illegal State: previous GeneratedFile not found for ${genFile.genFileUrl}.`);\n    }\n    const newRefs = genFileExternalReferences(genFile);\n    const oldRefs = oldGenFile.externalReferences;\n    let refsAreEqual = oldRefs.size === newRefs.size;\n    if (refsAreEqual) {\n      newRefs.forEach(r => refsAreEqual = refsAreEqual && oldRefs.has(r));\n    }\n    if (!refsAreEqual) {\n      throw new Error(\n          `Illegal State: external references changed in ${genFile.genFileUrl}.\\nOld: ${Array.from(oldRefs)}.\\nNew: ${Array.from(newRefs)}`);\n    }\n    return this.addGeneratedFile(genFile, newRefs);\n  }\n\n  private addGeneratedFile(genFile: GeneratedFile, externalReferences: Set<string>): ts.SourceFile {\n    if (!genFile.stmts) {\n      throw new Error(\n          `Invalid Argument: Expected a GenerateFile with statements. ${genFile.genFileUrl}`);\n    }\n    const {sourceText, context} = this.emitter.emitStatementsAndContext(\n        genFile.genFileUrl, genFile.stmts, /* preamble */ '',\n        /* emitSourceMaps */ false);\n    const sf = ts.createSourceFile(\n        genFile.genFileUrl, sourceText, this.options.target || ts.ScriptTarget.Latest);\n    if ((this.options.module === ts.ModuleKind.AMD || this.options.module === ts.ModuleKind.UMD) &&\n        this.context.amdModuleName) {\n      const moduleName = this.context.amdModuleName(sf);\n      if (moduleName) sf.moduleName = moduleName;\n    }\n    this.generatedSourceFiles.set(genFile.genFileUrl, {\n      sourceFile: sf,\n      emitCtx: context, externalReferences,\n    });\n    return sf;\n  }\n\n  shouldGenerateFile(fileName: string): {generate: boolean, baseFileName?: string} {\n    // TODO(tbosch): allow generating files that are not in the rootDir\n    // See https://github.com/angular/angular/issues/19337\n    if (!isInRootDir(fileName, this.options)) {\n      return {generate: false};\n    }\n    const genMatch = GENERATED_FILES.exec(fileName);\n    if (!genMatch) {\n      return {generate: false};\n    }\n    const [, base, genSuffix, suffix] = genMatch;\n    if (suffix !== 'ts' && suffix !== 'tsx') {\n      return {generate: false};\n    }\n    let baseFileName: string|undefined;\n    if (genSuffix.indexOf('ngstyle') >= 0) {\n      // Note: ngstyle files have names like `afile.css.ngstyle.ts`\n      if (!this.originalFileExists(base)) {\n        return {generate: false};\n      }\n    } else {\n      // Note: on-the-fly generated files always have a `.ts` suffix,\n      // but the file from which we generated it can be a `.ts`/ `.tsx`/ `.d.ts`\n      // (see options.generateCodeForLibraries).\n      baseFileName = [`${base}.ts`, `${base}.tsx`, `${base}.d.ts`].find(\n          baseFileName => this.isSourceFile(baseFileName) && this.originalFileExists(baseFileName));\n      if (!baseFileName) {\n        return {generate: false};\n      }\n    }\n    return {generate: true, baseFileName};\n  }\n\n  shouldGenerateFilesFor(fileName: string) {\n    // TODO(tbosch): allow generating files that are not in the rootDir\n    // See https://github.com/angular/angular/issues/19337\n    return !GENERATED_FILES.test(fileName) && this.isSourceFile(fileName) &&\n        isInRootDir(fileName, this.options);\n  }\n\n  getSourceFile(\n      fileName: string, languageVersion: ts.ScriptTarget,\n      onError?: ((message: string) => void)|undefined): ts.SourceFile {\n    // Note: Don't exit early in this method to make sure\n    // we always have up to date references on the file!\n    let genFileNames: string[] = [];\n    let sf = this.getGeneratedFile(fileName);\n    if (!sf) {\n      const summary = this.librarySummaries.get(fileName);\n      if (summary) {\n        if (!summary.sourceFile) {\n          summary.sourceFile = ts.createSourceFile(\n              fileName, summary.text, this.options.target || ts.ScriptTarget.Latest);\n        }\n        sf = summary.sourceFile;\n        genFileNames = [];\n      }\n    }\n    if (!sf) {\n      sf = this.getOriginalSourceFile(fileName);\n      const cachedGenFiles = this.generatedCodeFor.get(fileName);\n      if (cachedGenFiles) {\n        genFileNames = cachedGenFiles;\n      } else {\n        if (!this.options.noResolve && this.shouldGenerateFilesFor(fileName)) {\n          genFileNames = this.codeGenerator.findGeneratedFileNames(fileName).filter(\n              fileName => this.shouldGenerateFile(fileName).generate);\n        }\n        this.generatedCodeFor.set(fileName, genFileNames);\n      }\n    }\n    if (sf) {\n      addReferencesToSourceFile(sf, genFileNames);\n    }\n    // TODO(tbosch): TypeScript's typings for getSourceFile are incorrect,\n    // as it can very well return undefined.\n    return sf !;\n  }\n\n  private getGeneratedFile(fileName: string): ts.SourceFile|null {\n    const genSrcFile = this.generatedSourceFiles.get(fileName);\n    if (genSrcFile) {\n      return genSrcFile.sourceFile;\n    }\n    const {generate, baseFileName} = this.shouldGenerateFile(fileName);\n    if (generate) {\n      const genFile = this.codeGenerator.generateFile(fileName, baseFileName);\n      return this.addGeneratedFile(genFile, genFileExternalReferences(genFile));\n    }\n    return null;\n  }\n\n  private originalFileExists(fileName: string): boolean {\n    let fileExists = this.originalFileExistsCache.get(fileName);\n    if (fileExists == null) {\n      fileExists = this.context.fileExists(fileName);\n      this.originalFileExistsCache.set(fileName, fileExists);\n    }\n    return fileExists;\n  }\n\n  fileExists(fileName: string): boolean {\n    fileName = stripNgResourceSuffix(fileName);\n    if (this.librarySummaries.has(fileName) || this.generatedSourceFiles.has(fileName)) {\n      return true;\n    }\n    if (this.shouldGenerateFile(fileName).generate) {\n      return true;\n    }\n    return this.originalFileExists(fileName);\n  }\n\n  loadSummary(filePath: string): string|null {\n    const summary = this.librarySummaries.get(filePath);\n    if (summary) {\n      return summary.text;\n    }\n    if (this.originalFileExists(filePath)) {\n      return assert(this.context.readFile(filePath));\n    }\n    return null;\n  }\n\n  isSourceFile(filePath: string): boolean {\n    // Don't generate any files nor typecheck them\n    // if skipTemplateCodegen is set and fullTemplateTypeCheck is not yet set,\n    // for backwards compatibility.\n    if (this.options.skipTemplateCodegen && !this.options.fullTemplateTypeCheck) {\n      return false;\n    }\n    // If we have a summary from a previous compilation,\n    // treat the file never as a source file.\n    if (this.librarySummaries.has(filePath)) {\n      return false;\n    }\n    if (GENERATED_FILES.test(filePath)) {\n      return false;\n    }\n    if (this.options.generateCodeForLibraries === false && DTS.test(filePath)) {\n      return false;\n    }\n    if (DTS.test(filePath)) {\n      // Check for a bundle index.\n      if (this.hasBundleIndex(filePath)) {\n        const normalFilePath = path.normalize(filePath);\n        return this.flatModuleIndexNames.has(normalFilePath) ||\n            this.flatModuleIndexRedirectNames.has(normalFilePath);\n      }\n    }\n    return true;\n  }\n\n  readFile(fileName: string) {\n    const summary = this.librarySummaries.get(fileName);\n    if (summary) {\n      return summary.text;\n    }\n    return this.context.readFile(fileName);\n  }\n\n  getMetadataFor(filePath: string): ModuleMetadata[]|undefined {\n    return readMetadata(filePath, this.metadataReaderHost, this.metadataReaderCache);\n  }\n\n  loadResource(filePath: string): Promise<string>|string {\n    if (this.context.readResource) return this.context.readResource(filePath);\n    if (!this.originalFileExists(filePath)) {\n      throw syntaxError(`Error: Resource file not found: ${filePath}`);\n    }\n    return assert(this.context.readFile(filePath));\n  }\n\n  getOutputName(filePath: string): string {\n    return path.relative(this.getCurrentDirectory(), filePath);\n  }\n\n  private hasBundleIndex(filePath: string): boolean {\n    const checkBundleIndex = (directory: string): boolean => {\n      let result = this.flatModuleIndexCache.get(directory);\n      if (result == null) {\n        if (path.basename(directory) == 'node_module') {\n          // Don't look outside the node_modules this package is installed in.\n          result = false;\n        } else {\n          // A bundle index exists if the typings .d.ts file has a metadata.json that has an\n          // importAs.\n          try {\n            const packageFile = path.join(directory, 'package.json');\n            if (this.originalFileExists(packageFile)) {\n              // Once we see a package.json file, assume false until it we find the bundle index.\n              result = false;\n              const packageContent: any = JSON.parse(assert(this.context.readFile(packageFile)));\n              if (packageContent.typings) {\n                const typings = path.normalize(path.join(directory, packageContent.typings));\n                if (DTS.test(typings)) {\n                  const metadataFile = typings.replace(DTS, '.metadata.json');\n                  if (this.originalFileExists(metadataFile)) {\n                    const metadata = JSON.parse(assert(this.context.readFile(metadataFile)));\n                    if (metadata.flatModuleIndexRedirect) {\n                      this.flatModuleIndexRedirectNames.add(typings);\n                      // Note: don't set result = true,\n                      // as this would mark this folder\n                      // as having a bundleIndex too early without\n                      // filling the bundleIndexNames.\n                    } else if (metadata.importAs) {\n                      this.flatModuleIndexNames.add(typings);\n                      result = true;\n                    }\n                  }\n                }\n              }\n            } else {\n              const parent = path.dirname(directory);\n              if (parent != directory) {\n                // Try the parent directory.\n                result = checkBundleIndex(parent);\n              } else {\n                result = false;\n              }\n            }\n          } catch {\n            // If we encounter any errors assume we this isn't a bundle index.\n            result = false;\n          }\n        }\n        this.flatModuleIndexCache.set(directory, result);\n      }\n      return result;\n    };\n\n    return checkBundleIndex(path.dirname(filePath));\n  }\n\n  getDefaultLibFileName = (options: ts.CompilerOptions) =>\n      this.context.getDefaultLibFileName(options)\n  getCurrentDirectory = () => this.context.getCurrentDirectory();\n  getCanonicalFileName = (fileName: string) => this.context.getCanonicalFileName(fileName);\n  useCaseSensitiveFileNames = () => this.context.useCaseSensitiveFileNames();\n  getNewLine = () => this.context.getNewLine();\n  // Make sure we do not `host.realpath()` from TS as we do not want to resolve symlinks.\n  // https://github.com/Microsoft/TypeScript/issues/9552\n  realpath = (p: string) => p;\n  writeFile = this.context.writeFile.bind(this.context);\n}\n\nfunction genFileExternalReferences(genFile: GeneratedFile): Set<string> {\n  return new Set(collectExternalReferences(genFile.stmts !).map(er => er.moduleName !));\n}\n\nfunction addReferencesToSourceFile(sf: ts.SourceFile, genFileNames: string[]) {\n  // Note: as we modify ts.SourceFiles we need to keep the original\n  // value for `referencedFiles` around in cache the original host is caching ts.SourceFiles.\n  // Note: cloning the ts.SourceFile is expensive as the nodes in have parent pointers,\n  // i.e. we would also need to clone and adjust all nodes.\n  let originalReferencedFiles: ReadonlyArray<ts.FileReference> =\n      (sf as any).originalReferencedFiles;\n  if (!originalReferencedFiles) {\n    originalReferencedFiles = sf.referencedFiles;\n    (sf as any).originalReferencedFiles = originalReferencedFiles;\n  }\n  const newReferencedFiles = [...originalReferencedFiles];\n  genFileNames.forEach(gf => newReferencedFiles.push({fileName: gf, pos: 0, end: 0}));\n  sf.referencedFiles = newReferencedFiles;\n}\n\nexport function getOriginalReferences(sourceFile: ts.SourceFile): ts.FileReference[]|undefined {\n  return sourceFile && (sourceFile as any).originalReferencedFiles;\n}\n\nfunction dotRelative(from: string, to: string): string {\n  const rPath: string = path.relative(from, to).replace(/\\\\/g, '/');\n  return rPath.startsWith('.') ? rPath : './' + rPath;\n}\n\n/**\n * Moves the path into `genDir` folder while preserving the `node_modules` directory.\n */\nfunction getPackageName(filePath: string): string|null {\n  const match = NODE_MODULES_PACKAGE_NAME.exec(filePath);\n  return match ? match[1] : null;\n}\n\nfunction stripNodeModulesPrefix(filePath: string): string {\n  return filePath.replace(/.*node_modules\\//, '');\n}\n\nfunction getNodeModulesPrefix(filePath: string): string|null {\n  const match = /.*node_modules\\//.exec(filePath);\n  return match ? match[1] : null;\n}\n\nfunction stripNgResourceSuffix(fileName: string): string {\n  return fileName.replace(/\\.\\$ngresource\\$.*/, '');\n}\n\nfunction addNgResourceSuffix(fileName: string): string {\n  return `${fileName}.$ngresource$`;\n}\n"]}
|
|
587
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compiler_host.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/transformers/compiler_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 {AotCompilerHost, EmitterVisitorContext, ExternalReference, GeneratedFile, ParseSourceSpan, TypeScriptEmitter, collectExternalReferences, syntaxError} from '@angular/compiler';\nimport * as path from 'path';\nimport * as ts from 'typescript';\n\nimport {TypeCheckHost} from '../diagnostics/translate_diagnostics';\nimport {METADATA_VERSION, ModuleMetadata} from '../metadata/index';\n\nimport {CompilerHost, CompilerOptions, LibrarySummary} from './api';\nimport {MetadataReaderHost, createMetadataReaderCache, readMetadata} from './metadata_reader';\nimport {DTS, GENERATED_FILES, isInRootDir, relativeToRootDirs} from './util';\n\nconst NODE_MODULES_PACKAGE_NAME = /node_modules\\/((\\w|-|\\.)+|(@(\\w|-|\\.)+\\/(\\w|-|\\.)+))/;\nconst EXT = /(\\.ts|\\.d\\.ts|\\.js|\\.jsx|\\.tsx)$/;\nconst CSS_PREPROCESSOR_EXT = /(\\.scss|\\.less|\\.styl)$/;\n\nexport function createCompilerHost(\n    {options, tsHost = ts.createCompilerHost(options, true)}:\n        {options: CompilerOptions, tsHost?: ts.CompilerHost}): CompilerHost {\n  return tsHost;\n}\n\nexport interface MetadataProvider {\n  getMetadata(sourceFile: ts.SourceFile): ModuleMetadata|undefined;\n}\n\ninterface GenSourceFile {\n  externalReferences: Set<string>;\n  sourceFile: ts.SourceFile;\n  emitCtx: EmitterVisitorContext;\n}\n\nexport interface CodeGenerator {\n  generateFile(genFileName: string, baseFileName?: string): GeneratedFile;\n  findGeneratedFileNames(fileName: string): string[];\n}\n\nfunction assert<T>(condition: T | null | undefined) {\n  if (!condition) {\n    // TODO(chuckjaz): do the right thing\n  }\n  return condition !;\n}\n\n/**\n * Implements the following hosts based on an api.CompilerHost:\n * - ts.CompilerHost to be consumed by a ts.Program\n * - AotCompilerHost for @angular/compiler\n * - TypeCheckHost for mapping ts errors to ng errors (via translateDiagnostics)\n */\nexport class TsCompilerAotCompilerTypeCheckHostAdapter implements ts.CompilerHost, AotCompilerHost,\n    TypeCheckHost {\n  private metadataReaderCache = createMetadataReaderCache();\n  private fileNameToModuleNameCache = new Map<string, string>();\n  private flatModuleIndexCache = new Map<string, boolean>();\n  private flatModuleIndexNames = new Set<string>();\n  private flatModuleIndexRedirectNames = new Set<string>();\n  private rootDirs: string[];\n  private moduleResolutionCache: ts.ModuleResolutionCache;\n  private originalSourceFiles = new Map<string, ts.SourceFile|null>();\n  private originalFileExistsCache = new Map<string, boolean>();\n  private generatedSourceFiles = new Map<string, GenSourceFile>();\n  private generatedCodeFor = new Map<string, string[]>();\n  private emitter = new TypeScriptEmitter();\n  private metadataReaderHost: MetadataReaderHost;\n\n  // TODO(issue/24571): remove '!'.\n  getCancellationToken !: () => ts.CancellationToken;\n  // TODO(issue/24571): remove '!'.\n  getDefaultLibLocation !: () => string;\n  // TODO(issue/24571): remove '!'.\n  trace !: (s: string) => void;\n  // TODO(issue/24571): remove '!'.\n  getDirectories !: (path: string) => string[];\n  resolveTypeReferenceDirectives?:\n      (names: string[], containingFile: string) => ts.ResolvedTypeReferenceDirective[];\n  directoryExists?: (directoryName: string) => boolean;\n\n  constructor(\n      private rootFiles: ReadonlyArray<string>, private options: CompilerOptions,\n      private context: CompilerHost, private metadataProvider: MetadataProvider,\n      private codeGenerator: CodeGenerator,\n      private librarySummaries = new Map<string, LibrarySummary>()) {\n    this.moduleResolutionCache = ts.createModuleResolutionCache(\n        this.context.getCurrentDirectory !(), this.context.getCanonicalFileName.bind(this.context));\n    const basePath = this.options.basePath !;\n    this.rootDirs =\n        (this.options.rootDirs || [this.options.basePath !]).map(p => path.resolve(basePath, p));\n    if (context.getDirectories) {\n      this.getDirectories = path => context.getDirectories !(path);\n    }\n    if (context.directoryExists) {\n      this.directoryExists = directoryName => context.directoryExists !(directoryName);\n    }\n    if (context.getCancellationToken) {\n      this.getCancellationToken = () => context.getCancellationToken !();\n    }\n    if (context.getDefaultLibLocation) {\n      this.getDefaultLibLocation = () => context.getDefaultLibLocation !();\n    }\n    if (context.resolveTypeReferenceDirectives) {\n      // Backward compatibility with TypeScript 2.9 and older since return\n      // type has changed from (ts.ResolvedTypeReferenceDirective | undefined)[]\n      // to ts.ResolvedTypeReferenceDirective[] in Typescript 3.0\n      type ts3ResolveTypeReferenceDirectives = (names: string[], containingFile: string) =>\n          ts.ResolvedTypeReferenceDirective[];\n      this.resolveTypeReferenceDirectives = (names: string[], containingFile: string) =>\n          (context.resolveTypeReferenceDirectives as ts3ResolveTypeReferenceDirectives) !(\n              names, containingFile);\n    }\n    if (context.trace) {\n      this.trace = s => context.trace !(s);\n    }\n    if (context.fileNameToModuleName) {\n      this.fileNameToModuleName = context.fileNameToModuleName.bind(context);\n    }\n    // Note: don't copy over context.moduleNameToFileName as we first\n    // normalize undefined containingFile to a filled containingFile.\n    if (context.resourceNameToFileName) {\n      this.resourceNameToFileName = context.resourceNameToFileName.bind(context);\n    }\n    if (context.toSummaryFileName) {\n      this.toSummaryFileName = context.toSummaryFileName.bind(context);\n    }\n    if (context.fromSummaryFileName) {\n      this.fromSummaryFileName = context.fromSummaryFileName.bind(context);\n    }\n    this.metadataReaderHost = {\n      cacheMetadata: () => true,\n      getSourceFileMetadata: (filePath) => {\n        const sf = this.getOriginalSourceFile(filePath);\n        return sf ? this.metadataProvider.getMetadata(sf) : undefined;\n      },\n      fileExists: (filePath) => this.originalFileExists(filePath),\n      readFile: (filePath) => assert(this.context.readFile(filePath)),\n    };\n  }\n\n  private resolveModuleName(moduleName: string, containingFile: string): ts.ResolvedModule\n      |undefined {\n    const rm = ts.resolveModuleName(\n                     moduleName, containingFile.replace(/\\\\/g, '/'), this.options, this,\n                     this.moduleResolutionCache)\n                   .resolvedModule;\n    if (rm && this.isSourceFile(rm.resolvedFileName) && DTS.test(rm.resolvedFileName)) {\n      // Case: generateCodeForLibraries = true and moduleName is\n      // a .d.ts file in a node_modules folder.\n      // Need to set isExternalLibraryImport to false so that generated files for that file\n      // are emitted.\n      rm.isExternalLibraryImport = false;\n    }\n    return rm;\n  }\n\n  // Note: We implement this method so that TypeScript and Angular share the same\n  // ts.ModuleResolutionCache\n  // and that we can tell ts.Program about our different opinion about\n  // ResolvedModule.isExternalLibraryImport\n  // (see our isSourceFile method).\n  resolveModuleNames(moduleNames: string[], containingFile: string): ts.ResolvedModule[] {\n    // TODO(tbosch): this seems to be a typing error in TypeScript,\n    // as it contains assertions that the result contains the same number of entries\n    // as the given module names.\n    return <ts.ResolvedModule[]>moduleNames.map(\n        moduleName => this.resolveModuleName(moduleName, containingFile));\n  }\n\n  moduleNameToFileName(m: string, containingFile?: string): string|null {\n    if (!containingFile) {\n      if (m.indexOf('.') === 0) {\n        throw new Error('Resolution of relative paths requires a containing file.');\n      }\n      // Any containing file gives the same result for absolute imports\n      containingFile = this.rootFiles[0];\n    }\n    if (this.context.moduleNameToFileName) {\n      return this.context.moduleNameToFileName(m, containingFile);\n    }\n    const resolved = this.resolveModuleName(m, containingFile);\n    return resolved ? resolved.resolvedFileName : null;\n  }\n\n  /**\n   * We want a moduleId that will appear in import statements in the generated code\n   * which will be written to `containingFile`.\n   *\n   * Note that we also generate files for files in node_modules, as libraries\n   * only ship .metadata.json files but not the generated code.\n   *\n   * Logic:\n   * 1. if the importedFile and the containingFile are from the project sources\n   *    or from the same node_modules package, use a relative path\n   * 2. if the importedFile is in a node_modules package,\n   *    use a path that starts with the package name.\n   * 3. Error if the containingFile is in the node_modules package\n   *    and the importedFile is in the project soures,\n   *    as that is a violation of the principle that node_modules packages cannot\n   *    import project sources.\n   */\n  fileNameToModuleName(importedFile: string, containingFile: string): string {\n    const cacheKey = `${importedFile}:${containingFile}`;\n    let moduleName = this.fileNameToModuleNameCache.get(cacheKey);\n    if (moduleName != null) {\n      return moduleName;\n    }\n\n    const originalImportedFile = importedFile;\n    if (this.options.traceResolution) {\n      console.error(\n          'fileNameToModuleName from containingFile', containingFile, 'to importedFile',\n          importedFile);\n    }\n\n    // drop extension\n    importedFile = importedFile.replace(EXT, '');\n    const importedFilePackageName = getPackageName(importedFile);\n    const containingFilePackageName = getPackageName(containingFile);\n\n    if (importedFilePackageName === containingFilePackageName ||\n        GENERATED_FILES.test(originalImportedFile)) {\n      const rootedContainingFile = relativeToRootDirs(containingFile, this.rootDirs);\n      const rootedImportedFile = relativeToRootDirs(importedFile, this.rootDirs);\n\n      if (rootedContainingFile !== containingFile && rootedImportedFile !== importedFile) {\n        // if both files are contained in the `rootDirs`, then strip the rootDirs\n        containingFile = rootedContainingFile;\n        importedFile = rootedImportedFile;\n      }\n      moduleName = dotRelative(path.dirname(containingFile), importedFile);\n    } else if (importedFilePackageName) {\n      moduleName = stripNodeModulesPrefix(importedFile);\n      if (originalImportedFile.endsWith('.d.ts')) {\n        // the moduleName for these typings could be shortented to the npm package name\n        // if the npm package typings matches the importedFile\n        try {\n          const modulePath = importedFile.substring(0, importedFile.length - moduleName.length) +\n              importedFilePackageName;\n          const packageJson = require(modulePath + '/package.json');\n          const packageTypings = path.posix.join(modulePath, packageJson.typings);\n          if (packageTypings === originalImportedFile) {\n            moduleName = importedFilePackageName;\n          }\n        } catch {\n          // the above require() will throw if there is no package.json file\n          // and this is safe to ignore and correct to keep the longer\n          // moduleName in this case\n        }\n      }\n    } else {\n      throw new Error(\n          `Trying to import a source file from a node_modules package: import ${originalImportedFile} from ${containingFile}`);\n    }\n\n    this.fileNameToModuleNameCache.set(cacheKey, moduleName);\n    return moduleName;\n  }\n\n  resourceNameToFileName(resourceName: string, containingFile: string): string|null {\n    // Note: we convert package paths into relative paths to be compatible with the the\n    // previous implementation of UrlResolver.\n    const firstChar = resourceName[0];\n    if (firstChar === '/') {\n      resourceName = resourceName.slice(1);\n    } else if (firstChar !== '.') {\n      resourceName = `./${resourceName}`;\n    }\n    let filePathWithNgResource =\n        this.moduleNameToFileName(addNgResourceSuffix(resourceName), containingFile);\n    // If the user specified styleUrl pointing to *.scss, but the Sass compiler was run before\n    // Angular, then the resource may have been generated as *.css. Simply try the resolution again.\n    if (!filePathWithNgResource && CSS_PREPROCESSOR_EXT.test(resourceName)) {\n      const fallbackResourceName = resourceName.replace(CSS_PREPROCESSOR_EXT, '.css');\n      filePathWithNgResource =\n          this.moduleNameToFileName(addNgResourceSuffix(fallbackResourceName), containingFile);\n    }\n    const result = filePathWithNgResource ? stripNgResourceSuffix(filePathWithNgResource) : null;\n    // Used under Bazel to report more specific error with remediation advice\n    if (!result && (this.context as any).reportMissingResource) {\n      (this.context as any).reportMissingResource(resourceName);\n    }\n    return result;\n  }\n\n  toSummaryFileName(fileName: string, referringSrcFileName: string): string {\n    return this.fileNameToModuleName(fileName, referringSrcFileName);\n  }\n\n  fromSummaryFileName(fileName: string, referringLibFileName: string): string {\n    const resolved = this.moduleNameToFileName(fileName, referringLibFileName);\n    if (!resolved) {\n      throw new Error(`Could not resolve ${fileName} from ${referringLibFileName}`);\n    }\n    return resolved;\n  }\n\n  parseSourceSpanOf(fileName: string, line: number, character: number): ParseSourceSpan|null {\n    const data = this.generatedSourceFiles.get(fileName);\n    if (data && data.emitCtx) {\n      return data.emitCtx.spanOf(line, character);\n    }\n    return null;\n  }\n\n  private getOriginalSourceFile(\n      filePath: string, languageVersion?: ts.ScriptTarget,\n      onError?: ((message: string) => void)|undefined): ts.SourceFile|null {\n    // Note: we need the explicit check via `has` as we also cache results\n    // that were null / undefined.\n    if (this.originalSourceFiles.has(filePath)) {\n      return this.originalSourceFiles.get(filePath) !;\n    }\n    if (!languageVersion) {\n      languageVersion = this.options.target || ts.ScriptTarget.Latest;\n    }\n    // Note: This can also return undefined,\n    // as the TS typings are not correct!\n    const sf = this.context.getSourceFile(filePath, languageVersion, onError) || null;\n    this.originalSourceFiles.set(filePath, sf);\n    return sf;\n  }\n\n  updateGeneratedFile(genFile: GeneratedFile): ts.SourceFile {\n    if (!genFile.stmts) {\n      throw new Error(\n          `Invalid Argument: Expected a GenerateFile with statements. ${genFile.genFileUrl}`);\n    }\n    const oldGenFile = this.generatedSourceFiles.get(genFile.genFileUrl);\n    if (!oldGenFile) {\n      throw new Error(`Illegal State: previous GeneratedFile not found for ${genFile.genFileUrl}.`);\n    }\n    const newRefs = genFileExternalReferences(genFile);\n    const oldRefs = oldGenFile.externalReferences;\n    let refsAreEqual = oldRefs.size === newRefs.size;\n    if (refsAreEqual) {\n      newRefs.forEach(r => refsAreEqual = refsAreEqual && oldRefs.has(r));\n    }\n    if (!refsAreEqual) {\n      throw new Error(\n          `Illegal State: external references changed in ${genFile.genFileUrl}.\\nOld: ${Array.from(oldRefs)}.\\nNew: ${Array.from(newRefs)}`);\n    }\n    return this.addGeneratedFile(genFile, newRefs);\n  }\n\n  private addGeneratedFile(genFile: GeneratedFile, externalReferences: Set<string>): ts.SourceFile {\n    if (!genFile.stmts) {\n      throw new Error(\n          `Invalid Argument: Expected a GenerateFile with statements. ${genFile.genFileUrl}`);\n    }\n    const {sourceText, context} = this.emitter.emitStatementsAndContext(\n        genFile.genFileUrl, genFile.stmts, /* preamble */ '',\n        /* emitSourceMaps */ false);\n    const sf = ts.createSourceFile(\n        genFile.genFileUrl, sourceText, this.options.target || ts.ScriptTarget.Latest);\n    if ((this.options.module === ts.ModuleKind.AMD || this.options.module === ts.ModuleKind.UMD) &&\n        this.context.amdModuleName) {\n      const moduleName = this.context.amdModuleName(sf);\n      if (moduleName) sf.moduleName = moduleName;\n    }\n    this.generatedSourceFiles.set(genFile.genFileUrl, {\n      sourceFile: sf,\n      emitCtx: context, externalReferences,\n    });\n    return sf;\n  }\n\n  shouldGenerateFile(fileName: string): {generate: boolean, baseFileName?: string} {\n    // TODO(tbosch): allow generating files that are not in the rootDir\n    // See https://github.com/angular/angular/issues/19337\n    if (!isInRootDir(fileName, this.options)) {\n      return {generate: false};\n    }\n    const genMatch = GENERATED_FILES.exec(fileName);\n    if (!genMatch) {\n      return {generate: false};\n    }\n    const [, base, genSuffix, suffix] = genMatch;\n    if (suffix !== 'ts' && suffix !== 'tsx') {\n      return {generate: false};\n    }\n    let baseFileName: string|undefined;\n    if (genSuffix.indexOf('ngstyle') >= 0) {\n      // Note: ngstyle files have names like `afile.css.ngstyle.ts`\n      if (!this.originalFileExists(base)) {\n        return {generate: false};\n      }\n    } else {\n      // Note: on-the-fly generated files always have a `.ts` suffix,\n      // but the file from which we generated it can be a `.ts`/ `.tsx`/ `.d.ts`\n      // (see options.generateCodeForLibraries).\n      baseFileName = [`${base}.ts`, `${base}.tsx`, `${base}.d.ts`].find(\n          baseFileName => this.isSourceFile(baseFileName) && this.originalFileExists(baseFileName));\n      if (!baseFileName) {\n        return {generate: false};\n      }\n    }\n    return {generate: true, baseFileName};\n  }\n\n  shouldGenerateFilesFor(fileName: string) {\n    // TODO(tbosch): allow generating files that are not in the rootDir\n    // See https://github.com/angular/angular/issues/19337\n    return !GENERATED_FILES.test(fileName) && this.isSourceFile(fileName) &&\n        isInRootDir(fileName, this.options);\n  }\n\n  getSourceFile(\n      fileName: string, languageVersion: ts.ScriptTarget,\n      onError?: ((message: string) => void)|undefined): ts.SourceFile {\n    // Note: Don't exit early in this method to make sure\n    // we always have up to date references on the file!\n    let genFileNames: string[] = [];\n    let sf = this.getGeneratedFile(fileName);\n    if (!sf) {\n      const summary = this.librarySummaries.get(fileName);\n      if (summary) {\n        if (!summary.sourceFile) {\n          summary.sourceFile = ts.createSourceFile(\n              fileName, summary.text, this.options.target || ts.ScriptTarget.Latest);\n        }\n        sf = summary.sourceFile;\n        genFileNames = [];\n      }\n    }\n    if (!sf) {\n      sf = this.getOriginalSourceFile(fileName);\n      const cachedGenFiles = this.generatedCodeFor.get(fileName);\n      if (cachedGenFiles) {\n        genFileNames = cachedGenFiles;\n      } else {\n        if (!this.options.noResolve && this.shouldGenerateFilesFor(fileName)) {\n          genFileNames = this.codeGenerator.findGeneratedFileNames(fileName).filter(\n              fileName => this.shouldGenerateFile(fileName).generate);\n        }\n        this.generatedCodeFor.set(fileName, genFileNames);\n      }\n    }\n    if (sf) {\n      addReferencesToSourceFile(sf, genFileNames);\n    }\n    // TODO(tbosch): TypeScript's typings for getSourceFile are incorrect,\n    // as it can very well return undefined.\n    return sf !;\n  }\n\n  private getGeneratedFile(fileName: string): ts.SourceFile|null {\n    const genSrcFile = this.generatedSourceFiles.get(fileName);\n    if (genSrcFile) {\n      return genSrcFile.sourceFile;\n    }\n    const {generate, baseFileName} = this.shouldGenerateFile(fileName);\n    if (generate) {\n      const genFile = this.codeGenerator.generateFile(fileName, baseFileName);\n      return this.addGeneratedFile(genFile, genFileExternalReferences(genFile));\n    }\n    return null;\n  }\n\n  private originalFileExists(fileName: string): boolean {\n    let fileExists = this.originalFileExistsCache.get(fileName);\n    if (fileExists == null) {\n      fileExists = this.context.fileExists(fileName);\n      this.originalFileExistsCache.set(fileName, fileExists);\n    }\n    return fileExists;\n  }\n\n  fileExists(fileName: string): boolean {\n    fileName = stripNgResourceSuffix(fileName);\n    if (this.librarySummaries.has(fileName) || this.generatedSourceFiles.has(fileName)) {\n      return true;\n    }\n    if (this.shouldGenerateFile(fileName).generate) {\n      return true;\n    }\n    return this.originalFileExists(fileName);\n  }\n\n  loadSummary(filePath: string): string|null {\n    const summary = this.librarySummaries.get(filePath);\n    if (summary) {\n      return summary.text;\n    }\n    if (this.originalFileExists(filePath)) {\n      return assert(this.context.readFile(filePath));\n    }\n    return null;\n  }\n\n  isSourceFile(filePath: string): boolean {\n    // Don't generate any files nor typecheck them\n    // if skipTemplateCodegen is set and fullTemplateTypeCheck is not yet set,\n    // for backwards compatibility.\n    if (this.options.skipTemplateCodegen && !this.options.fullTemplateTypeCheck) {\n      return false;\n    }\n    // If we have a summary from a previous compilation,\n    // treat the file never as a source file.\n    if (this.librarySummaries.has(filePath)) {\n      return false;\n    }\n    if (GENERATED_FILES.test(filePath)) {\n      return false;\n    }\n    if (this.options.generateCodeForLibraries === false && DTS.test(filePath)) {\n      return false;\n    }\n    if (DTS.test(filePath)) {\n      // Check for a bundle index.\n      if (this.hasBundleIndex(filePath)) {\n        const normalFilePath = path.normalize(filePath);\n        return this.flatModuleIndexNames.has(normalFilePath) ||\n            this.flatModuleIndexRedirectNames.has(normalFilePath);\n      }\n    }\n    return true;\n  }\n\n  readFile(fileName: string) {\n    const summary = this.librarySummaries.get(fileName);\n    if (summary) {\n      return summary.text;\n    }\n    return this.context.readFile(fileName);\n  }\n\n  getMetadataFor(filePath: string): ModuleMetadata[]|undefined {\n    return readMetadata(filePath, this.metadataReaderHost, this.metadataReaderCache);\n  }\n\n  loadResource(filePath: string): Promise<string>|string {\n    if (this.context.readResource) return this.context.readResource(filePath);\n    if (!this.originalFileExists(filePath)) {\n      throw syntaxError(`Error: Resource file not found: ${filePath}`);\n    }\n    return assert(this.context.readFile(filePath));\n  }\n\n  getOutputName(filePath: string): string {\n    return path.relative(this.getCurrentDirectory(), filePath);\n  }\n\n  private hasBundleIndex(filePath: string): boolean {\n    const checkBundleIndex = (directory: string): boolean => {\n      let result = this.flatModuleIndexCache.get(directory);\n      if (result == null) {\n        if (path.basename(directory) == 'node_module') {\n          // Don't look outside the node_modules this package is installed in.\n          result = false;\n        } else {\n          // A bundle index exists if the typings .d.ts file has a metadata.json that has an\n          // importAs.\n          try {\n            const packageFile = path.join(directory, 'package.json');\n            if (this.originalFileExists(packageFile)) {\n              // Once we see a package.json file, assume false until it we find the bundle index.\n              result = false;\n              const packageContent: any = JSON.parse(assert(this.context.readFile(packageFile)));\n              if (packageContent.typings) {\n                const typings = path.normalize(path.join(directory, packageContent.typings));\n                if (DTS.test(typings)) {\n                  const metadataFile = typings.replace(DTS, '.metadata.json');\n                  if (this.originalFileExists(metadataFile)) {\n                    const metadata = JSON.parse(assert(this.context.readFile(metadataFile)));\n                    if (metadata.flatModuleIndexRedirect) {\n                      this.flatModuleIndexRedirectNames.add(typings);\n                      // Note: don't set result = true,\n                      // as this would mark this folder\n                      // as having a bundleIndex too early without\n                      // filling the bundleIndexNames.\n                    } else if (metadata.importAs) {\n                      this.flatModuleIndexNames.add(typings);\n                      result = true;\n                    }\n                  }\n                }\n              }\n            } else {\n              const parent = path.dirname(directory);\n              if (parent != directory) {\n                // Try the parent directory.\n                result = checkBundleIndex(parent);\n              } else {\n                result = false;\n              }\n            }\n          } catch {\n            // If we encounter any errors assume we this isn't a bundle index.\n            result = false;\n          }\n        }\n        this.flatModuleIndexCache.set(directory, result);\n      }\n      return result;\n    };\n\n    return checkBundleIndex(path.dirname(filePath));\n  }\n\n  getDefaultLibFileName = (options: ts.CompilerOptions) =>\n      this.context.getDefaultLibFileName(options)\n  getCurrentDirectory = () => this.context.getCurrentDirectory();\n  getCanonicalFileName = (fileName: string) => this.context.getCanonicalFileName(fileName);\n  useCaseSensitiveFileNames = () => this.context.useCaseSensitiveFileNames();\n  getNewLine = () => this.context.getNewLine();\n  // Make sure we do not `host.realpath()` from TS as we do not want to resolve symlinks.\n  // https://github.com/Microsoft/TypeScript/issues/9552\n  realpath = (p: string) => p;\n  writeFile = this.context.writeFile.bind(this.context);\n}\n\nfunction genFileExternalReferences(genFile: GeneratedFile): Set<string> {\n  return new Set(collectExternalReferences(genFile.stmts !).map(er => er.moduleName !));\n}\n\nfunction addReferencesToSourceFile(sf: ts.SourceFile, genFileNames: string[]) {\n  // Note: as we modify ts.SourceFiles we need to keep the original\n  // value for `referencedFiles` around in cache the original host is caching ts.SourceFiles.\n  // Note: cloning the ts.SourceFile is expensive as the nodes in have parent pointers,\n  // i.e. we would also need to clone and adjust all nodes.\n  let originalReferencedFiles: ReadonlyArray<ts.FileReference> =\n      (sf as any).originalReferencedFiles;\n  if (!originalReferencedFiles) {\n    originalReferencedFiles = sf.referencedFiles;\n    (sf as any).originalReferencedFiles = originalReferencedFiles;\n  }\n  const newReferencedFiles = [...originalReferencedFiles];\n  genFileNames.forEach(gf => newReferencedFiles.push({fileName: gf, pos: 0, end: 0}));\n  sf.referencedFiles = newReferencedFiles;\n}\n\nexport function getOriginalReferences(sourceFile: ts.SourceFile): ts.FileReference[]|undefined {\n  return sourceFile && (sourceFile as any).originalReferencedFiles;\n}\n\nfunction dotRelative(from: string, to: string): string {\n  const rPath: string = path.relative(from, to).replace(/\\\\/g, '/');\n  return rPath.startsWith('.') ? rPath : './' + rPath;\n}\n\n/**\n * Moves the path into `genDir` folder while preserving the `node_modules` directory.\n */\nfunction getPackageName(filePath: string): string|null {\n  const match = NODE_MODULES_PACKAGE_NAME.exec(filePath);\n  return match ? match[1] : null;\n}\n\nfunction stripNodeModulesPrefix(filePath: string): string {\n  return filePath.replace(/.*node_modules\\//, '');\n}\n\nfunction getNodeModulesPrefix(filePath: string): string|null {\n  const match = /.*node_modules\\//.exec(filePath);\n  return match ? match[1] : null;\n}\n\nfunction stripNgResourceSuffix(fileName: string): string {\n  return fileName.replace(/\\.\\$ngresource\\$.*/, '');\n}\n\nfunction addNgResourceSuffix(fileName: string): string {\n  return `${fileName}.$ngresource$`;\n}\n"]}
|