UNPKG

17 kBJavaScriptView Raw
1/**
2 * @license
3 * Copyright Google Inc. 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/identifiers", "@angular/compiler/src/output/output_ast", "@angular/compiler/src/render3/r3_factory", "@angular/compiler/src/render3/util"], factory);
15 }
16})(function (require, exports) {
17 "use strict";
18 Object.defineProperty(exports, "__esModule", { value: true });
19 var tslib_1 = require("tslib");
20 var identifiers_1 = require("@angular/compiler/src/identifiers");
21 var o = require("@angular/compiler/src/output/output_ast");
22 var r3_factory_1 = require("@angular/compiler/src/render3/r3_factory");
23 var util_1 = require("@angular/compiler/src/render3/util");
24 function compileInjectable(meta) {
25 var result = null;
26 var factoryMeta = {
27 name: meta.name,
28 type: meta.type,
29 internalType: meta.internalType,
30 typeArgumentCount: meta.typeArgumentCount,
31 deps: [],
32 injectFn: identifiers_1.Identifiers.inject,
33 target: r3_factory_1.R3FactoryTarget.Injectable,
34 };
35 if (meta.useClass !== undefined) {
36 // meta.useClass has two modes of operation. Either deps are specified, in which case `new` is
37 // used to instantiate the class with dependencies injected, or deps are not specified and
38 // the factory of the class is used to instantiate it.
39 //
40 // A special case exists for useClass: Type where Type is the injectable type itself and no
41 // deps are specified, in which case 'useClass' is effectively ignored.
42 var useClassOnSelf = meta.useClass.isEquivalent(meta.internalType);
43 var deps = undefined;
44 if (meta.userDeps !== undefined) {
45 deps = meta.userDeps;
46 }
47 if (deps !== undefined) {
48 // factory: () => new meta.useClass(...deps)
49 result = r3_factory_1.compileFactoryFunction(tslib_1.__assign(tslib_1.__assign({}, factoryMeta), { delegate: meta.useClass, delegateDeps: deps, delegateType: r3_factory_1.R3FactoryDelegateType.Class }));
50 }
51 else if (useClassOnSelf) {
52 result = r3_factory_1.compileFactoryFunction(factoryMeta);
53 }
54 else {
55 result = delegateToFactory(meta.type.value, meta.useClass);
56 }
57 }
58 else if (meta.useFactory !== undefined) {
59 if (meta.userDeps !== undefined) {
60 result = r3_factory_1.compileFactoryFunction(tslib_1.__assign(tslib_1.__assign({}, factoryMeta), { delegate: meta.useFactory, delegateDeps: meta.userDeps || [], delegateType: r3_factory_1.R3FactoryDelegateType.Function }));
61 }
62 else {
63 result = {
64 statements: [],
65 factory: o.fn([], [new o.ReturnStatement(meta.useFactory.callFn([]))])
66 };
67 }
68 }
69 else if (meta.useValue !== undefined) {
70 // Note: it's safe to use `meta.useValue` instead of the `USE_VALUE in meta` check used for
71 // client code because meta.useValue is an Expression which will be defined even if the actual
72 // value is undefined.
73 result = r3_factory_1.compileFactoryFunction(tslib_1.__assign(tslib_1.__assign({}, factoryMeta), { expression: meta.useValue }));
74 }
75 else if (meta.useExisting !== undefined) {
76 // useExisting is an `inject` call on the existing token.
77 result = r3_factory_1.compileFactoryFunction(tslib_1.__assign(tslib_1.__assign({}, factoryMeta), { expression: o.importExpr(identifiers_1.Identifiers.inject).callFn([meta.useExisting]) }));
78 }
79 else {
80 result = delegateToFactory(meta.type.value, meta.internalType);
81 }
82 var token = meta.internalType;
83 var injectableProps = { token: token, factory: result.factory };
84 // Only generate providedIn property if it has a non-null value
85 if (meta.providedIn.value !== null) {
86 injectableProps.providedIn = meta.providedIn;
87 }
88 var expression = o.importExpr(identifiers_1.Identifiers.ɵɵdefineInjectable).callFn([util_1.mapToMapExpression(injectableProps)]);
89 var type = new o.ExpressionType(o.importExpr(identifiers_1.Identifiers.InjectableDef, [util_1.typeWithParameters(meta.type.type, meta.typeArgumentCount)]));
90 return {
91 expression: expression,
92 type: type,
93 statements: result.statements,
94 };
95 }
96 exports.compileInjectable = compileInjectable;
97 function delegateToFactory(type, internalType) {
98 return {
99 statements: [],
100 // If types are the same, we can generate `factory: type.ɵfac`
101 // If types are different, we have to generate a wrapper function to ensure
102 // the internal type has been resolved (`factory: function(t) { return type.ɵfac(t); }`)
103 factory: type.node === internalType.node ?
104 internalType.prop('ɵfac') :
105 o.fn([new o.FnParam('t', o.DYNAMIC_TYPE)], [new o.ReturnStatement(internalType.callMethod('ɵfac', [o.variable('t')]))])
106 };
107 }
108});
109//# 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 Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Identifiers} from './identifiers';\nimport * as o from './output/output_ast';\nimport {compileFactoryFunction, R3DependencyMetadata, R3FactoryDelegateType, R3FactoryMetadata, R3FactoryTarget} from './render3/r3_factory';\nimport {mapToMapExpression, R3Reference, typeWithParameters} from './render3/util';\n\nexport interface InjectableDef {\n  expression: o.Expression;\n  type: o.Type;\n  statements: o.Statement[];\n}\n\nexport interface R3InjectableMetadata {\n  name: string;\n  type: R3Reference;\n  internalType: o.Expression;\n  typeArgumentCount: number;\n  providedIn: o.Expression;\n  useClass?: o.Expression;\n  useFactory?: o.Expression;\n  useExisting?: o.Expression;\n  useValue?: o.Expression;\n  userDeps?: R3DependencyMetadata[];\n}\n\nexport function compileInjectable(meta: R3InjectableMetadata): InjectableDef {\n  let result: {factory: 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    injectFn: Identifiers.inject,\n    target: R3FactoryTarget.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.isEquivalent(meta.internalType);\n    let deps: R3DependencyMetadata[]|undefined = undefined;\n    if (meta.userDeps !== undefined) {\n      deps = meta.userDeps;\n    }\n\n    if (deps !== undefined) {\n      // factory: () => new meta.useClass(...deps)\n      result = compileFactoryFunction({\n        ...factoryMeta,\n        delegate: meta.useClass,\n        delegateDeps: deps,\n        delegateType: R3FactoryDelegateType.Class,\n      });\n    } else if (useClassOnSelf) {\n      result = compileFactoryFunction(factoryMeta);\n    } else {\n      result = delegateToFactory(\n          meta.type.value as o.WrappedNodeExpr<any>, meta.useClass as o.WrappedNodeExpr<any>);\n    }\n  } else if (meta.useFactory !== undefined) {\n    if (meta.userDeps !== undefined) {\n      result = compileFactoryFunction({\n        ...factoryMeta,\n        delegate: meta.useFactory,\n        delegateDeps: meta.userDeps || [],\n        delegateType: R3FactoryDelegateType.Function,\n      });\n    } else {\n      result = {\n        statements: [],\n        factory: 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,\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]),\n    });\n  } else {\n    result = delegateToFactory(\n        meta.type.value as o.WrappedNodeExpr<any>, meta.internalType as o.WrappedNodeExpr<any>);\n  }\n\n  const token = meta.internalType;\n\n  const injectableProps: {[key: string]: o.Expression} = {token, factory: result.factory};\n\n  // Only generate providedIn property if it has a non-null value\n  if ((meta.providedIn as o.LiteralExpr).value !== null) {\n    injectableProps.providedIn = meta.providedIn;\n  }\n\n  const expression =\n      o.importExpr(Identifiers.ɵɵdefineInjectable).callFn([mapToMapExpression(injectableProps)]);\n  const type = new o.ExpressionType(o.importExpr(\n      Identifiers.InjectableDef, [typeWithParameters(meta.type.type, meta.typeArgumentCount)]));\n\n  return {\n    expression,\n    type,\n    statements: result.statements,\n  };\n}\n\nfunction delegateToFactory(type: o.WrappedNodeExpr<any>, internalType: o.WrappedNodeExpr<any>) {\n  return {\n    statements: [],\n    // If types are the same, we can generate `factory: type.ɵfac`\n    // If types are different, we have to generate a wrapper function to ensure\n    // the internal type has been resolved (`factory: function(t) { return type.ɵfac(t); }`)\n    factory: type.node === internalType.node ?\n        internalType.prop('ɵfac') :\n        o.fn([new o.FnParam('t', o.DYNAMIC_TYPE)], [new o.ReturnStatement(internalType.callMethod(\n                                                       'ɵfac', [o.variable('t')]))])\n  };\n}\n"]}
\No newline at end of file