UNPKG

11.9 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 */
8import * as tslib_1 from "tslib";
9import { Identifiers } from './identifiers';
10import * as o from './output/output_ast';
11import { R3FactoryDelegateType, compileFactoryFunction } from './render3/r3_factory';
12import { mapToMapExpression, typeWithParameters } from './render3/util';
13export 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