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 | ;
|
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 |