assemblerjs 1.1.17 → 1.1.19

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.
Files changed (58) hide show
  1. package/dist/index.d.ts +1 -0
  2. package/dist/index13.js +97 -82
  3. package/dist/index13.mjs +97 -82
  4. package/dist/index18.js +1 -1
  5. package/dist/index18.mjs +1 -1
  6. package/dist/index19.js +1 -1
  7. package/dist/index19.mjs +1 -1
  8. package/dist/index20.js +1 -1
  9. package/dist/index20.mjs +1 -1
  10. package/dist/index21.js +1 -1
  11. package/dist/index21.mjs +1 -1
  12. package/dist/index22.js +1 -1
  13. package/dist/index22.mjs +1 -1
  14. package/dist/index23.js +1 -1
  15. package/dist/index23.mjs +1 -1
  16. package/dist/index24.js +1 -1
  17. package/dist/index24.mjs +1 -1
  18. package/dist/index27.js +1 -1
  19. package/dist/index27.mjs +1 -1
  20. package/dist/index31.js +100 -35
  21. package/dist/index31.mjs +100 -34
  22. package/dist/index32.js +24 -101
  23. package/dist/index32.mjs +24 -101
  24. package/dist/index33.js +152 -22
  25. package/dist/index33.mjs +151 -22
  26. package/dist/index34.js +44 -16
  27. package/dist/index34.mjs +44 -16
  28. package/dist/index35.js +66 -145
  29. package/dist/index35.mjs +67 -145
  30. package/dist/index36.js +50 -45
  31. package/dist/index36.mjs +50 -45
  32. package/dist/index37.js +28 -76
  33. package/dist/index37.mjs +28 -76
  34. package/dist/index38.js +161 -50
  35. package/dist/index38.mjs +161 -50
  36. package/dist/index39.js +60 -28
  37. package/dist/index39.mjs +60 -28
  38. package/dist/index4.js +7 -7
  39. package/dist/index4.mjs +7 -7
  40. package/dist/index40.js +32 -158
  41. package/dist/index40.mjs +31 -158
  42. package/dist/index41.js +16 -57
  43. package/dist/index41.mjs +16 -57
  44. package/dist/index44.js +28 -941
  45. package/dist/index44.mjs +27 -941
  46. package/dist/index45.js +194 -2
  47. package/dist/index45.mjs +194 -2
  48. package/dist/index46.js +942 -2
  49. package/dist/index46.mjs +942 -2
  50. package/dist/index47.js +2 -29
  51. package/dist/index47.mjs +2 -28
  52. package/dist/index48.js +2 -194
  53. package/dist/index48.mjs +2 -194
  54. package/dist/index49.js +1 -1
  55. package/dist/index49.mjs +1 -1
  56. package/dist/index50.js +2 -2
  57. package/dist/index50.mjs +2 -2
  58. package/package.json +1 -1
package/dist/index35.js CHANGED
@@ -2,163 +2,84 @@
2
2
 
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
4
 
5
- const hookManager = require('./index37.js');
6
- const resolutionStrategies = require('./index47.js');
7
- const debugLogger = require('./index40.js');
8
5
  const core = require('@assemblerjs/core');
9
- const use = require('./index43.js');
10
- const inject = require('./index42.js');
11
- const injectable = require('./index48.js');
6
+ const debugLogger = require('./index38.js');
12
7
 
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';
8
+ class HookManager {
9
+ prepareInitHook(o, t) {
10
+ this.initCache.push({
11
+ instance: o,
12
+ configuration: t
13
+ });
14
+ return this.initCache;
22
15
  }
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]';
16
+ callInitHooks(o) {
17
+ for (const t of this.initCache){
18
+ HookManager.callHookImmediate(t.instance, 'onInit', o, t.configuration);
43
19
  }
44
20
  }
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';
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);
21
+ callInitedHooks(o) {
22
+ for (const t of [
23
+ ...this.initCache
24
+ ].reverse()){
25
+ HookManager.callHookImmediate(t.instance, 'onInited', o, t.configuration);
79
26
  }
80
- return f;
81
27
  }
