@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,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", "
|
|
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
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
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
|
-
|
|
28
|
-
|
|
29
|
-
newHost.fileExists =
|
|
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 =
|
|
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
|
-
|
|
36
|
+
(fileName, languageVersion, onError) => {
|
|
38
37
|
if (path.normalize(fileName) == normalSyntheticIndexName) {
|
|
39
|
-
|
|
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
|
-
|
|
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
|
-
|
|
54
|
-
|
|
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
|
-
|
|
62
|
-
|
|
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
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
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
|
|
79
|
+
host,
|
|
92
80
|
errors: [{
|
|
93
81
|
file: null,
|
|
94
82
|
start: null,
|
|
@@ -99,34 +87,34 @@
|
|
|
99
87
|
}]
|
|
100
88
|
};
|
|
101
89
|
}
|
|
102
|
-
|
|
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
|
-
|
|
109
|
-
|
|
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
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
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
|
|
119
|
-
content
|
|
120
|
-
getMetadata:
|
|
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
|
-
|
|
112
|
+
const metadataBundle = getMetadataBundle(getMetadataCache());
|
|
125
113
|
return JSON.stringify(metadataBundle.metadata);
|
|
126
114
|
}
|
|
127
115
|
});
|
|
128
|
-
return { host
|
|
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":"AAAA;;;;;;GAMG;;;;;;;;;;;;;IAGH,2BAA6B;IAC7B,+BAAiC;IAKjC,sEAA+D;IAC/D,gFAAqD;IAErD,IAAM,GAAG,GAAG,UAAU,CAAC;IACvB,IAAM,MAAM,GAAG,UAAU,CAAC;IAE1B,SAAS,wBAAwB,CAC7B,QAAW,EAAE,cAA0E;QACzF,IAAM,wBAAwB,GAAG,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAErE,IAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QACxC,OAAO,CAAC,UAAU,GAAG,UAAC,QAAgB;YACpC,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,wBAAwB,IAAI,QAAQ,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;QAC/F,CAAC,CAAC;QAEF,OAAO,CAAC,QAAQ,GAAG,UAAC,QAAgB;YAClC,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,wBAAwB,CAAC,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;gBACxB,QAAQ,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QAC5F,CAAC,CAAC;QAEF,OAAO,CAAC,aAAa;YACjB,UAAC,QAAgB,EAAE,eAAgC,EAAE,OAAmC;gBACtF,IAAI,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,wBAAwB,EAAE;oBACxD,IAAM,EAAE,GAAG,EAAE,CAAC,gBAAgB,CAAC,QAAQ,EAAE,cAAc,CAAC,OAAO,EAAE,eAAe,EAAE,IAAI,CAAC,CAAC;oBACxF,IAAK,QAAgB,CAAC,oBAAoB,EAAE;wBAC1C,EAAE,CAAC,UAAU,GAAI,QAAgB,CAAC,oBAAoB,CAAC,QAAQ,CAAC,CAAC;qBAClE;oBACD,OAAO,EAAE,CAAC;iBACX;gBACD,OAAO,QAAQ,CAAC,aAAa,CAAC,QAAQ,EAAE,eAAe,EAAE,OAAO,CAAC,CAAC;YACpE,CAAC,CAAC;QAEN,OAAO,CAAC,SAAS;YACb,UAAC,QAAgB,EAAE,IAAY,EAAE,kBAA2B,EAC3D,OAAgD,EAChD,WAAsC;gBACrC,QAAQ,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,EAAE,kBAAkB,EAAE,OAAO,EAAE,WAAW,CAAC,CAAC;gBAC7E,IAAI,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,WAAW,IAAI,WAAW,CAAC,MAAM,IAAI,CAAC;oBAC7D,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,wBAAwB,EAAE;oBACxE,wEAAwE;oBACxE,IAAM,YAAY,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAC;oBAC7D,IAAM,aAAa,GAAG,cAAc,CAAC,WAAW,EAAE,CAAC;oBACnD,QAAQ,CAAC,SAAS,CAAC,YAAY,EAAE,aAAa,EAAE,kBAAkB,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC;iBAClF;YACH,CAAC,CAAC;QACN,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,SAAgB,qBAAqB,CACjC,SAA0B,EAAE,SAAgC,EAAE,IAAO,EACrE,gBACiB;;QACnB,IAAM,KAAK,GAAG,SAAS,CAAC,MAAM,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAZ,CAAY,CAAC,CAAC;QAClD,IAAI,SAA2B,CAAC;QAChC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YACtB,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;SACtB;aAAM;;gBACL,KAAgB,IAAA,UAAA,iBAAA,KAAK,CAAA,4BAAA,+CAAE;oBAAlB,IAAM,CAAC,kBAAA;oBACV,iFAAiF;oBACjF,+EAA+E;oBAC/E,sBAAsB;oBACtB,IAAI,CAAC,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE;wBAC3B,IAAI,CAAC,SAAS,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,MAAM,EAAE;4BAC7C,SAAS,GAAG,CAAC,CAAC;yBACf;qBACF;iBACF;;;;;;;;;SACF;QACD,IAAI,CAAC,SAAS,EAAE;YACd,OAAO;gBACL,IAAI,MAAA;gBACJ,MAAM,EAAE,CAAC;wBACP,IAAI,EAAE,IAA4B;wBAClC,KAAK,EAAE,IAAqB;wBAC5B,MAAM,EAAE,IAAqB;wBAC7B,WAAW,EACP,oGAAoG;wBACxG,QAAQ,EAAE,EAAE,CAAC,kBAAkB,CAAC,KAAK;wBACrC,IAAI,EAAE,CAAC;qBACR,CAAC;aACH,CAAC;SACH;QAED,IAAM,WAAW,GAAG,SAAS,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QAEnD,iGAAiG;QACjG,kGAAkG;QAClG,iGAAiG;QACjG,gGAAgG;QAChG,OAAO;QACP,IAAM,iBAAiB,GAAG,UAAC,KAA2B;YACpD,IAAM,OAAO,GAAG,IAAI,yBAAe,CAC/B,WAAW,EAAE,SAAS,CAAC,YAAY,EAAE,IAAI,6BAAmB,CAAC,IAAI,EAAE,KAAK,EAAE,SAAS,CAAC,EACpF,SAAS,CAAC,6BAA6B,CAAC,CAAC;YAC7C,OAAO,OAAO,CAAC,iBAAiB,EAAE,CAAC;QACrC,CAAC,CAAC;QAEF,mDAAmD;QACnD,IAAM,cAAc,GAAG,iBAAiB,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;QACnE,IAAM,IAAI,GACN,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,SAAS,CAAC,iBAAmB,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC;QAC/F,IAAM,YAAY,GAAG,OAAK,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAG,CAAC;QACvD,IAAM,OAAO,GAAG,oCAAqB,CAAC,YAAY,EAAE,cAAc,CAAC,QAAQ,CAAC,CAAC;QAE7E,IAAI,GAAG,wBAAwB,CAAC,IAAI,EAAE;YACpC,IAAI,MAAA;YACJ,OAAO,SAAA;YACP,WAAW,EAAE;gBACX,yFAAyF;gBACzF,6FAA6F;gBAC7F,iDAAiD;gBACjD,IAAM,cAAc,GAAG,iBAAiB,CAAC,gBAAgB,EAAE,CAAC,CAAC;gBAC7D,OAAO,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;YACjD,CAAC;SACF,CAAC,CAAC;QACH,OAAO,EAAC,IAAI,MAAA,EAAE,SAAS,EAAE,IAAI,EAAC,CAAC;IACjC,CAAC;IApED,sDAoEC","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"]}
|