ts-ioc-container 16.0.1 → 17.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cjm/automock/AutoMockedContainer.d.ts +2 -2
- package/cjm/automock/AutoMockedContainer.js +2 -3
- package/cjm/automock/AutoMockedContainer.js.map +1 -1
- package/cjm/automock/IMockRepository.d.ts +2 -2
- package/cjm/core/IInjector.d.ts +15 -2
- package/cjm/core/IInjector.js +48 -0
- package/cjm/core/IInjector.js.map +1 -1
- package/cjm/core/container/Container.d.ts +2 -4
- package/cjm/core/container/Container.js +8 -14
- package/cjm/core/container/Container.js.map +1 -1
- package/cjm/core/container/EmptyContainer.d.ts +2 -1
- package/cjm/core/container/EmptyContainer.js +3 -0
- package/cjm/core/container/EmptyContainer.js.map +1 -1
- package/cjm/core/container/IContainer.d.ts +3 -4
- package/cjm/core/provider/IProvider.d.ts +2 -2
- package/cjm/core/utils/types.d.ts +1 -1
- package/cjm/index.d.ts +2 -3
- package/cjm/index.js +3 -3
- package/cjm/index.js.map +1 -1
- package/cjm/injectors/ProxyInjector.d.ts +3 -0
- package/cjm/injectors/ProxyInjector.js +7 -0
- package/cjm/injectors/ProxyInjector.js.map +1 -1
- package/cjm/injectors/SimpleInjector.d.ts +3 -0
- package/cjm/injectors/SimpleInjector.js +7 -0
- package/cjm/injectors/SimpleInjector.js.map +1 -1
- package/esm/automock/AutoMockedContainer.d.ts +2 -2
- package/esm/automock/AutoMockedContainer.js +2 -3
- package/esm/automock/AutoMockedContainer.js.map +1 -1
- package/esm/automock/IMockRepository.d.ts +2 -2
- package/esm/core/IInjector.d.ts +15 -2
- package/esm/core/IInjector.js +16 -1
- package/esm/core/IInjector.js.map +1 -1
- package/esm/core/container/Container.d.ts +2 -4
- package/esm/core/container/Container.js +8 -14
- package/esm/core/container/Container.js.map +1 -1
- package/esm/core/container/EmptyContainer.d.ts +2 -1
- package/esm/core/container/EmptyContainer.js +3 -0
- package/esm/core/container/EmptyContainer.js.map +1 -1
- package/esm/core/container/IContainer.d.ts +3 -4
- package/esm/core/provider/IProvider.d.ts +2 -2
- package/esm/core/utils/types.d.ts +1 -1
- package/esm/index.d.ts +2 -3
- package/esm/index.js +1 -1
- package/esm/index.js.map +1 -1
- package/esm/injectors/ProxyInjector.d.ts +3 -0
- package/esm/injectors/ProxyInjector.js +7 -0
- package/esm/injectors/ProxyInjector.js.map +1 -1
- package/esm/injectors/SimpleInjector.d.ts +3 -0
- package/esm/injectors/SimpleInjector.js +7 -0
- package/esm/injectors/SimpleInjector.js.map +1 -1
- package/package.json +2 -2
- package/cjm/core/container/IContainerHook.d.ts +0 -6
- package/cjm/core/container/IContainerHook.js +0 -10
- package/cjm/core/container/IContainerHook.js.map +0 -1
- package/cjm/hooks/ContainerHook.d.ts +0 -10
- package/cjm/hooks/ContainerHook.js +0 -49
- package/cjm/hooks/ContainerHook.js.map +0 -1
- package/esm/core/container/IContainerHook.d.ts +0 -6
- package/esm/core/container/IContainerHook.js +0 -7
- package/esm/core/container/IContainerHook.js.map +0 -1
- package/esm/hooks/ContainerHook.d.ts +0 -10
- package/esm/hooks/ContainerHook.js +0 -21
- package/esm/hooks/ContainerHook.js.map +0 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IContainer,
|
|
1
|
+
import { IContainer, InjectionToken, IProvider, Tag } from '../index';
|
|
2
2
|
import { IMockRepository } from './IMockRepository';
|
|
3
3
|
export declare class AutoMockedContainer implements IContainer {
|
|
4
4
|
private decorated;
|
|
@@ -9,5 +9,5 @@ export declare class AutoMockedContainer implements IContainer {
|
|
|
9
9
|
dispose(): void;
|
|
10
10
|
getProviders(): IProvider<unknown>[];
|
|
11
11
|
register(provider: IProvider<unknown>): this;
|
|
12
|
-
|
|
12
|
+
getInstances(): unknown[];
|
|
13
13
|
}
|
|
@@ -62,9 +62,8 @@ var AutoMockedContainer = /** @class */ (function () {
|
|
|
62
62
|
this.decorated.register(provider);
|
|
63
63
|
return this;
|
|
64
64
|
};
|
|
65
|
-
AutoMockedContainer.prototype.
|
|
66
|
-
this.decorated.
|
|
67
|
-
return this;
|
|
65
|
+
AutoMockedContainer.prototype.getInstances = function () {
|
|
66
|
+
return this.decorated.getInstances();
|
|
68
67
|
};
|
|
69
68
|
return AutoMockedContainer;
|
|
70
69
|
}());
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AutoMockedContainer.js","sourceRoot":"","sources":["../../lib/automock/AutoMockedContainer.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"AutoMockedContainer.js","sourceRoot":"","sources":["../../lib/automock/AutoMockedContainer.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,kCAA6F;AAG7F;IACI,6BAAoB,SAAqB,EAAU,cAA+B;QAA9D,cAAS,GAAT,SAAS,CAAY;QAAU,mBAAc,GAAd,cAAc,CAAiB;IAAG,CAAC;IAEtF,yCAAW,GAAX,UAAY,IAAY,EAAE,MAAyB;QAAzB,uBAAA,EAAA,aAAyB;QAC/C,OAAO,IAAI,mBAAmB,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,EAAE,MAAM,CAAC,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;IAClG,CAAC;IAED,qCAAO,GAAP,UAAW,GAAsB;;QAAE,cAAc;aAAd,UAAc,EAAd,qBAAc,EAAd,IAAc;YAAd,6BAAc;;QAC7C,IAAI;YACA,OAAO,CAAA,KAAA,IAAI,CAAC,SAAS,CAAA,CAAC,OAAO,0BAAC,GAAG,UAAK,IAAI,WAAE;SAC/C;QAAC,OAAO,CAAC,EAAE;YACR,IAAI,CAAC,YAAY,6BAAqB,EAAE;gBACpC,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,CAAI,GAAG,CAAC,CAAC;aAC9C;YAED,MAAM,CAAC,CAAC;SACX;IACL,CAAC;IAED,qCAAO,GAAP;QACI,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;IAED,0CAAY,GAAZ;QACI,OAAO,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,CAAC;IACzC,CAAC;IAED,sCAAQ,GAAR,UAAS,QAA4B;QACjC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QAClC,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,0CAAY,GAAZ;QACI,OAAO,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,CAAC;IACzC,CAAC;IACL,0BAAC;AAAD,CAAC,AAnCD,IAmCC;AAnCY,kDAAmB"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import {
|
|
2
|
-
export interface IMockRepository extends
|
|
1
|
+
import { Disposable, Resolveable } from '../index';
|
|
2
|
+
export interface IMockRepository extends Disposable, Resolveable {
|
|
3
3
|
}
|
package/cjm/core/IInjector.d.ts
CHANGED
|
@@ -1,5 +1,18 @@
|
|
|
1
|
-
import { constructor } from './utils/types';
|
|
1
|
+
import { constructor, Disposable } from './utils/types';
|
|
2
2
|
import { IContainer } from './container/IContainer';
|
|
3
|
-
export
|
|
3
|
+
export declare type VisitInstance = (instance: unknown) => Promise<void>;
|
|
4
|
+
export interface Traversable {
|
|
5
|
+
getInstances(): unknown[];
|
|
6
|
+
}
|
|
7
|
+
export interface IInjector extends Disposable, Traversable {
|
|
8
|
+
resolve<T>(container: IContainer, value: constructor<T>, ...deps: any[]): T;
|
|
9
|
+
clone(): IInjector;
|
|
10
|
+
}
|
|
11
|
+
export declare abstract class Injector implements IInjector {
|
|
12
|
+
private values;
|
|
13
|
+
abstract clone(): IInjector;
|
|
14
|
+
getInstances(): unknown[];
|
|
15
|
+
dispose(): void;
|
|
4
16
|
resolve<T>(container: IContainer, value: constructor<T>, ...deps: any[]): T;
|
|
17
|
+
protected abstract resolver<T>(container: IContainer, value: constructor<T>, ...args: any[]): T;
|
|
5
18
|
}
|
package/cjm/core/IInjector.js
CHANGED
|
@@ -1,3 +1,51 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __read = (this && this.__read) || function (o, n) {
|
|
3
|
+
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
4
|
+
if (!m) return o;
|
|
5
|
+
var i = m.call(o), r, ar = [], e;
|
|
6
|
+
try {
|
|
7
|
+
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
8
|
+
}
|
|
9
|
+
catch (error) { e = { error: error }; }
|
|
10
|
+
finally {
|
|
11
|
+
try {
|
|
12
|
+
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
13
|
+
}
|
|
14
|
+
finally { if (e) throw e.error; }
|
|
15
|
+
}
|
|
16
|
+
return ar;
|
|
17
|
+
};
|
|
18
|
+
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
19
|
+
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
20
|
+
if (ar || !(i in from)) {
|
|
21
|
+
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
22
|
+
ar[i] = from[i];
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
return to.concat(ar || Array.prototype.slice.call(from));
|
|
26
|
+
};
|
|
2
27
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
28
|
+
exports.Injector = void 0;
|
|
29
|
+
var Injector = /** @class */ (function () {
|
|
30
|
+
function Injector() {
|
|
31
|
+
this.values = [];
|
|
32
|
+
}
|
|
33
|
+
Injector.prototype.getInstances = function () {
|
|
34
|
+
return this.values;
|
|
35
|
+
};
|
|
36
|
+
Injector.prototype.dispose = function () {
|
|
37
|
+
this.values = [];
|
|
38
|
+
};
|
|
39
|
+
Injector.prototype.resolve = function (container, value) {
|
|
40
|
+
var deps = [];
|
|
41
|
+
for (var _i = 2; _i < arguments.length; _i++) {
|
|
42
|
+
deps[_i - 2] = arguments[_i];
|
|
43
|
+
}
|
|
44
|
+
var instance = this.resolver.apply(this, __spreadArray([container, value], __read(deps), false));
|
|
45
|
+
this.values.push(instance);
|
|
46
|
+
return instance;
|
|
47
|
+
};
|
|
48
|
+
return Injector;
|
|
49
|
+
}());
|
|
50
|
+
exports.Injector = Injector;
|
|
3
51
|
//# sourceMappingURL=IInjector.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"IInjector.js","sourceRoot":"","sources":["../../lib/core/IInjector.ts"],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"IInjector.js","sourceRoot":"","sources":["../../lib/core/IInjector.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAeA;IAAA;QACY,WAAM,GAAc,EAAE,CAAC;IAmBnC,CAAC;IAfG,+BAAY,GAAZ;QACI,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,0BAAO,GAAP;QACI,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,0BAAO,GAAP,UAAW,SAAqB,EAAE,KAAqB;QAAE,cAAc;aAAd,UAAc,EAAd,qBAAc,EAAd,IAAc;YAAd,6BAAc;;QACnE,IAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,OAAb,IAAI,iBAAU,SAAS,EAAE,KAAK,UAAK,IAAI,UAAC,CAAC;QAC1D,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC3B,OAAO,QAAQ,CAAC;IACpB,CAAC;IAGL,eAAC;AAAD,CAAC,AApBD,IAoBC;AApBqB,4BAAQ"}
|
|
@@ -1,20 +1,18 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { IContainer, InjectionToken } from './IContainer';
|
|
2
2
|
import { IInjector } from '../IInjector';
|
|
3
3
|
import { IProvider, ScopeOptions, Tag } from '../provider/IProvider';
|
|
4
|
-
import { IContainerHook } from './IContainerHook';
|
|
5
4
|
export declare class Container implements IContainer, ScopeOptions {
|
|
6
5
|
private readonly injector;
|
|
7
6
|
private readonly providers;
|
|
8
7
|
private parent;
|
|
9
8
|
level: number;
|
|
10
9
|
tags: Tag[];
|
|
11
|
-
private hook;
|
|
12
10
|
private isDisposed;
|
|
13
11
|
constructor(injector: IInjector);
|
|
12
|
+
getInstances(): unknown[];
|
|
14
13
|
setParent(parent: IContainer): this;
|
|
15
14
|
setTags(tags: Tag[]): this;
|
|
16
15
|
setLevel(level?: number): this;
|
|
17
|
-
setHook(hook: IContainerHook): this;
|
|
18
16
|
register(provider: IProvider<unknown>): this;
|
|
19
17
|
resolve<T>(key: InjectionToken<T>, ...args: any[]): T;
|
|
20
18
|
createScope(tags?: Tag[], parent?: IContainer): Container;
|
|
@@ -39,7 +39,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
39
39
|
exports.Container = void 0;
|
|
40
40
|
var IProvider_1 = require("../provider/IProvider");
|
|
41
41
|
var EmptyContainer_1 = require("./EmptyContainer");
|
|
42
|
-
var IContainerHook_1 = require("./IContainerHook");
|
|
43
42
|
var ProviderRepo_1 = require("../provider/ProviderRepo");
|
|
44
43
|
var ContainerDisposedError_1 = require("./ContainerDisposedError");
|
|
45
44
|
var Container = /** @class */ (function () {
|
|
@@ -49,9 +48,11 @@ var Container = /** @class */ (function () {
|
|
|
49
48
|
this.parent = new EmptyContainer_1.EmptyContainer();
|
|
50
49
|
this.level = 0;
|
|
51
50
|
this.tags = [];
|
|
52
|
-
this.hook = IContainerHook_1.emptyHook;
|
|
53
51
|
this.isDisposed = false;
|
|
54
52
|
}
|
|
53
|
+
Container.prototype.getInstances = function () {
|
|
54
|
+
return this.injector.getInstances();
|
|
55
|
+
};
|
|
55
56
|
Container.prototype.setParent = function (parent) {
|
|
56
57
|
this.parent = parent;
|
|
57
58
|
return this;
|
|
@@ -65,10 +66,6 @@ var Container = /** @class */ (function () {
|
|
|
65
66
|
this.level = level;
|
|
66
67
|
return this;
|
|
67
68
|
};
|
|
68
|
-
Container.prototype.setHook = function (hook) {
|
|
69
|
-
this.hook = hook;
|
|
70
|
-
return this;
|
|
71
|
-
};
|
|
72
69
|
Container.prototype.register = function (provider) {
|
|
73
70
|
this.validateContainer();
|
|
74
71
|
this.providers.add(provider);
|
|
@@ -83,22 +80,19 @@ var Container = /** @class */ (function () {
|
|
|
83
80
|
this.validateContainer();
|
|
84
81
|
if ((0, IProvider_1.isProviderKey)(key)) {
|
|
85
82
|
var provider = this.providers.get(key);
|
|
86
|
-
return (provider === null || provider === void 0 ? void 0 : provider.isValid(this))
|
|
87
|
-
? this.hook.resolve(provider.resolve.apply(provider, __spreadArray([this], __read(args), false)))
|
|
88
|
-
: (_a = this.parent).resolve.apply(_a, __spreadArray([key], __read(args), false));
|
|
83
|
+
return (provider === null || provider === void 0 ? void 0 : provider.isValid(this)) ? provider.resolve.apply(provider, __spreadArray([this], __read(args), false)) : (_a = this.parent).resolve.apply(_a, __spreadArray([key], __read(args), false));
|
|
89
84
|
}
|
|
90
|
-
return
|
|
85
|
+
return (_b = this.injector).resolve.apply(_b, __spreadArray([this, key], __read(args), false));
|
|
91
86
|
};
|
|
92
87
|
Container.prototype.createScope = function (tags, parent) {
|
|
93
88
|
var e_1, _a;
|
|
94
89
|
if (tags === void 0) { tags = []; }
|
|
95
90
|
if (parent === void 0) { parent = this; }
|
|
96
91
|
this.validateContainer();
|
|
97
|
-
var scope = new Container(this.injector)
|
|
92
|
+
var scope = new Container(this.injector.clone())
|
|
98
93
|
.setParent(parent)
|
|
99
94
|
.setLevel(this.level + 1)
|
|
100
|
-
.setTags(tags)
|
|
101
|
-
.setHook(this.hook.clone());
|
|
95
|
+
.setTags(tags);
|
|
102
96
|
try {
|
|
103
97
|
for (var _b = __values(parent.getProviders().filter(function (p) { return p.isValid(scope); })), _c = _b.next(); !_c.done; _c = _b.next()) {
|
|
104
98
|
var provider = _c.value;
|
|
@@ -121,7 +115,7 @@ var Container = /** @class */ (function () {
|
|
|
121
115
|
this.isDisposed = true;
|
|
122
116
|
this.parent = new EmptyContainer_1.EmptyContainer();
|
|
123
117
|
this.providers.dispose();
|
|
124
|
-
this.
|
|
118
|
+
this.injector.dispose();
|
|
125
119
|
};
|
|
126
120
|
Container.prototype.map = function (transform) {
|
|
127
121
|
this.parent = transform(this.parent);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Container.js","sourceRoot":"","sources":["../../../lib/core/container/Container.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,mDAAoF;AACpF,mDAAkD;AAClD,
|
|
1
|
+
{"version":3,"file":"Container.js","sourceRoot":"","sources":["../../../lib/core/container/Container.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { IContainer, InjectionToken } from './IContainer';
|
|
2
2
|
import { IProvider } from '../provider/IProvider';
|
|
3
3
|
export declare class EmptyContainer implements IContainer {
|
|
4
4
|
createScope(): IContainer;
|
|
@@ -7,4 +7,5 @@ export declare class EmptyContainer implements IContainer {
|
|
|
7
7
|
resolve<T>(key: InjectionToken<T>): T;
|
|
8
8
|
getProviders(): IProvider<unknown>[];
|
|
9
9
|
setHook(): this;
|
|
10
|
+
getInstances(): unknown[];
|
|
10
11
|
}
|
|
@@ -24,6 +24,9 @@ var EmptyContainer = /** @class */ (function () {
|
|
|
24
24
|
EmptyContainer.prototype.setHook = function () {
|
|
25
25
|
throw new MethodNotImplementedError_1.MethodNotImplementedError();
|
|
26
26
|
};
|
|
27
|
+
EmptyContainer.prototype.getInstances = function () {
|
|
28
|
+
return [];
|
|
29
|
+
};
|
|
27
30
|
return EmptyContainer;
|
|
28
31
|
}());
|
|
29
32
|
exports.EmptyContainer = EmptyContainer;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EmptyContainer.js","sourceRoot":"","sources":["../../../lib/core/container/EmptyContainer.ts"],"names":[],"mappings":";;;AACA,gFAA+E;AAC/E,2EAA0E;AAG1E;IAAA;
|
|
1
|
+
{"version":3,"file":"EmptyContainer.js","sourceRoot":"","sources":["../../../lib/core/container/EmptyContainer.ts"],"names":[],"mappings":";;;AACA,gFAA+E;AAC/E,2EAA0E;AAG1E;IAAA;IA4BA,CAAC;IA3BG,oCAAW,GAAX;QACI,MAAM,IAAI,qDAAyB,EAAE,CAAC;IAC1C,CAAC;IAED,gCAAO,GAAP;QACI,MAAM,IAAI,qDAAyB,EAAE,CAAC;IAC1C,CAAC;IAED,iCAAQ,GAAR;QACI,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,gCAAO,GAAP,UAAW,GAAsB;QAC7B,MAAM,IAAI,6CAAqB,CAAC,iBAAe,GAAG,CAAC,QAAQ,EAAI,CAAC,CAAC;IACrE,CAAC;IAED,qCAAY,GAAZ;QACI,OAAO,EAAE,CAAC;IACd,CAAC;IAED,gCAAO,GAAP;QACI,MAAM,IAAI,qDAAyB,EAAE,CAAC;IAC1C,CAAC;IAED,qCAAY,GAAZ;QACI,OAAO,EAAE,CAAC;IACd,CAAC;IACL,qBAAC;AAAD,CAAC,AA5BD,IA4BC;AA5BY,wCAAc"}
|
|
@@ -1,13 +1,12 @@
|
|
|
1
1
|
import { IProvider, ProviderKey, Tag } from '../provider/IProvider';
|
|
2
|
-
import { constructor,
|
|
3
|
-
import {
|
|
2
|
+
import { constructor, Disposable } from '../utils/types';
|
|
3
|
+
import { Traversable } from '../IInjector';
|
|
4
4
|
export declare type InjectionToken<T = any> = constructor<T> | ProviderKey;
|
|
5
5
|
export interface Resolveable {
|
|
6
6
|
resolve<T>(key: InjectionToken<T>, ...args: any[]): T;
|
|
7
7
|
}
|
|
8
|
-
export interface IContainer extends
|
|
8
|
+
export interface IContainer extends Disposable, Resolveable, Traversable {
|
|
9
9
|
createScope(tags?: Tag[], parent?: IContainer): IContainer;
|
|
10
10
|
register(provider: IProvider<unknown>): this;
|
|
11
11
|
getProviders(): IProvider<unknown>[];
|
|
12
|
-
setHook(hook: IContainerHook): this;
|
|
13
12
|
}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { InjectionToken, Resolveable } from '../container/IContainer';
|
|
2
|
-
import {
|
|
2
|
+
import { Disposable } from '../utils/types';
|
|
3
3
|
export declare type ResolveDependency<T> = (container: Resolveable, ...args: any[]) => T;
|
|
4
4
|
export declare type Tag = string;
|
|
5
5
|
export interface ScopeOptions {
|
|
6
6
|
level: number;
|
|
7
7
|
tags: Tag[];
|
|
8
8
|
}
|
|
9
|
-
export interface IProvider<T> extends
|
|
9
|
+
export interface IProvider<T> extends Disposable {
|
|
10
10
|
setKey(key: ProviderKey): this;
|
|
11
11
|
getKeyOrFail(): ProviderKey;
|
|
12
12
|
clone(): IProvider<T>;
|
package/cjm/index.d.ts
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { IContainer, InjectionToken } from './core/container/IContainer';
|
|
2
|
-
export { ContainerHook } from './hooks/ContainerHook';
|
|
3
2
|
export { ProviderReducer } from './core/provider/IProviderReflector';
|
|
4
3
|
export { IContainer, Resolveable } from './core/container/IContainer';
|
|
5
4
|
export { constructor } from './core/utils/types';
|
|
@@ -15,7 +14,6 @@ export { MethodNotImplementedError } from './core/utils/MethodNotImplementedErro
|
|
|
15
14
|
export { ContainerDisposedError } from './core/container/ContainerDisposedError';
|
|
16
15
|
export { Provider } from './core/provider/Provider';
|
|
17
16
|
export { ArgsProvider, ArgsFn, createArgsFnDecorator } from './providers/ArgsProvider';
|
|
18
|
-
export { IContainerHook } from './core/container/IContainerHook';
|
|
19
17
|
export { TaggedProvider } from './providers/TaggedProvider';
|
|
20
18
|
export { ProxyInjector } from './injectors/ProxyInjector';
|
|
21
19
|
export { LevelProvider, perLevel } from './providers/LevelProvider';
|
|
@@ -25,10 +23,11 @@ export { SingletonProvider } from './providers/SingletonProvider';
|
|
|
25
23
|
export { ProviderBuilder } from './providers/ProviderBuilder';
|
|
26
24
|
export { IProviderReflector } from './core/provider/IProviderReflector';
|
|
27
25
|
export { ProviderReflector } from './core/provider/ProviderReflector';
|
|
28
|
-
export {
|
|
26
|
+
export { Disposable } from './core/utils/types';
|
|
29
27
|
export { ProviderKey } from './core/provider/IProvider';
|
|
30
28
|
export { isProviderKey } from './core/provider/IProvider';
|
|
31
29
|
export { perTags } from './providers/TaggedProvider';
|
|
32
30
|
export { asSingleton } from './providers/SingletonProvider';
|
|
33
31
|
export { forKey } from './core/provider/Provider';
|
|
32
|
+
export { VisitInstance, Injector } from './core/IInjector';
|
|
34
33
|
export declare const by: <T>(key: InjectionToken<T>, ...args: unknown[]) => (l: IContainer) => T;
|
package/cjm/index.js
CHANGED
|
@@ -25,9 +25,7 @@ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
|
25
25
|
return to.concat(ar || Array.prototype.slice.call(from));
|
|
26
26
|
};
|
|
27
27
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
28
|
-
exports.by = exports.forKey = exports.asSingleton = exports.perTags = exports.isProviderKey = exports.ProviderReflector = exports.ProviderBuilder = exports.SingletonProvider = exports.AutoMockedContainer = exports.perLevel = exports.LevelProvider = exports.ProxyInjector = exports.TaggedProvider = exports.createArgsFnDecorator = exports.ArgsProvider = exports.Provider = exports.ContainerDisposedError = exports.MethodNotImplementedError = exports.ProviderNotFoundError = exports.MethodReflector = exports.SimpleInjector = exports.Container =
|
|
29
|
-
var ContainerHook_1 = require("./hooks/ContainerHook");
|
|
30
|
-
Object.defineProperty(exports, "ContainerHook", { enumerable: true, get: function () { return ContainerHook_1.ContainerHook; } });
|
|
28
|
+
exports.by = exports.Injector = exports.forKey = exports.asSingleton = exports.perTags = exports.isProviderKey = exports.ProviderReflector = exports.ProviderBuilder = exports.SingletonProvider = exports.AutoMockedContainer = exports.perLevel = exports.LevelProvider = exports.ProxyInjector = exports.TaggedProvider = exports.createArgsFnDecorator = exports.ArgsProvider = exports.Provider = exports.ContainerDisposedError = exports.MethodNotImplementedError = exports.ProviderNotFoundError = exports.MethodReflector = exports.SimpleInjector = exports.Container = void 0;
|
|
31
29
|
var Container_1 = require("./core/container/Container");
|
|
32
30
|
Object.defineProperty(exports, "Container", { enumerable: true, get: function () { return Container_1.Container; } });
|
|
33
31
|
var SimpleInjector_1 = require("./injectors/SimpleInjector");
|
|
@@ -68,6 +66,8 @@ var SingletonProvider_2 = require("./providers/SingletonProvider");
|
|
|
68
66
|
Object.defineProperty(exports, "asSingleton", { enumerable: true, get: function () { return SingletonProvider_2.asSingleton; } });
|
|
69
67
|
var Provider_2 = require("./core/provider/Provider");
|
|
70
68
|
Object.defineProperty(exports, "forKey", { enumerable: true, get: function () { return Provider_2.forKey; } });
|
|
69
|
+
var IInjector_1 = require("./core/IInjector");
|
|
70
|
+
Object.defineProperty(exports, "Injector", { enumerable: true, get: function () { return IInjector_1.Injector; } });
|
|
71
71
|
var by = function (key) {
|
|
72
72
|
var args = [];
|
|
73
73
|
for (var _i = 1; _i < arguments.length; _i++) {
|
package/cjm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../lib/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../lib/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAKA,wDAAuD;AAA9C,sGAAA,SAAS,OAAA;AAGlB,6DAA4D;AAAnD,gHAAA,cAAc,OAAA;AAEvB,2DAA0D;AAAjD,kHAAA,eAAe,OAAA;AAExB,+EAA8E;AAArE,8HAAA,qBAAqB,OAAA;AAC9B,oFAAmF;AAA1E,sIAAA,yBAAyB,OAAA;AAClC,kFAAiF;AAAxE,gIAAA,sBAAsB,OAAA;AAC/B,qDAAoD;AAA3C,oGAAA,QAAQ,OAAA;AACjB,yDAAuF;AAA9E,4GAAA,YAAY,OAAA;AAAU,qHAAA,qBAAqB,OAAA;AACpD,6DAA4D;AAAnD,gHAAA,cAAc,OAAA;AACvB,2DAA0D;AAAjD,8GAAA,aAAa,OAAA;AACtB,2DAAoE;AAA3D,8GAAA,aAAa,OAAA;AAAE,yGAAA,QAAQ,OAAA;AAEhC,sEAAqE;AAA5D,0HAAA,mBAAmB,OAAA;AAC5B,mEAAkE;AAAzD,sHAAA,iBAAiB,OAAA;AAC1B,+DAA8D;AAArD,kHAAA,eAAe,OAAA;AAExB,uEAAsE;AAA7D,sHAAA,iBAAiB,OAAA;AAG1B,uDAA0D;AAAjD,0GAAA,aAAa,OAAA;AACtB,6DAAqD;AAA5C,yGAAA,OAAO,OAAA;AAChB,mEAA4D;AAAnD,gHAAA,WAAW,OAAA;AACpB,qDAAkD;AAAzC,kGAAA,MAAM,OAAA;AACf,8CAA2D;AAAnC,qGAAA,QAAQ,OAAA;AAEzB,IAAM,EAAE,GACX,UAAI,GAAsB;IAAE,cAAkB;SAAlB,UAAkB,EAAlB,qBAAkB,EAAlB,IAAkB;QAAlB,6BAAkB;;IAC9C,OAAA,UAAC,CAAa;QACV,OAAA,CAAC,CAAC,OAAO,OAAT,CAAC,iBAAY,GAAG,UAAK,IAAI;IAAzB,CAA0B;AAD9B,CAC8B,CAAC;AAHtB,QAAA,EAAE,MAGoB"}
|
|
@@ -4,4 +4,7 @@ import { constructor } from '../core/utils/types';
|
|
|
4
4
|
import { ProviderKey } from '../core/provider/IProvider';
|
|
5
5
|
export declare class ProxyInjector implements IInjector {
|
|
6
6
|
resolve<T>(container: IContainer, value: constructor<T>, ...deps: Record<ProviderKey, unknown>[]): T;
|
|
7
|
+
clone(): IInjector;
|
|
8
|
+
dispose(): void;
|
|
9
|
+
getInstances(): unknown[];
|
|
7
10
|
}
|
|
@@ -30,6 +30,13 @@ var ProxyInjector = /** @class */ (function () {
|
|
|
30
30
|
},
|
|
31
31
|
}));
|
|
32
32
|
};
|
|
33
|
+
ProxyInjector.prototype.clone = function () {
|
|
34
|
+
return new ProxyInjector();
|
|
35
|
+
};
|
|
36
|
+
ProxyInjector.prototype.dispose = function () { };
|
|
37
|
+
ProxyInjector.prototype.getInstances = function () {
|
|
38
|
+
return [];
|
|
39
|
+
};
|
|
33
40
|
return ProxyInjector;
|
|
34
41
|
}());
|
|
35
42
|
exports.ProxyInjector = ProxyInjector;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProxyInjector.js","sourceRoot":"","sources":["../../lib/injectors/ProxyInjector.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAKA;IAAA;
|
|
1
|
+
{"version":3,"file":"ProxyInjector.js","sourceRoot":"","sources":["../../lib/injectors/ProxyInjector.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAKA;IAAA;IAwBA,CAAC;IAvBG,wDAAwD;IACxD,+BAAO,GAAP,UAAW,SAAqB,EAAE,KAAqB;QAAE,cAAuC;aAAvC,UAAuC,EAAvC,qBAAuC,EAAvC,IAAuC;YAAvC,6BAAuC;;QAC5F,IAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,UAAC,GAAG,EAAE,EAAE,IAAK,OAAA,uBAAM,GAAG,GAAK,EAAE,EAAG,EAAnB,CAAmB,EAAE,EAAE,CAAC,CAAC;QAC/D,OAAO,IAAI,KAAK,CACZ,IAAI,KAAK,CAAC,SAAS,EAAE;YACjB,wDAAwD;YACxD,GAAG,EAAH,UAAI,MAAkB,EAAE,IAAiB;gBACrC,iDAAiD;gBACjD,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACzE,CAAC;SACJ,CAAC,CACL,CAAC;IACN,CAAC;IAED,6BAAK,GAAL;QACI,OAAO,IAAI,aAAa,EAAE,CAAC;IAC/B,CAAC;IAED,+BAAO,GAAP,cAAiB,CAAC;IAElB,oCAAY,GAAZ;QACI,OAAO,EAAE,CAAC;IACd,CAAC;IACL,oBAAC;AAAD,CAAC,AAxBD,IAwBC;AAxBY,sCAAa"}
|
|
@@ -3,4 +3,7 @@ import { IContainer } from '../core/container/IContainer';
|
|
|
3
3
|
import { IInjector } from '../core/IInjector';
|
|
4
4
|
export declare class SimpleInjector implements IInjector {
|
|
5
5
|
resolve<T>(container: IContainer, value: constructor<T>, ...deps: any[]): T;
|
|
6
|
+
clone(): IInjector;
|
|
7
|
+
dispose(): void;
|
|
8
|
+
getInstances(): unknown[];
|
|
6
9
|
}
|
|
@@ -36,6 +36,13 @@ var SimpleInjector = /** @class */ (function () {
|
|
|
36
36
|
}
|
|
37
37
|
return new (value.bind.apply(value, __spreadArray([void 0, container], __read(deps), false)))();
|
|
38
38
|
};
|
|
39
|
+
SimpleInjector.prototype.clone = function () {
|
|
40
|
+
return new SimpleInjector();
|
|
41
|
+
};
|
|
42
|
+
SimpleInjector.prototype.dispose = function () { };
|
|
43
|
+
SimpleInjector.prototype.getInstances = function () {
|
|
44
|
+
return [];
|
|
45
|
+
};
|
|
39
46
|
return SimpleInjector;
|
|
40
47
|
}());
|
|
41
48
|
exports.SimpleInjector = SimpleInjector;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SimpleInjector.js","sourceRoot":"","sources":["../../lib/injectors/SimpleInjector.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA;IAAA;
|
|
1
|
+
{"version":3,"file":"SimpleInjector.js","sourceRoot":"","sources":["../../lib/injectors/SimpleInjector.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA;IAAA;IAcA,CAAC;IAbG,gCAAO,GAAP,UAAW,SAAqB,EAAE,KAAqB;QAAE,cAAc;aAAd,UAAc,EAAd,qBAAc,EAAd,IAAc;YAAd,6BAAc;;QACnE,YAAW,KAAK,YAAL,KAAK,yBAAC,SAAS,UAAK,IAAI,cAAE;IACzC,CAAC;IAED,8BAAK,GAAL;QACI,OAAO,IAAI,cAAc,EAAE,CAAC;IAChC,CAAC;IAED,gCAAO,GAAP,cAAiB,CAAC;IAElB,qCAAY,GAAZ;QACI,OAAO,EAAE,CAAC;IACd,CAAC;IACL,qBAAC;AAAD,CAAC,AAdD,IAcC;AAdY,wCAAc"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IContainer,
|
|
1
|
+
import { IContainer, InjectionToken, IProvider, Tag } from '../index';
|
|
2
2
|
import { IMockRepository } from './IMockRepository';
|
|
3
3
|
export declare class AutoMockedContainer implements IContainer {
|
|
4
4
|
private decorated;
|
|
@@ -9,5 +9,5 @@ export declare class AutoMockedContainer implements IContainer {
|
|
|
9
9
|
dispose(): void;
|
|
10
10
|
getProviders(): IProvider<unknown>[];
|
|
11
11
|
register(provider: IProvider<unknown>): this;
|
|
12
|
-
|
|
12
|
+
getInstances(): unknown[];
|
|
13
13
|
}
|
|
@@ -28,9 +28,8 @@ export class AutoMockedContainer {
|
|
|
28
28
|
this.decorated.register(provider);
|
|
29
29
|
return this;
|
|
30
30
|
}
|
|
31
|
-
|
|
32
|
-
this.decorated.
|
|
33
|
-
return this;
|
|
31
|
+
getInstances() {
|
|
32
|
+
return this.decorated.getInstances();
|
|
34
33
|
}
|
|
35
34
|
}
|
|
36
35
|
//# sourceMappingURL=AutoMockedContainer.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AutoMockedContainer.js","sourceRoot":"","sources":["../../lib/automock/AutoMockedContainer.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"AutoMockedContainer.js","sourceRoot":"","sources":["../../lib/automock/AutoMockedContainer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyC,qBAAqB,EAAO,MAAM,UAAU,CAAC;AAG7F,MAAM,OAAO,mBAAmB;IAC5B,YAAoB,SAAqB,EAAU,cAA+B;QAA9D,cAAS,GAAT,SAAS,CAAY;QAAU,mBAAc,GAAd,cAAc,CAAiB;IAAG,CAAC;IAEtF,WAAW,CAAC,IAAY,EAAE,SAAqB,IAAI;QAC/C,OAAO,IAAI,mBAAmB,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,EAAE,MAAM,CAAC,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;IAClG,CAAC;IAED,OAAO,CAAI,GAAsB,EAAE,GAAG,IAAW;QAC7C,IAAI;YACA,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;SAC/C;QAAC,OAAO,CAAC,EAAE;YACR,IAAI,CAAC,YAAY,qBAAqB,EAAE;gBACpC,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,CAAI,GAAG,CAAC,CAAC;aAC9C;YAED,MAAM,CAAC,CAAC;SACX;IACL,CAAC;IAED,OAAO;QACH,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;IAED,YAAY;QACR,OAAO,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,CAAC;IACzC,CAAC;IAED,QAAQ,CAAC,QAA4B;QACjC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QAClC,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,YAAY;QACR,OAAO,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,CAAC;IACzC,CAAC;CACJ"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import {
|
|
2
|
-
export interface IMockRepository extends
|
|
1
|
+
import { Disposable, Resolveable } from '../index';
|
|
2
|
+
export interface IMockRepository extends Disposable, Resolveable {
|
|
3
3
|
}
|
package/esm/core/IInjector.d.ts
CHANGED
|
@@ -1,5 +1,18 @@
|
|
|
1
|
-
import { constructor } from './utils/types';
|
|
1
|
+
import { constructor, Disposable } from './utils/types';
|
|
2
2
|
import { IContainer } from './container/IContainer';
|
|
3
|
-
export
|
|
3
|
+
export declare type VisitInstance = (instance: unknown) => Promise<void>;
|
|
4
|
+
export interface Traversable {
|
|
5
|
+
getInstances(): unknown[];
|
|
6
|
+
}
|
|
7
|
+
export interface IInjector extends Disposable, Traversable {
|
|
8
|
+
resolve<T>(container: IContainer, value: constructor<T>, ...deps: any[]): T;
|
|
9
|
+
clone(): IInjector;
|
|
10
|
+
}
|
|
11
|
+
export declare abstract class Injector implements IInjector {
|
|
12
|
+
private values;
|
|
13
|
+
abstract clone(): IInjector;
|
|
14
|
+
getInstances(): unknown[];
|
|
15
|
+
dispose(): void;
|
|
4
16
|
resolve<T>(container: IContainer, value: constructor<T>, ...deps: any[]): T;
|
|
17
|
+
protected abstract resolver<T>(container: IContainer, value: constructor<T>, ...args: any[]): T;
|
|
5
18
|
}
|
package/esm/core/IInjector.js
CHANGED
|
@@ -1,2 +1,17 @@
|
|
|
1
|
-
export {
|
|
1
|
+
export class Injector {
|
|
2
|
+
constructor() {
|
|
3
|
+
this.values = [];
|
|
4
|
+
}
|
|
5
|
+
getInstances() {
|
|
6
|
+
return this.values;
|
|
7
|
+
}
|
|
8
|
+
dispose() {
|
|
9
|
+
this.values = [];
|
|
10
|
+
}
|
|
11
|
+
resolve(container, value, ...deps) {
|
|
12
|
+
const instance = this.resolver(container, value, ...deps);
|
|
13
|
+
this.values.push(instance);
|
|
14
|
+
return instance;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
2
17
|
//# sourceMappingURL=IInjector.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"IInjector.js","sourceRoot":"","sources":["../../lib/core/IInjector.ts"],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"IInjector.js","sourceRoot":"","sources":["../../lib/core/IInjector.ts"],"names":[],"mappings":"AAeA,MAAM,OAAgB,QAAQ;IAA9B;QACY,WAAM,GAAc,EAAE,CAAC;IAmBnC,CAAC;IAfG,YAAY;QACR,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,OAAO;QACH,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,OAAO,CAAI,SAAqB,EAAE,KAAqB,EAAE,GAAG,IAAW;QACnE,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,CAAC;QAC1D,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC3B,OAAO,QAAQ,CAAC;IACpB,CAAC;CAGJ"}
|
|
@@ -1,20 +1,18 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { IContainer, InjectionToken } from './IContainer';
|
|
2
2
|
import { IInjector } from '../IInjector';
|
|
3
3
|
import { IProvider, ScopeOptions, Tag } from '../provider/IProvider';
|
|
4
|
-
import { IContainerHook } from './IContainerHook';
|
|
5
4
|
export declare class Container implements IContainer, ScopeOptions {
|
|
6
5
|
private readonly injector;
|
|
7
6
|
private readonly providers;
|
|
8
7
|
private parent;
|
|
9
8
|
level: number;
|
|
10
9
|
tags: Tag[];
|
|
11
|
-
private hook;
|
|
12
10
|
private isDisposed;
|
|
13
11
|
constructor(injector: IInjector);
|
|
12
|
+
getInstances(): unknown[];
|
|
14
13
|
setParent(parent: IContainer): this;
|
|
15
14
|
setTags(tags: Tag[]): this;
|
|
16
15
|
setLevel(level?: number): this;
|
|
17
|
-
setHook(hook: IContainerHook): this;
|
|
18
16
|
register(provider: IProvider<unknown>): this;
|
|
19
17
|
resolve<T>(key: InjectionToken<T>, ...args: any[]): T;
|
|
20
18
|
createScope(tags?: Tag[], parent?: IContainer): Container;
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { isProviderKey } from '../provider/IProvider';
|
|
2
2
|
import { EmptyContainer } from './EmptyContainer';
|
|
3
|
-
import { emptyHook } from './IContainerHook';
|
|
4
3
|
import { ProviderRepo } from '../provider/ProviderRepo';
|
|
5
4
|
import { ContainerDisposedError } from './ContainerDisposedError';
|
|
6
5
|
export class Container {
|
|
@@ -10,9 +9,11 @@ export class Container {
|
|
|
10
9
|
this.parent = new EmptyContainer();
|
|
11
10
|
this.level = 0;
|
|
12
11
|
this.tags = [];
|
|
13
|
-
this.hook = emptyHook;
|
|
14
12
|
this.isDisposed = false;
|
|
15
13
|
}
|
|
14
|
+
getInstances() {
|
|
15
|
+
return this.injector.getInstances();
|
|
16
|
+
}
|
|
16
17
|
setParent(parent) {
|
|
17
18
|
this.parent = parent;
|
|
18
19
|
return this;
|
|
@@ -25,10 +26,6 @@ export class Container {
|
|
|
25
26
|
this.level = level;
|
|
26
27
|
return this;
|
|
27
28
|
}
|
|
28
|
-
setHook(hook) {
|
|
29
|
-
this.hook = hook;
|
|
30
|
-
return this;
|
|
31
|
-
}
|
|
32
29
|
register(provider) {
|
|
33
30
|
this.validateContainer();
|
|
34
31
|
this.providers.add(provider);
|
|
@@ -38,19 +35,16 @@ export class Container {
|
|
|
38
35
|
this.validateContainer();
|
|
39
36
|
if (isProviderKey(key)) {
|
|
40
37
|
const provider = this.providers.get(key);
|
|
41
|
-
return (provider === null || provider === void 0 ? void 0 : provider.isValid(this))
|
|
42
|
-
? this.hook.resolve(provider.resolve(this, ...args))
|
|
43
|
-
: this.parent.resolve(key, ...args);
|
|
38
|
+
return (provider === null || provider === void 0 ? void 0 : provider.isValid(this)) ? provider.resolve(this, ...args) : this.parent.resolve(key, ...args);
|
|
44
39
|
}
|
|
45
|
-
return this.
|
|
40
|
+
return this.injector.resolve(this, key, ...args);
|
|
46
41
|
}
|
|
47
42
|
createScope(tags = [], parent = this) {
|
|
48
43
|
this.validateContainer();
|
|
49
|
-
const scope = new Container(this.injector)
|
|
44
|
+
const scope = new Container(this.injector.clone())
|
|
50
45
|
.setParent(parent)
|
|
51
46
|
.setLevel(this.level + 1)
|
|
52
|
-
.setTags(tags)
|
|
53
|
-
.setHook(this.hook.clone());
|
|
47
|
+
.setTags(tags);
|
|
54
48
|
for (const provider of parent.getProviders().filter((p) => p.isValid(scope))) {
|
|
55
49
|
scope.register(provider.clone());
|
|
56
50
|
}
|
|
@@ -63,7 +57,7 @@ export class Container {
|
|
|
63
57
|
this.isDisposed = true;
|
|
64
58
|
this.parent = new EmptyContainer();
|
|
65
59
|
this.providers.dispose();
|
|
66
|
-
this.
|
|
60
|
+
this.injector.dispose();
|
|
67
61
|
}
|
|
68
62
|
map(transform) {
|
|
69
63
|
this.parent = transform(this.parent);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Container.js","sourceRoot":"","sources":["../../../lib/core/container/Container.ts"],"names":[],"mappings":"AAEA,OAAO,EAAa,aAAa,EAAqB,MAAM,uBAAuB,CAAC;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"Container.js","sourceRoot":"","sources":["../../../lib/core/container/Container.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { IContainer, InjectionToken } from './IContainer';
|
|
2
2
|
import { IProvider } from '../provider/IProvider';
|
|
3
3
|
export declare class EmptyContainer implements IContainer {
|
|
4
4
|
createScope(): IContainer;
|
|
@@ -7,4 +7,5 @@ export declare class EmptyContainer implements IContainer {
|
|
|
7
7
|
resolve<T>(key: InjectionToken<T>): T;
|
|
8
8
|
getProviders(): IProvider<unknown>[];
|
|
9
9
|
setHook(): this;
|
|
10
|
+
getInstances(): unknown[];
|
|
10
11
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EmptyContainer.js","sourceRoot":"","sources":["../../../lib/core/container/EmptyContainer.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,yBAAyB,EAAE,MAAM,oCAAoC,CAAC;AAC/E,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAG1E,MAAM,OAAO,cAAc;IACvB,WAAW;QACP,MAAM,IAAI,yBAAyB,EAAE,CAAC;IAC1C,CAAC;IAED,OAAO;QACH,MAAM,IAAI,yBAAyB,EAAE,CAAC;IAC1C,CAAC;IAED,QAAQ;QACJ,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,OAAO,CAAI,GAAsB;QAC7B,MAAM,IAAI,qBAAqB,CAAC,eAAe,GAAG,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IACrE,CAAC;IAED,YAAY;QACR,OAAO,EAAE,CAAC;IACd,CAAC;IAED,OAAO;QACH,MAAM,IAAI,yBAAyB,EAAE,CAAC;IAC1C,CAAC;CACJ"}
|
|
1
|
+
{"version":3,"file":"EmptyContainer.js","sourceRoot":"","sources":["../../../lib/core/container/EmptyContainer.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,yBAAyB,EAAE,MAAM,oCAAoC,CAAC;AAC/E,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAG1E,MAAM,OAAO,cAAc;IACvB,WAAW;QACP,MAAM,IAAI,yBAAyB,EAAE,CAAC;IAC1C,CAAC;IAED,OAAO;QACH,MAAM,IAAI,yBAAyB,EAAE,CAAC;IAC1C,CAAC;IAED,QAAQ;QACJ,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,OAAO,CAAI,GAAsB;QAC7B,MAAM,IAAI,qBAAqB,CAAC,eAAe,GAAG,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IACrE,CAAC;IAED,YAAY;QACR,OAAO,EAAE,CAAC;IACd,CAAC;IAED,OAAO;QACH,MAAM,IAAI,yBAAyB,EAAE,CAAC;IAC1C,CAAC;IAED,YAAY;QACR,OAAO,EAAE,CAAC;IACd,CAAC;CACJ"}
|
|
@@ -1,13 +1,12 @@
|
|
|
1
1
|
import { IProvider, ProviderKey, Tag } from '../provider/IProvider';
|
|
2
|
-
import { constructor,
|
|
3
|
-
import {
|
|
2
|
+
import { constructor, Disposable } from '../utils/types';
|
|
3
|
+
import { Traversable } from '../IInjector';
|
|
4
4
|
export declare type InjectionToken<T = any> = constructor<T> | ProviderKey;
|
|
5
5
|
export interface Resolveable {
|
|
6
6
|
resolve<T>(key: InjectionToken<T>, ...args: any[]): T;
|
|
7
7
|
}
|
|
8
|
-
export interface IContainer extends
|
|
8
|
+
export interface IContainer extends Disposable, Resolveable, Traversable {
|
|
9
9
|
createScope(tags?: Tag[], parent?: IContainer): IContainer;
|
|
10
10
|
register(provider: IProvider<unknown>): this;
|
|
11
11
|
getProviders(): IProvider<unknown>[];
|
|
12
|
-
setHook(hook: IContainerHook): this;
|
|
13
12
|
}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { InjectionToken, Resolveable } from '../container/IContainer';
|
|
2
|
-
import {
|
|
2
|
+
import { Disposable } from '../utils/types';
|
|
3
3
|
export declare type ResolveDependency<T> = (container: Resolveable, ...args: any[]) => T;
|
|
4
4
|
export declare type Tag = string;
|
|
5
5
|
export interface ScopeOptions {
|
|
6
6
|
level: number;
|
|
7
7
|
tags: Tag[];
|
|
8
8
|
}
|
|
9
|
-
export interface IProvider<T> extends
|
|
9
|
+
export interface IProvider<T> extends Disposable {
|
|
10
10
|
setKey(key: ProviderKey): this;
|
|
11
11
|
getKeyOrFail(): ProviderKey;
|
|
12
12
|
clone(): IProvider<T>;
|
package/esm/index.d.ts
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { IContainer, InjectionToken } from './core/container/IContainer';
|
|
2
|
-
export { ContainerHook } from './hooks/ContainerHook';
|
|
3
2
|
export { ProviderReducer } from './core/provider/IProviderReflector';
|
|
4
3
|
export { IContainer, Resolveable } from './core/container/IContainer';
|
|
5
4
|
export { constructor } from './core/utils/types';
|
|
@@ -15,7 +14,6 @@ export { MethodNotImplementedError } from './core/utils/MethodNotImplementedErro
|
|
|
15
14
|
export { ContainerDisposedError } from './core/container/ContainerDisposedError';
|
|
16
15
|
export { Provider } from './core/provider/Provider';
|
|
17
16
|
export { ArgsProvider, ArgsFn, createArgsFnDecorator } from './providers/ArgsProvider';
|
|
18
|
-
export { IContainerHook } from './core/container/IContainerHook';
|
|
19
17
|
export { TaggedProvider } from './providers/TaggedProvider';
|
|
20
18
|
export { ProxyInjector } from './injectors/ProxyInjector';
|
|
21
19
|
export { LevelProvider, perLevel } from './providers/LevelProvider';
|
|
@@ -25,10 +23,11 @@ export { SingletonProvider } from './providers/SingletonProvider';
|
|
|
25
23
|
export { ProviderBuilder } from './providers/ProviderBuilder';
|
|
26
24
|
export { IProviderReflector } from './core/provider/IProviderReflector';
|
|
27
25
|
export { ProviderReflector } from './core/provider/ProviderReflector';
|
|
28
|
-
export {
|
|
26
|
+
export { Disposable } from './core/utils/types';
|
|
29
27
|
export { ProviderKey } from './core/provider/IProvider';
|
|
30
28
|
export { isProviderKey } from './core/provider/IProvider';
|
|
31
29
|
export { perTags } from './providers/TaggedProvider';
|
|
32
30
|
export { asSingleton } from './providers/SingletonProvider';
|
|
33
31
|
export { forKey } from './core/provider/Provider';
|
|
32
|
+
export { VisitInstance, Injector } from './core/IInjector';
|
|
34
33
|
export declare const by: <T>(key: InjectionToken<T>, ...args: unknown[]) => (l: IContainer) => T;
|
package/esm/index.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
export { ContainerHook } from './hooks/ContainerHook';
|
|
2
1
|
export { Container } from './core/container/Container';
|
|
3
2
|
export { SimpleInjector } from './injectors/SimpleInjector';
|
|
4
3
|
export { MethodReflector } from './hooks/MethodReflector';
|
|
@@ -18,5 +17,6 @@ export { isProviderKey } from './core/provider/IProvider';
|
|
|
18
17
|
export { perTags } from './providers/TaggedProvider';
|
|
19
18
|
export { asSingleton } from './providers/SingletonProvider';
|
|
20
19
|
export { forKey } from './core/provider/Provider';
|
|
20
|
+
export { Injector } from './core/IInjector';
|
|
21
21
|
export const by = (key, ...args) => (l) => l.resolve(key, ...args);
|
|
22
22
|
//# sourceMappingURL=index.js.map
|
package/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../lib/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../lib/index.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AAGvD,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAE5D,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAE1D,OAAO,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAC;AAC9E,OAAO,EAAE,yBAAyB,EAAE,MAAM,wCAAwC,CAAC;AACnF,OAAO,EAAE,sBAAsB,EAAE,MAAM,yCAAyC,CAAC;AACjF,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AACpD,OAAO,EAAE,YAAY,EAAU,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACvF,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AAEpE,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AACrE,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAE9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAC;AAGtE,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,MAAM,EAAE,MAAM,0BAA0B,CAAC;AAClD,OAAO,EAAiB,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAE3D,MAAM,CAAC,MAAM,EAAE,GACX,CAAI,GAAsB,EAAE,GAAG,IAAe,EAAE,EAAE,CAClD,CAAC,CAAa,EAAE,EAAE,CACd,CAAC,CAAC,OAAO,CAAI,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC"}
|
|
@@ -4,4 +4,7 @@ import { constructor } from '../core/utils/types';
|
|
|
4
4
|
import { ProviderKey } from '../core/provider/IProvider';
|
|
5
5
|
export declare class ProxyInjector implements IInjector {
|
|
6
6
|
resolve<T>(container: IContainer, value: constructor<T>, ...deps: Record<ProviderKey, unknown>[]): T;
|
|
7
|
+
clone(): IInjector;
|
|
8
|
+
dispose(): void;
|
|
9
|
+
getInstances(): unknown[];
|
|
7
10
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProxyInjector.js","sourceRoot":"","sources":["../../lib/injectors/ProxyInjector.ts"],"names":[],"mappings":"AAKA,MAAM,OAAO,aAAa;IACtB,wDAAwD;IACxD,OAAO,CAAI,SAAqB,EAAE,KAAqB,EAAE,GAAG,IAAoC;QAC5F,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,CAAC,iCAAM,GAAG,GAAK,EAAE,EAAG,EAAE,EAAE,CAAC,CAAC;QAC/D,OAAO,IAAI,KAAK,CACZ,IAAI,KAAK,CAAC,SAAS,EAAE;YACjB,wDAAwD;YACxD,GAAG,CAAC,MAAkB,EAAE,IAAiB;gBACrC,iDAAiD;gBACjD,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACzE,CAAC;SACJ,CAAC,CACL,CAAC;IACN,CAAC;CACJ"}
|
|
1
|
+
{"version":3,"file":"ProxyInjector.js","sourceRoot":"","sources":["../../lib/injectors/ProxyInjector.ts"],"names":[],"mappings":"AAKA,MAAM,OAAO,aAAa;IACtB,wDAAwD;IACxD,OAAO,CAAI,SAAqB,EAAE,KAAqB,EAAE,GAAG,IAAoC;QAC5F,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,CAAC,iCAAM,GAAG,GAAK,EAAE,EAAG,EAAE,EAAE,CAAC,CAAC;QAC/D,OAAO,IAAI,KAAK,CACZ,IAAI,KAAK,CAAC,SAAS,EAAE;YACjB,wDAAwD;YACxD,GAAG,CAAC,MAAkB,EAAE,IAAiB;gBACrC,iDAAiD;gBACjD,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACzE,CAAC;SACJ,CAAC,CACL,CAAC;IACN,CAAC;IAED,KAAK;QACD,OAAO,IAAI,aAAa,EAAE,CAAC;IAC/B,CAAC;IAED,OAAO,KAAU,CAAC;IAElB,YAAY;QACR,OAAO,EAAE,CAAC;IACd,CAAC;CACJ"}
|
|
@@ -3,4 +3,7 @@ import { IContainer } from '../core/container/IContainer';
|
|
|
3
3
|
import { IInjector } from '../core/IInjector';
|
|
4
4
|
export declare class SimpleInjector implements IInjector {
|
|
5
5
|
resolve<T>(container: IContainer, value: constructor<T>, ...deps: any[]): T;
|
|
6
|
+
clone(): IInjector;
|
|
7
|
+
dispose(): void;
|
|
8
|
+
getInstances(): unknown[];
|
|
6
9
|
}
|
|
@@ -2,5 +2,12 @@ export class SimpleInjector {
|
|
|
2
2
|
resolve(container, value, ...deps) {
|
|
3
3
|
return new value(container, ...deps);
|
|
4
4
|
}
|
|
5
|
+
clone() {
|
|
6
|
+
return new SimpleInjector();
|
|
7
|
+
}
|
|
8
|
+
dispose() { }
|
|
9
|
+
getInstances() {
|
|
10
|
+
return [];
|
|
11
|
+
}
|
|
5
12
|
}
|
|
6
13
|
//# sourceMappingURL=SimpleInjector.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SimpleInjector.js","sourceRoot":"","sources":["../../lib/injectors/SimpleInjector.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,cAAc;IACvB,OAAO,CAAI,SAAqB,EAAE,KAAqB,EAAE,GAAG,IAAW;QACnE,OAAO,IAAI,KAAK,CAAC,SAAS,EAAE,GAAG,IAAI,CAAC,CAAC;IACzC,CAAC;CACJ"}
|
|
1
|
+
{"version":3,"file":"SimpleInjector.js","sourceRoot":"","sources":["../../lib/injectors/SimpleInjector.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,cAAc;IACvB,OAAO,CAAI,SAAqB,EAAE,KAAqB,EAAE,GAAG,IAAW;QACnE,OAAO,IAAI,KAAK,CAAC,SAAS,EAAE,GAAG,IAAI,CAAC,CAAC;IACzC,CAAC;IAED,KAAK;QACD,OAAO,IAAI,cAAc,EAAE,CAAC;IAChC,CAAC;IAED,OAAO,KAAU,CAAC;IAElB,YAAY;QACR,OAAO,EAAE,CAAC;IACd,CAAC;CACJ"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "ts-ioc-container",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "17.0.0",
|
|
4
4
|
"description": "Typescript IoC container",
|
|
5
5
|
"author": "ibabkin <igba14@gmail.com>",
|
|
6
6
|
"homepage": "https://github.com/IgorBabkin/ts-ioc-container/tree/master/packages/ts-ioc-container",
|
|
@@ -46,5 +46,5 @@
|
|
|
46
46
|
"ts-jest": "27.0.5",
|
|
47
47
|
"typescript": "4.4.3"
|
|
48
48
|
},
|
|
49
|
-
"gitHead": "
|
|
49
|
+
"gitHead": "d5e50ef9a900768d2f8e4732972a7f29d4d8d6d3"
|
|
50
50
|
}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.emptyHook = void 0;
|
|
4
|
-
var others_1 = require("../utils/others");
|
|
5
|
-
exports.emptyHook = {
|
|
6
|
-
resolve: others_1.id,
|
|
7
|
-
dispose: others_1.noop,
|
|
8
|
-
clone: function () { return exports.emptyHook; },
|
|
9
|
-
};
|
|
10
|
-
//# sourceMappingURL=IContainerHook.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"IContainerHook.js","sourceRoot":"","sources":["../../../lib/core/container/IContainerHook.ts"],"names":[],"mappings":";;;AAAA,0CAA2C;AAS9B,QAAA,SAAS,GAAmB;IACrC,OAAO,EAAE,WAAE;IACX,OAAO,EAAE,aAAI;IACb,KAAK,EAAE,cAAM,OAAA,iBAAS,EAAT,CAAS;CACzB,CAAC"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { IContainerHook } from '../core/container/IContainerHook';
|
|
2
|
-
export declare type OnDisposeHook = (instance: unknown) => void;
|
|
3
|
-
export declare class ContainerHook implements IContainerHook {
|
|
4
|
-
private onDisposeFn;
|
|
5
|
-
private instances;
|
|
6
|
-
constructor(onDisposeFn?: OnDisposeHook);
|
|
7
|
-
resolve<T>(instance: T): T;
|
|
8
|
-
dispose(): void;
|
|
9
|
-
clone(): IContainerHook;
|
|
10
|
-
}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __values = (this && this.__values) || function(o) {
|
|
3
|
-
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
|
|
4
|
-
if (m) return m.call(o);
|
|
5
|
-
if (o && typeof o.length === "number") return {
|
|
6
|
-
next: function () {
|
|
7
|
-
if (o && i >= o.length) o = void 0;
|
|
8
|
-
return { value: o && o[i++], done: !o };
|
|
9
|
-
}
|
|
10
|
-
};
|
|
11
|
-
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
|
|
12
|
-
};
|
|
13
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
-
exports.ContainerHook = void 0;
|
|
15
|
-
var others_1 = require("../core/utils/others");
|
|
16
|
-
var ContainerHook = /** @class */ (function () {
|
|
17
|
-
function ContainerHook(onDisposeFn) {
|
|
18
|
-
if (onDisposeFn === void 0) { onDisposeFn = others_1.noop; }
|
|
19
|
-
this.onDisposeFn = onDisposeFn;
|
|
20
|
-
this.instances = new Set();
|
|
21
|
-
}
|
|
22
|
-
ContainerHook.prototype.resolve = function (instance) {
|
|
23
|
-
this.instances.add(instance);
|
|
24
|
-
return instance;
|
|
25
|
-
};
|
|
26
|
-
ContainerHook.prototype.dispose = function () {
|
|
27
|
-
var e_1, _a;
|
|
28
|
-
try {
|
|
29
|
-
for (var _b = __values(this.instances), _c = _b.next(); !_c.done; _c = _b.next()) {
|
|
30
|
-
var it_1 = _c.value;
|
|
31
|
-
this.onDisposeFn(it_1);
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
35
|
-
finally {
|
|
36
|
-
try {
|
|
37
|
-
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
38
|
-
}
|
|
39
|
-
finally { if (e_1) throw e_1.error; }
|
|
40
|
-
}
|
|
41
|
-
this.instances.clear();
|
|
42
|
-
};
|
|
43
|
-
ContainerHook.prototype.clone = function () {
|
|
44
|
-
return new ContainerHook(this.onDisposeFn);
|
|
45
|
-
};
|
|
46
|
-
return ContainerHook;
|
|
47
|
-
}());
|
|
48
|
-
exports.ContainerHook = ContainerHook;
|
|
49
|
-
//# sourceMappingURL=ContainerHook.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ContainerHook.js","sourceRoot":"","sources":["../../lib/hooks/ContainerHook.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AACA,+CAA4C;AAI5C;IAGI,uBAAoB,WAAiC;QAAjC,4BAAA,EAAA,cAA6B,aAAI;QAAjC,gBAAW,GAAX,WAAW,CAAsB;QAF7C,cAAS,GAAG,IAAI,GAAG,EAAE,CAAC;IAE0B,CAAC;IAEzD,+BAAO,GAAP,UAAW,QAAW;QAClB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC7B,OAAO,QAAQ,CAAC;IACpB,CAAC;IAED,+BAAO,GAAP;;;YACI,KAAiB,IAAA,KAAA,SAAA,IAAI,CAAC,SAAS,CAAA,gBAAA,4BAAE;gBAA5B,IAAM,IAAE,WAAA;gBACT,IAAI,CAAC,WAAW,CAAC,IAAE,CAAC,CAAC;aACxB;;;;;;;;;QACD,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;IAED,6BAAK,GAAL;QACI,OAAO,IAAI,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAC/C,CAAC;IACL,oBAAC;AAAD,CAAC,AApBD,IAoBC;AApBY,sCAAa"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"IContainerHook.js","sourceRoot":"","sources":["../../../lib/core/container/IContainerHook.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AAS3C,MAAM,CAAC,MAAM,SAAS,GAAmB;IACrC,OAAO,EAAE,EAAE;IACX,OAAO,EAAE,IAAI;IACb,KAAK,EAAE,GAAG,EAAE,CAAC,SAAS;CACzB,CAAC"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { IContainerHook } from '../core/container/IContainerHook';
|
|
2
|
-
export declare type OnDisposeHook = (instance: unknown) => void;
|
|
3
|
-
export declare class ContainerHook implements IContainerHook {
|
|
4
|
-
private onDisposeFn;
|
|
5
|
-
private instances;
|
|
6
|
-
constructor(onDisposeFn?: OnDisposeHook);
|
|
7
|
-
resolve<T>(instance: T): T;
|
|
8
|
-
dispose(): void;
|
|
9
|
-
clone(): IContainerHook;
|
|
10
|
-
}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { noop } from '../core/utils/others';
|
|
2
|
-
export class ContainerHook {
|
|
3
|
-
constructor(onDisposeFn = noop) {
|
|
4
|
-
this.onDisposeFn = onDisposeFn;
|
|
5
|
-
this.instances = new Set();
|
|
6
|
-
}
|
|
7
|
-
resolve(instance) {
|
|
8
|
-
this.instances.add(instance);
|
|
9
|
-
return instance;
|
|
10
|
-
}
|
|
11
|
-
dispose() {
|
|
12
|
-
for (const it of this.instances) {
|
|
13
|
-
this.onDisposeFn(it);
|
|
14
|
-
}
|
|
15
|
-
this.instances.clear();
|
|
16
|
-
}
|
|
17
|
-
clone() {
|
|
18
|
-
return new ContainerHook(this.onDisposeFn);
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
//# sourceMappingURL=ContainerHook.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ContainerHook.js","sourceRoot":"","sources":["../../lib/hooks/ContainerHook.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAC;AAI5C,MAAM,OAAO,aAAa;IAGtB,YAAoB,cAA6B,IAAI;QAAjC,gBAAW,GAAX,WAAW,CAAsB;QAF7C,cAAS,GAAG,IAAI,GAAG,EAAE,CAAC;IAE0B,CAAC;IAEzD,OAAO,CAAI,QAAW;QAClB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC7B,OAAO,QAAQ,CAAC;IACpB,CAAC;IAED,OAAO;QACH,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,SAAS,EAAE;YAC7B,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;SACxB;QACD,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;IAED,KAAK;QACD,OAAO,IAAI,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAC/C,CAAC;CACJ"}
|