82
- has(e) {
83
- return this.injectables.has(e);
28
+ clearCache() {
29
+ this.initCache.length = 0;
84
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
+ getCache() {
32
+ return this.initCache;
125
33
  }
126
- concrete(e) {
127
- const t = this.injectables.get(e);
128
- if (t) return t.concrete;
129
- return;
34
+ constructor(){
35
+ this.initCache = [];
130
36
  }
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());
37
+ }
38
+ HookManager.callHook = (e, i, n, a)=>{
39
+ const c = debugLogger.DebugLogger.getInstance();
40
+ const r = c.logHook(i, e, a);
41
+ return new Promise((t, c)=>{
42
+ const s = e[i];
43
+ if (s) {
44
+ if (core.isAsync(s)) {
45
+ s.bind(e)(n, a).then(()=>{
46
+ if (r) r();
47
+ t();
48
+ }).catch((o)=>{
49
+ if (r) r();
50
+ c(o);
51
+ });
52
+ return;
53
+ }
54
+ try {
55
+ s.bind(e)(n, a);
56
+ if (r) r();
57
+ t();
58
+ } catch (o) {
59
+ if (r) r();
60
+ c(o);
136
61
  }
62
+ } else {
63
+ if (r) r();
64
+ t();
137
65
  }
138
- return t;
139
- }
140
- dispose() {
141
- for (const [e, t] of this.injectables){
142
- t.dispose();
66
+ });
67
+ };
68
+ HookManager.callHookImmediate = (e, i, n, a)=>{
69
+ const c = debugLogger.DebugLogger.getInstance();
70
+ const r = c.logHook(i, e, a);
71
+ const s = e[i];
72
+ if (s) {
73
+ if (core.isAsync(s)) {
74
+ s.bind(e)(n, a).catch(()=>{});
75
+ if (r) r();
76
+ return;
143
77
  }
144
- this.resolvingStack.clear();
78
+ s.bind(e)(n, a);
79
+ if (r) r();
80
+ } else {
81
+ if (r) r();
145
82
  }
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
- }
83
+ };
162
84
 
163
- exports.InjectableManager = InjectableManager;
164
- exports.formatIdentifier = formatIdentifier;
85
+ exports.HookManager = HookManager;
package/dist/index35.mjs CHANGED
@@ -1,159 +1,81 @@
1
- import { HookManager } from './index37.mjs';
2
- import { SingletonStrategy, TransientStrategy } from './index47.mjs';
3
- import { DebugLogger } from './index40.mjs';
4
- import { isClass } from '@assemblerjs/core';
5
- import { resolveInstanceInjectionTuple } from './index43.mjs';
6
- import { resolveInjectionTuple } from './index42.mjs';
7
- import { Injectable } from './index48.mjs';
1
+ import { isAsync } from '@assemblerjs/core';
2
+ import { DebugLogger } from './index38.mjs';
8
3
 
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';
4
+ class HookManager {
5
+ prepareInitHook(o, t) {
6
+ this.initCache.push({
7
+ instance: o,
8
+ configuration: t
9
+ });
10
+ return this.initCache;
18
11
  }
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]';
12
+ callInitHooks(o) {
13
+ for (const t of this.initCache){
14
+ HookManager.callHookImmediate(t.instance, 'onInit', o, t.configuration);
39
15
  }
40
16
  }
41
- return String(e);
42
- }
43
- function c(e) {
44
- if (isClass(e)) {
45
- const t = e.prototype && Object.getOwnPropertyNames(e.prototype).length > 1;
46
- return t ? 'class' : 'class';
47
- }
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);
17
+ callInitedHooks(o) {
18
+ for (const t of [
19
+ ...this.initCache
20
+ ].reverse()){
21
+ HookManager.callHookImmediate(t.instance, 'onInited', o, t.configuration);
75
22
  }
76
- return f;
77
23
  }
