1 | /**
|
---|
2 | * @license
|
---|
3 | * Copyright Google LLC All Rights Reserved.
|
---|
4 | *
|
---|
5 | * Use of this source code is governed by an MIT-style license that can be
|
---|
6 | * found in the LICENSE file at https://angular.io/license
|
---|
7 | */
|
---|
8 | (function (factory) {
|
---|
9 | if (typeof module === "object" && typeof module.exports === "object") {
|
---|
10 | var v = factory(require, exports);
|
---|
11 | if (v !== undefined) module.exports = v;
|
---|
12 | }
|
---|
13 | else if (typeof define === "function" && define.amd) {
|
---|
14 | define("@angular/compiler/src/injectable_compiler_2", ["require", "exports", "tslib", "@angular/compiler/src/output/output_ast", "@angular/compiler/src/render3/partial/util", "@angular/compiler/src/render3/r3_factory", "@angular/compiler/src/render3/r3_identifiers", "@angular/compiler/src/render3/util", "@angular/compiler/src/render3/view/util"], factory);
|
---|
15 | }
|
---|
16 | })(function (require, exports) {
|
---|
17 | "use strict";
|
---|
18 | Object.defineProperty(exports, "__esModule", { value: true });
|
---|
19 | exports.createInjectableType = exports.compileInjectable = exports.createR3ProviderExpression = void 0;
|
---|
20 | var tslib_1 = require("tslib");
|
---|
21 | var o = require("@angular/compiler/src/output/output_ast");
|
---|
22 | var util_1 = require("@angular/compiler/src/render3/partial/util");
|
---|
23 | var r3_factory_1 = require("@angular/compiler/src/render3/r3_factory");
|
---|
24 | var r3_identifiers_1 = require("@angular/compiler/src/render3/r3_identifiers");
|
---|
25 | var util_2 = require("@angular/compiler/src/render3/util");
|
---|
26 | var util_3 = require("@angular/compiler/src/render3/view/util");
|
---|
27 | function createR3ProviderExpression(expression, isForwardRef) {
|
---|
28 | return { expression: expression, isForwardRef: isForwardRef };
|
---|
29 | }
|
---|
30 | exports.createR3ProviderExpression = createR3ProviderExpression;
|
---|
31 | function compileInjectable(meta, resolveForwardRefs) {
|
---|
32 | var result = null;
|
---|
33 | var factoryMeta = {
|
---|
34 | name: meta.name,
|
---|
35 | type: meta.type,
|
---|
36 | internalType: meta.internalType,
|
---|
37 | typeArgumentCount: meta.typeArgumentCount,
|
---|
38 | deps: [],
|
---|
39 | target: r3_factory_1.FactoryTarget.Injectable,
|
---|
40 | };
|
---|
41 | if (meta.useClass !== undefined) {
|
---|
42 | // meta.useClass has two modes of operation. Either deps are specified, in which case `new` is
|
---|
43 | // used to instantiate the class with dependencies injected, or deps are not specified and
|
---|
44 | // the factory of the class is used to instantiate it.
|
---|
45 | //
|
---|
46 | // A special case exists for useClass: Type where Type is the injectable type itself and no
|
---|
47 | // deps are specified, in which case 'useClass' is effectively ignored.
|
---|
48 | var useClassOnSelf = meta.useClass.expression.isEquivalent(meta.internalType);
|
---|
49 | var deps = undefined;
|
---|
50 | if (meta.deps !== undefined) {
|
---|
51 | deps = meta.deps;
|
---|
52 | }
|
---|
53 | if (deps !== undefined) {
|
---|
54 | // factory: () => new meta.useClass(...deps)
|
---|
55 | result = r3_factory_1.compileFactoryFunction(tslib_1.__assign(tslib_1.__assign({}, factoryMeta), { delegate: meta.useClass.expression, delegateDeps: deps, delegateType: r3_factory_1.R3FactoryDelegateType.Class }));
|
---|
56 | }
|
---|
57 | else if (useClassOnSelf) {
|
---|
58 | result = r3_factory_1.compileFactoryFunction(factoryMeta);
|
---|
59 | }
|
---|
60 | else {
|
---|
61 | result = {
|
---|
62 | statements: [],
|
---|
63 | expression: delegateToFactory(meta.type.value, meta.useClass.expression, resolveForwardRefs)
|
---|
64 | };
|
---|
65 | }
|
---|
66 | }
|
---|
67 | else if (meta.useFactory !== undefined) {
|
---|
68 | if (meta.deps !== undefined) {
|
---|
69 | result = r3_factory_1.compileFactoryFunction(tslib_1.__assign(tslib_1.__assign({}, factoryMeta), { delegate: meta.useFactory, delegateDeps: meta.deps || [], delegateType: r3_factory_1.R3FactoryDelegateType.Function }));
|
---|
70 | }
|
---|
71 | else {
|
---|
72 | result = {
|
---|
73 | statements: [],
|
---|
74 | expression: o.fn([], [new o.ReturnStatement(meta.useFactory.callFn([]))])
|
---|
75 | };
|
---|
76 | }
|
---|
77 | }
|
---|
78 | else if (meta.useValue !== undefined) {
|
---|
79 | // Note: it's safe to use `meta.useValue` instead of the `USE_VALUE in meta` check used for
|
---|
80 | // client code because meta.useValue is an Expression which will be defined even if the actual
|
---|
81 | // value is undefined.
|
---|
82 | result = r3_factory_1.compileFactoryFunction(tslib_1.__assign(tslib_1.__assign({}, factoryMeta), { expression: meta.useValue.expression }));
|
---|
83 | }
|
---|
84 | else if (meta.useExisting !== undefined) {
|
---|
85 | // useExisting is an `inject` call on the existing token.
|
---|
86 | result = r3_factory_1.compileFactoryFunction(tslib_1.__assign(tslib_1.__assign({}, factoryMeta), { expression: o.importExpr(r3_identifiers_1.Identifiers.inject).callFn([meta.useExisting.expression]) }));
|
---|
87 | }
|
---|
88 | else {
|
---|
89 | result = {
|
---|
90 | statements: [],
|
---|
91 | expression: delegateToFactory(meta.type.value, meta.internalType, resolveForwardRefs)
|
---|
92 | };
|
---|
93 | }
|
---|
94 | var token = meta.internalType;
|
---|
95 | var injectableProps = new util_3.DefinitionMap();
|
---|
96 | injectableProps.set('token', token);
|
---|
97 | injectableProps.set('factory', result.expression);
|
---|
98 | // Only generate providedIn property if it has a non-null value
|
---|
99 | if (meta.providedIn.expression.value !== null) {
|
---|
100 | injectableProps.set('providedIn', meta.providedIn.isForwardRef ? util_1.generateForwardRef(meta.providedIn.expression) :
|
---|
101 | meta.providedIn.expression);
|
---|
102 | }
|
---|
103 | var expression = o.importExpr(r3_identifiers_1.Identifiers.ɵɵdefineInjectable)
|
---|
104 | .callFn([injectableProps.toLiteralMap()], undefined, true);
|
---|
105 | return {
|
---|
106 | expression: expression,
|
---|
107 | type: createInjectableType(meta),
|
---|
108 | statements: result.statements,
|
---|
109 | };
|
---|
110 | }
|
---|
111 | exports.compileInjectable = compileInjectable;
|
---|
112 | function createInjectableType(meta) {
|
---|
113 | return new o.ExpressionType(o.importExpr(r3_identifiers_1.Identifiers.InjectableDeclaration, [util_2.typeWithParameters(meta.type.type, meta.typeArgumentCount)]));
|
---|
114 | }
|
---|
115 | exports.createInjectableType = createInjectableType;
|
---|
116 | function delegateToFactory(type, internalType, unwrapForwardRefs) {
|
---|
117 | if (type.node === internalType.node) {
|
---|
118 | // The types are the same, so we can simply delegate directly to the type's factory.
|
---|
119 | // ```
|
---|
120 | // factory: type.ɵfac
|
---|
121 | // ```
|
---|
122 | return internalType.prop('ɵfac');
|
---|
123 | }
|
---|
124 | if (!unwrapForwardRefs) {
|
---|
125 | // The type is not wrapped in a `forwardRef()`, so we create a simple factory function that
|
---|
126 | // accepts a sub-type as an argument.
|
---|
127 | // ```
|
---|
128 | // factory: function(t) { return internalType.ɵfac(t); }
|
---|
129 | // ```
|
---|
130 | return createFactoryFunction(internalType);
|
---|
131 | }
|
---|
132 | // The internalType is actually wrapped in a `forwardRef()` so we need to resolve that before
|
---|
133 | // calling its factory.
|
---|
134 | // ```
|
---|
135 | // factory: function(t) { return core.resolveForwardRef(type).ɵfac(t); }
|
---|
136 | // ```
|
---|
137 | var unwrappedType = o.importExpr(r3_identifiers_1.Identifiers.resolveForwardRef).callFn([internalType]);
|
---|
138 | return createFactoryFunction(unwrappedType);
|
---|
139 | }
|
---|
140 | function createFactoryFunction(type) {
|
---|
141 | return o.fn([new o.FnParam('t', o.DYNAMIC_TYPE)], [new o.ReturnStatement(type.callMethod('ɵfac', [o.variable('t')]))]);
|
---|
142 | }
|
---|
143 | });
|
---|
144 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"injectable_compiler_2.js","sourceRoot":"","sources":["../../../../../../packages/compiler/src/injectable_compiler_2.ts"],"names":[],"mappings":"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","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 * as o from './output/output_ast';\nimport {generateForwardRef} from './render3/partial/util';\nimport {compileFactoryFunction, FactoryTarget, R3DependencyMetadata, R3FactoryDelegateType, R3FactoryMetadata} from './render3/r3_factory';\nimport {Identifiers} from './render3/r3_identifiers';\nimport {R3CompiledExpression, R3Reference, typeWithParameters} from './render3/util';\nimport {DefinitionMap} from './render3/view/util';\n\nexport interface R3InjectableMetadata {\n  name: string;\n  type: R3Reference;\n  internalType: o.Expression;\n  typeArgumentCount: number;\n  providedIn: R3ProviderExpression;\n  useClass?: R3ProviderExpression;\n  useFactory?: o.Expression;\n  useExisting?: R3ProviderExpression;\n  useValue?: R3ProviderExpression;\n  deps?: R3DependencyMetadata[];\n}\n\n/**\n * An expression used when instantiating an injectable.\n *\n * This is the type of the `useClass`, `useExisting` and `useValue` properties of\n * `R3InjectableMetadata` since those can refer to types that may eagerly reference types that have\n * not yet been defined.\n */\nexport interface R3ProviderExpression<T extends o.Expression = o.Expression> {\n  /**\n   * The expression that is used to instantiate the Injectable.\n   */\n  expression: T;\n  /**\n   * If true, then the `expression` contains a reference to something that has not yet been\n   * defined.\n   *\n   * This means that the expression must not be eagerly evaluated. Instead it must be wrapped in a\n   * function closure that will be evaluated lazily to allow the definition of the expression to be\n   * evaluated first.\n   *\n   * In some cases the expression will naturally be placed inside such a function closure, such as\n   * in a fully compiled factory function. In those case nothing more needs to be done.\n   *\n   * But in other cases, such as partial-compilation the expression will be located in top level\n   * code so will need to be wrapped in a function that is passed to a `forwardRef()` call.\n   */\n  isForwardRef: boolean;\n}\n\nexport function createR3ProviderExpression<T extends o.Expression>(\n    expression: T, isForwardRef: boolean): R3ProviderExpression<T> {\n  return {expression, isForwardRef};\n}\n\nexport function compileInjectable(\n    meta: R3InjectableMetadata, resolveForwardRefs: boolean): R3CompiledExpression {\n  let result: {expression: o.Expression, statements: o.Statement[]}|null = null;\n\n  const factoryMeta: R3FactoryMetadata = {\n    name: meta.name,\n    type: meta.type,\n    internalType: meta.internalType,\n    typeArgumentCount: meta.typeArgumentCount,\n    deps: [],\n    target: FactoryTarget.Injectable,\n  };\n\n  if (meta.useClass !== undefined) {\n    // meta.useClass has two modes of operation. Either deps are specified, in which case `new` is\n    // used to instantiate the class with dependencies injected, or deps are not specified and\n    // the factory of the class is used to instantiate it.\n    //\n    // A special case exists for useClass: Type where Type is the injectable type itself and no\n    // deps are specified, in which case 'useClass' is effectively ignored.\n\n    const useClassOnSelf = meta.useClass.expression.isEquivalent(meta.internalType);\n    let deps: R3DependencyMetadata[]|undefined = undefined;\n    if (meta.deps !== undefined) {\n      deps = meta.deps;\n    }\n\n    if (deps !== undefined) {\n      // factory: () => new meta.useClass(...deps)\n      result = compileFactoryFunction({\n        ...factoryMeta,\n        delegate: meta.useClass.expression,\n        delegateDeps: deps,\n        delegateType: R3FactoryDelegateType.Class,\n      });\n    } else if (useClassOnSelf) {\n      result = compileFactoryFunction(factoryMeta);\n    } else {\n      result = {\n        statements: [],\n        expression: delegateToFactory(\n            meta.type.value as o.WrappedNodeExpr<any>,\n            meta.useClass.expression as o.WrappedNodeExpr<any>, resolveForwardRefs)\n      };\n    }\n  } else if (meta.useFactory !== undefined) {\n    if (meta.deps !== undefined) {\n      result = compileFactoryFunction({\n        ...factoryMeta,\n        delegate: meta.useFactory,\n        delegateDeps: meta.deps || [],\n        delegateType: R3FactoryDelegateType.Function,\n      });\n    } else {\n      result = {\n        statements: [],\n        expression: o.fn([], [new o.ReturnStatement(meta.useFactory.callFn([]))])\n      };\n    }\n  } else if (meta.useValue !== undefined) {\n    // Note: it's safe to use `meta.useValue` instead of the `USE_VALUE in meta` check used for\n    // client code because meta.useValue is an Expression which will be defined even if the actual\n    // value is undefined.\n    result = compileFactoryFunction({\n      ...factoryMeta,\n      expression: meta.useValue.expression,\n    });\n  } else if (meta.useExisting !== undefined) {\n    // useExisting is an `inject` call on the existing token.\n    result = compileFactoryFunction({\n      ...factoryMeta,\n      expression: o.importExpr(Identifiers.inject).callFn([meta.useExisting.expression]),\n    });\n  } else {\n    result = {\n      statements: [],\n      expression: delegateToFactory(\n          meta.type.value as o.WrappedNodeExpr<any>, meta.internalType as o.WrappedNodeExpr<any>,\n          resolveForwardRefs)\n    };\n  }\n\n  const token = meta.internalType;\n\n  const injectableProps =\n      new DefinitionMap<{token: o.Expression, factory: o.Expression, providedIn: o.Expression}>();\n  injectableProps.set('token', token);\n  injectableProps.set('factory', result.expression);\n\n  // Only generate providedIn property if it has a non-null value\n  if ((meta.providedIn.expression as o.LiteralExpr).value !== null) {\n    injectableProps.set(\n        'providedIn',\n        meta.providedIn.isForwardRef ? generateForwardRef(meta.providedIn.expression) :\n                                       meta.providedIn.expression);\n  }\n\n  const expression = o.importExpr(Identifiers.ɵɵdefineInjectable)\n                         .callFn([injectableProps.toLiteralMap()], undefined, true);\n  return {\n    expression,\n    type: createInjectableType(meta),\n    statements: result.statements,\n  };\n}\n\nexport function createInjectableType(meta: R3InjectableMetadata) {\n  return new o.ExpressionType(o.importExpr(\n      Identifiers.InjectableDeclaration,\n      [typeWithParameters(meta.type.type, meta.typeArgumentCount)]));\n}\n\nfunction delegateToFactory(\n    type: o.WrappedNodeExpr<any>, internalType: o.WrappedNodeExpr<any>,\n    unwrapForwardRefs: boolean): o.Expression {\n  if (type.node === internalType.node) {\n    // The types are the same, so we can simply delegate directly to the type's factory.\n    // ```\n    // factory: type.ɵfac\n    // ```\n    return internalType.prop('ɵfac');\n  }\n\n  if (!unwrapForwardRefs) {\n    // The type is not wrapped in a `forwardRef()`, so we create a simple factory function that\n    // accepts a sub-type as an argument.\n    // ```\n    // factory: function(t) { return internalType.ɵfac(t); }\n    // ```\n    return createFactoryFunction(internalType);\n  }\n\n  // The internalType is actually wrapped in a `forwardRef()` so we need to resolve that before\n  // calling its factory.\n  // ```\n  // factory: function(t) { return core.resolveForwardRef(type).ɵfac(t); }\n  // ```\n  const unwrappedType = o.importExpr(Identifiers.resolveForwardRef).callFn([internalType]);\n  return createFactoryFunction(unwrappedType);\n}\n\nfunction createFactoryFunction(type: o.Expression): o.FunctionExpr {\n  return o.fn(\n      [new o.FnParam('t', o.DYNAMIC_TYPE)],\n      [new o.ReturnStatement(type.callMethod('ɵfac', [o.variable('t')]))]);\n}\n"]} |
---|