(function (factory) { if (typeof module === "object" && typeof module.exports === "object") { var v = factory(require, exports); if (v !== undefined) module.exports = v; } else if (typeof define === "function" && define.amd) { define("@angular/compiler-cli/src/metadata/bundler", ["require", "exports", "tslib", "path", "typescript", "@angular/compiler-cli/src/metadata/collector", "@angular/compiler-cli/src/metadata/schema"], factory); } })(function (require, exports) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var tslib_1 = require("tslib"); /** * @license * Copyright Google Inc. All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://angular.io/license */ var path = require("path"); var ts = require("typescript"); var collector_1 = require("@angular/compiler-cli/src/metadata/collector"); var schema_1 = require("@angular/compiler-cli/src/metadata/schema"); // The character set used to produce private names. var PRIVATE_NAME_CHARS = 'abcdefghijklmnopqrstuvwxyz'; var MetadataBundler = /** @class */ (function () { function MetadataBundler(root, importAs, host, privateSymbolPrefix) { this.root = root; this.importAs = importAs; this.host = host; this.symbolMap = new Map(); this.metadataCache = new Map(); this.exports = new Map(); this.rootModule = "./" + path.basename(root); this.privateSymbolPrefix = (privateSymbolPrefix || '').replace(/\W/g, '_'); } MetadataBundler.prototype.getMetadataBundle = function () { // Export the root module. This also collects the transitive closure of all values referenced by // the exports. var exportedSymbols = this.exportAll(this.rootModule); this.canonicalizeSymbols(exportedSymbols); // TODO: exports? e.g. a module re-exports a symbol from another bundle var metadata = this.getEntries(exportedSymbols); var privates = Array.from(this.symbolMap.values()) .filter(function (s) { return s.referenced && s.isPrivate; }) .map(function (s) { return ({ privateName: s.privateName, name: s.declaration.name, module: s.declaration.module }); }); var origins = Array.from(this.symbolMap.values()) .filter(function (s) { return s.referenced && !s.reexport; }) .reduce(function (p, s) { p[s.isPrivate ? s.privateName : s.name] = s.declaration.module; return p; }, {}); var exports = this.getReExports(exportedSymbols); return { metadata: { __symbolic: 'module', version: schema_1.METADATA_VERSION, exports: exports.length ? exports : undefined, metadata: metadata, origins: origins, importAs: this.importAs }, privates: privates }; }; MetadataBundler.resolveModule = function (importName, from) { return resolveModule(importName, from); }; MetadataBundler.prototype.getMetadata = function (moduleName) { var result = this.metadataCache.get(moduleName); if (!result) { if (moduleName.startsWith('.')) { var fullModuleName = resolveModule(moduleName, this.root); result = this.host.getMetadataFor(fullModuleName, this.root); } this.metadataCache.set(moduleName, result); } return result; }; MetadataBundler.prototype.exportAll = function (moduleName) { var e_1, _a, e_2, _b, e_3, _c; var _this = this; var module = this.getMetadata(moduleName); var result = this.exports.get(moduleName); if (result) { return result; } result = []; var exportSymbol = function (exportedSymbol, exportAs) { var symbol = _this.symbolOf(moduleName, exportAs); result.push(symbol); exportedSymbol.reexportedAs = symbol; symbol.exports = exportedSymbol; }; // Export all the symbols defined in this module. if (module && module.metadata) { for (var key in module.metadata) { var data = module.metadata[key]; if (schema_1.isMetadataImportedSymbolReferenceExpression(data)) { // This is a re-export of an imported symbol. Record this as a re-export. var exportFrom = resolveModule(data.module, moduleName); this.exportAll(exportFrom); var symbol = this.symbolOf(exportFrom, data.name); exportSymbol(symbol, key); } else { // Record that this symbol is exported by this module. result.push(this.symbolOf(moduleName, key)); } } } // Export all the re-exports from this module if (module && module.exports) { var unnamedModuleExportsIdx = 0; try { for (var _d = tslib_1.__values(module.exports), _e = _d.next(); !_e.done; _e = _d.next()) { var exportDeclaration = _e.value; var exportFrom = resolveModule(exportDeclaration.from, moduleName); // Record all the exports from the module even if we don't use it directly. var exportedSymbols = this.exportAll(exportFrom); if (exportDeclaration.export) { try { // Re-export all the named exports from a module. for (var _f = (e_2 = void 0, tslib_1.__values(exportDeclaration.export)), _g = _f.next(); !_g.done; _g = _f.next()) { var exportItem = _g.value; var name = typeof exportItem == 'string' ? exportItem : exportItem.name; var exportAs = typeof exportItem == 'string' ? exportItem : exportItem.as; var symbol = this.symbolOf(exportFrom, name); if (exportedSymbols && exportedSymbols.length == 1 && exportedSymbols[0].reexport && exportedSymbols[0].name == '*') { // This is a named export from a module we have no metadata about. Record the named // export as a re-export. symbol.reexport = true; } exportSymbol(this.symbolOf(exportFrom, name), exportAs); } } catch (e_2_1) { e_2 = { error: e_2_1 }; } finally { try { if (_g && !_g.done && (_b = _f.return)) _b.call(_f); } finally { if (e_2) throw e_2.error; } } } else { // Re-export all the symbols from the module var exportedSymbols_2 = this.exportAll(exportFrom); try { for (var exportedSymbols_1 = (e_3 = void 0, tslib_1.__values(exportedSymbols_2)), exportedSymbols_1_1 = exportedSymbols_1.next(); !exportedSymbols_1_1.done; exportedSymbols_1_1 = exportedSymbols_1.next()) { var exportedSymbol = exportedSymbols_1_1.value; // In case the exported symbol does not have a name, we need to give it an unique // name for the current module. This is necessary because there can be multiple // unnamed re-exports in a given module. var name = exportedSymbol.name === '*' ? "unnamed_reexport_" + unnamedModuleExportsIdx++ : exportedSymbol.name; exportSymbol(exportedSymbol, name); } } catch (e_3_1) { e_3 = { error: e_3_1 }; } finally { try { if (exportedSymbols_1_1 && !exportedSymbols_1_1.done && (_c = exportedSymbols_1.return)) _c.call(exportedSymbols_1); } finally { if (e_3) throw e_3.error; } } } } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (_e && !_e.done && (_a = _d.return)) _a.call(_d); } finally { if (e_1) throw e_1.error; } } } if (!module) { // If no metadata is found for this import then it is considered external to the // library and should be recorded as a re-export in the final metadata if it is // eventually re-exported. var symbol = this.symbolOf(moduleName, '*'); symbol.reexport = true; result.push(symbol); } this.exports.set(moduleName, result); return result; }; /** * Fill in the canonicalSymbol which is the symbol that should be imported by factories. * The canonical symbol is the one exported by the index file for the bundle or definition * symbol for private symbols that are not exported by bundle index. */ MetadataBundler.prototype.canonicalizeSymbols = function (exportedSymbols) { var symbols = Array.from(this.symbolMap.values()); this.exported = new Set(exportedSymbols); symbols.forEach(this.canonicalizeSymbol, this); }; MetadataBundler.prototype.canonicalizeSymbol = function (symbol) { var rootExport = getRootExport(symbol); var declaration = getSymbolDeclaration(symbol); var isPrivate = !this.exported.has(rootExport); var canonicalSymbol = isPrivate ? declaration : rootExport; symbol.isPrivate = isPrivate; symbol.declaration = declaration; symbol.canonicalSymbol = canonicalSymbol; symbol.reexport = declaration.reexport; }; MetadataBundler.prototype.getEntries = function (exportedSymbols) { var _this = this; var result = {}; var exportedNames = new Set(exportedSymbols.map(function (s) { return s.name; })); var privateName = 0; function newPrivateName(prefix) { while (true) { var digits = []; var index = privateName++; var base = PRIVATE_NAME_CHARS; while (!digits.length || index > 0) { digits.unshift(base[index % base.length]); index = Math.floor(index / base.length); } var result_1 = "\u0275" + prefix + digits.join(''); if (!exportedNames.has(result_1)) return result_1; } } exportedSymbols.forEach(function (symbol) { return _this.convertSymbol(symbol); }); var symbolsMap = new Map(); Array.from(this.symbolMap.values()).forEach(function (symbol) { if (symbol.referenced && !symbol.reexport) { var name = symbol.name; var identifier = symbol.declaration.module + ":" + symbol.declaration.name; if (symbol.isPrivate && !symbol.privateName) { name = newPrivateName(_this.privateSymbolPrefix); symbol.privateName = name; } if (symbolsMap.has(identifier)) { var names = symbolsMap.get(identifier); names.push(name); } else { symbolsMap.set(identifier, [name]); } result[name] = symbol.value; } }); // check for duplicated entries symbolsMap.forEach(function (names, identifier) { if (names.length > 1) { var _a = tslib_1.__read(identifier.split(':'), 2), module_1 = _a[0], declaredName = _a[1]; // prefer the export that uses the declared name (if any) var reference_1 = names.indexOf(declaredName); if (reference_1 === -1) { reference_1 = 0; } // keep one entry and replace the others by references names.forEach(function (name, i) { if (i !== reference_1) { result[name] = { __symbolic: 'reference', name: names[reference_1] }; } }); } }); return result; }; MetadataBundler.prototype.getReExports = function (exportedSymbols) { var e_4, _a; var modules = new Map(); var exportAlls = new Set(); try { for (var exportedSymbols_3 = tslib_1.__values(exportedSymbols), exportedSymbols_3_1 = exportedSymbols_3.next(); !exportedSymbols_3_1.done; exportedSymbols_3_1 = exportedSymbols_3.next()) { var symbol = exportedSymbols_3_1.value; if (symbol.reexport) { // symbol.declaration is guaranteed to be defined during the phase this method is called. var declaration = symbol.declaration; var module_2 = declaration.module; if (declaration.name == '*') { // Reexport all the symbols. exportAlls.add(declaration.module); } else { // Re-export the symbol as the exported name. var entry = modules.get(module_2); if (!entry) { entry = []; modules.set(module_2, entry); } var as = symbol.name; var name = declaration.name; entry.push({ name: name, as: as }); } } } } catch (e_4_1) { e_4 = { error: e_4_1 }; } finally { try { if (exportedSymbols_3_1 && !exportedSymbols_3_1.done && (_a = exportedSymbols_3.return)) _a.call(exportedSymbols_3); } finally { if (e_4) throw e_4.error; } } return tslib_1.__spread(Array.from(exportAlls.values()).map(function (from) { return ({ from: from }); }), Array.from(modules.entries()).map(function (_a) { var _b = tslib_1.__read(_a, 2), from = _b[0], exports = _b[1]; return ({ export: exports, from: from }); })); }; MetadataBundler.prototype.convertSymbol = function (symbol) { // canonicalSymbol is ensured to be defined before this is called. var canonicalSymbol = symbol.canonicalSymbol; if (!canonicalSymbol.referenced) { canonicalSymbol.referenced = true; // declaration is ensured to be definded before this method is called. var declaration = canonicalSymbol.declaration; var module_3 = this.getMetadata(declaration.module); if (module_3) { var value = module_3.metadata[declaration.name]; if (value && !declaration.name.startsWith('___')) { canonicalSymbol.value = this.convertEntry(declaration.module, value); } } } }; MetadataBundler.prototype.convertEntry = function (moduleName, value) { if (schema_1.isClassMetadata(value)) { return this.convertClass(moduleName, value); } if (schema_1.isFunctionMetadata(value)) { return this.convertFunction(moduleName, value); } if (schema_1.isInterfaceMetadata(value)) { return value; } return this.convertValue(moduleName, value); }; MetadataBundler.prototype.convertClass = function (moduleName, value) { var _this = this; return { __symbolic: 'class', arity: value.arity, extends: this.convertExpression(moduleName, value.extends), decorators: value.decorators && value.decorators.map(function (d) { return _this.convertExpression(moduleName, d); }), members: this.convertMembers(moduleName, value.members), statics: value.statics && this.convertStatics(moduleName, value.statics) }; }; MetadataBundler.prototype.convertMembers = function (moduleName, members) { var _this = this; var result = {}; for (var name in members) { var value = members[name]; result[name] = value.map(function (v) { return _this.convertMember(moduleName, v); }); } return result; }; MetadataBundler.prototype.convertMember = function (moduleName, member) { var _this = this; var result = { __symbolic: member.__symbolic }; result.decorators = member.decorators && member.decorators.map(function (d) { return _this.convertExpression(moduleName, d); }); if (schema_1.isMethodMetadata(member)) { result.parameterDecorators = member.parameterDecorators && member.parameterDecorators.map(function (d) { return d && d.map(function (p) { return _this.convertExpression(moduleName, p); }); }); if (schema_1.isConstructorMetadata(member)) { if (member.parameters) { result.parameters = member.parameters.map(function (p) { return _this.convertExpression(moduleName, p); }); } } } return result; }; MetadataBundler.prototype.convertStatics = function (moduleName, statics) { var result = {}; for (var key in statics) { var value = statics[key]; if (schema_1.isFunctionMetadata(value)) { result[key] = this.convertFunction(moduleName, value); } else if (schema_1.isMetadataSymbolicCallExpression(value)) { // Class members can also contain static members that call a function with module // references. e.g. "static ɵprov = ɵɵdefineInjectable(..)". We also need to // convert these module references because otherwise these resolve to non-existent files. result[key] = this.convertValue(moduleName, value); } else { result[key] = value; } } return result; }; MetadataBundler.prototype.convertFunction = function (moduleName, value) { var _this = this; return { __symbolic: 'function', parameters: value.parameters, defaults: value.defaults && value.defaults.map(function (v) { return _this.convertValue(moduleName, v); }), value: this.convertValue(moduleName, value.value) }; }; MetadataBundler.prototype.convertValue = function (moduleName, value) { var _this = this; if (isPrimitive(value)) { return value; } if (schema_1.isMetadataError(value)) { return this.convertError(moduleName, value); } if (schema_1.isMetadataSymbolicExpression(value)) { return this.convertExpression(moduleName, value); } if (Array.isArray(value)) { return value.map(function (v) { return _this.convertValue(moduleName, v); }); } // Otherwise it is a metadata object. var object = value; var result = {}; for (var key in object) { result[key] = this.convertValue(moduleName, object[key]); } return result; }; MetadataBundler.prototype.convertExpression = function (moduleName, value) { if (value) { switch (value.__symbolic) { case 'error': return this.convertError(moduleName, value); case 'reference': return this.convertReference(moduleName, value); default: return this.convertExpressionNode(moduleName, value); } } return value; }; MetadataBundler.prototype.convertError = function (module, value) { return { __symbolic: 'error', message: value.message, line: value.line, character: value.character, context: value.context, module: module }; }; MetadataBundler.prototype.convertReference = function (moduleName, value) { var _this = this; var createReference = function (symbol) { var declaration = symbol.declaration; if (declaration.module.startsWith('.')) { // Reference to a symbol defined in the module. Ensure it is converted then return a // references to the final symbol. _this.convertSymbol(symbol); return { __symbolic: 'reference', get name() { // Resolved lazily because private names are assigned late. var canonicalSymbol = symbol.canonicalSymbol; if (canonicalSymbol.isPrivate == null) { throw Error('Invalid state: isPrivate was not initialized'); } return canonicalSymbol.isPrivate ? canonicalSymbol.privateName : canonicalSymbol.name; } }; } else { // The symbol was a re-exported symbol from another module. Return a reference to the // original imported symbol. return { __symbolic: 'reference', name: declaration.name, module: declaration.module }; } }; if (schema_1.isMetadataGlobalReferenceExpression(value)) { var metadata = this.getMetadata(moduleName); if (metadata && metadata.metadata && metadata.metadata[value.name]) { // Reference to a symbol defined in the module return createReference(this.canonicalSymbolOf(moduleName, value.name)); } // If a reference has arguments, the arguments need to be converted. if (value.arguments) { return { __symbolic: 'reference', name: value.name, arguments: value.arguments.map(function (a) { return _this.convertValue(moduleName, a); }) }; } // Global references without arguments (such as to Math or JSON) are unmodified. return value; } if (schema_1.isMetadataImportedSymbolReferenceExpression(value)) { // References to imported symbols are separated into two, references to bundled modules and // references to modules external to the bundle. If the module reference is relative it is // assumed to be in the bundle. If it is Global it is assumed to be outside the bundle. // References to symbols outside the bundle are left unmodified. References to symbol inside // the bundle need to be converted to a bundle import reference reachable from the bundle // index. if (value.module.startsWith('.')) { // Reference is to a symbol defined inside the module. Convert the reference to a reference // to the canonical symbol. var referencedModule = resolveModule(value.module, moduleName); var referencedName = value.name; return createReference(this.canonicalSymbolOf(referencedModule, referencedName)); } // Value is a reference to a symbol defined outside the module. if (value.arguments) { // If a reference has arguments the arguments need to be converted. return { __symbolic: 'reference', name: value.name, module: value.module, arguments: value.arguments.map(function (a) { return _this.convertValue(moduleName, a); }) }; } return value; } if (schema_1.isMetadataModuleReferenceExpression(value)) { // Cannot support references to bundled modules as the internal modules of a bundle are erased // by the bundler. if (value.module.startsWith('.')) { return { __symbolic: 'error', message: 'Unsupported bundled module reference', context: { module: value.module } }; } // References to unbundled modules are unmodified. return value; } }; MetadataBundler.prototype.convertExpressionNode = function (moduleName, value) { var result = { __symbolic: value.__symbolic }; for (var key in value) { result[key] = this.convertValue(moduleName, value[key]); } return result; }; MetadataBundler.prototype.symbolOf = function (module, name) { var symbolKey = module + ":" + name; var symbol = this.symbolMap.get(symbolKey); if (!symbol) { symbol = { module: module, name: name }; this.symbolMap.set(symbolKey, symbol); } return symbol; }; MetadataBundler.prototype.canonicalSymbolOf = function (module, name) { // Ensure the module has been seen. this.exportAll(module); var symbol = this.symbolOf(module, name); if (!symbol.canonicalSymbol) { this.canonicalizeSymbol(symbol); } return symbol; }; return MetadataBundler; }()); exports.MetadataBundler = MetadataBundler; var CompilerHostAdapter = /** @class */ (function () { function CompilerHostAdapter(host, cache, options) { this.host = host; this.cache = cache; this.options = options; this.collector = new collector_1.MetadataCollector(); } CompilerHostAdapter.prototype.getMetadataFor = function (fileName, containingFile) { var resolvedModule = ts.resolveModuleName(fileName, containingFile, this.options, this.host).resolvedModule; var sourceFile; if (resolvedModule) { var resolvedFileName = resolvedModule.resolvedFileName; if (resolvedModule.extension !== '.ts') { resolvedFileName = resolvedFileName.replace(/(\.d\.ts|\.js)$/, '.ts'); } sourceFile = this.host.getSourceFile(resolvedFileName, ts.ScriptTarget.Latest); } else { // If typescript is unable to resolve the file, fallback on old behavior if (!this.host.fileExists(fileName + '.ts')) return undefined; sourceFile = this.host.getSourceFile(fileName + '.ts', ts.ScriptTarget.Latest); } // If there is a metadata cache, use it to get the metadata for this source file. Otherwise, // fall back on the locally created MetadataCollector. if (!sourceFile) { return undefined; } else if (this.cache) { return this.cache.getMetadata(sourceFile); } else { return this.collector.getMetadata(sourceFile); } }; return CompilerHostAdapter; }()); exports.CompilerHostAdapter = CompilerHostAdapter; function resolveModule(importName, from) { if (importName.startsWith('.') && from) { var normalPath = path.normalize(path.join(path.dirname(from), importName)); if (!normalPath.startsWith('.') && from.startsWith('.')) { // path.normalize() preserves leading '../' but not './'. This adds it back. normalPath = "." + path.sep + normalPath; } // Replace windows path delimiters with forward-slashes. Otherwise the paths are not // TypeScript compatible when building the bundle. return normalPath.replace(/\\/g, '/'); } return importName; } function isPrimitive(o) { return o === null || (typeof o !== 'function' && typeof o !== 'object'); } function getRootExport(symbol) { return symbol.reexportedAs ? getRootExport(symbol.reexportedAs) : symbol; } function getSymbolDeclaration(symbol) { return symbol.exports ? getSymbolDeclaration(symbol.exports) : symbol; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundler.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/metadata/bundler.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 */\nimport * as path from 'path';\nimport * as ts from 'typescript';\n\nimport {MetadataCache} from '../transformers/metadata_cache';\n\nimport {MetadataCollector} from './collector';\nimport {ClassMetadata, ConstructorMetadata, FunctionMetadata, METADATA_VERSION, MemberMetadata, MetadataEntry, MetadataError, MetadataMap, MetadataObject, MetadataSymbolicExpression, MetadataSymbolicReferenceExpression, MetadataValue, MethodMetadata, ModuleExportMetadata, ModuleMetadata, isClassMetadata, isConstructorMetadata, isFunctionMetadata, isInterfaceMetadata, isMetadataError, isMetadataGlobalReferenceExpression, isMetadataImportedSymbolReferenceExpression, isMetadataModuleReferenceExpression, isMetadataSymbolicCallExpression, isMetadataSymbolicExpression, isMethodMetadata} from './schema';\n\n\n\n// The character set used to produce private names.\nconst PRIVATE_NAME_CHARS = 'abcdefghijklmnopqrstuvwxyz';\n\ninterface Symbol {\n  module: string;\n  name: string;\n\n  // Produced by indirectly by exportAll() for symbols re-export another symbol.\n  exports?: Symbol;\n\n  // Produced by indirectly by exportAll() for symbols are re-exported by another symbol.\n  reexportedAs?: Symbol;\n\n  // Produced by canonicalizeSymbols() for all symbols. A symbol is private if it is not\n  // exported by the index.\n  isPrivate?: boolean;\n\n  // Produced by canonicalizeSymbols() for all symbols. This is the one symbol that\n  // respresents all other symbols and is the only symbol that, among all the re-exported\n  // aliases, whose fields can be trusted to contain the correct information.\n  // For private symbols this is the declaration symbol. For public symbols this is the\n  // symbol that is exported.\n  canonicalSymbol?: Symbol;\n\n  // Produced by canonicalizeSymbols() for all symbols. This the symbol that originally\n  // declared the value and should be used to fetch the value.\n  declaration?: Symbol;\n\n  // A symbol is referenced if it is exported from index or referenced by the value of\n  // a referenced symbol's value.\n  referenced?: boolean;\n\n  // A symbol is marked as a re-export the symbol was rexported from a module that is\n  // not part of the flat module bundle.\n  reexport?: boolean;\n\n  // Only valid for referenced canonical symbols. Produces by convertSymbols().\n  value?: MetadataEntry;\n\n  // Only valid for referenced private symbols. It is the name to use to import the symbol from\n  // the bundle index. Produce by assignPrivateNames();\n  privateName?: string;\n}\n\nexport interface BundleEntries { [name: string]: MetadataEntry; }\n\nexport interface BundlePrivateEntry {\n  privateName: string;\n  name: string;\n  module: string;\n}\n\nexport interface BundledModule {\n  metadata: ModuleMetadata;\n  privates: BundlePrivateEntry[];\n}\n\nexport interface MetadataBundlerHost {\n  getMetadataFor(moduleName: string, containingFile: string): ModuleMetadata|undefined;\n}\n\ntype StaticsMetadata = {\n  [name: string]: MetadataValue | FunctionMetadata;\n};\n\nexport class MetadataBundler {\n  private symbolMap = new Map<string, Symbol>();\n  private metadataCache = new Map<string, ModuleMetadata|undefined>();\n  private exports = new Map<string, Symbol[]>();\n  private rootModule: string;\n  private privateSymbolPrefix: string;\n  // TODO(issue/24571): remove '!'.\n  private exported !: Set<Symbol>;\n\n  constructor(\n      private root: string, private importAs: string|undefined, private host: MetadataBundlerHost,\n      privateSymbolPrefix?: string) {\n    this.rootModule = `./${path.basename(root)}`;\n    this.privateSymbolPrefix = (privateSymbolPrefix || '').replace(/\\W/g, '_');\n  }\n\n  getMetadataBundle(): BundledModule {\n    // Export the root module. This also collects the transitive closure of all values referenced by\n    // the exports.\n    const exportedSymbols = this.exportAll(this.rootModule);\n    this.canonicalizeSymbols(exportedSymbols);\n    // TODO: exports? e.g. a module re-exports a symbol from another bundle\n    const metadata = this.getEntries(exportedSymbols);\n    const privates = Array.from(this.symbolMap.values())\n                         .filter(s => s.referenced && s.isPrivate)\n                         .map(s => ({\n                                privateName: s.privateName !,\n                                name: s.declaration !.name,\n                                module: s.declaration !.module\n                              }));\n    const origins = Array.from(this.symbolMap.values())\n                        .filter(s => s.referenced && !s.reexport)\n                        .reduce<{[name: string]: string}>((p, s) => {\n                          p[s.isPrivate ? s.privateName ! : s.name] = s.declaration !.module;\n                          return p;\n                        }, {});\n    const exports = this.getReExports(exportedSymbols);\n    return {\n      metadata: {\n        __symbolic: 'module',\n        version: METADATA_VERSION,\n        exports: exports.length ? exports : undefined, metadata, origins,\n        importAs: this.importAs !\n      },\n      privates\n    };\n  }\n\n  static resolveModule(importName: string, from: string): string {\n    return resolveModule(importName, from);\n  }\n\n  private getMetadata(moduleName: string): ModuleMetadata|undefined {\n    let result = this.metadataCache.get(moduleName);\n    if (!result) {\n      if (moduleName.startsWith('.')) {\n        const fullModuleName = resolveModule(moduleName, this.root);\n        result = this.host.getMetadataFor(fullModuleName, this.root);\n      }\n      this.metadataCache.set(moduleName, result);\n    }\n    return result;\n  }\n\n  private exportAll(moduleName: string): Symbol[] {\n    const module = this.getMetadata(moduleName);\n    let result = this.exports.get(moduleName);\n\n    if (result) {\n      return result;\n    }\n\n    result = [];\n\n    const exportSymbol = (exportedSymbol: Symbol, exportAs: string) => {\n      const symbol = this.symbolOf(moduleName, exportAs);\n      result !.push(symbol);\n      exportedSymbol.reexportedAs = symbol;\n      symbol.exports = exportedSymbol;\n    };\n\n    // Export all the symbols defined in this module.\n    if (module && module.metadata) {\n      for (let key in module.metadata) {\n        const data = module.metadata[key];\n        if (isMetadataImportedSymbolReferenceExpression(data)) {\n          // This is a re-export of an imported symbol. Record this as a re-export.\n          const exportFrom = resolveModule(data.module, moduleName);\n          this.exportAll(exportFrom);\n          const symbol = this.symbolOf(exportFrom, data.name);\n          exportSymbol(symbol, key);\n        } else {\n          // Record that this symbol is exported by this module.\n          result.push(this.symbolOf(moduleName, key));\n        }\n      }\n    }\n\n    // Export all the re-exports from this module\n    if (module && module.exports) {\n      let unnamedModuleExportsIdx = 0;\n      for (const exportDeclaration of module.exports) {\n        const exportFrom = resolveModule(exportDeclaration.from, moduleName);\n        // Record all the exports from the module even if we don't use it directly.\n        const exportedSymbols = this.exportAll(exportFrom);\n        if (exportDeclaration.export) {\n          // Re-export all the named exports from a module.\n          for (const exportItem of exportDeclaration.export) {\n            const name = typeof exportItem == 'string' ? exportItem : exportItem.name;\n            const exportAs = typeof exportItem == 'string' ? exportItem : exportItem.as;\n            const symbol = this.symbolOf(exportFrom, name);\n            if (exportedSymbols && exportedSymbols.length == 1 && exportedSymbols[0].reexport &&\n                exportedSymbols[0].name == '*') {\n              // This is a named export from a module we have no metadata about. Record the named\n              // export as a re-export.\n              symbol.reexport = true;\n            }\n            exportSymbol(this.symbolOf(exportFrom, name), exportAs);\n          }\n        } else {\n          // Re-export all the symbols from the module\n          const exportedSymbols = this.exportAll(exportFrom);\n          for (const exportedSymbol of exportedSymbols) {\n            // In case the exported symbol does not have a name, we need to give it an unique\n            // name for the current module. This is necessary because there can be multiple\n            // unnamed re-exports in a given module.\n            const name = exportedSymbol.name === '*' ?\n                `unnamed_reexport_${unnamedModuleExportsIdx++}` :\n                exportedSymbol.name;\n            exportSymbol(exportedSymbol, name);\n          }\n        }\n      }\n    }\n\n    if (!module) {\n      // If no metadata is found for this import then it is considered external to the\n      // library and should be recorded as a re-export in the final metadata if it is\n      // eventually re-exported.\n      const symbol = this.symbolOf(moduleName, '*');\n      symbol.reexport = true;\n      result.push(symbol);\n    }\n    this.exports.set(moduleName, result);\n\n    return result;\n  }\n\n  /**\n   * Fill in the canonicalSymbol which is the symbol that should be imported by factories.\n   * The canonical symbol is the one exported by the index file for the bundle or definition\n   * symbol for private symbols that are not exported by bundle index.\n   */\n  private canonicalizeSymbols(exportedSymbols: Symbol[]) {\n    const symbols = Array.from(this.symbolMap.values());\n    this.exported = new Set(exportedSymbols);\n    symbols.forEach(this.canonicalizeSymbol, this);\n  }\n\n  private canonicalizeSymbol(symbol: Symbol) {\n    const rootExport = getRootExport(symbol);\n    const declaration = getSymbolDeclaration(symbol);\n    const isPrivate = !this.exported.has(rootExport);\n    const canonicalSymbol = isPrivate ? declaration : rootExport;\n    symbol.isPrivate = isPrivate;\n    symbol.declaration = declaration;\n    symbol.canonicalSymbol = canonicalSymbol;\n    symbol.reexport = declaration.reexport;\n  }\n\n  private getEntries(exportedSymbols: Symbol[]): BundleEntries {\n    const result: BundleEntries = {};\n\n    const exportedNames = new Set(exportedSymbols.map(s => s.name));\n    let privateName = 0;\n\n    function newPrivateName(prefix: string): string {\n      while (true) {\n        let digits: string[] = [];\n        let index = privateName++;\n        let base = PRIVATE_NAME_CHARS;\n        while (!digits.length || index > 0) {\n          digits.unshift(base[index % base.length]);\n          index = Math.floor(index / base.length);\n        }\n        const result = `\\u0275${prefix}${digits.join('')}`;\n        if (!exportedNames.has(result)) return result;\n      }\n    }\n\n    exportedSymbols.forEach(symbol => this.convertSymbol(symbol));\n\n    const symbolsMap = new Map<string, string[]>();\n    Array.from(this.symbolMap.values()).forEach(symbol => {\n      if (symbol.referenced && !symbol.reexport) {\n        let name = symbol.name;\n        const identifier = `${symbol.declaration!.module}:${symbol.declaration !.name}`;\n        if (symbol.isPrivate && !symbol.privateName) {\n          name = newPrivateName(this.privateSymbolPrefix);\n          symbol.privateName = name;\n        }\n        if (symbolsMap.has(identifier)) {\n          const names = symbolsMap.get(identifier);\n          names !.push(name);\n        } else {\n          symbolsMap.set(identifier, [name]);\n        }\n        result[name] = symbol.value !;\n      }\n    });\n\n    // check for duplicated entries\n    symbolsMap.forEach((names: string[], identifier: string) => {\n      if (names.length > 1) {\n        const [module, declaredName] = identifier.split(':');\n        // prefer the export that uses the declared name (if any)\n        let reference = names.indexOf(declaredName);\n        if (reference === -1) {\n          reference = 0;\n        }\n\n        // keep one entry and replace the others by references\n        names.forEach((name: string, i: number) => {\n          if (i !== reference) {\n            result[name] = {__symbolic: 'reference', name: names[reference]};\n          }\n        });\n      }\n    });\n\n    return result;\n  }\n\n  private getReExports(exportedSymbols: Symbol[]): ModuleExportMetadata[] {\n    type ExportClause = {name: string, as: string}[];\n    const modules = new Map<string, ExportClause>();\n    const exportAlls = new Set<string>();\n    for (const symbol of exportedSymbols) {\n      if (symbol.reexport) {\n        // symbol.declaration is guaranteed to be defined during the phase this method is called.\n        const declaration = symbol.declaration !;\n        const module = declaration.module;\n        if (declaration !.name == '*') {\n          // Reexport all the symbols.\n          exportAlls.add(declaration.module);\n        } else {\n          // Re-export the symbol as the exported name.\n          let entry = modules.get(module);\n          if (!entry) {\n            entry = [];\n            modules.set(module, entry);\n          }\n          const as = symbol.name;\n          const name = declaration.name;\n          entry.push({name, as});\n        }\n      }\n    }\n    return [\n      ...Array.from(exportAlls.values()).map(from => ({from})),\n      ...Array.from(modules.entries()).map(([from, exports]) => ({export: exports, from}))\n    ];\n  }\n\n  private convertSymbol(symbol: Symbol) {\n    // canonicalSymbol is ensured to be defined before this is called.\n    const canonicalSymbol = symbol.canonicalSymbol !;\n\n    if (!canonicalSymbol.referenced) {\n      canonicalSymbol.referenced = true;\n      // declaration is ensured to be definded before this method is called.\n      const declaration = canonicalSymbol.declaration !;\n      const module = this.getMetadata(declaration.module);\n      if (module) {\n        const value = module.metadata[declaration.name];\n        if (value && !declaration.name.startsWith('___')) {\n          canonicalSymbol.value = this.convertEntry(declaration.module, value);\n        }\n      }\n    }\n  }\n\n  private convertEntry(moduleName: string, value: MetadataEntry): MetadataEntry {\n    if (isClassMetadata(value)) {\n      return this.convertClass(moduleName, value);\n    }\n    if (isFunctionMetadata(value)) {\n      return this.convertFunction(moduleName, value);\n    }\n    if (isInterfaceMetadata(value)) {\n      return value;\n    }\n    return this.convertValue(moduleName, value);\n  }\n\n  private convertClass(moduleName: string, value: ClassMetadata): ClassMetadata {\n    return {\n      __symbolic: 'class',\n      arity: value.arity,\n      extends: this.convertExpression(moduleName, value.extends) !,\n      decorators:\n          value.decorators && value.decorators.map(d => this.convertExpression(moduleName, d) !),\n      members: this.convertMembers(moduleName, value.members !),\n      statics: value.statics && this.convertStatics(moduleName, value.statics)\n    };\n  }\n\n  private convertMembers(moduleName: string, members: MetadataMap): MetadataMap {\n    const result: MetadataMap = {};\n    for (const name in members) {\n      const value = members[name];\n      result[name] = value.map(v => this.convertMember(moduleName, v));\n    }\n    return result;\n  }\n\n  private convertMember(moduleName: string, member: MemberMetadata) {\n    const result: MemberMetadata = {__symbolic: member.__symbolic};\n    result.decorators =\n        member.decorators && member.decorators.map(d => this.convertExpression(moduleName, d) !);\n    if (isMethodMetadata(member)) {\n      (result as MethodMetadata).parameterDecorators = member.parameterDecorators &&\n          member.parameterDecorators.map(\n              d => d && d.map(p => this.convertExpression(moduleName, p) !));\n      if (isConstructorMetadata(member)) {\n        if (member.parameters) {\n          (result as ConstructorMetadata).parameters =\n              member.parameters.map(p => this.convertExpression(moduleName, p));\n        }\n      }\n    }\n    return result;\n  }\n\n  private convertStatics(moduleName: string, statics: StaticsMetadata): StaticsMetadata {\n    let result: StaticsMetadata = {};\n    for (const key in statics) {\n      const value = statics[key];\n\n      if (isFunctionMetadata(value)) {\n        result[key] = this.convertFunction(moduleName, value);\n      } else if (isMetadataSymbolicCallExpression(value)) {\n        // Class members can also contain static members that call a function with module\n        // references. e.g. \"static ɵprov = ɵɵdefineInjectable(..)\". We also need to\n        // convert these module references because otherwise these resolve to non-existent files.\n        result[key] = this.convertValue(moduleName, value);\n      } else {\n        result[key] = value;\n      }\n    }\n    return result;\n  }\n\n  private convertFunction(moduleName: string, value: FunctionMetadata): FunctionMetadata {\n    return {\n      __symbolic: 'function',\n      parameters: value.parameters,\n      defaults: value.defaults && value.defaults.map(v => this.convertValue(moduleName, v)),\n      value: this.convertValue(moduleName, value.value)\n    };\n  }\n\n  private convertValue(moduleName: string, value: MetadataValue): MetadataValue {\n    if (isPrimitive(value)) {\n      return value;\n    }\n    if (isMetadataError(value)) {\n      return this.convertError(moduleName, value);\n    }\n    if (isMetadataSymbolicExpression(value)) {\n      return this.convertExpression(moduleName, value) !;\n    }\n    if (Array.isArray(value)) {\n      return value.map(v => this.convertValue(moduleName, v));\n    }\n\n    // Otherwise it is a metadata object.\n    const object = value as MetadataObject;\n    const result: MetadataObject = {};\n    for (const key in object) {\n      result[key] = this.convertValue(moduleName, object[key]);\n    }\n    return result;\n  }\n\n  private convertExpression(\n      moduleName: string, value: MetadataSymbolicExpression|MetadataError|null|\n      undefined): MetadataSymbolicExpression|MetadataError|undefined|null {\n    if (value) {\n      switch (value.__symbolic) {\n        case 'error':\n          return this.convertError(moduleName, value as MetadataError);\n        case 'reference':\n          return this.convertReference(moduleName, value as MetadataSymbolicReferenceExpression);\n        default:\n          return this.convertExpressionNode(moduleName, value);\n      }\n    }\n    return value;\n  }\n\n  private convertError(module: string, value: MetadataError): MetadataError {\n    return {\n      __symbolic: 'error',\n      message: value.message,\n      line: value.line,\n      character: value.character,\n      context: value.context, module\n    };\n  }\n\n  private convertReference(moduleName: string, value: MetadataSymbolicReferenceExpression):\n      MetadataSymbolicReferenceExpression|MetadataError|undefined {\n    const createReference = (symbol: Symbol): MetadataSymbolicReferenceExpression => {\n      const declaration = symbol.declaration !;\n      if (declaration.module.startsWith('.')) {\n        // Reference to a symbol defined in the module. Ensure it is converted then return a\n        // references to the final symbol.\n        this.convertSymbol(symbol);\n        return {\n          __symbolic: 'reference',\n          get name() {\n            // Resolved lazily because private names are assigned late.\n            const canonicalSymbol = symbol.canonicalSymbol !;\n            if (canonicalSymbol.isPrivate == null) {\n              throw Error('Invalid state: isPrivate was not initialized');\n            }\n            return canonicalSymbol.isPrivate ? canonicalSymbol.privateName ! : canonicalSymbol.name;\n          }\n        };\n      } else {\n        // The symbol was a re-exported symbol from another module. Return a reference to the\n        // original imported symbol.\n        return {__symbolic: 'reference', name: declaration.name, module: declaration.module};\n      }\n    };\n\n    if (isMetadataGlobalReferenceExpression(value)) {\n      const metadata = this.getMetadata(moduleName);\n      if (metadata && metadata.metadata && metadata.metadata[value.name]) {\n        // Reference to a symbol defined in the module\n        return createReference(this.canonicalSymbolOf(moduleName, value.name));\n      }\n\n      // If a reference has arguments, the arguments need to be converted.\n      if (value.arguments) {\n        return {\n          __symbolic: 'reference',\n          name: value.name,\n          arguments: value.arguments.map(a => this.convertValue(moduleName, a))\n        };\n      }\n\n      // Global references without arguments (such as to Math or JSON) are unmodified.\n      return value;\n    }\n\n    if (isMetadataImportedSymbolReferenceExpression(value)) {\n      // References to imported symbols are separated into two, references to bundled modules and\n      // references to modules external to the bundle. If the module reference is relative it is\n      // assumed to be in the bundle. If it is Global it is assumed to be outside the bundle.\n      // References to symbols outside the bundle are left unmodified. References to symbol inside\n      // the bundle need to be converted to a bundle import reference reachable from the bundle\n      // index.\n\n      if (value.module.startsWith('.')) {\n        // Reference is to a symbol defined inside the module. Convert the reference to a reference\n        // to the canonical symbol.\n        const referencedModule = resolveModule(value.module, moduleName);\n        const referencedName = value.name;\n        return createReference(this.canonicalSymbolOf(referencedModule, referencedName));\n      }\n\n      // Value is a reference to a symbol defined outside the module.\n      if (value.arguments) {\n        // If a reference has arguments the arguments need to be converted.\n        return {\n          __symbolic: 'reference',\n          name: value.name,\n          module: value.module,\n          arguments: value.arguments.map(a => this.convertValue(moduleName, a))\n        };\n      }\n      return value;\n    }\n\n    if (isMetadataModuleReferenceExpression(value)) {\n      // Cannot support references to bundled modules as the internal modules of a bundle are erased\n      // by the bundler.\n      if (value.module.startsWith('.')) {\n        return {\n          __symbolic: 'error',\n          message: 'Unsupported bundled module reference',\n          context: {module: value.module}\n        };\n      }\n\n      // References to unbundled modules are unmodified.\n      return value;\n    }\n  }\n\n  private convertExpressionNode(moduleName: string, value: MetadataSymbolicExpression):\n      MetadataSymbolicExpression {\n    const result: MetadataSymbolicExpression = { __symbolic: value.__symbolic } as any;\n    for (const key in value) {\n      (result as any)[key] = this.convertValue(moduleName, (value as any)[key]);\n    }\n    return result;\n  }\n\n  private symbolOf(module: string, name: string): Symbol {\n    const symbolKey = `${module}:${name}`;\n    let symbol = this.symbolMap.get(symbolKey);\n    if (!symbol) {\n      symbol = {module, name};\n      this.symbolMap.set(symbolKey, symbol);\n    }\n    return symbol;\n  }\n\n  private canonicalSymbolOf(module: string, name: string): Symbol {\n    // Ensure the module has been seen.\n    this.exportAll(module);\n    const symbol = this.symbolOf(module, name);\n    if (!symbol.canonicalSymbol) {\n      this.canonicalizeSymbol(symbol);\n    }\n    return symbol;\n  }\n}\n\nexport class CompilerHostAdapter implements MetadataBundlerHost {\n  private collector = new MetadataCollector();\n\n  constructor(\n      private host: ts.CompilerHost, private cache: MetadataCache|null,\n      private options: ts.CompilerOptions) {}\n\n  getMetadataFor(fileName: string, containingFile: string): ModuleMetadata|undefined {\n    const {resolvedModule} =\n        ts.resolveModuleName(fileName, containingFile, this.options, this.host);\n\n    let sourceFile: ts.SourceFile|undefined;\n    if (resolvedModule) {\n      let {resolvedFileName} = resolvedModule;\n      if (resolvedModule.extension !== '.ts') {\n        resolvedFileName = resolvedFileName.replace(/(\\.d\\.ts|\\.js)$/, '.ts');\n      }\n      sourceFile = this.host.getSourceFile(resolvedFileName, ts.ScriptTarget.Latest);\n    } else {\n      // If typescript is unable to resolve the file, fallback on old behavior\n      if (!this.host.fileExists(fileName + '.ts')) return undefined;\n      sourceFile = this.host.getSourceFile(fileName + '.ts', ts.ScriptTarget.Latest);\n    }\n\n    // If there is a metadata cache, use it to get the metadata for this source file. Otherwise,\n    // fall back on the locally created MetadataCollector.\n    if (!sourceFile) {\n      return undefined;\n    } else if (this.cache) {\n      return this.cache.getMetadata(sourceFile);\n    } else {\n      return this.collector.getMetadata(sourceFile);\n    }\n  }\n}\n\nfunction resolveModule(importName: string, from: string): string {\n  if (importName.startsWith('.') && from) {\n    let normalPath = path.normalize(path.join(path.dirname(from), importName));\n    if (!normalPath.startsWith('.') && from.startsWith('.')) {\n      // path.normalize() preserves leading '../' but not './'. This adds it back.\n      normalPath = `.${path.sep}${normalPath}`;\n    }\n    // Replace windows path delimiters with forward-slashes. Otherwise the paths are not\n    // TypeScript compatible when building the bundle.\n    return normalPath.replace(/\\\\/g, '/');\n  }\n  return importName;\n}\n\nfunction isPrimitive(o: any): o is boolean|string|number {\n  return o === null || (typeof o !== 'function' && typeof o !== 'object');\n}\n\nfunction getRootExport(symbol: Symbol): Symbol {\n  return symbol.reexportedAs ? getRootExport(symbol.reexportedAs) : symbol;\n}\n\nfunction getSymbolDeclaration(symbol: Symbol): Symbol {\n  return symbol.exports ? getSymbolDeclaration(symbol.exports) : symbol;\n}\n"]}