78
- has(e) {
79
- return this.injectables.has(e);
24
+ clearCache() {
25
+ this.initCache.length = 0;
80
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
+ getCache() {
28
+ return this.initCache;
121
29
  }
122
- concrete(e) {
123
- const t = this.injectables.get(e);
124
- if (t) return t.concrete;
125
- return;
30
+ constructor(){
31
+ this.initCache = [];
126
32
  }
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());
33
+ }
34
+ HookManager.callHook = (e, i, n, a)=>{
35
+ const c = DebugLogger.getInstance();
36
+ const r = c.logHook(i, e, a);
37
+ return new Promise((t, c)=>{
38
+ const s = e[i];
39
+ if (s) {
40
+ if (isAsync(s)) {
41
+ s.bind(e)(n, a).then(()=>{
42
+ if (r) r();
43
+ t();
44
+ }).catch((o)=>{
45
+ if (r) r();
46
+ c(o);
47
+ });
48
+ return;
49
+ }
50
+ try {
51
+ s.bind(e)(n, a);
52
+ if (r) r();
53
+ t();
54
+ } catch (o) {
55
+ if (r) r();
56
+ c(o);
132
57
  }
58
+ } else {
59
+ if (r) r();
60
+ t();
133
61
  }
134
- return t;
135
- }
136
- dispose() {
137
- for (const [e, t] of this.injectables){
138
- t.dispose();
62
+ });
63
+ };
64
+ HookManager.callHookImmediate = (e, i, n, a)=>{
65
+ const c = DebugLogger.getInstance();
66
+ const r = c.logHook(i, e, a);
67
+ const s = e[i];
68
+ if (s) {
69
+ if (isAsync(s)) {
70
+ s.bind(e)(n, a).catch(()=>{});
71
+ if (r) r();
72
+ return;
139
73
  }
140
- this.resolvingStack.clear();
74
+ s.bind(e)(n, a);
75
+ if (r) r();
76
+ } else {
77
+ if (r) r();
141
78
  }
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
- }
79
+ };
158
80
 
159
- export { InjectableManager, formatIdentifier };
81
+ export { HookManager };
package/dist/index36.js CHANGED
@@ -2,55 +2,60 @@
2
2
 
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
4
 
5
- const debugLogger = require('./index40.js');
5
+ const hookManager = require('./index35.js');
6
+ const debugLogger = require('./index38.js');
7
+ const cycleDetector = require('./index39.js');
8
+ const injectableManager = require('./index33.js');
9
+ const schema = require('./index30.js');
6
10
 
7
- function t(e) {
8
- return typeof e === 'symbol' ? 'symbol' : 'string';
9
- }
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
19
- });
20
- throw new Error(s);
21
- }
22
- this.objects.set(r, o);
23
- return o;
24
- }
25
- has(e) {
26
- return this.objects.has(e);
27
- }
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', {
33
- identifier: o,
34
- type: t(r),
35
- error: s
36
- });
37
- throw new Error(s);
11
+ class AssemblerBuilder {
12
+ build(n, r) {
13
+ const i = debugLogger.DebugLogger.getInstance();
14
+ schema.setDefinitionValue('singleton', true, n);
15
+ i.logPhaseStart('registration');
16
+ const l = this.assembler.register([
17
+ n
18
+ ]);
19
+ const c = this.assembler.injectableManager.getRegisteredIdentifiers();
20
+ i.logPhaseEnd('registration', undefined, {
21
+ registered: c
22
+ });
23
+ const h = cycleDetector.CycleDetector.getInstance().detect(this.assembler.injectableManager.getInjectables(), (e)=>injectableManager.formatIdentifier(e));
24
+ if (h.length > 0) {
25
+ for (const e of h){
26
+ i.log('error', 'Circular dependency detected', {
27
+ cycle: e.cycle,
28
+ path: e.path
29
+ });
30
+ }
38
31
  }
39
- return this.objects.get(r);
40
- }
41
- addGlobal(e, t) {
42
- if (this.globals.has(e)) {
43
- throw new Error(`Global value with key '${e}' has already been registered.`);
32
+ i.logPhaseStart('resolution');
33
+ const g = this.assembler.require(l.identifier, r);
34
+ i.logPhaseEnd('resolution');
35
+ const m = this.assembler.hookManager.getCache().find((e)=>e.instance === g);
36
+ if (!m) {
37
+ throw new Error('Root instance not found in assemblages cache.');
44
38
  }
45
- this.globals.set(e, t);
46
- }
47
- global(e) {
48
- return this.globals.get(e);
39
+ const b = this.assembler.hookManager.getCache().indexOf(m);
40
+ this.assembler.hookManager.getCache().splice(b, 1);
41
+ i.logPhaseStart('hooks:onInit');
42
+ this.assembler.hookManager.callInitHooks(this.assembler.publicContext);
43
+ const d = r ? {
44
+ ...l.configuration,
45
+ ...r
46
+ } : l.configuration;
47
+ hookManager.HookManager.callHookImmediate(g, 'onInit', this.assembler.publicContext, d);
48
+ i.logPhaseEnd('hooks:onInit');
49
+ i.logPhaseStart('hooks:onInited');
50
+ this.assembler.hookManager.callInitedHooks(this.assembler.publicContext);
51
+ hookManager.HookManager.callHookImmediate(g, 'onInited', this.assembler.publicContext, d);
52
+ i.logPhaseEnd('hooks:onInited');
53
+ this.assembler.hookManager.clearCache();
54
+ return g;
49
55
  }
50
- constructor(){
51
- this.objects = new Map();
52
- this.globals = new Map();
56
+ constructor(e){
57
+ this.assembler = e;
53
58
  }
54
59
  }
55
60
 
56
- exports.ObjectManager = ObjectManager;
61
+ exports.AssemblerBuilder = AssemblerBuilder;
package/dist/index36.mjs CHANGED
@@ -1,52 +1,57 @@
1
- import { DebugLogger } from './index40.mjs';
1
+ import { HookManager } from './index35.mjs';
2
+ import { DebugLogger } from './index38.mjs';
3
+ import { CycleDetector } from './index39.mjs';
4
+ import { formatIdentifier } from './index33.mjs';
5
+ import { setDefinitionValue } from './index30.mjs';
2
6
 
3
- function t(e) {
4
- return typeof e === 'symbol' ? 'symbol' : 'string';
5
- }
6
- class ObjectManager {
7
- use(r, o) {
8
- if (this.has(r)) {
9
- const o = typeof r === 'symbol' ? r.toString() : String(r);
10
- const s = `Object/value '${o}' is already registered (cannot register twice).`;
11
- DebugLogger.getInstance().log('error', 'Duplicate object/value registration', {
12
- identifier: o,
13
- type: t(r),
14
- error: s
15
- });
16
- throw new Error(s);
17
- }
18
- this.objects.set(r, o);
19
- return o;
20
- }
21
- has(e) {
22
- return this.objects.has(e);
23
- }
24
- require(r) {
25
- if (!this.objects.has(r)) {
26
- const o = typeof r === 'symbol' ? r.toString() : String(r);
27
- const s = `Object/value '${o}' has not been registered in the object store.`;
28
- DebugLogger.getInstance().log('error', 'Object/value not found', {
29
- identifier: o,
30
- type: t(r),
31
- error: s
32
- });
33
- throw new Error(s);
7
+ class AssemblerBuilder {
8
+ build(n, r) {
9
+ const i = DebugLogger.getInstance();
10
+ setDefinitionValue('singleton', true, n);
11
+ i.logPhaseStart('registration');
12
+ const l = this.assembler.register([
13
+ n
14
+ ]);
15
+ const c = this.assembler.injectableManager.getRegisteredIdentifiers();
16
+ i.logPhaseEnd('registration', undefined, {
17
+ registered: c
18
+ });
19
+ const h = CycleDetector.getInstance().detect(this.assembler.injectableManager.getInjectables(), (e)=>formatIdentifier(e));
20
+ if (h.length > 0) {
21
+ for (const e of h){
22
+ i.log('error', 'Circular dependency detected', {
23
+ cycle: e.cycle,
24
+ path: e.path
25
+ });
26
+ }
34
27
  }
35
- return this.objects.get(r);
36
- }
37
- addGlobal(e, t) {
38
- if (this.globals.has(e)) {
39
- throw new Error(`Global value with key '${e}' has already been registered.`);
28
+ i.logPhaseStart('resolution');
29
+ const g = this.assembler.require(l.identifier, r);
30
+ i.logPhaseEnd('resolution');
31
+ const m = this.assembler.hookManager.getCache().find((e)=>e.instance === g);
32
+ if (!m) {
33
+ throw new Error('Root instance not found in assemblages cache.');
40
34
  }
41
- this.globals.set(e, t);
42
- }
43
- global(e) {
44
- return this.globals.get(e);
35
+ const b = this.assembler.hookManager.getCache().indexOf(m);
36
+ this.assembler.hookManager.getCache().splice(b, 1);
37
+ i.logPhaseStart('hooks:onInit');
38
+ this.assembler.hookManager.callInitHooks(this.assembler.publicContext);
39
+ const d = r ? {
40
+ ...l.configuration,
41
+ ...r
42
+ } : l.configuration;
43
+ HookManager.callHookImmediate(g, 'onInit', this.assembler.publicContext, d);
44
+ i.logPhaseEnd('hooks:onInit');
45
+ i.logPhaseStart('hooks:onInited');
46
+ this.assembler.hookManager.callInitedHooks(this.assembler.publicContext);
47
+ HookManager.callHookImmediate(g, 'onInited', this.assembler.publicContext, d);
48
+ i.logPhaseEnd('hooks:onInited');
49
+ this.assembler.hookManager.clearCache();
50
+ return g;
45
51
  }
46
- constructor(){
47
- this.objects = new Map();
48
- this.globals = new Map();
52
+ constructor(e){
53
+ this.assembler = e;
49
54
  }
50
55
  }
51
56
 
52
- export { ObjectManager };
57
+ export { AssemblerBuilder };