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 | import * as tslib_1 from "tslib";
|
9 | import { Identifiers } from './identifiers';
|
10 | import * as o from './output/output_ast';
|
11 | import { R3FactoryDelegateType, compileFactoryFunction } from './render3/r3_factory';
|
12 | import { mapToMapExpression, typeWithParameters } from './render3/util';
|
13 | export function compileInjectable(meta) {
|
14 | var result = null;
|
15 | var factoryMeta = {
|
16 | name: meta.name,
|
17 | type: meta.type,
|
18 | deps: meta.ctorDeps,
|
19 | injectFn: Identifiers.inject,
|
20 | };
|
21 | if (meta.useClass !== undefined) {
|
22 | // meta.useClass has two modes of operation. Either deps are specified, in which case `new` is
|
23 | // used to instantiate the class with dependencies injected, or deps are not specified and
|
24 | // the factory of the class is used to instantiate it.
|
25 | //
|
26 | // A special case exists for useClass: Type where Type is the injectable type itself and no
|
27 | // deps are specified, in which case 'useClass' is effectively ignored.
|
28 | var useClassOnSelf = meta.useClass.isEquivalent(meta.type);
|
29 | var deps = undefined;
|
30 | if (meta.userDeps !== undefined) {
|
31 | deps = meta.userDeps;
|
32 | }
|
33 | if (deps !== undefined) {
|
34 | // factory: () => new meta.useClass(...deps)
|
35 | result = compileFactoryFunction(tslib_1.__assign({}, factoryMeta, { delegate: meta.useClass, delegateDeps: deps, delegateType: R3FactoryDelegateType.Class }));
|
36 | }
|
37 | else if (useClassOnSelf) {
|
38 | result = compileFactoryFunction(factoryMeta);
|
39 | }
|
40 | else {
|
41 | result = compileFactoryFunction(tslib_1.__assign({}, factoryMeta, { delegate: meta.useClass, delegateType: R3FactoryDelegateType.Factory }));
|
42 | }
|
43 | }
|
44 | else if (meta.useFactory !== undefined) {
|
45 | result = compileFactoryFunction(tslib_1.__assign({}, factoryMeta, { delegate: meta.useFactory, delegateDeps: meta.userDeps || [], delegateType: R3FactoryDelegateType.Function }));
|
46 | }
|
47 | else if (meta.useValue !== undefined) {
|
48 | // Note: it's safe to use `meta.useValue` instead of the `USE_VALUE in meta` check used for
|
49 | // client code because meta.useValue is an Expression which will be defined even if the actual
|
50 | // value is undefined.
|
51 | result = compileFactoryFunction(tslib_1.__assign({}, factoryMeta, { expression: meta.useValue }));
|
52 | }
|
53 | else if (meta.useExisting !== undefined) {
|
54 | // useExisting is an `inject` call on the existing token.
|
55 | result = compileFactoryFunction(tslib_1.__assign({}, factoryMeta, { expression: o.importExpr(Identifiers.inject).callFn([meta.useExisting]) }));
|
56 | }
|
57 | else {
|
58 | result = compileFactoryFunction(factoryMeta);
|
59 | }
|
60 | var token = meta.type;
|
61 | var providedIn = meta.providedIn;
|
62 | var expression = o.importExpr(Identifiers.ɵɵdefineInjectable).callFn([mapToMapExpression({ token: token, factory: result.factory, providedIn: providedIn })]);
|
63 | var type = new o.ExpressionType(o.importExpr(Identifiers.InjectableDef, [typeWithParameters(meta.type, meta.typeArgumentCount)]));
|
64 | return {
|
65 | expression: expression,
|
66 | type: type,
|
67 | statements: result.statements,
|
68 | };
|
69 | }
|
70 | //# 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 {InjectFlags} from './core';\nimport {Identifiers} from './identifiers';\nimport * as o from './output/output_ast';\nimport {R3DependencyMetadata, R3FactoryDelegateType, R3FactoryMetadata, compileFactoryFunction} from './render3/r3_factory';\nimport {mapToMapExpression, 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: o.Expression;\n  typeArgumentCount: number;\n  ctorDeps: R3DependencyMetadata[]|'invalid'|null;\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 = {\n    name: meta.name,\n    type: meta.type,\n    deps: meta.ctorDeps,\n    injectFn: Identifiers.inject,\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.type);\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 = compileFactoryFunction({\n        ...factoryMeta,\n        delegate: meta.useClass,\n        delegateType: R3FactoryDelegateType.Factory,\n      });\n    }\n  } else if (meta.useFactory !== undefined) {\n    result = compileFactoryFunction({\n      ...factoryMeta,\n      delegate: meta.useFactory,\n      delegateDeps: meta.userDeps || [],\n      delegateType: R3FactoryDelegateType.Function,\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 = compileFactoryFunction(factoryMeta);\n  }\n\n  const token = meta.type;\n  const providedIn = meta.providedIn;\n\n  const expression = o.importExpr(Identifiers.ɵɵdefineInjectable).callFn([mapToMapExpression(\n      {token, factory: result.factory, providedIn})]);\n  const type = new o.ExpressionType(o.importExpr(\n      Identifiers.InjectableDef, [typeWithParameters(meta.type, meta.typeArgumentCount)]));\n\n  return {\n    expression,\n    type,\n    statements: result.statements,\n  };\n}\n"]} |
\ | No newline at end of file |