UNPKG

@angular/compiler

Version:

Angular - the compiler library

171 lines 30.6 kB
/** * @license * Copyright Google LLC 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 */ (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/src/render3/r3_module_compiler", ["require", "exports", "tslib", "@angular/compiler/src/compile_metadata", "@angular/compiler/src/output/map_util", "@angular/compiler/src/output/output_ast", "@angular/compiler/src/render3/r3_factory", "@angular/compiler/src/render3/r3_identifiers", "@angular/compiler/src/render3/util"], factory); } })(function (require, exports) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.compileNgModuleFromRender2 = exports.compileInjector = exports.compileNgModule = void 0; var tslib_1 = require("tslib"); var compile_metadata_1 = require("@angular/compiler/src/compile_metadata"); var map_util_1 = require("@angular/compiler/src/output/map_util"); var o = require("@angular/compiler/src/output/output_ast"); var r3_factory_1 = require("@angular/compiler/src/render3/r3_factory"); var r3_identifiers_1 = require("@angular/compiler/src/render3/r3_identifiers"); var util_1 = require("@angular/compiler/src/render3/util"); /** * Construct an `R3NgModuleDef` for the given `R3NgModuleMetadata`. */ function compileNgModule(meta) { var internalType = meta.internalType, moduleType = meta.type, bootstrap = meta.bootstrap, declarations = meta.declarations, imports = meta.imports, exports = meta.exports, schemas = meta.schemas, containsForwardDecls = meta.containsForwardDecls, emitInline = meta.emitInline, id = meta.id; var additionalStatements = []; var definitionMap = { type: internalType }; // Only generate the keys in the metadata if the arrays have values. if (bootstrap.length) { definitionMap.bootstrap = refsToArray(bootstrap, containsForwardDecls); } // If requested to emit scope information inline, pass the declarations, imports and exports to // the `ɵɵdefineNgModule` call. The JIT compilation uses this. if (emitInline) { if (declarations.length) { definitionMap.declarations = refsToArray(declarations, containsForwardDecls); } if (imports.length) { definitionMap.imports = refsToArray(imports, containsForwardDecls); } if (exports.length) { definitionMap.exports = refsToArray(exports, containsForwardDecls); } } // If not emitting inline, the scope information is not passed into `ɵɵdefineNgModule` as it would // prevent tree-shaking of the declarations, imports and exports references. else { var setNgModuleScopeCall = generateSetNgModuleScopeCall(meta); if (setNgModuleScopeCall !== null) { additionalStatements.push(setNgModuleScopeCall); } } if (schemas && schemas.length) { definitionMap.schemas = o.literalArr(schemas.map(function (ref) { return ref.value; })); } if (id) { definitionMap.id = id; } var expression = o.importExpr(r3_identifiers_1.Identifiers.defineNgModule).callFn([util_1.mapToMapExpression(definitionMap)]); var type = new o.ExpressionType(o.importExpr(r3_identifiers_1.Identifiers.NgModuleDefWithMeta, [ new o.ExpressionType(moduleType.type), tupleTypeOf(declarations), tupleTypeOf(imports), tupleTypeOf(exports) ])); return { expression: expression, type: type, additionalStatements: additionalStatements }; } exports.compileNgModule = compileNgModule; /** * Generates a function call to `ɵɵsetNgModuleScope` with all necessary information so that the * transitive module scope can be computed during runtime in JIT mode. This call is marked pure * such that the references to declarations, imports and exports may be elided causing these * symbols to become tree-shakeable. */ function generateSetNgModuleScopeCall(meta) { var moduleType = meta.adjacentType, declarations = meta.declarations, imports = meta.imports, exports = meta.exports, containsForwardDecls = meta.containsForwardDecls; var scopeMap = {}; if (declarations.length) { scopeMap.declarations = refsToArray(declarations, containsForwardDecls); } if (imports.length) { scopeMap.imports = refsToArray(imports, containsForwardDecls); } if (exports.length) { scopeMap.exports = refsToArray(exports, containsForwardDecls); } if (Object.keys(scopeMap).length === 0) { return null; } // setNgModuleScope(...) var fnCall = new o.InvokeFunctionExpr( /* fn */ o.importExpr(r3_identifiers_1.Identifiers.setNgModuleScope), /* args */ [moduleType, util_1.mapToMapExpression(scopeMap)]); // (ngJitMode guard) && setNgModuleScope(...) var guardedCall = util_1.jitOnlyGuardedExpression(fnCall); // function() { (ngJitMode guard) && setNgModuleScope(...); } var iife = new o.FunctionExpr( /* params */ [], /* statements */ [guardedCall.toStmt()]); // (function() { (ngJitMode guard) && setNgModuleScope(...); })() var iifeCall = new o.InvokeFunctionExpr( /* fn */ iife, /* args */ []); return iifeCall.toStmt(); } function compileInjector(meta) { var result = r3_factory_1.compileFactoryFunction({ name: meta.name, type: meta.type, internalType: meta.internalType, typeArgumentCount: 0, deps: meta.deps, injectFn: r3_identifiers_1.Identifiers.inject, target: r3_factory_1.R3FactoryTarget.NgModule, }); var definitionMap = { factory: result.factory, }; if (meta.providers !== null) { definitionMap.providers = meta.providers; } if (meta.imports.length > 0) { definitionMap.imports = o.literalArr(meta.imports); } var expression = o.importExpr(r3_identifiers_1.Identifiers.defineInjector).callFn([util_1.mapToMapExpression(definitionMap)]); var type = new o.ExpressionType(o.importExpr(r3_identifiers_1.Identifiers.InjectorDef, [new o.ExpressionType(meta.type.type)])); return { expression: expression, type: type, statements: result.statements }; } exports.compileInjector = compileInjector; // TODO(alxhub): integrate this with `compileNgModule`. Currently the two are separate operations. function compileNgModuleFromRender2(ctx, ngModule, injectableCompiler) { var className = compile_metadata_1.identifierName(ngModule.type); var rawImports = ngModule.rawImports ? [ngModule.rawImports] : []; var rawExports = ngModule.rawExports ? [ngModule.rawExports] : []; var injectorDefArg = map_util_1.mapLiteral({ 'factory': injectableCompiler.factoryFor({ type: ngModule.type, symbol: ngModule.type.reference }, ctx), 'providers': util_1.convertMetaToOutput(ngModule.rawProviders, ctx), 'imports': util_1.convertMetaToOutput(tslib_1.__spread(rawImports, rawExports), ctx), }); var injectorDef = o.importExpr(r3_identifiers_1.Identifiers.defineInjector).callFn([injectorDefArg]); ctx.statements.push(new o.ClassStmt( /* name */ className, /* parent */ null, /* fields */ [new o.ClassField( /* name */ 'ɵinj', /* type */ o.INFERRED_TYPE, /* modifiers */ [o.StmtModifier.Static], /* initializer */ injectorDef)], /* getters */ [], /* constructorMethod */ new o.ClassMethod(null, [], []), /* methods */ [])); } exports.compileNgModuleFromRender2 = compileNgModuleFromRender2; function accessExportScope(module) { var selectorScope = new o.ReadPropExpr(module, 'ɵmod'); return new o.ReadPropExpr(selectorScope, 'exported'); } function tupleTypeOf(exp) { var types = exp.map(function (ref) { return o.typeofExpr(ref.type); }); return exp.length > 0 ? o.expressionType(o.literalArr(types)) : o.NONE_TYPE; } function refsToArray(refs, shouldForwardDeclare) { var values = o.literalArr(refs.map(function (ref) { return ref.value; })); return shouldForwardDeclare ? o.fn([], [new o.ReturnStatement(values)]) : values; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"r3_module_compiler.js","sourceRoot":"","sources":["../../../../../../../packages/compiler/src/render3/r3_module_compiler.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;;IAEH,2EAAiF;IAEjF,kEAA8C;IAC9C,2DAA0C;IAG1C,uEAA2F;IAC3F,+EAAmD;IACnD,2DAAsG;IA4EtG;;OAEG;IACH,SAAgB,eAAe,CAAC,IAAwB;QAEpD,IAAA,YAAY,GAUV,IAAI,aAVM,EACN,UAAU,GASd,IAAI,KATU,EAChB,SAAS,GAQP,IAAI,UARG,EACT,YAAY,GAOV,IAAI,aAPM,EACZ,OAAO,GAML,IAAI,QANC,EACP,OAAO,GAKL,IAAI,QALC,EACP,OAAO,GAIL,IAAI,QAJC,EACP,oBAAoB,GAGlB,IAAI,qBAHc,EACpB,UAAU,GAER,IAAI,WAFI,EACV,EAAE,GACA,IAAI,GADJ,CACK;QAET,IAAM,oBAAoB,GAAkB,EAAE,CAAC;QAC/C,IAAM,aAAa,GAAG,EAAC,IAAI,EAAE,YAAY,EAQxC,CAAC;QAEF,oEAAoE;QACpE,IAAI,SAAS,CAAC,MAAM,EAAE;YACpB,aAAa,CAAC,SAAS,GAAG,WAAW,CAAC,SAAS,EAAE,oBAAoB,CAAC,CAAC;SACxE;QAED,+FAA+F;QAC/F,8DAA8D;QAC9D,IAAI,UAAU,EAAE;YACd,IAAI,YAAY,CAAC,MAAM,EAAE;gBACvB,aAAa,CAAC,YAAY,GAAG,WAAW,CAAC,YAAY,EAAE,oBAAoB,CAAC,CAAC;aAC9E;YAED,IAAI,OAAO,CAAC,MAAM,EAAE;gBAClB,aAAa,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO,EAAE,oBAAoB,CAAC,CAAC;aACpE;YAED,IAAI,OAAO,CAAC,MAAM,EAAE;gBAClB,aAAa,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO,EAAE,oBAAoB,CAAC,CAAC;aACpE;SACF;QAED,kGAAkG;QAClG,4EAA4E;aACvE;YACH,IAAM,oBAAoB,GAAG,4BAA4B,CAAC,IAAI,CAAC,CAAC;YAChE,IAAI,oBAAoB,KAAK,IAAI,EAAE;gBACjC,oBAAoB,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;aACjD;SACF;QAED,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,EAAE;YAC7B,aAAa,CAAC,OAAO,GAAG,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,UAAA,GAAG,IAAI,OAAA,GAAG,CAAC,KAAK,EAAT,CAAS,CAAC,CAAC,CAAC;SACrE;QAED,IAAI,EAAE,EAAE;YACN,aAAa,CAAC,EAAE,GAAG,EAAE,CAAC;SACvB;QAED,IAAM,UAAU,GAAG,CAAC,CAAC,UAAU,CAAC,4BAAE,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,CAAC,yBAAkB,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;QAC/F,IAAM,IAAI,GAAG,IAAI,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,UAAU,CAAC,4BAAE,CAAC,mBAAmB,EAAE;YACrE,IAAI,CAAC,CAAC,cAAc,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,WAAW,CAAC,YAAY,CAAC,EAAE,WAAW,CAAC,OAAO,CAAC;YACtF,WAAW,CAAC,OAAO,CAAC;SACrB,CAAC,CAAC,CAAC;QAGJ,OAAO,EAAC,UAAU,YAAA,EAAE,IAAI,MAAA,EAAE,oBAAoB,sBAAA,EAAC,CAAC;IAClD,CAAC;IAvED,0CAuEC;IAED;;;;;OAKG;IACH,SAAS,4BAA4B,CAAC,IAAwB;QACrD,IAAc,UAAU,GAA0D,IAAI,aAA9D,EAAE,YAAY,GAA4C,IAAI,aAAhD,EAAE,OAAO,GAAmC,IAAI,QAAvC,EAAE,OAAO,GAA0B,IAAI,QAA9B,EAAE,oBAAoB,GAAI,IAAI,qBAAR,CAAS;QAE9F,IAAM,QAAQ,GAAG,EAIhB,CAAC;QAEF,IAAI,YAAY,CAAC,MAAM,EAAE;YACvB,QAAQ,CAAC,YAAY,GAAG,WAAW,CAAC,YAAY,EAAE,oBAAoB,CAAC,CAAC;SACzE;QAED,IAAI,OAAO,CAAC,MAAM,EAAE;YAClB,QAAQ,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO,EAAE,oBAAoB,CAAC,CAAC;SAC/D;QAED,IAAI,OAAO,CAAC,MAAM,EAAE;YAClB,QAAQ,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO,EAAE,oBAAoB,CAAC,CAAC;SAC/D;QAED,IAAI,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE;YACtC,OAAO,IAAI,CAAC;SACb;QAED,wBAAwB;QACxB,IAAM,MAAM,GAAG,IAAI,CAAC,CAAC,kBAAkB;QACnC,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,4BAAE,CAAC,gBAAgB,CAAC;QAC1C,UAAU,CAAA,CAAC,UAAU,EAAE,yBAAkB,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QAE1D,6CAA6C;QAC7C,IAAM,WAAW,GAAG,+BAAwB,CAAC,MAAM,CAAC,CAAC;QAErD,6DAA6D;QAC7D,IAAM,IAAI,GAAG,IAAI,CAAC,CAAC,YAAY;QAC3B,YAAY,CAAA,EAAE;QACd,gBAAgB,CAAA,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QAE5C,iEAAiE;QACjE,IAAM,QAAQ,GAAG,IAAI,CAAC,CAAC,kBAAkB;QACrC,QAAQ,CAAC,IAAI;QACb,UAAU,CAAA,EAAE,CAAC,CAAC;QAElB,OAAO,QAAQ,CAAC,MAAM,EAAE,CAAC;IAC3B,CAAC;IAiBD,SAAgB,eAAe,CAAC,IAAwB;QACtD,IAAM,MAAM,GAAG,mCAAsB,CAAC;YACpC,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,iBAAiB,EAAE,CAAC;YACpB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,QAAQ,EAAE,4BAAE,CAAC,MAAM;YACnB,MAAM,EAAE,4BAAe,CAAC,QAAQ;SACjC,CAAC,CAAC;QACH,IAAM,aAAa,GAAG;YACpB,OAAO,EAAE,MAAM,CAAC,OAAO;SACmD,CAAC;QAE7E,IAAI,IAAI,CAAC,SAAS,KAAK,IAAI,EAAE;YAC3B,aAAa,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;SAC1C;QAED,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;YAC3B,aAAa,CAAC,OAAO,GAAG,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SACpD;QAED,IAAM,UAAU,GAAG,CAAC,CAAC,UAAU,CAAC,4BAAE,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,CAAC,yBAAkB,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;QAC/F,IAAM,IAAI,GACN,IAAI,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,UAAU,CAAC,4BAAE,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/F,OAAO,EAAC,UAAU,YAAA,EAAE,IAAI,MAAA,EAAE,UAAU,EAAE,MAAM,CAAC,UAAU,EAAC,CAAC;IAC3D,CAAC;IA1BD,0CA0BC;IAED,kGAAkG;IAClG,SAAgB,0BAA0B,CACtC,GAAkB,EAAE,QAAsC,EAC1D,kBAAsC;QACxC,IAAM,SAAS,GAAG,iCAAc,CAAC,QAAQ,CAAC,IAAI,CAAE,CAAC;QAEjD,IAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACpE,IAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAEpE,IAAM,cAAc,GAAG,qBAAU,CAAC;YAChC,SAAS,EACL,kBAAkB,CAAC,UAAU,CAAC,EAAC,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAC,EAAE,GAAG,CAAC;YAC9F,WAAW,EAAE,0BAAmB,CAAC,QAAQ,CAAC,YAAY,EAAE,GAAG,CAAC;YAC5D,SAAS,EAAE,0BAAmB,kBAAK,UAAU,EAAK,UAAU,GAAG,GAAG,CAAC;SACpE,CAAC,CAAC;QAEH,IAAM,WAAW,GAAG,CAAC,CAAC,UAAU,CAAC,4BAAE,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC;QAE7E,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,SAAS;QAC/B,UAAU,CAAC,SAAS;QACpB,YAAY,CAAC,IAAI;QACjB,YAAY,CAAA,CAAC,IAAI,CAAC,CAAC,UAAU;YACzB,UAAU,CAAC,MAAM;YACjB,UAAU,CAAC,CAAC,CAAC,aAAa;YAC1B,eAAe,CAAA,CAAC,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC;YACtC,iBAAiB,CAAC,WAAW,CAC5B,CAAC;QACN,aAAa,CAAA,EAAE;QACf,uBAAuB,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC;QACvD,aAAa,CAAA,EAAE,CAAC,CAAC,CAAC;IACxB,CAAC;IA7BD,gEA6BC;IAED,SAAS,iBAAiB,CAAC,MAAoB;QAC7C,IAAM,aAAa,GAAG,IAAI,CAAC,CAAC,YAAY,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QACzD,OAAO,IAAI,CAAC,CAAC,YAAY,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;IACvD,CAAC;IAED,SAAS,WAAW,CAAC,GAAkB;QACrC,IAAM,KAAK,GAAG,GAAG,CAAC,GAAG,CAAC,UAAA,GAAG,IAAI,OAAA,CAAC,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,EAAtB,CAAsB,CAAC,CAAC;QACrD,OAAO,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IAC9E,CAAC;IAED,SAAS,WAAW,CAAC,IAAmB,EAAE,oBAA6B;QACrE,IAAM,MAAM,GAAG,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,UAAA,GAAG,IAAI,OAAA,GAAG,CAAC,KAAK,EAAT,CAAS,CAAC,CAAC,CAAC;QACxD,OAAO,oBAAoB,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;IACnF,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 {CompileShallowModuleMetadata, identifierName} from '../compile_metadata';\nimport {InjectableCompiler} from '../injectable_compiler';\nimport {mapLiteral} from '../output/map_util';\nimport * as o from '../output/output_ast';\nimport {OutputContext} from '../util';\n\nimport {compileFactoryFunction, R3DependencyMetadata, R3FactoryTarget} from './r3_factory';\nimport {Identifiers as R3} from './r3_identifiers';\nimport {convertMetaToOutput, jitOnlyGuardedExpression, mapToMapExpression, R3Reference} from './util';\n\nexport interface R3NgModuleDef {\n  expression: o.Expression;\n  type: o.Type;\n  additionalStatements: o.Statement[];\n}\n\n/**\n * Metadata required by the module compiler to generate a module def (`ɵmod`) for a type.\n */\nexport interface R3NgModuleMetadata {\n  /**\n   * An expression representing the module type being compiled.\n   */\n  type: R3Reference;\n\n  /**\n   * An expression representing the module type being compiled, intended for use within a class\n   * definition itself.\n   *\n   * This can differ from the outer `type` if the class is being compiled by ngcc and is inside\n   * an IIFE structure that uses a different name internally.\n   */\n  internalType: o.Expression;\n\n  /**\n   * An expression intended for use by statements that are adjacent (i.e. tightly coupled) to but\n   * not internal to a class definition.\n   *\n   * This can differ from the outer `type` if the class is being compiled by ngcc and is inside\n   * an IIFE structure that uses a different name internally.\n   */\n  adjacentType: o.Expression;\n\n  /**\n   * An array of expressions representing the bootstrap components specified by the module.\n   */\n  bootstrap: R3Reference[];\n\n  /**\n   * An array of expressions representing the directives and pipes declared by the module.\n   */\n  declarations: R3Reference[];\n\n  /**\n   * An array of expressions representing the imports of the module.\n   */\n  imports: R3Reference[];\n\n  /**\n   * An array of expressions representing the exports of the module.\n   */\n  exports: R3Reference[];\n\n  /**\n   * Whether to emit the selector scope values (declarations, imports, exports) inline into the\n   * module definition, or to generate additional statements which patch them on. Inline emission\n   * does not allow components to be tree-shaken, but is useful for JIT mode.\n   */\n  emitInline: boolean;\n\n  /**\n   * Whether to generate closure wrappers for bootstrap, declarations, imports, and exports.\n   */\n  containsForwardDecls: boolean;\n\n  /**\n   * The set of schemas that declare elements to be allowed in the NgModule.\n   */\n  schemas: R3Reference[]|null;\n\n  /** Unique ID or expression representing the unique ID of an NgModule. */\n  id: o.Expression|null;\n}\n\n/**\n * Construct an `R3NgModuleDef` for the given `R3NgModuleMetadata`.\n */\nexport function compileNgModule(meta: R3NgModuleMetadata): R3NgModuleDef {\n  const {\n    internalType,\n    type: moduleType,\n    bootstrap,\n    declarations,\n    imports,\n    exports,\n    schemas,\n    containsForwardDecls,\n    emitInline,\n    id\n  } = meta;\n\n  const additionalStatements: o.Statement[] = [];\n  const definitionMap = {type: internalType} as {\n    type: o.Expression,\n    bootstrap: o.Expression,\n    declarations: o.Expression,\n    imports: o.Expression,\n    exports: o.Expression,\n    schemas: o.LiteralArrayExpr,\n    id: o.Expression\n  };\n\n  // Only generate the keys in the metadata if the arrays have values.\n  if (bootstrap.length) {\n    definitionMap.bootstrap = refsToArray(bootstrap, containsForwardDecls);\n  }\n\n  // If requested to emit scope information inline, pass the declarations, imports and exports to\n  // the `ɵɵdefineNgModule` call. The JIT compilation uses this.\n  if (emitInline) {\n    if (declarations.length) {\n      definitionMap.declarations = refsToArray(declarations, containsForwardDecls);\n    }\n\n    if (imports.length) {\n      definitionMap.imports = refsToArray(imports, containsForwardDecls);\n    }\n\n    if (exports.length) {\n      definitionMap.exports = refsToArray(exports, containsForwardDecls);\n    }\n  }\n\n  // If not emitting inline, the scope information is not passed into `ɵɵdefineNgModule` as it would\n  // prevent tree-shaking of the declarations, imports and exports references.\n  else {\n    const setNgModuleScopeCall = generateSetNgModuleScopeCall(meta);\n    if (setNgModuleScopeCall !== null) {\n      additionalStatements.push(setNgModuleScopeCall);\n    }\n  }\n\n  if (schemas && schemas.length) {\n    definitionMap.schemas = o.literalArr(schemas.map(ref => ref.value));\n  }\n\n  if (id) {\n    definitionMap.id = id;\n  }\n\n  const expression = o.importExpr(R3.defineNgModule).callFn([mapToMapExpression(definitionMap)]);\n  const type = new o.ExpressionType(o.importExpr(R3.NgModuleDefWithMeta, [\n    new o.ExpressionType(moduleType.type), tupleTypeOf(declarations), tupleTypeOf(imports),\n    tupleTypeOf(exports)\n  ]));\n\n\n  return {expression, type, additionalStatements};\n}\n\n/**\n * Generates a function call to `ɵɵsetNgModuleScope` with all necessary information so that the\n * transitive module scope can be computed during runtime in JIT mode. This call is marked pure\n * such that the references to declarations, imports and exports may be elided causing these\n * symbols to become tree-shakeable.\n */\nfunction generateSetNgModuleScopeCall(meta: R3NgModuleMetadata): o.Statement|null {\n  const {adjacentType: moduleType, declarations, imports, exports, containsForwardDecls} = meta;\n\n  const scopeMap = {} as {\n    declarations: o.Expression,\n    imports: o.Expression,\n    exports: o.Expression,\n  };\n\n  if (declarations.length) {\n    scopeMap.declarations = refsToArray(declarations, containsForwardDecls);\n  }\n\n  if (imports.length) {\n    scopeMap.imports = refsToArray(imports, containsForwardDecls);\n  }\n\n  if (exports.length) {\n    scopeMap.exports = refsToArray(exports, containsForwardDecls);\n  }\n\n  if (Object.keys(scopeMap).length === 0) {\n    return null;\n  }\n\n  // setNgModuleScope(...)\n  const fnCall = new o.InvokeFunctionExpr(\n      /* fn */ o.importExpr(R3.setNgModuleScope),\n      /* args */[moduleType, mapToMapExpression(scopeMap)]);\n\n  // (ngJitMode guard) && setNgModuleScope(...)\n  const guardedCall = jitOnlyGuardedExpression(fnCall);\n\n  // function() { (ngJitMode guard) && setNgModuleScope(...); }\n  const iife = new o.FunctionExpr(\n      /* params */[],\n      /* statements */[guardedCall.toStmt()]);\n\n  // (function() { (ngJitMode guard) && setNgModuleScope(...); })()\n  const iifeCall = new o.InvokeFunctionExpr(\n      /* fn */ iife,\n      /* args */[]);\n\n  return iifeCall.toStmt();\n}\n\nexport interface R3InjectorDef {\n  expression: o.Expression;\n  type: o.Type;\n  statements: o.Statement[];\n}\n\nexport interface R3InjectorMetadata {\n  name: string;\n  type: R3Reference;\n  internalType: o.Expression;\n  deps: R3DependencyMetadata[]|null;\n  providers: o.Expression|null;\n  imports: o.Expression[];\n}\n\nexport function compileInjector(meta: R3InjectorMetadata): R3InjectorDef {\n  const result = compileFactoryFunction({\n    name: meta.name,\n    type: meta.type,\n    internalType: meta.internalType,\n    typeArgumentCount: 0,\n    deps: meta.deps,\n    injectFn: R3.inject,\n    target: R3FactoryTarget.NgModule,\n  });\n  const definitionMap = {\n    factory: result.factory,\n  } as {factory: o.Expression, providers: o.Expression, imports: o.Expression};\n\n  if (meta.providers !== null) {\n    definitionMap.providers = meta.providers;\n  }\n\n  if (meta.imports.length > 0) {\n    definitionMap.imports = o.literalArr(meta.imports);\n  }\n\n  const expression = o.importExpr(R3.defineInjector).callFn([mapToMapExpression(definitionMap)]);\n  const type =\n      new o.ExpressionType(o.importExpr(R3.InjectorDef, [new o.ExpressionType(meta.type.type)]));\n  return {expression, type, statements: result.statements};\n}\n\n// TODO(alxhub): integrate this with `compileNgModule`. Currently the two are separate operations.\nexport function compileNgModuleFromRender2(\n    ctx: OutputContext, ngModule: CompileShallowModuleMetadata,\n    injectableCompiler: InjectableCompiler): void {\n  const className = identifierName(ngModule.type)!;\n\n  const rawImports = ngModule.rawImports ? [ngModule.rawImports] : [];\n  const rawExports = ngModule.rawExports ? [ngModule.rawExports] : [];\n\n  const injectorDefArg = mapLiteral({\n    'factory':\n        injectableCompiler.factoryFor({type: ngModule.type, symbol: ngModule.type.reference}, ctx),\n    'providers': convertMetaToOutput(ngModule.rawProviders, ctx),\n    'imports': convertMetaToOutput([...rawImports, ...rawExports], ctx),\n  });\n\n  const injectorDef = o.importExpr(R3.defineInjector).callFn([injectorDefArg]);\n\n  ctx.statements.push(new o.ClassStmt(\n      /* name */ className,\n      /* parent */ null,\n      /* fields */[new o.ClassField(\n          /* name */ 'ɵinj',\n          /* type */ o.INFERRED_TYPE,\n          /* modifiers */[o.StmtModifier.Static],\n          /* initializer */ injectorDef,\n          )],\n      /* getters */[],\n      /* constructorMethod */ new o.ClassMethod(null, [], []),\n      /* methods */[]));\n}\n\nfunction accessExportScope(module: o.Expression): o.Expression {\n  const selectorScope = new o.ReadPropExpr(module, 'ɵmod');\n  return new o.ReadPropExpr(selectorScope, 'exported');\n}\n\nfunction tupleTypeOf(exp: R3Reference[]): o.Type {\n  const types = exp.map(ref => o.typeofExpr(ref.type));\n  return exp.length > 0 ? o.expressionType(o.literalArr(types)) : o.NONE_TYPE;\n}\n\nfunction refsToArray(refs: R3Reference[], shouldForwardDeclare: boolean): o.Expression {\n  const values = o.literalArr(refs.map(ref => ref.value));\n  return shouldForwardDeclare ? o.fn([], [new o.ReturnStatement(values)]) : values;\n}\n"]}