assemblerjs 1.1.2 → 1.1.3
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/dist/index.d.ts +26 -0
- package/dist/index11.js +2 -2
- package/dist/index11.mjs +2 -2
- package/dist/index13.js +2 -2
- package/dist/index13.mjs +2 -2
- package/dist/index16.js +1 -1
- package/dist/index16.mjs +1 -1
- package/dist/index17.js +1 -1
- package/dist/index17.mjs +1 -1
- package/dist/index18.js +1 -1
- package/dist/index18.mjs +1 -1
- package/dist/index19.js +1 -1
- package/dist/index19.mjs +1 -1
- package/dist/index2.js +2 -2
- package/dist/index2.mjs +2 -2
- package/dist/index20.js +1 -1
- package/dist/index20.mjs +1 -1
- package/dist/index21.js +1 -1
- package/dist/index21.mjs +1 -1
- package/dist/index22.js +2 -2
- package/dist/index22.mjs +2 -2
- package/dist/index23.js +2 -2
- package/dist/index23.mjs +2 -2
- package/dist/index24.js +2 -2
- package/dist/index24.mjs +2 -2
- package/dist/index25.js +1 -1
- package/dist/index25.mjs +1 -1
- package/dist/index26.js +1 -1
- package/dist/index26.mjs +1 -1
- package/dist/index27.js +1 -1
- package/dist/index27.mjs +1 -1
- package/dist/index29.js +15 -38
- package/dist/index29.mjs +12 -37
- package/dist/index3.js +1 -1
- package/dist/index3.mjs +1 -1
- package/dist/index30.js +100 -58
- package/dist/index30.mjs +98 -58
- package/dist/index31.js +36 -27
- package/dist/index31.mjs +35 -27
- package/dist/index32.js +16 -59
- package/dist/index32.mjs +16 -59
- package/dist/index33.js +65 -28
- package/dist/index33.mjs +65 -28
- package/dist/index34.js +28 -28
- package/dist/index34.mjs +28 -28
- package/dist/index35.js +77 -15
- package/dist/index35.mjs +77 -12
- package/dist/index36.js +38 -104
- package/dist/index36.mjs +38 -102
- package/dist/index37.js +28 -102
- package/dist/index37.mjs +28 -102
- package/dist/index38.js +128 -23
- package/dist/index38.mjs +128 -23
- package/dist/index39.js +101 -18
- package/dist/index39.mjs +101 -18
- package/dist/index4.js +21 -8
- package/dist/index4.mjs +21 -8
- package/dist/index40.js +25 -25
- package/dist/index40.mjs +25 -24
- package/dist/index41.js +44 -18
- package/dist/index41.mjs +44 -17
- package/dist/index42.js +18 -44
- package/dist/index42.mjs +17 -44
- package/dist/index43.js +26 -191
- package/dist/index43.mjs +25 -191
- package/dist/index44.js +192 -940
- package/dist/index44.mjs +192 -940
- package/dist/index45.js +942 -2
- package/dist/index45.mjs +942 -2
- package/dist/index46.js +2 -2
- package/dist/index46.mjs +2 -2
- package/dist/index47.js +2 -14
- package/dist/index47.mjs +2 -14
- package/dist/index48.js +9 -34
- package/dist/index48.mjs +9 -34
- package/dist/index49.js +32 -55
- package/dist/index49.mjs +32 -54
- package/dist/index50.js +67 -0
- package/dist/index50.mjs +62 -0
- package/package.json +1 -1
package/dist/index46.js
CHANGED
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
4
4
|
|
|
5
|
-
var
|
|
5
|
+
var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
|
|
6
6
|
|
|
7
|
-
exports.
|
|
7
|
+
exports.commonjsGlobal = commonjsGlobal;
|
package/dist/index46.mjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
var
|
|
1
|
+
var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
|
|
2
2
|
|
|
3
|
-
export {
|
|
3
|
+
export { commonjsGlobal };
|
package/dist/index47.js
CHANGED
|
@@ -2,18 +2,6 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
4
4
|
|
|
5
|
-
|
|
5
|
+
var _Reflect = {};
|
|
6
6
|
|
|
7
|
-
|
|
8
|
-
static getResolver(r) {
|
|
9
|
-
return resolverStore.ResolverStore.getResolver(r);
|
|
10
|
-
}
|
|
11
|
-
static registerResolver(r, s) {
|
|
12
|
-
resolverStore.ResolverStore.register(r, s);
|
|
13
|
-
}
|
|
14
|
-
static hasResolver(r) {
|
|
15
|
-
return resolverStore.ResolverStore.hasResolver(r);
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
exports.ParameterResolverFactory = ParameterResolverFactory;
|
|
7
|
+
exports.__exports = _Reflect;
|
package/dist/index47.mjs
CHANGED
|
@@ -1,15 +1,3 @@
|
|
|
1
|
-
|
|
1
|
+
var _Reflect = {};
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
static getResolver(r) {
|
|
5
|
-
return ResolverStore.getResolver(r);
|
|
6
|
-
}
|
|
7
|
-
static registerResolver(r, s) {
|
|
8
|
-
ResolverStore.register(r, s);
|
|
9
|
-
}
|
|
10
|
-
static hasResolver(r) {
|
|
11
|
-
return ResolverStore.hasResolver(r);
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
export { ParameterResolverFactory };
|
|
3
|
+
export { _Reflect as __exports };
|
package/dist/index48.js
CHANGED
|
@@ -2,43 +2,18 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
4
4
|
|
|
5
|
-
const
|
|
6
|
-
const transversalWeaver = require('./index37.js');
|
|
7
|
-
const helpers = require('./index29.js');
|
|
5
|
+
const resolverStore = require('./index32.js');
|
|
8
6
|
|
|
9
|
-
class
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
let c;
|
|
13
|
-
if (this.injectable.singletonInstance) {
|
|
14
|
-
return this.injectable.singletonInstance;
|
|
15
|
-
}
|
|
16
|
-
if (this.injectable.factory) {
|
|
17
|
-
c = this.injectable.factory();
|
|
18
|
-
} else if (this.injectable.concrete) {
|
|
19
|
-
const e = dependencies.resolveInjectableParameters(this.injectable, r);
|
|
20
|
-
c = new this.injectable.concrete(...e);
|
|
21
|
-
} else {
|
|
22
|
-
throw new Error(`Injectable with identifier '${String(this.injectable.identifier)}' has neither concrete class nor factory.`);
|
|
23
|
-
}
|
|
24
|
-
const s = this.injectable.concrete || c.constructor;
|
|
25
|
-
const o = transversalWeaver.TransversalWeaver.weave(c, s, this.injectable.publicContext);
|
|
26
|
-
helpers.registerEvents(this.injectable, o);
|
|
27
|
-
return o;
|
|
7
|
+
class ParameterResolverFactory {
|
|
8
|
+
static getResolver(r) {
|
|
9
|
+
return resolverStore.ResolverStore.getResolver(r);
|
|
28
10
|
}
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
if (e) {
|
|
32
|
-
return {
|
|
33
|
-
...t,
|
|
34
|
-
...e
|
|
35
|
-
};
|
|
36
|
-
}
|
|
37
|
-
return t;
|
|
11
|
+
static registerResolver(r, s) {
|
|
12
|
+
resolverStore.ResolverStore.register(r, s);
|
|
38
13
|
}
|
|
39
|
-
|
|
40
|
-
|
|
14
|
+
static hasResolver(r) {
|
|
15
|
+
return resolverStore.ResolverStore.hasResolver(r);
|
|
41
16
|
}
|
|
42
17
|
}
|
|
43
18
|
|
|
44
|
-
exports.
|
|
19
|
+
exports.ParameterResolverFactory = ParameterResolverFactory;
|
package/dist/index48.mjs
CHANGED
|
@@ -1,40 +1,15 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { TransversalWeaver } from './index37.mjs';
|
|
3
|
-
import { registerEvents } from './index29.mjs';
|
|
1
|
+
import { ResolverStore } from './index32.mjs';
|
|
4
2
|
|
|
5
|
-
class
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
let c;
|
|
9
|
-
if (this.injectable.singletonInstance) {
|
|
10
|
-
return this.injectable.singletonInstance;
|
|
11
|
-
}
|
|
12
|
-
if (this.injectable.factory) {
|
|
13
|
-
c = this.injectable.factory();
|
|
14
|
-
} else if (this.injectable.concrete) {
|
|
15
|
-
const e = resolveInjectableParameters(this.injectable, r);
|
|
16
|
-
c = new this.injectable.concrete(...e);
|
|
17
|
-
} else {
|
|
18
|
-
throw new Error(`Injectable with identifier '${String(this.injectable.identifier)}' has neither concrete class nor factory.`);
|
|
19
|
-
}
|
|
20
|
-
const s = this.injectable.concrete || c.constructor;
|
|
21
|
-
const o = TransversalWeaver.weave(c, s, this.injectable.publicContext);
|
|
22
|
-
registerEvents(this.injectable, o);
|
|
23
|
-
return o;
|
|
3
|
+
class ParameterResolverFactory {
|
|
4
|
+
static getResolver(r) {
|
|
5
|
+
return ResolverStore.getResolver(r);
|
|
24
6
|
}
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
if (e) {
|
|
28
|
-
return {
|
|
29
|
-
...t,
|
|
30
|
-
...e
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
|
-
return t;
|
|
7
|
+
static registerResolver(r, s) {
|
|
8
|
+
ResolverStore.register(r, s);
|
|
34
9
|
}
|
|
35
|
-
|
|
36
|
-
|
|
10
|
+
static hasResolver(r) {
|
|
11
|
+
return ResolverStore.hasResolver(r);
|
|
37
12
|
}
|
|
38
13
|
}
|
|
39
14
|
|
|
40
|
-
export {
|
|
15
|
+
export { ParameterResolverFactory };
|
package/dist/index49.js
CHANGED
|
@@ -2,66 +2,43 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
4
4
|
|
|
5
|
-
const
|
|
6
|
-
const
|
|
7
|
-
const
|
|
8
|
-
const decorators = require('./index11.js');
|
|
9
|
-
const transversalManager = require('./index13.js');
|
|
5
|
+
const dependencies = require('./index50.js');
|
|
6
|
+
const transversalWeaver = require('./index39.js');
|
|
7
|
+
const helpers = require('./index31.js');
|
|
10
8
|
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
9
|
+
class InjectableBuilder {
|
|
10
|
+
build(i) {
|
|
11
|
+
const r = this.mergeConfiguration(i);
|
|
12
|
+
let c;
|
|
13
|
+
if (this.injectable.singletonInstance) {
|
|
14
|
+
return this.injectable.singletonInstance;
|
|
16
15
|
}
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
}
|
|
20
|
-
const
|
|
21
|
-
|
|
22
|
-
const l = reflection.getParamTypes(n.concrete);
|
|
23
|
-
const u = helpers.getDecoratedParametersIndexes(n.concrete);
|
|
24
|
-
for(let e = 0; e < l.length; e++){
|
|
25
|
-
const t = c(u, e);
|
|
26
|
-
if (t) {
|
|
27
|
-
const s = parameterResolver_factory.ParameterResolverFactory.getResolver(t);
|
|
28
|
-
i.push(s.resolve(e, n, n.concrete, a));
|
|
16
|
+
if (this.injectable.factory) {
|
|
17
|
+
c = this.injectable.factory();
|
|
18
|
+
} else if (this.injectable.concrete) {
|
|
19
|
+
const e = dependencies.resolveInjectableParameters(this.injectable, r);
|
|
20
|
+
c = new this.injectable.concrete(...e);
|
|
29
21
|
} else {
|
|
30
|
-
|
|
31
|
-
if (decorators.isTransversal(t)) {
|
|
32
|
-
const e = transversalManager.TransversalManager.getInstance(n.publicContext);
|
|
33
|
-
const r = e.getTransversalInstance(t.name);
|
|
34
|
-
if (!r) {
|
|
35
|
-
throw new Error(`Transversal ${t.name} is injected in constructor but not registered in transversals[]. ` + `Add it to transversals[] in @Assemblage decorator.`);
|
|
36
|
-
}
|
|
37
|
-
i.push(r);
|
|
38
|
-
} else {
|
|
39
|
-
i.push(n.privateContext.require(t));
|
|
40
|
-
}
|
|
22
|
+
throw new Error(`Injectable with identifier '${String(this.injectable.identifier)}' has neither concrete class nor factory.`);
|
|
41
23
|
}
|
|
24
|
+
const s = this.injectable.concrete || c.constructor;
|
|
25
|
+
const o = transversalWeaver.TransversalWeaver.weave(c, s, this.injectable.publicContext);
|
|
26
|
+
helpers.registerEvents(this.injectable, o);
|
|
27
|
+
return o;
|
|
42
28
|
}
|
|
43
|
-
|
|
44
|
-
};
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
const o = reflection.getParamTypes(r);
|
|
51
|
-
const c = helpers.getDecoratedParametersIndexes(r);
|
|
52
|
-
let a = 0;
|
|
53
|
-
for (const e of o){
|
|
54
|
-
const t = Object.values(c).some((e)=>e.includes(a));
|
|
55
|
-
if (t) {
|
|
56
|
-
a++;
|
|
57
|
-
continue;
|
|
29
|
+
mergeConfiguration(e) {
|
|
30
|
+
const t = this.injectable.configuration || {};
|
|
31
|
+
if (e) {
|
|
32
|
+
return {
|
|
33
|
+
...t,
|
|
34
|
+
...e
|
|
35
|
+
};
|
|
58
36
|
}
|
|
59
|
-
|
|
60
|
-
|
|
37
|
+
return t;
|
|
38
|
+
}
|
|
39
|
+
constructor(e){
|
|
40
|
+
this.injectable = e;
|
|
61
41
|
}
|
|
62
|
-
|
|
63
|
-
return s;
|
|
64
|
-
};
|
|
42
|
+
}
|
|
65
43
|
|
|
66
|
-
exports.
|
|
67
|
-
exports.resolveInjectableParameters = resolveInjectableParameters;
|
|
44
|
+
exports.InjectableBuilder = InjectableBuilder;
|
package/dist/index49.mjs
CHANGED
|
@@ -1,62 +1,40 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import { isTransversal } from './index11.mjs';
|
|
5
|
-
import { TransversalManager } from './index13.mjs';
|
|
1
|
+
import { resolveInjectableParameters } from './index50.mjs';
|
|
2
|
+
import { TransversalWeaver } from './index39.mjs';
|
|
3
|
+
import { registerEvents } from './index31.mjs';
|
|
6
4
|
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
5
|
+
class InjectableBuilder {
|
|
6
|
+
build(i) {
|
|
7
|
+
const r = this.mergeConfiguration(i);
|
|
8
|
+
let c;
|
|
9
|
+
if (this.injectable.singletonInstance) {
|
|
10
|
+
return this.injectable.singletonInstance;
|
|
12
11
|
}
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
}
|
|
16
|
-
const
|
|
17
|
-
|
|
18
|
-
const l = getParamTypes(n.concrete);
|
|
19
|
-
const u = getDecoratedParametersIndexes(n.concrete);
|
|
20
|
-
for(let e = 0; e < l.length; e++){
|
|
21
|
-
const t = c(u, e);
|
|
22
|
-
if (t) {
|
|
23
|
-
const s = ParameterResolverFactory.getResolver(t);
|
|
24
|
-
i.push(s.resolve(e, n, n.concrete, a));
|
|
12
|
+
if (this.injectable.factory) {
|
|
13
|
+
c = this.injectable.factory();
|
|
14
|
+
} else if (this.injectable.concrete) {
|
|
15
|
+
const e = resolveInjectableParameters(this.injectable, r);
|
|
16
|
+
c = new this.injectable.concrete(...e);
|
|
25
17
|
} else {
|
|
26
|
-
|
|
27
|
-
if (isTransversal(t)) {
|
|
28
|
-
const e = TransversalManager.getInstance(n.publicContext);
|
|
29
|
-
const r = e.getTransversalInstance(t.name);
|
|
30
|
-
if (!r) {
|
|
31
|
-
throw new Error(`Transversal ${t.name} is injected in constructor but not registered in transversals[]. ` + `Add it to transversals[] in @Assemblage decorator.`);
|
|
32
|
-
}
|
|
33
|
-
i.push(r);
|
|
34
|
-
} else {
|
|
35
|
-
i.push(n.privateContext.require(t));
|
|
36
|
-
}
|
|
18
|
+
throw new Error(`Injectable with identifier '${String(this.injectable.identifier)}' has neither concrete class nor factory.`);
|
|
37
19
|
}
|
|
20
|
+
const s = this.injectable.concrete || c.constructor;
|
|
21
|
+
const o = TransversalWeaver.weave(c, s, this.injectable.publicContext);
|
|
22
|
+
registerEvents(this.injectable, o);
|
|
23
|
+
return o;
|
|
38
24
|
}
|
|
39
|
-
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
const o = getParamTypes(r);
|
|
47
|
-
const c = getDecoratedParametersIndexes(r);
|
|
48
|
-
let a = 0;
|
|
49
|
-
for (const e of o){
|
|
50
|
-
const t = Object.values(c).some((e)=>e.includes(a));
|
|
51
|
-
if (t) {
|
|
52
|
-
a++;
|
|
53
|
-
continue;
|
|
25
|
+
mergeConfiguration(e) {
|
|
26
|
+
const t = this.injectable.configuration || {};
|
|
27
|
+
if (e) {
|
|
28
|
+
return {
|
|
29
|
+
...t,
|
|
30
|
+
...e
|
|
31
|
+
};
|
|
54
32
|
}
|
|
55
|
-
|
|
56
|
-
|
|
33
|
+
return t;
|
|
34
|
+
}
|
|
35
|
+
constructor(e){
|
|
36
|
+
this.injectable = e;
|
|
57
37
|
}
|
|
58
|
-
|
|
59
|
-
return s;
|
|
60
|
-
};
|
|
38
|
+
}
|
|
61
39
|
|
|
62
|
-
export {
|
|
40
|
+
export { InjectableBuilder };
|
package/dist/index50.js
ADDED
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
4
|
+
|
|
5
|
+
const reflection = require('./index29.js');
|
|
6
|
+
const helpers = require('./index25.js');
|
|
7
|
+
const parameterResolver_factory = require('./index48.js');
|
|
8
|
+
const decorators = require('./index11.js');
|
|
9
|
+
const transversalManager = require('./index13.js');
|
|
10
|
+
|
|
11
|
+
const n = new WeakMap();
|
|
12
|
+
const c = (e, t)=>{
|
|
13
|
+
for (const [r, s] of Object.entries(e)){
|
|
14
|
+
if (s.includes(t)) {
|
|
15
|
+
return r;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
return null;
|
|
19
|
+
};
|
|
20
|
+
const resolveInjectableParameters = (n, a)=>{
|
|
21
|
+
const i = [];
|
|
22
|
+
const l = reflection.getParamTypes(n.concrete);
|
|
23
|
+
const u = helpers.getDecoratedParametersIndexes(n.concrete);
|
|
24
|
+
for(let e = 0; e < l.length; e++){
|
|
25
|
+
const t = c(u, e);
|
|
26
|
+
if (t) {
|
|
27
|
+
const s = parameterResolver_factory.ParameterResolverFactory.getResolver(t);
|
|
28
|
+
i.push(s.resolve(e, n, n.concrete, a));
|
|
29
|
+
} else {
|
|
30
|
+
const t = l[e];
|
|
31
|
+
if (decorators.isTransversal(t)) {
|
|
32
|
+
const e = transversalManager.TransversalManager.getInstance(n.publicContext);
|
|
33
|
+
const r = e.getTransversalInstance(t.name);
|
|
34
|
+
if (!r) {
|
|
35
|
+
throw new Error(`Transversal ${t.name} is injected in constructor but not registered in transversals[]. ` + `Add it to transversals[] in @Assemblage decorator.`);
|
|
36
|
+
}
|
|
37
|
+
i.push(r);
|
|
38
|
+
} else {
|
|
39
|
+
i.push(n.privateContext.require(t));
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
return i;
|
|
44
|
+
};
|
|
45
|
+
const resolveDependencies = (r)=>{
|
|
46
|
+
if (n.has(r)) {
|
|
47
|
+
return n.get(r);
|
|
48
|
+
}
|
|
49
|
+
const s = [];
|
|
50
|
+
const o = reflection.getParamTypes(r);
|
|
51
|
+
const c = helpers.getDecoratedParametersIndexes(r);
|
|
52
|
+
let a = 0;
|
|
53
|
+
for (const e of o){
|
|
54
|
+
const t = Object.values(c).some((e)=>e.includes(a));
|
|
55
|
+
if (t) {
|
|
56
|
+
a++;
|
|
57
|
+
continue;
|
|
58
|
+
}
|
|
59
|
+
s.push(e);
|
|
60
|
+
a++;
|
|
61
|
+
}
|
|
62
|
+
n.set(r, s);
|
|
63
|
+
return s;
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
exports.resolveDependencies = resolveDependencies;
|
|
67
|
+
exports.resolveInjectableParameters = resolveInjectableParameters;
|
package/dist/index50.mjs
ADDED
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { getParamTypes } from './index29.mjs';
|
|
2
|
+
import { getDecoratedParametersIndexes } from './index25.mjs';
|
|
3
|
+
import { ParameterResolverFactory } from './index48.mjs';
|
|
4
|
+
import { isTransversal } from './index11.mjs';
|
|
5
|
+
import { TransversalManager } from './index13.mjs';
|
|
6
|
+
|
|
7
|
+
const n = new WeakMap();
|
|
8
|
+
const c = (e, t)=>{
|
|
9
|
+
for (const [r, s] of Object.entries(e)){
|
|
10
|
+
if (s.includes(t)) {
|
|
11
|
+
return r;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
return null;
|
|
15
|
+
};
|
|
16
|
+
const resolveInjectableParameters = (n, a)=>{
|
|
17
|
+
const i = [];
|
|
18
|
+
const l = getParamTypes(n.concrete);
|
|
19
|
+
const u = getDecoratedParametersIndexes(n.concrete);
|
|
20
|
+
for(let e = 0; e < l.length; e++){
|
|
21
|
+
const t = c(u, e);
|
|
22
|
+
if (t) {
|
|
23
|
+
const s = ParameterResolverFactory.getResolver(t);
|
|
24
|
+
i.push(s.resolve(e, n, n.concrete, a));
|
|
25
|
+
} else {
|
|
26
|
+
const t = l[e];
|
|
27
|
+
if (isTransversal(t)) {
|
|
28
|
+
const e = TransversalManager.getInstance(n.publicContext);
|
|
29
|
+
const r = e.getTransversalInstance(t.name);
|
|
30
|
+
if (!r) {
|
|
31
|
+
throw new Error(`Transversal ${t.name} is injected in constructor but not registered in transversals[]. ` + `Add it to transversals[] in @Assemblage decorator.`);
|
|
32
|
+
}
|
|
33
|
+
i.push(r);
|
|
34
|
+
} else {
|
|
35
|
+
i.push(n.privateContext.require(t));
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
return i;
|
|
40
|
+
};
|
|
41
|
+
const resolveDependencies = (r)=>{
|
|
42
|
+
if (n.has(r)) {
|
|
43
|
+
return n.get(r);
|
|
44
|
+
}
|
|
45
|
+
const s = [];
|
|
46
|
+
const o = getParamTypes(r);
|
|
47
|
+
const c = getDecoratedParametersIndexes(r);
|
|
48
|
+
let a = 0;
|
|
49
|
+
for (const e of o){
|
|
50
|
+
const t = Object.values(c).some((e)=>e.includes(a));
|
|
51
|
+
if (t) {
|
|
52
|
+
a++;
|
|
53
|
+
continue;
|
|
54
|
+
}
|
|
55
|
+
s.push(e);
|
|
56
|
+
a++;
|
|
57
|
+
}
|
|
58
|
+
n.set(r, s);
|
|
59
|
+
return s;
|
|
60
|
+
};
|
|
61
|
+
|
|
62
|
+
export { resolveDependencies, resolveInjectableParameters };
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "assemblerjs",
|
|
3
3
|
"description": "A general purpose Dependency Injection library for node and browser.",
|
|
4
|
-
"version": "1.1.
|
|
4
|
+
"version": "1.1.3",
|
|
5
5
|
"author": "Benoît LAHOZ <info@benoitlahoz.io>",
|
|
6
6
|
"bugs": "https://github.com/benoitlahoz/assemblerjs/issues",
|
|
7
7
|
"homepage": "https://github.com/benoitlahoz/assemblerjs#README",
|