[6a3a178] | 1 | (function (factory) {
|
---|
| 2 | if (typeof module === "object" && typeof module.exports === "object") {
|
---|
| 3 | var v = factory(require, exports);
|
---|
| 4 | if (v !== undefined) module.exports = v;
|
---|
| 5 | }
|
---|
| 6 | else if (typeof define === "function" && define.amd) {
|
---|
| 7 | define("@angular/compiler/src/render3/partial/injectable", ["require", "exports", "@angular/compiler/src/injectable_compiler_2", "@angular/compiler/src/output/output_ast", "@angular/compiler/src/render3/r3_identifiers", "@angular/compiler/src/render3/view/util", "@angular/compiler/src/render3/partial/util"], factory);
|
---|
| 8 | }
|
---|
| 9 | })(function (require, exports) {
|
---|
| 10 | "use strict";
|
---|
| 11 | Object.defineProperty(exports, "__esModule", { value: true });
|
---|
| 12 | exports.createInjectableDefinitionMap = exports.compileDeclareInjectableFromMetadata = void 0;
|
---|
| 13 | /**
|
---|
| 14 | * @license
|
---|
| 15 | * Copyright Google LLC All Rights Reserved.
|
---|
| 16 | *
|
---|
| 17 | * Use of this source code is governed by an MIT-style license that can be
|
---|
| 18 | * found in the LICENSE file at https://angular.io/license
|
---|
| 19 | */
|
---|
| 20 | var injectable_compiler_2_1 = require("@angular/compiler/src/injectable_compiler_2");
|
---|
| 21 | var o = require("@angular/compiler/src/output/output_ast");
|
---|
| 22 | var r3_identifiers_1 = require("@angular/compiler/src/render3/r3_identifiers");
|
---|
| 23 | var util_1 = require("@angular/compiler/src/render3/view/util");
|
---|
| 24 | var util_2 = require("@angular/compiler/src/render3/partial/util");
|
---|
| 25 | /**
|
---|
| 26 | * Every time we make a breaking change to the declaration interface or partial-linker behavior, we
|
---|
| 27 | * must update this constant to prevent old partial-linkers from incorrectly processing the
|
---|
| 28 | * declaration.
|
---|
| 29 | *
|
---|
| 30 | * Do not include any prerelease in these versions as they are ignored.
|
---|
| 31 | */
|
---|
| 32 | var MINIMUM_PARTIAL_LINKER_VERSION = '12.0.0';
|
---|
| 33 | /**
|
---|
| 34 | * Compile a Injectable declaration defined by the `R3InjectableMetadata`.
|
---|
| 35 | */
|
---|
| 36 | function compileDeclareInjectableFromMetadata(meta) {
|
---|
| 37 | var definitionMap = createInjectableDefinitionMap(meta);
|
---|
| 38 | var expression = o.importExpr(r3_identifiers_1.Identifiers.declareInjectable).callFn([definitionMap.toLiteralMap()]);
|
---|
| 39 | var type = injectable_compiler_2_1.createInjectableType(meta);
|
---|
| 40 | return { expression: expression, type: type, statements: [] };
|
---|
| 41 | }
|
---|
| 42 | exports.compileDeclareInjectableFromMetadata = compileDeclareInjectableFromMetadata;
|
---|
| 43 | /**
|
---|
| 44 | * Gathers the declaration fields for a Injectable into a `DefinitionMap`.
|
---|
| 45 | */
|
---|
| 46 | function createInjectableDefinitionMap(meta) {
|
---|
| 47 | var definitionMap = new util_1.DefinitionMap();
|
---|
| 48 | definitionMap.set('minVersion', o.literal(MINIMUM_PARTIAL_LINKER_VERSION));
|
---|
[e29cc2e] | 49 | definitionMap.set('version', o.literal('12.2.13'));
|
---|
[6a3a178] | 50 | definitionMap.set('ngImport', o.importExpr(r3_identifiers_1.Identifiers.core));
|
---|
| 51 | definitionMap.set('type', meta.internalType);
|
---|
| 52 | // Only generate providedIn property if it has a non-null value
|
---|
| 53 | if (meta.providedIn !== undefined) {
|
---|
| 54 | var providedIn = convertFromProviderExpression(meta.providedIn);
|
---|
| 55 | if (providedIn.value !== null) {
|
---|
| 56 | definitionMap.set('providedIn', providedIn);
|
---|
| 57 | }
|
---|
| 58 | }
|
---|
| 59 | if (meta.useClass !== undefined) {
|
---|
| 60 | definitionMap.set('useClass', convertFromProviderExpression(meta.useClass));
|
---|
| 61 | }
|
---|
| 62 | if (meta.useExisting !== undefined) {
|
---|
| 63 | definitionMap.set('useExisting', convertFromProviderExpression(meta.useExisting));
|
---|
| 64 | }
|
---|
| 65 | if (meta.useValue !== undefined) {
|
---|
| 66 | definitionMap.set('useValue', convertFromProviderExpression(meta.useValue));
|
---|
| 67 | }
|
---|
| 68 | // Factories do not contain `ForwardRef`s since any types are already wrapped in a function call
|
---|
| 69 | // so the types will not be eagerly evaluated. Therefore we do not need to process this expression
|
---|
| 70 | // with `convertFromProviderExpression()`.
|
---|
| 71 | if (meta.useFactory !== undefined) {
|
---|
| 72 | definitionMap.set('useFactory', meta.useFactory);
|
---|
| 73 | }
|
---|
| 74 | if (meta.deps !== undefined) {
|
---|
| 75 | definitionMap.set('deps', o.literalArr(meta.deps.map(util_2.compileDependency)));
|
---|
| 76 | }
|
---|
| 77 | return definitionMap;
|
---|
| 78 | }
|
---|
| 79 | exports.createInjectableDefinitionMap = createInjectableDefinitionMap;
|
---|
| 80 | /**
|
---|
| 81 | * Convert an `R3ProviderExpression` to an `Expression`, possibly wrapping its expression in a
|
---|
| 82 | * `forwardRef()` call.
|
---|
| 83 | *
|
---|
| 84 | * If `R3ProviderExpression.isForwardRef` is true then the expression was originally wrapped in a
|
---|
| 85 | * `forwardRef()` call to prevent the value from being eagerly evaluated in the code.
|
---|
| 86 | *
|
---|
| 87 | * Normally, the linker will statically process the code, putting the `expression` inside a factory
|
---|
| 88 | * function so the `forwardRef()` wrapper is not evaluated before it has been defined. But if the
|
---|
| 89 | * partial declaration is evaluated by the JIT compiler the `forwardRef()` call is still needed to
|
---|
| 90 | * prevent eager evaluation of the `expression`.
|
---|
| 91 | *
|
---|
| 92 | * So in partial declarations, expressions that could be forward-refs are wrapped in `forwardRef()`
|
---|
| 93 | * calls, and this is then unwrapped in the linker as necessary.
|
---|
| 94 | *
|
---|
| 95 | * See `packages/compiler-cli/src/ngtsc/annotations/src/injectable.ts` and
|
---|
| 96 | * `packages/compiler/src/jit_compiler_facade.ts` for more information.
|
---|
| 97 | */
|
---|
| 98 | function convertFromProviderExpression(_a) {
|
---|
| 99 | var expression = _a.expression, isForwardRef = _a.isForwardRef;
|
---|
| 100 | return isForwardRef ? util_2.generateForwardRef(expression) : expression;
|
---|
| 101 | }
|
---|
| 102 | });
|
---|
| 103 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"injectable.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler/src/render3/partial/injectable.ts"],"names":[],"mappings":";;;;;;;;;;;;IAAA;;;;;;OAMG;IACH,qFAA6G;IAC7G,2DAA6C;IAC7C,+EAAoD;IAEpD,gEAA2C;IAG3C,mEAA6D;IAE7D;;;;;;OAMG;IACH,IAAM,8BAA8B,GAAG,QAAQ,CAAC;IAEhD;;OAEG;IACH,SAAgB,oCAAoC,CAAC,IAA0B;QAE7E,IAAM,aAAa,GAAG,6BAA6B,CAAC,IAAI,CAAC,CAAC;QAE1D,IAAM,UAAU,GAAG,CAAC,CAAC,UAAU,CAAC,4BAAE,CAAC,iBAAiB,CAAC,CAAC,MAAM,CAAC,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;QAC7F,IAAM,IAAI,GAAG,4CAAoB,CAAC,IAAI,CAAC,CAAC;QAExC,OAAO,EAAC,UAAU,YAAA,EAAE,IAAI,MAAA,EAAE,UAAU,EAAE,EAAE,EAAC,CAAC;IAC5C,CAAC;IARD,oFAQC;IAED;;OAEG;IACH,SAAgB,6BAA6B,CAAC,IAA0B;QAEtE,IAAM,aAAa,GAAG,IAAI,oBAAa,EAA+B,CAAC;QAEvE,aAAa,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC,CAAC,OAAO,CAAC,8BAA8B,CAAC,CAAC,CAAC;QAC3E,aAAa,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC,CAAC;QAC7D,aAAa,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,CAAC,UAAU,CAAC,4BAAE,CAAC,IAAI,CAAC,CAAC,CAAC;QACrD,aAAa,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAE7C,+DAA+D;QAC/D,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,EAAE;YACjC,IAAM,UAAU,GAAG,6BAA6B,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAClE,IAAK,UAA4B,CAAC,KAAK,KAAK,IAAI,EAAE;gBAChD,aAAa,CAAC,GAAG,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC;aAC7C;SACF;QAED,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,EAAE;YAC/B,aAAa,CAAC,GAAG,CAAC,UAAU,EAAE,6BAA6B,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;SAC7E;QACD,IAAI,IAAI,CAAC,WAAW,KAAK,SAAS,EAAE;YAClC,aAAa,CAAC,GAAG,CAAC,aAAa,EAAE,6BAA6B,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;SACnF;QACD,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,EAAE;YAC/B,aAAa,CAAC,GAAG,CAAC,UAAU,EAAE,6BAA6B,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;SAC7E;QACD,gGAAgG;QAChG,kGAAkG;QAClG,0CAA0C;QAC1C,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,EAAE;YACjC,aAAa,CAAC,GAAG,CAAC,YAAY,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;SAClD;QAED,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE;YAC3B,aAAa,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,wBAAiB,CAAC,CAAC,CAAC,CAAC;SAC3E;QAED,OAAO,aAAa,CAAC;IACvB,CAAC;IAtCD,sEAsCC;IAED;;;;;;;;;;;;;;;;;OAiBG;IACH,SAAS,6BAA6B,CAAC,EAAgD;YAA/C,UAAU,gBAAA,EAAE,YAAY,kBAAA;QAE9D,OAAO,YAAY,CAAC,CAAC,CAAC,yBAAkB,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC;IACpE,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 */\nimport {createInjectableType, R3InjectableMetadata, R3ProviderExpression} from '../../injectable_compiler_2';\nimport * as o from '../../output/output_ast';\nimport {Identifiers as R3} from '../r3_identifiers';\nimport {R3CompiledExpression} from '../util';\nimport {DefinitionMap} from '../view/util';\n\nimport {R3DeclareInjectableMetadata} from './api';\nimport {compileDependency, generateForwardRef} from './util';\n\n/**\n * Every time we make a breaking change to the declaration interface or partial-linker behavior, we\n * must update this constant to prevent old partial-linkers from incorrectly processing the\n * declaration.\n *\n * Do not include any prerelease in these versions as they are ignored.\n */\nconst MINIMUM_PARTIAL_LINKER_VERSION = '12.0.0';\n\n/**\n * Compile a Injectable declaration defined by the `R3InjectableMetadata`.\n */\nexport function compileDeclareInjectableFromMetadata(meta: R3InjectableMetadata):\n    R3CompiledExpression {\n  const definitionMap = createInjectableDefinitionMap(meta);\n\n  const expression = o.importExpr(R3.declareInjectable).callFn([definitionMap.toLiteralMap()]);\n  const type = createInjectableType(meta);\n\n  return {expression, type, statements: []};\n}\n\n/**\n * Gathers the declaration fields for a Injectable into a `DefinitionMap`.\n */\nexport function createInjectableDefinitionMap(meta: R3InjectableMetadata):\n    DefinitionMap<R3DeclareInjectableMetadata> {\n  const definitionMap = new DefinitionMap<R3DeclareInjectableMetadata>();\n\n  definitionMap.set('minVersion', o.literal(MINIMUM_PARTIAL_LINKER_VERSION));\n  definitionMap.set('version', o.literal('0.0.0-PLACEHOLDER'));\n  definitionMap.set('ngImport', o.importExpr(R3.core));\n  definitionMap.set('type', meta.internalType);\n\n  // Only generate providedIn property if it has a non-null value\n  if (meta.providedIn !== undefined) {\n    const providedIn = convertFromProviderExpression(meta.providedIn);\n    if ((providedIn as o.LiteralExpr).value !== null) {\n      definitionMap.set('providedIn', providedIn);\n    }\n  }\n\n  if (meta.useClass !== undefined) {\n    definitionMap.set('useClass', convertFromProviderExpression(meta.useClass));\n  }\n  if (meta.useExisting !== undefined) {\n    definitionMap.set('useExisting', convertFromProviderExpression(meta.useExisting));\n  }\n  if (meta.useValue !== undefined) {\n    definitionMap.set('useValue', convertFromProviderExpression(meta.useValue));\n  }\n  // Factories do not contain `ForwardRef`s since any types are already wrapped in a function call\n  // so the types will not be eagerly evaluated. Therefore we do not need to process this expression\n  // with `convertFromProviderExpression()`.\n  if (meta.useFactory !== undefined) {\n    definitionMap.set('useFactory', meta.useFactory);\n  }\n\n  if (meta.deps !== undefined) {\n    definitionMap.set('deps', o.literalArr(meta.deps.map(compileDependency)));\n  }\n\n  return definitionMap;\n}\n\n/**\n * Convert an `R3ProviderExpression` to an `Expression`, possibly wrapping its expression in a\n * `forwardRef()` call.\n *\n * If `R3ProviderExpression.isForwardRef` is true then the expression was originally wrapped in a\n * `forwardRef()` call to prevent the value from being eagerly evaluated in the code.\n *\n * Normally, the linker will statically process the code, putting the `expression` inside a factory\n * function so the `forwardRef()` wrapper is not evaluated before it has been defined. But if the\n * partial declaration is evaluated by the JIT compiler the `forwardRef()` call is still needed to\n * prevent eager evaluation of the `expression`.\n *\n * So in partial declarations, expressions that could be forward-refs are wrapped in `forwardRef()`\n * calls, and this is then unwrapped in the linker as necessary.\n *\n * See `packages/compiler-cli/src/ngtsc/annotations/src/injectable.ts` and\n * `packages/compiler/src/jit_compiler_facade.ts` for more information.\n */\nfunction convertFromProviderExpression({expression, isForwardRef}: R3ProviderExpression):\n    o.Expression {\n  return isForwardRef ? generateForwardRef(expression) : expression;\n}\n"]} |
---|