assemblerjs 1.1.19 → 1.1.21
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 +4 -0
- package/dist/index13.js +1 -1
- package/dist/index13.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/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 +11 -5
- package/dist/index22.mjs +11 -5
- package/dist/index23.js +13 -7
- package/dist/index23.mjs +13 -7
- package/dist/index24.js +1 -1
- package/dist/index24.mjs +1 -1
- package/dist/index31.js +35 -100
- package/dist/index31.mjs +34 -100
- package/dist/index32.js +152 -22
- package/dist/index32.mjs +151 -22
- package/dist/index33.js +35 -143
- package/dist/index33.mjs +35 -142
- package/dist/index34.js +70 -41
- package/dist/index34.mjs +70 -41
- package/dist/index35.js +49 -73
- package/dist/index35.mjs +49 -73
- package/dist/index36.js +29 -53
- package/dist/index36.mjs +29 -53
- package/dist/index37.js +170 -26
- package/dist/index37.mjs +170 -26
- package/dist/index38.js +48 -151
- package/dist/index38.mjs +48 -151
- package/dist/index39.js +16 -57
- package/dist/index39.mjs +16 -57
- package/dist/index4.js +7 -7
- package/dist/index4.mjs +7 -7
- package/dist/index40.js +100 -35
- package/dist/index40.mjs +100 -34
- package/dist/index41.js +24 -18
- package/dist/index41.mjs +24 -18
- package/dist/index45.js +54 -22
- package/dist/index45.mjs +54 -22
- package/dist/index49.js +1 -1
- package/dist/index49.mjs +1 -1
- package/dist/index50.js +2 -2
- package/dist/index50.mjs +2 -2
- package/package.json +1 -1
package/dist/index32.js
CHANGED
|
@@ -2,33 +2,163 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
4
4
|
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
5
|
+
const hookManager = require('./index34.js');
|
|
6
|
+
const resolutionStrategies = require('./index44.js');
|
|
7
|
+
const debugLogger = require('./index37.js');
|
|
8
|
+
const core = require('@assemblerjs/core');
|
|
9
|
+
const use = require('./index43.js');
|
|
10
|
+
const inject = require('./index42.js');
|
|
11
|
+
const injectable = require('./index45.js');
|
|
12
|
+
|
|
13
|
+
function formatIdentifier(e) {
|
|
14
|
+
if (e === undefined) return 'undefined';
|
|
15
|
+
if (e === null) return 'null';
|
|
16
|
+
if (typeof e === 'function') {
|
|
17
|
+
if (e.name) return e.name;
|
|
18
|
+
if (e.constructor?.name && e.constructor.name !== 'Function') {
|
|
19
|
+
return e.constructor.name;
|
|
20
|
+
}
|
|
21
|
+
return 'AnonymousFunction';
|
|
22
|
+
}
|
|
23
|
+
if (typeof e === 'string') return e;
|
|
24
|
+
if (typeof e === 'symbol') return e.toString();
|
|
25
|
+
if (typeof e === 'number') return String(e);
|
|
26
|
+
if (typeof e === 'boolean') return String(e);
|
|
27
|
+
if (typeof e === 'object') {
|
|
28
|
+
if (e.name && typeof e.name === 'string') {
|
|
29
|
+
return e.name;
|
|
30
|
+
}
|
|
31
|
+
const t = e.constructor?.name;
|
|
32
|
+
if (t && t !== 'Object') {
|
|
33
|
+
return t;
|
|
34
|
+
}
|
|
35
|
+
try {
|
|
36
|
+
const t = JSON.stringify(e);
|
|
37
|
+
if (t.length > 100) {
|
|
38
|
+
return t.substring(0, 100) + '...';
|
|
39
|
+
}
|
|
40
|
+
return t;
|
|
41
|
+
} catch {
|
|
42
|
+
return '[UnknownObject]';
|
|
10
43
|
}
|
|
11
|
-
const [, c, r] = e;
|
|
12
|
-
return new ExecutionPointcutMatcher(c, r);
|
|
13
44
|
}
|
|
45
|
+
return String(e);
|
|
14
46
|
}
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
const
|
|
18
|
-
|
|
19
|
-
return this.classRegex.test(e) && this.methodRegex.test(c);
|
|
47
|
+
function c(e) {
|
|
48
|
+
if (core.isClass(e)) {
|
|
49
|
+
const t = e.prototype && Object.getOwnPropertyNames(e.prototype).length > 1;
|
|
50
|
+
return t ? 'class' : 'class';
|
|
20
51
|
}
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
52
|
+
if (typeof e === 'function') return 'function';
|
|
53
|
+
if (typeof e === 'string') return 'string';
|
|
54
|
+
if (typeof e === 'symbol') return 'symbol';
|
|
55
|
+
if (typeof e === 'object' && e !== null) return 'object';
|
|
56
|
+
return 'unknown';
|
|
57
|
+
}
|
|
58
|
+
class InjectableManager {
|
|
59
|
+
setContexts(e, t) {
|
|
60
|
+
this.privateContext = e;
|
|
61
|
+
this.publicContext = t;
|
|
62
|
+
}
|
|
63
|
+
register(i, o = false) {
|
|
64
|
+
const a = debugLogger.DebugLogger.getInstance();
|
|
65
|
+
const c = o === true ? use.resolveInstanceInjectionTuple(i) : inject.resolveInjectionTuple(i);
|
|
66
|
+
if (this.has(c.identifier)) {
|
|
67
|
+
const e = `An assemblage is already registered with identifier '${c.identifier.name}'.`;
|
|
68
|
+
a.log('error', 'Duplicate registration', {
|
|
69
|
+
identifier: c.identifier.name,
|
|
70
|
+
error: e
|
|
71
|
+
});
|
|
72
|
+
throw new Error(e);
|
|
73
|
+
}
|
|
74
|
+
const f = injectable.Injectable.of(c, this.privateContext, this.publicContext);
|
|
75
|
+
a.logRegistration(f);
|
|
76
|
+
this.injectables.set(f.identifier, f);
|
|
77
|
+
if (f.concrete) {
|
|
78
|
+
hookManager.HookManager.callHook(f.concrete, 'onRegister', this.publicContext, f.configuration);
|
|
24
79
|
}
|
|
25
|
-
|
|
26
|
-
|
|
80
|
+
return f;
|
|
81
|
+
}
|
|
82
|
+
has(e) {
|
|
83
|
+
return this.injectables.has(e);
|
|
27
84
|
}
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
85
|
+
require(e, t, n) {
|
|
86
|
+
if (!this.injectables.has(e)) {
|
|
87
|
+
const r = this.resolvingStack.has(e);
|
|
88
|
+
const i = r ? 'Circular dependency detected' : 'Dependency not registered';
|
|
89
|
+
const o = formatIdentifier(e);
|
|
90
|
+
const a = c(e);
|
|
91
|
+
const f = t?.__paramIndex;
|
|
92
|
+
const u = t?.__paramCount;
|
|
93
|
+
const l = t?.__expectedType;
|
|
94
|
+
const g = r ? `Circular dependency detected: '${o}' is already being resolved.` : `Dependency '${o}' has not been registered (Class/Service not found in current assemblages).`;
|
|
95
|
+
const d = {
|
|
96
|
+
identifier: o,
|
|
97
|
+
caller: n ? formatIdentifier(n) : 'unknown',
|
|
98
|
+
type: a,
|
|
99
|
+
error: g
|
|
100
|
+
};
|
|
101
|
+
if (f !== undefined) {
|
|
102
|
+
d.paramIndex = f;
|
|
103
|
+
}
|
|
104
|
+
if (u !== undefined) {
|
|
105
|
+
d.paramCount = u;
|
|
106
|
+
}
|
|
107
|
+
if (l !== undefined) {
|
|
108
|
+
const e = l?.name || formatIdentifier(l);
|
|
109
|
+
d.expectedType = e;
|
|
110
|
+
}
|
|
111
|
+
debugLogger.DebugLogger.getInstance().log('error', i, d);
|
|
112
|
+
throw new Error(g);
|
|
113
|
+
}
|
|
114
|
+
const r = this.injectables.get(e);
|
|
115
|
+
this.resolvingStack.add(r.identifier);
|
|
116
|
+
try {
|
|
117
|
+
if (r.isSingleton) {
|
|
118
|
+
return this.singletonStrategy.resolve(r, t);
|
|
119
|
+
} else {
|
|
120
|
+
return this.transientStrategy.resolve(r, t);
|
|
121
|
+
}
|
|
122
|
+
} finally{
|
|
123
|
+
this.resolvingStack.delete(r.identifier);
|
|
124
|
+
}
|
|
31
125
|
}
|
|
32
|
-
|
|
126
|
+
concrete(e) {
|
|
127
|
+
const t = this.injectables.get(e);
|
|
128
|
+
if (t) return t.concrete;
|
|
129
|
+
return;
|
|
130
|
+
}
|
|
131
|
+
tagged(...e) {
|
|
132
|
+
const t = [];
|
|
133
|
+
for (const n of e){
|
|
134
|
+
for (const [e, r] of this.injectables){
|
|
135
|
+
if (r.tags.includes(n)) t.push(r.build());
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
return t;
|
|
139
|
+
}
|
|
140
|
+
dispose() {
|
|
141
|
+
for (const [e, t] of this.injectables){
|
|
142
|
+
t.dispose();
|
|
143
|
+
}
|
|
144
|
+
this.resolvingStack.clear();
|
|
145
|
+
}
|
|
146
|
+
get size() {
|
|
147
|
+
return this.injectables.size;
|
|
148
|
+
}
|
|
149
|
+
getRegisteredIdentifiers() {
|
|
150
|
+
return Array.from(this.injectables.keys()).map((e)=>e?.name || String(e));
|
|
151
|
+
}
|
|
152
|
+
getInjectables() {
|
|
153
|
+
return this.injectables;
|
|
154
|
+
}
|
|
155
|
+
constructor(){
|
|
156
|
+
this.injectables = new Map();
|
|
157
|
+
this.resolvingStack = new Set();
|
|
158
|
+
this.singletonStrategy = new resolutionStrategies.SingletonStrategy();
|
|
159
|
+
this.transientStrategy = new resolutionStrategies.TransientStrategy();
|
|
160
|
+
}
|
|
161
|
+
}
|
|
33
162
|
|
|
34
|
-
exports.
|
|
163
|
+
exports.InjectableManager = InjectableManager;
|
|
164
|
+
exports.formatIdentifier = formatIdentifier;
|
package/dist/index32.mjs
CHANGED
|
@@ -1,30 +1,159 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
import { HookManager } from './index34.mjs';
|
|
2
|
+
import { SingletonStrategy, TransientStrategy } from './index44.mjs';
|
|
3
|
+
import { DebugLogger } from './index37.mjs';
|
|
4
|
+
import { isClass } from '@assemblerjs/core';
|
|
5
|
+
import { resolveInstanceInjectionTuple } from './index43.mjs';
|
|
6
|
+
import { resolveInjectionTuple } from './index42.mjs';
|
|
7
|
+
import { Injectable } from './index45.mjs';
|
|
8
|
+
|
|
9
|
+
function formatIdentifier(e) {
|
|
10
|
+
if (e === undefined) return 'undefined';
|
|
11
|
+
if (e === null) return 'null';
|
|
12
|
+
if (typeof e === 'function') {
|
|
13
|
+
if (e.name) return e.name;
|
|
14
|
+
if (e.constructor?.name && e.constructor.name !== 'Function') {
|
|
15
|
+
return e.constructor.name;
|
|
16
|
+
}
|
|
17
|
+
return 'AnonymousFunction';
|
|
18
|
+
}
|
|
19
|
+
if (typeof e === 'string') return e;
|
|
20
|
+
if (typeof e === 'symbol') return e.toString();
|
|
21
|
+
if (typeof e === 'number') return String(e);
|
|
22
|
+
if (typeof e === 'boolean') return String(e);
|
|
23
|
+
if (typeof e === 'object') {
|
|
24
|
+
if (e.name && typeof e.name === 'string') {
|
|
25
|
+
return e.name;
|
|
26
|
+
}
|
|
27
|
+
const t = e.constructor?.name;
|
|
28
|
+
if (t && t !== 'Object') {
|
|
29
|
+
return t;
|
|
30
|
+
}
|
|
31
|
+
try {
|
|
32
|
+
const t = JSON.stringify(e);
|
|
33
|
+
if (t.length > 100) {
|
|
34
|
+
return t.substring(0, 100) + '...';
|
|
35
|
+
}
|
|
36
|
+
return t;
|
|
37
|
+
} catch {
|
|
38
|
+
return '[UnknownObject]';
|
|
6
39
|
}
|
|
7
|
-
const [, c, r] = e;
|
|
8
|
-
return new ExecutionPointcutMatcher(c, r);
|
|
9
40
|
}
|
|
41
|
+
return String(e);
|
|
10
42
|
}
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
const
|
|
14
|
-
|
|
15
|
-
return this.classRegex.test(e) && this.methodRegex.test(c);
|
|
43
|
+
function c(e) {
|
|
44
|
+
if (isClass(e)) {
|
|
45
|
+
const t = e.prototype && Object.getOwnPropertyNames(e.prototype).length > 1;
|
|
46
|
+
return t ? 'class' : 'class';
|
|
16
47
|
}
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
48
|
+
if (typeof e === 'function') return 'function';
|
|
49
|
+
if (typeof e === 'string') return 'string';
|
|
50
|
+
if (typeof e === 'symbol') return 'symbol';
|
|
51
|
+
if (typeof e === 'object' && e !== null) return 'object';
|
|
52
|
+
return 'unknown';
|
|
53
|
+
}
|
|
54
|
+
class InjectableManager {
|
|
55
|
+
setContexts(e, t) {
|
|
56
|
+
this.privateContext = e;
|
|
57
|
+
this.publicContext = t;
|
|
58
|
+
}
|
|
59
|
+
register(i, o = false) {
|
|
60
|
+
const a = DebugLogger.getInstance();
|
|
61
|
+
const c = o === true ? resolveInstanceInjectionTuple(i) : resolveInjectionTuple(i);
|
|
62
|
+
if (this.has(c.identifier)) {
|
|
63
|
+
const e = `An assemblage is already registered with identifier '${c.identifier.name}'.`;
|
|
64
|
+
a.log('error', 'Duplicate registration', {
|
|
65
|
+
identifier: c.identifier.name,
|
|
66
|
+
error: e
|
|
67
|
+
});
|
|
68
|
+
throw new Error(e);
|
|
69
|
+
}
|
|
70
|
+
const f = Injectable.of(c, this.privateContext, this.publicContext);
|
|
71
|
+
a.logRegistration(f);
|
|
72
|
+
this.injectables.set(f.identifier, f);
|
|
73
|
+
if (f.concrete) {
|
|
74
|
+
HookManager.callHook(f.concrete, 'onRegister', this.publicContext, f.configuration);
|
|
20
75
|
}
|
|
21
|
-
|
|
22
|
-
|
|
76
|
+
return f;
|
|
77
|
+
}
|
|
78
|
+
has(e) {
|
|
79
|
+
return this.injectables.has(e);
|
|
23
80
|
}
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
81
|
+
require(e, t, n) {
|
|
82
|
+
if (!this.injectables.has(e)) {
|
|
83
|
+
const r = this.resolvingStack.has(e);
|
|
84
|
+
const i = r ? 'Circular dependency detected' : 'Dependency not registered';
|
|
85
|
+
const o = formatIdentifier(e);
|
|
86
|
+
const a = c(e);
|
|
87
|
+
const f = t?.__paramIndex;
|
|
88
|
+
const u = t?.__paramCount;
|
|
89
|
+
const l = t?.__expectedType;
|
|
90
|
+
const g = r ? `Circular dependency detected: '${o}' is already being resolved.` : `Dependency '${o}' has not been registered (Class/Service not found in current assemblages).`;
|
|
91
|
+
const d = {
|
|
92
|
+
identifier: o,
|
|
93
|
+
caller: n ? formatIdentifier(n) : 'unknown',
|
|
94
|
+
type: a,
|
|
95
|
+
error: g
|
|
96
|
+
};
|
|
97
|
+
if (f !== undefined) {
|
|
98
|
+
d.paramIndex = f;
|
|
99
|
+
}
|
|
100
|
+
if (u !== undefined) {
|
|
101
|
+
d.paramCount = u;
|
|
102
|
+
}
|
|
103
|
+
if (l !== undefined) {
|
|
104
|
+
const e = l?.name || formatIdentifier(l);
|
|
105
|
+
d.expectedType = e;
|
|
106
|
+
}
|
|
107
|
+
DebugLogger.getInstance().log('error', i, d);
|
|
108
|
+
throw new Error(g);
|
|
109
|
+
}
|
|
110
|
+
const r = this.injectables.get(e);
|
|
111
|
+
this.resolvingStack.add(r.identifier);
|
|
112
|
+
try {
|
|
113
|
+
if (r.isSingleton) {
|
|
114
|
+
return this.singletonStrategy.resolve(r, t);
|
|
115
|
+
} else {
|
|
116
|
+
return this.transientStrategy.resolve(r, t);
|
|
117
|
+
}
|
|
118
|
+
} finally{
|
|
119
|
+
this.resolvingStack.delete(r.identifier);
|
|
120
|
+
}
|
|
27
121
|
}
|
|
28
|
-
|
|
122
|
+
concrete(e) {
|
|
123
|
+
const t = this.injectables.get(e);
|
|
124
|
+
if (t) return t.concrete;
|
|
125
|
+
return;
|
|
126
|
+
}
|
|
127
|
+
tagged(...e) {
|
|
128
|
+
const t = [];
|
|
129
|
+
for (const n of e){
|
|
130
|
+
for (const [e, r] of this.injectables){
|
|
131
|
+
if (r.tags.includes(n)) t.push(r.build());
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
return t;
|
|
135
|
+
}
|
|
136
|
+
dispose() {
|
|
137
|
+
for (const [e, t] of this.injectables){
|
|
138
|
+
t.dispose();
|
|
139
|
+
}
|
|
140
|
+
this.resolvingStack.clear();
|
|
141
|
+
}
|
|
142
|
+
get size() {
|
|
143
|
+
return this.injectables.size;
|
|
144
|
+
}
|
|
145
|
+
getRegisteredIdentifiers() {
|
|
146
|
+
return Array.from(this.injectables.keys()).map((e)=>e?.name || String(e));
|
|
147
|
+
}
|
|
148
|
+
getInjectables() {
|
|
149
|
+
return this.injectables;
|
|
150
|
+
}
|
|
151
|
+
constructor(){
|
|
152
|
+
this.injectables = new Map();
|
|
153
|
+
this.resolvingStack = new Set();
|
|
154
|
+
this.singletonStrategy = new SingletonStrategy();
|
|
155
|
+
this.transientStrategy = new TransientStrategy();
|
|
156
|
+
}
|
|
157
|
+
}
|
|
29
158
|
|
|
30
|
-
export {
|
|
159
|
+
export { InjectableManager, formatIdentifier };
|
package/dist/index33.js
CHANGED
|
@@ -2,163 +2,55 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
4
4
|
|
|
5
|
-
const
|
|
6
|
-
const resolutionStrategies = require('./index44.js');
|
|
7
|
-
const debugLogger = require('./index38.js');
|
|
8
|
-
const core = require('@assemblerjs/core');
|
|
9
|
-
const use = require('./index43.js');
|
|
10
|
-
const inject = require('./index42.js');
|
|
11
|
-
const injectable = require('./index45.js');
|
|
5
|
+
const debugLogger = require('./index37.js');
|
|
12
6
|
|
|
13
|
-
function
|
|
14
|
-
|
|
15
|
-
if (e === null) return 'null';
|
|
16
|
-
if (typeof e === 'function') {
|
|
17
|
-
if (e.name) return e.name;
|
|
18
|
-
if (e.constructor?.name && e.constructor.name !== 'Function') {
|
|
19
|
-
return e.constructor.name;
|
|
20
|
-
}
|
|
21
|
-
return 'AnonymousFunction';
|
|
22
|
-
}
|
|
23
|
-
if (typeof e === 'string') return e;
|
|
24
|
-
if (typeof e === 'symbol') return e.toString();
|
|
25
|
-
if (typeof e === 'number') return String(e);
|
|
26
|
-
if (typeof e === 'boolean') return String(e);
|
|
27
|
-
if (typeof e === 'object') {
|
|
28
|
-
if (e.name && typeof e.name === 'string') {
|
|
29
|
-
return e.name;
|
|
30
|
-
}
|
|
31
|
-
const t = e.constructor?.name;
|
|
32
|
-
if (t && t !== 'Object') {
|
|
33
|
-
return t;
|
|
34
|
-
}
|
|
35
|
-
try {
|
|
36
|
-
const t = JSON.stringify(e);
|
|
37
|
-
if (t.length > 100) {
|
|
38
|
-
return t.substring(0, 100) + '...';
|
|
39
|
-
}
|
|
40
|
-
return t;
|
|
41
|
-
} catch {
|
|
42
|
-
return '[UnknownObject]';
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
return String(e);
|
|
46
|
-
}
|
|
47
|
-
function c(e) {
|
|
48
|
-
if (core.isClass(e)) {
|
|
49
|
-
const t = e.prototype && Object.getOwnPropertyNames(e.prototype).length > 1;
|
|
50
|
-
return t ? 'class' : 'class';
|
|
51
|
-
}
|
|
52
|
-
if (typeof e === 'function') return 'function';
|
|
53
|
-
if (typeof e === 'string') return 'string';
|
|
54
|
-
if (typeof e === 'symbol') return 'symbol';
|
|
55
|
-
if (typeof e === 'object' && e !== null) return 'object';
|
|
56
|
-
return 'unknown';
|
|
7
|
+
function t(e) {
|
|
8
|
+
return typeof e === 'symbol' ? 'symbol' : 'string';
|
|
57
9
|
}
|
|
58
|
-
class
|
|
59
|
-
|
|
60
|
-
this.
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
const e = `An assemblage is already registered with identifier '${c.identifier.name}'.`;
|
|
68
|
-
a.log('error', 'Duplicate registration', {
|
|
69
|
-
identifier: c.identifier.name,
|
|
70
|
-
error: e
|
|
10
|
+
class ObjectManager {
|
|
11
|
+
use(r, o) {
|
|
12
|
+
if (this.has(r)) {
|
|
13
|
+
const o = typeof r === 'symbol' ? r.toString() : String(r);
|
|
14
|
+
const s = `Object/value '${o}' is already registered (cannot register twice).`;
|
|
15
|
+
debugLogger.DebugLogger.getInstance().log('error', 'Duplicate object/value registration', {
|
|
16
|
+
identifier: o,
|
|
17
|
+
type: t(r),
|
|
18
|
+
error: s
|
|
71
19
|
});
|
|
72
|
-
throw new Error(
|
|
73
|
-
}
|
|
74
|
-
const f = injectable.Injectable.of(c, this.privateContext, this.publicContext);
|
|
75
|
-
a.logRegistration(f);
|
|
76
|
-
this.injectables.set(f.identifier, f);
|
|
77
|
-
if (f.concrete) {
|
|
78
|
-
hookManager.HookManager.callHook(f.concrete, 'onRegister', this.publicContext, f.configuration);
|
|
20
|
+
throw new Error(s);
|
|
79
21
|
}
|
|
80
|
-
|
|
22
|
+
this.objects.set(r, o);
|
|
23
|
+
return o;
|
|
81
24
|
}
|
|
82
25
|
has(e) {
|
|
83
|
-
return this.
|
|
26
|
+
return this.objects.has(e);
|
|
84
27
|
}
|
|
85
|
-
require(
|
|
86
|
-
if (!this.
|
|
87
|
-
const
|
|
88
|
-
const
|
|
89
|
-
|
|
90
|
-
const a = c(e);
|
|
91
|
-
const f = t?.__paramIndex;
|
|
92
|
-
const u = t?.__paramCount;
|
|
93
|
-
const l = t?.__expectedType;
|
|
94
|
-
const g = r ? `Circular dependency detected: '${o}' is already being resolved.` : `Dependency '${o}' has not been registered (Class/Service not found in current assemblages).`;
|
|
95
|
-
const d = {
|
|
28
|
+
require(r) {
|
|
29
|
+
if (!this.objects.has(r)) {
|
|
30
|
+
const o = typeof r === 'symbol' ? r.toString() : String(r);
|
|
31
|
+
const s = `Object/value '${o}' has not been registered in the object store.`;
|
|
32
|
+
debugLogger.DebugLogger.getInstance().log('error', 'Object/value not found', {
|
|
96
33
|
identifier: o,
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
if (f !== undefined) {
|
|
102
|
-
d.paramIndex = f;
|
|
103
|
-
}
|
|
104
|
-
if (u !== undefined) {
|
|
105
|
-
d.paramCount = u;
|
|
106
|
-
}
|
|
107
|
-
if (l !== undefined) {
|
|
108
|
-
const e = l?.name || formatIdentifier(l);
|
|
109
|
-
d.expectedType = e;
|
|
110
|
-
}
|
|
111
|
-
debugLogger.DebugLogger.getInstance().log('error', i, d);
|
|
112
|
-
throw new Error(g);
|
|
113
|
-
}
|
|
114
|
-
const r = this.injectables.get(e);
|
|
115
|
-
this.resolvingStack.add(r.identifier);
|
|
116
|
-
try {
|
|
117
|
-
if (r.isSingleton) {
|
|
118
|
-
return this.singletonStrategy.resolve(r, t);
|
|
119
|
-
} else {
|
|
120
|
-
return this.transientStrategy.resolve(r, t);
|
|
121
|
-
}
|
|
122
|
-
} finally{
|
|
123
|
-
this.resolvingStack.delete(r.identifier);
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
concrete(e) {
|
|
127
|
-
const t = this.injectables.get(e);
|
|
128
|
-
if (t) return t.concrete;
|
|
129
|
-
return;
|
|
130
|
-
}
|
|
131
|
-
tagged(...e) {
|
|
132
|
-
const t = [];
|
|
133
|
-
for (const n of e){
|
|
134
|
-
for (const [e, r] of this.injectables){
|
|
135
|
-
if (r.tags.includes(n)) t.push(r.build());
|
|
136
|
-
}
|
|
34
|
+
type: t(r),
|
|
35
|
+
error: s
|
|
36
|
+
});
|
|
37
|
+
throw new Error(s);
|
|
137
38
|
}
|
|
138
|
-
return
|
|
39
|
+
return this.objects.get(r);
|
|
139
40
|
}
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
41
|
+
addGlobal(e, t) {
|
|
42
|
+
if (this.globals.has(e)) {
|
|
43
|
+
throw new Error(`Global value with key '${e}' has already been registered.`);
|
|
143
44
|
}
|
|
144
|
-
this.
|
|
145
|
-
}
|
|
146
|
-
get size() {
|
|
147
|
-
return this.injectables.size;
|
|
148
|
-
}
|
|
149
|
-
getRegisteredIdentifiers() {
|
|
150
|
-
return Array.from(this.injectables.keys()).map((e)=>e?.name || String(e));
|
|
45
|
+
this.globals.set(e, t);
|
|
151
46
|
}
|
|
152
|
-
|
|
153
|
-
return this.
|
|
47
|
+
global(e) {
|
|
48
|
+
return this.globals.get(e);
|
|
154
49
|
}
|
|
155
50
|
constructor(){
|
|
156
|
-
this.
|
|
157
|
-
this.
|
|
158
|
-
this.singletonStrategy = new resolutionStrategies.SingletonStrategy();
|
|
159
|
-
this.transientStrategy = new resolutionStrategies.TransientStrategy();
|
|
51
|
+
this.objects = new Map();
|
|
52
|
+
this.globals = new Map();
|
|
160
53
|
}
|
|
161
54
|
}
|
|
162
55
|
|
|
163
|
-
exports.
|
|
164
|
-
exports.formatIdentifier = formatIdentifier;
|
|
56
|
+
exports.ObjectManager = ObjectManager;
|