@directive-run/core 0.1.1
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/LICENSE +21 -0
- package/README.md +57 -0
- package/dist/adapter-utils.cjs +2 -0
- package/dist/adapter-utils.cjs.map +1 -0
- package/dist/adapter-utils.d.cts +230 -0
- package/dist/adapter-utils.d.ts +230 -0
- package/dist/adapter-utils.js +2 -0
- package/dist/adapter-utils.js.map +1 -0
- package/dist/index.cjs +35 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +2016 -0
- package/dist/index.d.ts +2016 -0
- package/dist/index.js +35 -0
- package/dist/index.js.map +1 -0
- package/dist/migration.cjs +25 -0
- package/dist/migration.cjs.map +1 -0
- package/dist/migration.d.cts +109 -0
- package/dist/migration.d.ts +109 -0
- package/dist/migration.js +25 -0
- package/dist/migration.js.map +1 -0
- package/dist/plugins/index.cjs +3 -0
- package/dist/plugins/index.cjs.map +1 -0
- package/dist/plugins/index.d.cts +697 -0
- package/dist/plugins/index.d.ts +697 -0
- package/dist/plugins/index.js +3 -0
- package/dist/plugins/index.js.map +1 -0
- package/dist/plugins-CcwEXXMS.d.cts +1876 -0
- package/dist/plugins-CcwEXXMS.d.ts +1876 -0
- package/dist/testing.cjs +12 -0
- package/dist/testing.cjs.map +1 -0
- package/dist/testing.d.cts +235 -0
- package/dist/testing.d.ts +235 -0
- package/dist/testing.js +12 -0
- package/dist/testing.js.map +1 -0
- package/dist/utils-4JrY5fk9.d.cts +198 -0
- package/dist/utils-4JrY5fk9.d.ts +198 -0
- package/dist/worker.cjs +12 -0
- package/dist/worker.cjs.map +1 -0
- package/dist/worker.d.cts +241 -0
- package/dist/worker.d.ts +241 -0
- package/dist/worker.js +12 -0
- package/dist/worker.js.map +1 -0
- package/package.json +85 -0
|
@@ -0,0 +1,241 @@
|
|
|
1
|
+
import { M as ModuleSchema, ac as DistributableSnapshotOptions, ab as DistributableSnapshot, aE as SystemInspection, R as Requirement } from './plugins-CcwEXXMS.cjs';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Web Worker Adapter - Run Directive engine off the main thread
|
|
5
|
+
*
|
|
6
|
+
* Features:
|
|
7
|
+
* - Run computations in a dedicated worker
|
|
8
|
+
* - Synchronized state between main thread and worker
|
|
9
|
+
* - Automatic serialization of facts and derivations
|
|
10
|
+
* - Event-based communication
|
|
11
|
+
*/
|
|
12
|
+
|
|
13
|
+
/** Messages sent from main thread to worker */
|
|
14
|
+
type WorkerInboundMessage = {
|
|
15
|
+
type: "INIT";
|
|
16
|
+
config: WorkerSystemConfig;
|
|
17
|
+
} | {
|
|
18
|
+
type: "START";
|
|
19
|
+
} | {
|
|
20
|
+
type: "STOP";
|
|
21
|
+
} | {
|
|
22
|
+
type: "DESTROY";
|
|
23
|
+
} | {
|
|
24
|
+
type: "SET_FACT";
|
|
25
|
+
key: string;
|
|
26
|
+
value: unknown;
|
|
27
|
+
} | {
|
|
28
|
+
type: "SET_FACTS";
|
|
29
|
+
facts: Record<string, unknown>;
|
|
30
|
+
} | {
|
|
31
|
+
type: "DISPATCH";
|
|
32
|
+
event: {
|
|
33
|
+
type: string;
|
|
34
|
+
[key: string]: unknown;
|
|
35
|
+
};
|
|
36
|
+
} | {
|
|
37
|
+
type: "GET_SNAPSHOT";
|
|
38
|
+
options?: DistributableSnapshotOptions;
|
|
39
|
+
requestId: string;
|
|
40
|
+
} | {
|
|
41
|
+
type: "INSPECT";
|
|
42
|
+
requestId: string;
|
|
43
|
+
} | {
|
|
44
|
+
type: "SETTLE";
|
|
45
|
+
timeout?: number;
|
|
46
|
+
requestId: string;
|
|
47
|
+
};
|
|
48
|
+
/** Messages sent from worker to main thread */
|
|
49
|
+
type WorkerOutboundMessage = {
|
|
50
|
+
type: "READY";
|
|
51
|
+
} | {
|
|
52
|
+
type: "STARTED";
|
|
53
|
+
} | {
|
|
54
|
+
type: "STOPPED";
|
|
55
|
+
} | {
|
|
56
|
+
type: "DESTROYED";
|
|
57
|
+
} | {
|
|
58
|
+
type: "FACT_CHANGED";
|
|
59
|
+
key: string;
|
|
60
|
+
value: unknown;
|
|
61
|
+
prev: unknown;
|
|
62
|
+
} | {
|
|
63
|
+
type: "DERIVATION_CHANGED";
|
|
64
|
+
key: string;
|
|
65
|
+
value: unknown;
|
|
66
|
+
} | {
|
|
67
|
+
type: "REQUIREMENT_CREATED";
|
|
68
|
+
requirement: Requirement & {
|
|
69
|
+
id: string;
|
|
70
|
+
};
|
|
71
|
+
} | {
|
|
72
|
+
type: "REQUIREMENT_MET";
|
|
73
|
+
requirementId: string;
|
|
74
|
+
resolverId: string;
|
|
75
|
+
} | {
|
|
76
|
+
type: "ERROR";
|
|
77
|
+
error: string;
|
|
78
|
+
source?: string;
|
|
79
|
+
} | {
|
|
80
|
+
type: "SNAPSHOT_RESULT";
|
|
81
|
+
requestId: string;
|
|
82
|
+
snapshot: DistributableSnapshot;
|
|
83
|
+
} | {
|
|
84
|
+
type: "INSPECT_RESULT";
|
|
85
|
+
requestId: string;
|
|
86
|
+
inspection: SystemInspection;
|
|
87
|
+
} | {
|
|
88
|
+
type: "SETTLE_RESULT";
|
|
89
|
+
requestId: string;
|
|
90
|
+
success: boolean;
|
|
91
|
+
error?: string;
|
|
92
|
+
};
|
|
93
|
+
/**
|
|
94
|
+
* Configuration for creating a system inside a worker.
|
|
95
|
+
* Note: Functions cannot be serialized, so modules must be defined
|
|
96
|
+
* in the worker script itself using createWorkerModule.
|
|
97
|
+
*/
|
|
98
|
+
interface WorkerSystemConfig {
|
|
99
|
+
/** Module names to initialize (modules must be registered in worker) */
|
|
100
|
+
moduleNames: string[];
|
|
101
|
+
/** Debug configuration */
|
|
102
|
+
debug?: {
|
|
103
|
+
timeTravel?: boolean;
|
|
104
|
+
maxSnapshots?: number;
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
/**
|
|
108
|
+
* Options for creating a worker client.
|
|
109
|
+
*/
|
|
110
|
+
interface WorkerClientOptions {
|
|
111
|
+
/** The web worker instance */
|
|
112
|
+
worker: Worker;
|
|
113
|
+
/** Callback when a fact changes in the worker */
|
|
114
|
+
onFactChange?: (key: string, value: unknown, prev: unknown) => void;
|
|
115
|
+
/** Callback when a derivation changes in the worker */
|
|
116
|
+
onDerivationChange?: (key: string, value: unknown) => void;
|
|
117
|
+
/** Callback when a requirement is created */
|
|
118
|
+
onRequirementCreated?: (requirement: Requirement & {
|
|
119
|
+
id: string;
|
|
120
|
+
}) => void;
|
|
121
|
+
/** Callback when a requirement is met */
|
|
122
|
+
onRequirementMet?: (requirementId: string, resolverId: string) => void;
|
|
123
|
+
/** Callback when an error occurs */
|
|
124
|
+
onError?: (error: string, source?: string) => void;
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Client for interacting with a Directive system running in a Web Worker.
|
|
128
|
+
*/
|
|
129
|
+
interface WorkerClient {
|
|
130
|
+
/** Initialize the worker system */
|
|
131
|
+
init(config: WorkerSystemConfig): Promise<void>;
|
|
132
|
+
/** Start the worker system */
|
|
133
|
+
start(): Promise<void>;
|
|
134
|
+
/** Stop the worker system */
|
|
135
|
+
stop(): Promise<void>;
|
|
136
|
+
/** Destroy the worker system and terminate the worker */
|
|
137
|
+
destroy(): Promise<void>;
|
|
138
|
+
/** Set a single fact */
|
|
139
|
+
setFact(key: string, value: unknown): void;
|
|
140
|
+
/** Set multiple facts at once */
|
|
141
|
+
setFacts(facts: Record<string, unknown>): void;
|
|
142
|
+
/** Dispatch an event */
|
|
143
|
+
dispatch(event: {
|
|
144
|
+
type: string;
|
|
145
|
+
[key: string]: unknown;
|
|
146
|
+
}): void;
|
|
147
|
+
/** Get a distributable snapshot */
|
|
148
|
+
getSnapshot(options?: DistributableSnapshotOptions): Promise<DistributableSnapshot>;
|
|
149
|
+
/** Inspect the system state */
|
|
150
|
+
inspect(): Promise<SystemInspection>;
|
|
151
|
+
/** Wait for the system to settle */
|
|
152
|
+
settle(timeout?: number): Promise<void>;
|
|
153
|
+
/** Terminate the worker */
|
|
154
|
+
terminate(): void;
|
|
155
|
+
}
|
|
156
|
+
/**
|
|
157
|
+
* Create a client for communicating with a Directive worker.
|
|
158
|
+
*
|
|
159
|
+
* @example
|
|
160
|
+
* ```typescript
|
|
161
|
+
* // main.ts
|
|
162
|
+
* const worker = new Worker(new URL('./directive.worker.ts', import.meta.url));
|
|
163
|
+
* const client = createWorkerClient({
|
|
164
|
+
* worker,
|
|
165
|
+
* onFactChange: (key, value) => console.log(`Fact ${key} = ${value}`),
|
|
166
|
+
* });
|
|
167
|
+
*
|
|
168
|
+
* await client.init({ moduleNames: ['myModule'] });
|
|
169
|
+
* await client.start();
|
|
170
|
+
* client.setFact('userId', '123');
|
|
171
|
+
* ```
|
|
172
|
+
*/
|
|
173
|
+
declare function createWorkerClient(options: WorkerClientOptions): WorkerClient;
|
|
174
|
+
/**
|
|
175
|
+
* Module registration for worker-side systems.
|
|
176
|
+
* Since functions can't be serialized, modules must be registered in the worker.
|
|
177
|
+
*/
|
|
178
|
+
type ModuleRegistry = Map<string, any>;
|
|
179
|
+
/**
|
|
180
|
+
* Get or create the module registry for worker-side modules.
|
|
181
|
+
*/
|
|
182
|
+
declare function getWorkerModuleRegistry(): ModuleRegistry;
|
|
183
|
+
/**
|
|
184
|
+
* Register a module for use in workers.
|
|
185
|
+
* Call this in your worker script before handling INIT messages.
|
|
186
|
+
*
|
|
187
|
+
* @example
|
|
188
|
+
* ```typescript
|
|
189
|
+
* // directive.worker.ts
|
|
190
|
+
* import { registerWorkerModule, handleWorkerMessages } from '@directive-run/core/worker';
|
|
191
|
+
* import { myModule } from './modules/my-module';
|
|
192
|
+
*
|
|
193
|
+
* registerWorkerModule('myModule', myModule);
|
|
194
|
+
* handleWorkerMessages();
|
|
195
|
+
* ```
|
|
196
|
+
*/
|
|
197
|
+
declare function registerWorkerModule(name: string, module: any): void;
|
|
198
|
+
/**
|
|
199
|
+
* Handler for worker-side message processing.
|
|
200
|
+
* Sets up the message listener and creates/manages the Directive system.
|
|
201
|
+
*
|
|
202
|
+
* @example
|
|
203
|
+
* ```typescript
|
|
204
|
+
* // directive.worker.ts
|
|
205
|
+
* import { registerWorkerModule, handleWorkerMessages } from '@directive-run/core/worker';
|
|
206
|
+
*
|
|
207
|
+
* registerWorkerModule('myModule', myModule);
|
|
208
|
+
* handleWorkerMessages();
|
|
209
|
+
* ```
|
|
210
|
+
*/
|
|
211
|
+
declare function handleWorkerMessages(): void;
|
|
212
|
+
/**
|
|
213
|
+
* Type helper for creating type-safe worker clients.
|
|
214
|
+
* Use this to get proper typing for facts and events.
|
|
215
|
+
*
|
|
216
|
+
* @example
|
|
217
|
+
* ```typescript
|
|
218
|
+
* type MyWorkerClient = TypedWorkerClient<typeof myModuleSchema>;
|
|
219
|
+
* const client = createWorkerClient(options) as MyWorkerClient;
|
|
220
|
+
* client.setFact('userId', '123'); // Type-checked!
|
|
221
|
+
* ```
|
|
222
|
+
*/
|
|
223
|
+
type TypedWorkerClient<M extends ModuleSchema> = Omit<WorkerClient, "setFact" | "setFacts" | "dispatch"> & {
|
|
224
|
+
setFact<K extends keyof M["facts"]>(key: K, value: M["facts"][K] extends {
|
|
225
|
+
_type: infer T;
|
|
226
|
+
} ? T : M["facts"][K]): void;
|
|
227
|
+
setFacts(facts: Partial<{
|
|
228
|
+
[K in keyof M["facts"]]: M["facts"][K] extends {
|
|
229
|
+
_type: infer T;
|
|
230
|
+
} ? T : M["facts"][K];
|
|
231
|
+
}>): void;
|
|
232
|
+
dispatch(event: M["events"] extends Record<string, unknown> ? {
|
|
233
|
+
[K in keyof M["events"]]: {
|
|
234
|
+
type: K;
|
|
235
|
+
} & M["events"][K];
|
|
236
|
+
}[keyof M["events"]] : {
|
|
237
|
+
type: string;
|
|
238
|
+
}): void;
|
|
239
|
+
};
|
|
240
|
+
|
|
241
|
+
export { type TypedWorkerClient, type WorkerClient, type WorkerClientOptions, type WorkerInboundMessage, type WorkerOutboundMessage, type WorkerSystemConfig, createWorkerClient, getWorkerModuleRegistry, handleWorkerMessages, registerWorkerModule };
|
package/dist/worker.d.ts
ADDED
|
@@ -0,0 +1,241 @@
|
|
|
1
|
+
import { M as ModuleSchema, ac as DistributableSnapshotOptions, ab as DistributableSnapshot, aE as SystemInspection, R as Requirement } from './plugins-CcwEXXMS.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Web Worker Adapter - Run Directive engine off the main thread
|
|
5
|
+
*
|
|
6
|
+
* Features:
|
|
7
|
+
* - Run computations in a dedicated worker
|
|
8
|
+
* - Synchronized state between main thread and worker
|
|
9
|
+
* - Automatic serialization of facts and derivations
|
|
10
|
+
* - Event-based communication
|
|
11
|
+
*/
|
|
12
|
+
|
|
13
|
+
/** Messages sent from main thread to worker */
|
|
14
|
+
type WorkerInboundMessage = {
|
|
15
|
+
type: "INIT";
|
|
16
|
+
config: WorkerSystemConfig;
|
|
17
|
+
} | {
|
|
18
|
+
type: "START";
|
|
19
|
+
} | {
|
|
20
|
+
type: "STOP";
|
|
21
|
+
} | {
|
|
22
|
+
type: "DESTROY";
|
|
23
|
+
} | {
|
|
24
|
+
type: "SET_FACT";
|
|
25
|
+
key: string;
|
|
26
|
+
value: unknown;
|
|
27
|
+
} | {
|
|
28
|
+
type: "SET_FACTS";
|
|
29
|
+
facts: Record<string, unknown>;
|
|
30
|
+
} | {
|
|
31
|
+
type: "DISPATCH";
|
|
32
|
+
event: {
|
|
33
|
+
type: string;
|
|
34
|
+
[key: string]: unknown;
|
|
35
|
+
};
|
|
36
|
+
} | {
|
|
37
|
+
type: "GET_SNAPSHOT";
|
|
38
|
+
options?: DistributableSnapshotOptions;
|
|
39
|
+
requestId: string;
|
|
40
|
+
} | {
|
|
41
|
+
type: "INSPECT";
|
|
42
|
+
requestId: string;
|
|
43
|
+
} | {
|
|
44
|
+
type: "SETTLE";
|
|
45
|
+
timeout?: number;
|
|
46
|
+
requestId: string;
|
|
47
|
+
};
|
|
48
|
+
/** Messages sent from worker to main thread */
|
|
49
|
+
type WorkerOutboundMessage = {
|
|
50
|
+
type: "READY";
|
|
51
|
+
} | {
|
|
52
|
+
type: "STARTED";
|
|
53
|
+
} | {
|
|
54
|
+
type: "STOPPED";
|
|
55
|
+
} | {
|
|
56
|
+
type: "DESTROYED";
|
|
57
|
+
} | {
|
|
58
|
+
type: "FACT_CHANGED";
|
|
59
|
+
key: string;
|
|
60
|
+
value: unknown;
|
|
61
|
+
prev: unknown;
|
|
62
|
+
} | {
|
|
63
|
+
type: "DERIVATION_CHANGED";
|
|
64
|
+
key: string;
|
|
65
|
+
value: unknown;
|
|
66
|
+
} | {
|
|
67
|
+
type: "REQUIREMENT_CREATED";
|
|
68
|
+
requirement: Requirement & {
|
|
69
|
+
id: string;
|
|
70
|
+
};
|
|
71
|
+
} | {
|
|
72
|
+
type: "REQUIREMENT_MET";
|
|
73
|
+
requirementId: string;
|
|
74
|
+
resolverId: string;
|
|
75
|
+
} | {
|
|
76
|
+
type: "ERROR";
|
|
77
|
+
error: string;
|
|
78
|
+
source?: string;
|
|
79
|
+
} | {
|
|
80
|
+
type: "SNAPSHOT_RESULT";
|
|
81
|
+
requestId: string;
|
|
82
|
+
snapshot: DistributableSnapshot;
|
|
83
|
+
} | {
|
|
84
|
+
type: "INSPECT_RESULT";
|
|
85
|
+
requestId: string;
|
|
86
|
+
inspection: SystemInspection;
|
|
87
|
+
} | {
|
|
88
|
+
type: "SETTLE_RESULT";
|
|
89
|
+
requestId: string;
|
|
90
|
+
success: boolean;
|
|
91
|
+
error?: string;
|
|
92
|
+
};
|
|
93
|
+
/**
|
|
94
|
+
* Configuration for creating a system inside a worker.
|
|
95
|
+
* Note: Functions cannot be serialized, so modules must be defined
|
|
96
|
+
* in the worker script itself using createWorkerModule.
|
|
97
|
+
*/
|
|
98
|
+
interface WorkerSystemConfig {
|
|
99
|
+
/** Module names to initialize (modules must be registered in worker) */
|
|
100
|
+
moduleNames: string[];
|
|
101
|
+
/** Debug configuration */
|
|
102
|
+
debug?: {
|
|
103
|
+
timeTravel?: boolean;
|
|
104
|
+
maxSnapshots?: number;
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
/**
|
|
108
|
+
* Options for creating a worker client.
|
|
109
|
+
*/
|
|
110
|
+
interface WorkerClientOptions {
|
|
111
|
+
/** The web worker instance */
|
|
112
|
+
worker: Worker;
|
|
113
|
+
/** Callback when a fact changes in the worker */
|
|
114
|
+
onFactChange?: (key: string, value: unknown, prev: unknown) => void;
|
|
115
|
+
/** Callback when a derivation changes in the worker */
|
|
116
|
+
onDerivationChange?: (key: string, value: unknown) => void;
|
|
117
|
+
/** Callback when a requirement is created */
|
|
118
|
+
onRequirementCreated?: (requirement: Requirement & {
|
|
119
|
+
id: string;
|
|
120
|
+
}) => void;
|
|
121
|
+
/** Callback when a requirement is met */
|
|
122
|
+
onRequirementMet?: (requirementId: string, resolverId: string) => void;
|
|
123
|
+
/** Callback when an error occurs */
|
|
124
|
+
onError?: (error: string, source?: string) => void;
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Client for interacting with a Directive system running in a Web Worker.
|
|
128
|
+
*/
|
|
129
|
+
interface WorkerClient {
|
|
130
|
+
/** Initialize the worker system */
|
|
131
|
+
init(config: WorkerSystemConfig): Promise<void>;
|
|
132
|
+
/** Start the worker system */
|
|
133
|
+
start(): Promise<void>;
|
|
134
|
+
/** Stop the worker system */
|
|
135
|
+
stop(): Promise<void>;
|
|
136
|
+
/** Destroy the worker system and terminate the worker */
|
|
137
|
+
destroy(): Promise<void>;
|
|
138
|
+
/** Set a single fact */
|
|
139
|
+
setFact(key: string, value: unknown): void;
|
|
140
|
+
/** Set multiple facts at once */
|
|
141
|
+
setFacts(facts: Record<string, unknown>): void;
|
|
142
|
+
/** Dispatch an event */
|
|
143
|
+
dispatch(event: {
|
|
144
|
+
type: string;
|
|
145
|
+
[key: string]: unknown;
|
|
146
|
+
}): void;
|
|
147
|
+
/** Get a distributable snapshot */
|
|
148
|
+
getSnapshot(options?: DistributableSnapshotOptions): Promise<DistributableSnapshot>;
|
|
149
|
+
/** Inspect the system state */
|
|
150
|
+
inspect(): Promise<SystemInspection>;
|
|
151
|
+
/** Wait for the system to settle */
|
|
152
|
+
settle(timeout?: number): Promise<void>;
|
|
153
|
+
/** Terminate the worker */
|
|
154
|
+
terminate(): void;
|
|
155
|
+
}
|
|
156
|
+
/**
|
|
157
|
+
* Create a client for communicating with a Directive worker.
|
|
158
|
+
*
|
|
159
|
+
* @example
|
|
160
|
+
* ```typescript
|
|
161
|
+
* // main.ts
|
|
162
|
+
* const worker = new Worker(new URL('./directive.worker.ts', import.meta.url));
|
|
163
|
+
* const client = createWorkerClient({
|
|
164
|
+
* worker,
|
|
165
|
+
* onFactChange: (key, value) => console.log(`Fact ${key} = ${value}`),
|
|
166
|
+
* });
|
|
167
|
+
*
|
|
168
|
+
* await client.init({ moduleNames: ['myModule'] });
|
|
169
|
+
* await client.start();
|
|
170
|
+
* client.setFact('userId', '123');
|
|
171
|
+
* ```
|
|
172
|
+
*/
|
|
173
|
+
declare function createWorkerClient(options: WorkerClientOptions): WorkerClient;
|
|
174
|
+
/**
|
|
175
|
+
* Module registration for worker-side systems.
|
|
176
|
+
* Since functions can't be serialized, modules must be registered in the worker.
|
|
177
|
+
*/
|
|
178
|
+
type ModuleRegistry = Map<string, any>;
|
|
179
|
+
/**
|
|
180
|
+
* Get or create the module registry for worker-side modules.
|
|
181
|
+
*/
|
|
182
|
+
declare function getWorkerModuleRegistry(): ModuleRegistry;
|
|
183
|
+
/**
|
|
184
|
+
* Register a module for use in workers.
|
|
185
|
+
* Call this in your worker script before handling INIT messages.
|
|
186
|
+
*
|
|
187
|
+
* @example
|
|
188
|
+
* ```typescript
|
|
189
|
+
* // directive.worker.ts
|
|
190
|
+
* import { registerWorkerModule, handleWorkerMessages } from '@directive-run/core/worker';
|
|
191
|
+
* import { myModule } from './modules/my-module';
|
|
192
|
+
*
|
|
193
|
+
* registerWorkerModule('myModule', myModule);
|
|
194
|
+
* handleWorkerMessages();
|
|
195
|
+
* ```
|
|
196
|
+
*/
|
|
197
|
+
declare function registerWorkerModule(name: string, module: any): void;
|
|
198
|
+
/**
|
|
199
|
+
* Handler for worker-side message processing.
|
|
200
|
+
* Sets up the message listener and creates/manages the Directive system.
|
|
201
|
+
*
|
|
202
|
+
* @example
|
|
203
|
+
* ```typescript
|
|
204
|
+
* // directive.worker.ts
|
|
205
|
+
* import { registerWorkerModule, handleWorkerMessages } from '@directive-run/core/worker';
|
|
206
|
+
*
|
|
207
|
+
* registerWorkerModule('myModule', myModule);
|
|
208
|
+
* handleWorkerMessages();
|
|
209
|
+
* ```
|
|
210
|
+
*/
|
|
211
|
+
declare function handleWorkerMessages(): void;
|
|
212
|
+
/**
|
|
213
|
+
* Type helper for creating type-safe worker clients.
|
|
214
|
+
* Use this to get proper typing for facts and events.
|
|
215
|
+
*
|
|
216
|
+
* @example
|
|
217
|
+
* ```typescript
|
|
218
|
+
* type MyWorkerClient = TypedWorkerClient<typeof myModuleSchema>;
|
|
219
|
+
* const client = createWorkerClient(options) as MyWorkerClient;
|
|
220
|
+
* client.setFact('userId', '123'); // Type-checked!
|
|
221
|
+
* ```
|
|
222
|
+
*/
|
|
223
|
+
type TypedWorkerClient<M extends ModuleSchema> = Omit<WorkerClient, "setFact" | "setFacts" | "dispatch"> & {
|
|
224
|
+
setFact<K extends keyof M["facts"]>(key: K, value: M["facts"][K] extends {
|
|
225
|
+
_type: infer T;
|
|
226
|
+
} ? T : M["facts"][K]): void;
|
|
227
|
+
setFacts(facts: Partial<{
|
|
228
|
+
[K in keyof M["facts"]]: M["facts"][K] extends {
|
|
229
|
+
_type: infer T;
|
|
230
|
+
} ? T : M["facts"][K];
|
|
231
|
+
}>): void;
|
|
232
|
+
dispatch(event: M["events"] extends Record<string, unknown> ? {
|
|
233
|
+
[K in keyof M["events"]]: {
|
|
234
|
+
type: K;
|
|
235
|
+
} & M["events"][K];
|
|
236
|
+
}[keyof M["events"]] : {
|
|
237
|
+
type: string;
|
|
238
|
+
}): void;
|
|
239
|
+
};
|
|
240
|
+
|
|
241
|
+
export { type TypedWorkerClient, type WorkerClient, type WorkerClientOptions, type WorkerInboundMessage, type WorkerOutboundMessage, type WorkerSystemConfig, createWorkerClient, getWorkerModuleRegistry, handleWorkerMessages, registerWorkerModule };
|
package/dist/worker.js
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
var ot=Object.defineProperty;var Z=(r,n)=>()=>(r&&(n=r(r=0)),n);var it=(r,n)=>{for(var g in n)ot(r,g,{get:n[g],enumerable:true});};async function fe(r,n,g){let S,i=new Promise((t,d)=>{S=setTimeout(()=>d(new Error(g)),n);});try{return await Promise.race([r,i])}finally{clearTimeout(S);}}function he(r,n=50){let g=new WeakSet;function S(i,t){if(t>n)return '"[max depth exceeded]"';if(i===null)return "null";if(i===void 0)return "undefined";let d=typeof i;if(d==="string")return JSON.stringify(i);if(d==="number"||d==="boolean")return String(i);if(d==="function")return '"[function]"';if(d==="symbol")return '"[symbol]"';if(Array.isArray(i)){if(g.has(i))return '"[circular]"';g.add(i);let m=`[${i.map(v=>S(v,t+1)).join(",")}]`;return g.delete(i),m}if(d==="object"){let m=i;if(g.has(m))return '"[circular]"';g.add(m);let E=`{${Object.keys(m).sort().map(x=>`${JSON.stringify(x)}:${S(m[x],t+1)}`).join(",")}}`;return g.delete(m),E}return '"[unknown]"'}return S(r,0)}function oe(r,n=50){let g=new Set(["__proto__","constructor","prototype"]),S=new WeakSet;function i(t,d){if(d>n)return false;if(t==null||typeof t!="object")return true;let m=t;if(S.has(m))return true;if(S.add(m),Array.isArray(m)){for(let v of m)if(!i(v,d+1))return S.delete(m),false;return S.delete(m),true}for(let v of Object.keys(m))if(g.has(v)||!i(m[v],d+1))return S.delete(m),false;return S.delete(m),true}return i(r,0)}function Te(r){let n=he(r),g=5381;for(let S=0;S<n.length;S++)g=(g<<5)+g^n.charCodeAt(S);return (g>>>0).toString(16)}var ce=Z(()=>{});function at(r,n){if(n)return n(r);let{type:g,...S}=r,i=he(S);return `${g}:${i}`}function De(r,n,g){return {requirement:r,id:at(r,g),fromConstraint:n}}var ue,ve=Z(()=>{ce();ue=class r{map=new Map;add(n){this.map.has(n.id)||this.map.set(n.id,n);}remove(n){return this.map.delete(n)}has(n){return this.map.has(n)}get(n){return this.map.get(n)}all(){return [...this.map.values()]}ids(){return [...this.map.keys()]}get size(){return this.map.size}clear(){this.map.clear();}clone(){let n=new r;for(let g of this.map.values())n.add(g);return n}diff(n){let g=[],S=[],i=[];for(let t of this.map.values())n.has(t.id)?i.push(t):g.push(t);for(let t of n.map.values())this.map.has(t.id)||S.push(t);return {added:g,removed:S,unchanged:i}}};});function ct(){let r=new Set;return {get isTracking(){return true},track(n){r.add(n);},getDependencies(){return r}}}function dt(){return de[de.length-1]??ut}function le(r){let n=ct();de.push(n);try{return {value:r(),deps:n.getDependencies()}}finally{de.pop();}}function Se(r){let n=de.splice(0,de.length);try{return r()}finally{de.push(...n);}}function ye(r){dt().track(r);}var de,ut,me=Z(()=>{de=[];ut={isTracking:false,track(){},getDependencies(){return new Set}};});function Ee(r){let{definitions:n,facts:g,requirementKeys:S={},defaultTimeout:i=lt,onEvaluate:t,onError:d}=r,m=new Map,v=new Set,u=new Set,E=new Map,x=new Map,N=new Set,C=new Map,j=new Map,q=false,A=new Set,D=new Set,P=new Map,K=[],o=new Map;function p(){for(let[s,l]of Object.entries(n))if(l.after)for(let h of l.after)n[h]&&(P.has(h)||P.set(h,new Set),P.get(h).add(s));}function w(){let s=new Set,l=new Set,h=[];function I(M,L){if(s.has(M))return;if(l.has(M)){let H=L.indexOf(M),W=[...L.slice(H),M].join(" \u2192 ");throw new Error(`[Directive] Constraint cycle detected: ${W}. Remove one of the \`after\` dependencies to break the cycle.`)}l.add(M),L.push(M);let U=n[M];if(U?.after)for(let H of U.after)n[H]&&I(H,L);L.pop(),l.delete(M),s.add(M),h.push(M);}for(let M of Object.keys(n))I(M,[]);K=h,o=new Map(K.map((M,L)=>[M,L]));}if(w(),p(),process.env.NODE_ENV!=="production"){for(let[s,l]of Object.entries(n))if(l.after)for(let h of l.after)n[h]||console.warn(`[Directive] Constraint "${s}" references unknown constraint "${h}" in \`after\`. This dependency will be ignored. Check for typos or ensure the constraint exists.`);}function $(s,l){return l.async!==void 0?l.async:!!u.has(s)}function k(s){let l=n[s];if(!l)throw new Error(`[Directive] Unknown constraint: ${s}`);let h=$(s,l);h&&u.add(s);let I={id:s,priority:l.priority??0,isAsync:h,lastResult:null,isEvaluating:false,error:null,lastResolvedAt:null,after:l.after??[]};return m.set(s,I),I}function O(s){return m.get(s)??k(s)}function b(s,l){let h=E.get(s)??new Set;for(let I of h){let M=x.get(I);M?.delete(s),M&&M.size===0&&x.delete(I);}for(let I of l)x.has(I)||x.set(I,new Set),x.get(I).add(s);E.set(s,l);}function f(s){let l=n[s];if(!l)return false;let h=O(s);h.isEvaluating=true,h.error=null;try{let I;if(l.deps)I=l.when(g),C.set(s,new Set(l.deps));else {let M=le(()=>l.when(g));I=M.value,C.set(s,M.deps);}return I instanceof Promise?(u.add(s),h.isAsync=!0,process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Constraint "${s}" returned a Promise but was not marked as async. Add \`async: true\` to the constraint definition to avoid this warning and improve performance.`),I.then(M=>(h.lastResult=M,h.isEvaluating=!1,t?.(s,M),M)).catch(M=>(h.error=M instanceof Error?M:new Error(String(M)),h.lastResult=!1,h.isEvaluating=!1,d?.(s,M),!1))):(h.lastResult=I,h.isEvaluating=!1,t?.(s,I),I)}catch(I){return h.error=I instanceof Error?I:new Error(String(I)),h.lastResult=false,h.isEvaluating=false,d?.(s,I),false}}async function a(s){let l=n[s];if(!l)return false;let h=O(s),I=l.timeout??i;if(h.isEvaluating=true,h.error=null,l.deps?.length){let M=new Set(l.deps);b(s,M),C.set(s,M);}try{let M=l.when(g),L=await fe(M,I,`Constraint "${s}" timed out after ${I}ms`);return h.lastResult=L,h.isEvaluating=!1,t?.(s,L),L}catch(M){return h.error=M instanceof Error?M:new Error(String(M)),h.lastResult=false,h.isEvaluating=false,d?.(s,M),false}}let R=10;function _(s,l){if(s==null)return [];if(Array.isArray(s)){let h=s.filter(I=>I!=null);return process.env.NODE_ENV!=="production"&&h.length>R&&l&&console.warn(`[Directive] Constraint "${l}" produced ${h.length} requirements. Consider splitting into multiple constraints for better performance.`),h}return [s]}function F(s){let l=n[s];if(!l)return {requirements:[],deps:new Set};let h=l.require;if(typeof h=="function"){let{value:M,deps:L}=le(()=>h(g));return {requirements:_(M,s),deps:L}}return {requirements:_(h,s),deps:new Set}}function V(s,l){if(l.size===0)return;let h=E.get(s)??new Set;for(let I of l)h.add(I),x.has(I)||x.set(I,new Set),x.get(I).add(s);E.set(s,h);}let e=null;function c(){return e||(e=Object.keys(n).sort((s,l)=>{let h=O(s),M=O(l).priority-h.priority;if(M!==0)return M;let L=o.get(s)??0,U=o.get(l)??0;return L-U})),e}for(let s of Object.keys(n))k(s);if(process.env.NODE_ENV!=="production")for(let[s,l]of Object.entries(n))l.async&&!l.deps&&console.warn(`[Directive] Async constraint "${s}" has no \`deps\` declared. Auto-tracking cannot work across async boundaries. Add \`deps: ["key1", "key2"]\` to enable dependency tracking.`);function y(s){let l=m.get(s);if(!l||l.after.length===0)return true;for(let h of l.after)if(n[h]&&!v.has(h)&&!D.has(h)&&!A.has(h))return false;return true}return {async evaluate(s){let l=new ue;D.clear();let h=c().filter(W=>!v.has(W)),I;if(!q||!s||s.size===0)I=h,q=true;else {let W=new Set;for(let z of s){let G=x.get(z);if(G)for(let ee of G)v.has(ee)||W.add(ee);}for(let z of N)v.has(z)||W.add(z);N.clear(),I=[...W];for(let z of h)if(!W.has(z)){let G=j.get(z);if(G)for(let ee of G)l.add(ee);}}function M(W,z){if(v.has(W))return;let G=C.get(W);if(!z){G!==void 0&&b(W,G),D.add(W),j.set(W,[]);return}D.delete(W);let ee,ie;try{let te=F(W);ee=te.requirements,ie=te.deps;}catch(te){d?.(W,te),G!==void 0&&b(W,G),j.set(W,[]);return}if(G!==void 0){let te=new Set(G);for(let Y of ie)te.add(Y);b(W,te);}else V(W,ie);if(ee.length>0){let te=S[W],Y=ee.map(Q=>De(Q,W,te));for(let Q of Y)l.add(Q);j.set(W,Y);}else j.set(W,[]);}async function L(W){let z=[],G=[];for(let Y of W)if(y(Y))G.push(Y);else {z.push(Y);let Q=j.get(Y);if(Q)for(let ae of Q)l.add(ae);}if(G.length===0)return z;let ee=[],ie=[];for(let Y of G)O(Y).isAsync?ie.push(Y):ee.push(Y);let te=[];for(let Y of ee){let Q=f(Y);if(Q instanceof Promise){te.push({id:Y,promise:Q});continue}M(Y,Q);}if(te.length>0){let Y=await Promise.all(te.map(async({id:Q,promise:ae})=>({id:Q,active:await ae})));for(let{id:Q,active:ae}of Y)M(Q,ae);}if(ie.length>0){let Y=await Promise.all(ie.map(async Q=>({id:Q,active:await a(Q)})));for(let{id:Q,active:ae}of Y)M(Q,ae);}return z}let U=I,H=I.length+1;for(;U.length>0&&H>0;){let W=U.length;if(U=await L(U),U.length===W)break;H--;}return l.all()},getState(s){return m.get(s)},getAllStates(){return [...m.values()]},disable(s){v.add(s),e=null,j.delete(s);let l=E.get(s);if(l){for(let h of l){let I=x.get(h);I&&(I.delete(s),I.size===0&&x.delete(h));}E.delete(s);}C.delete(s);},enable(s){v.delete(s),e=null,N.add(s);},invalidate(s){let l=x.get(s);if(l)for(let h of l)N.add(h);},markResolved(s){A.add(s);let l=m.get(s);l&&(l.lastResolvedAt=Date.now());let h=P.get(s);if(h)for(let I of h)N.add(I);},isResolved(s){return A.has(s)},registerDefinitions(s){for(let[l,h]of Object.entries(s))n[l]=h,k(l),N.add(l);e=null,w(),p();}}}var lt,xe=Z(()=>{ve();me();ce();lt=5e3;});function Ce(r){let{definitions:n,facts:g,onCompute:i,onInvalidate:t,onError:d}=r,m=new Map,v=new Map,u=new Map,E=new Map,x=new Set(["__proto__","constructor","prototype"]),N=0,C=new Set,j=false,q=100,A;function D(k){if(!n[k])throw new Error(`[Directive] Unknown derivation: ${k}`);let b={id:k,compute:()=>K(k),cachedValue:void 0,dependencies:new Set,isStale:true,isComputing:false};return m.set(k,b),b}function P(k){return m.get(k)??D(k)}function K(k){let O=P(k),b=n[k];if(!b)throw new Error(`[Directive] Unknown derivation: ${k}`);if(O.isComputing)throw new Error(`[Directive] Circular dependency detected in derivation: ${k}`);O.isComputing=true;try{let{value:f,deps:a}=le(()=>b(g,A));return O.cachedValue=f,O.isStale=!1,o(k,a),i?.(k,f,[...a]),f}catch(f){throw d?.(k,f),f}finally{O.isComputing=false;}}function o(k,O){let b=P(k),f=b.dependencies;for(let a of f)if(m.has(a)){let R=E.get(a);R?.delete(k),R&&R.size===0&&E.delete(a);}else {let R=u.get(a);R?.delete(k),R&&R.size===0&&u.delete(a);}for(let a of O)n[a]?(E.has(a)||E.set(a,new Set),E.get(a).add(k)):(u.has(a)||u.set(a,new Set),u.get(a).add(k));b.dependencies=O;}function p(){if(!(N>0||j)){j=true;try{let k=0;for(;C.size>0;){if(++k>q){let b=[...C];throw C.clear(),new Error(`[Directive] Infinite derivation notification loop detected after ${q} iterations. Remaining: ${b.join(", ")}. This usually means a derivation listener is mutating facts that re-trigger the same derivation.`)}let O=[...C];C.clear();for(let b of O)v.get(b)?.forEach(f=>f());}}finally{j=false;}}}function w(k,O=new Set){if(O.has(k))return;O.add(k);let b=m.get(k);if(!b||b.isStale)return;b.isStale=true,t?.(k),C.add(k);let f=E.get(k);if(f)for(let a of f)w(a,O);}return A=new Proxy({},{get(k,O){if(typeof O=="symbol"||x.has(O))return;ye(O);let b=P(O);return b.isStale&&K(O),b.cachedValue}}),{get(k){let O=P(k);return O.isStale&&K(k),O.cachedValue},isStale(k){return m.get(k)?.isStale??true},invalidate(k){let O=u.get(k);if(O){N++;try{for(let b of O)w(b);}finally{N--,p();}}},invalidateMany(k){N++;try{for(let O of k){let b=u.get(O);if(b)for(let f of b)w(f);}}finally{N--,p();}},invalidateAll(){N++;try{for(let k of m.values())k.isStale||(k.isStale=!0,C.add(k.id));}finally{N--,p();}},subscribe(k,O){for(let b of k){let f=b;v.has(f)||v.set(f,new Set),v.get(f).add(O);}return ()=>{for(let b of k){let f=b,a=v.get(f);a?.delete(O),a&&a.size===0&&v.delete(f);}}},getProxy(){return A},getDependencies(k){return P(k).dependencies},registerDefinitions(k){for(let[O,b]of Object.entries(k))n[O]=b,D(O);}}}var Me=Z(()=>{me();});function Ie(r){let{definitions:n,facts:g,store:S,onRun:i,onError:t}=r,d=new Map,m=null,v=false;function u(D){let P=n[D];if(!P)throw new Error(`[Directive] Unknown effect: ${D}`);let K={id:D,enabled:true,hasExplicitDeps:!!P.deps,dependencies:P.deps?new Set(P.deps):null,lastSnapshot:null,cleanup:null};return d.set(D,K),K}function E(D){return d.get(D)??u(D)}function x(){return g.$snapshot()}function N(D,P){let K=E(D);if(!K.enabled)return false;if(K.dependencies){for(let o of K.dependencies)if(P.has(o))return true;return false}return true}function C(D){if(D.cleanup){try{D.cleanup();}catch(P){t?.(D.id,P),console.error(`[Directive] Effect "${D.id}" cleanup threw an error:`,P);}D.cleanup=null;}}function j(D,P){if(typeof P=="function")if(v)try{P();}catch(K){t?.(D.id,K),console.error(`[Directive] Effect "${D.id}" cleanup threw an error:`,K);}else D.cleanup=P;}async function q(D){let P=E(D),K=n[D];if(!(!P.enabled||!K)){C(P),i?.(D);try{if(P.hasExplicitDeps){let o;if(S.batch(()=>{o=K.run(g,m);}),o instanceof Promise){let p=await o;j(P,p);}else j(P,o);}else {let o=null,p,w=le(()=>(S.batch(()=>{p=K.run(g,m);}),p));o=w.deps;let $=w.value;$ instanceof Promise&&($=await $),j(P,$),P.dependencies=o.size>0?o:null;}}catch(o){t?.(D,o),console.error(`[Directive] Effect "${D}" threw an error:`,o);}}}for(let D of Object.keys(n))u(D);return {async runEffects(D){let P=[];for(let K of Object.keys(n))N(K,D)&&P.push(K);await Promise.all(P.map(q)),m=x();},async runAll(){let D=Object.keys(n);await Promise.all(D.map(P=>E(P).enabled?q(P):Promise.resolve())),m=x();},disable(D){let P=E(D);P.enabled=false;},enable(D){let P=E(D);P.enabled=true;},isEnabled(D){return E(D).enabled},cleanupAll(){v=true;for(let D of d.values())C(D);},registerDefinitions(D){for(let[P,K]of Object.entries(D))n[P]=K,u(P);}}}var Oe=Z(()=>{me();});var ge,qe=Z(()=>{ge=class extends Error{constructor(g,S,i,t,d=true){super(g);this.source=S;this.sourceId=i;this.context=t;this.recoverable=d;this.name="DirectiveError";}};});var $e=Z(()=>{qe();});var Ae=Z(()=>{$e();});function ft(r={}){let{delayMs:n=1e3,maxRetries:g=3,backoffMultiplier:S=2,maxDelayMs:i=3e4}=r,t=new Map;function d(m){let v=n*Math.pow(S,m-1);return Math.min(v,i)}return {scheduleRetry(m,v,u,E,x){if(E>g)return null;let N=d(E),C={source:m,sourceId:v,context:u,attempt:E,nextRetryTime:Date.now()+N,callback:x};return t.set(v,C),C},getPendingRetries(){return Array.from(t.values())},processDueRetries(){let m=Date.now(),v=[];for(let[u,E]of t)E.nextRetryTime<=m&&(v.push(E),t.delete(u));return v},cancelRetry(m){t.delete(m);},clearAll(){t.clear();}}}function Pe(r={}){let{config:n={},onError:g,onRecovery:S}=r,i=[],t=100,d=ft(n.retryLater),m=new Map;function v(x,N,C,j){if(C instanceof ge)return C;let q=C instanceof Error?C.message:String(C),A=x!=="system";return new ge(q,x,N,j,A)}function u(x,N,C){let j=(()=>{switch(x){case "constraint":return n.onConstraintError;case "resolver":return n.onResolverError;case "effect":return n.onEffectError;case "derivation":return n.onDerivationError;default:return}})();if(typeof j=="function"){try{j(C,N);}catch(q){console.error("[Directive] Error in error handler callback:",q);}return "skip"}return typeof j=="string"?j:gt[x]}return {handleError(x,N,C,j){let q=v(x,N,C,j);i.push(q),i.length>t&&i.shift();try{g?.(q);}catch(D){console.error("[Directive] Error in onError callback:",D);}try{n.onError?.(q);}catch(D){console.error("[Directive] Error in config.onError callback:",D);}let A=u(x,N,C instanceof Error?C:new Error(String(C)));if(A==="retry-later"){let D=(m.get(N)??0)+1;m.set(N,D),d.scheduleRetry(x,N,j,D)||(A="skip",m.delete(N),typeof process<"u"&&process.env?.NODE_ENV!=="production"&&console.warn(`[Directive] ${x} "${N}" exceeded max retry-later attempts. Skipping.`));}try{S?.(q,A);}catch(D){console.error("[Directive] Error in onRecovery callback:",D);}if(A==="throw")throw q;return A},getLastError(){return i[i.length-1]??null},getAllErrors(){return [...i]},clearErrors(){i.length=0;},getRetryLaterManager(){return d},processDueRetries(){return d.processDueRetries()},clearRetryAttempts(x){m.delete(x),d.cancelRetry(x);}}}var gt,_e=Z(()=>{Ae();gt={constraint:"skip",resolver:"skip",effect:"skip",derivation:"skip",system:"throw"};});function yt(r,n=100){try{return JSON.stringify(r)?.slice(0,n)??String(r)}catch{return "[circular or non-serializable]"}}function mt(r){let{schema:n,onChange:g,onBatch:S}=r,t=Object.keys(n).length===0,d=r.validate??process.env.NODE_ENV!=="production",m=r.strictKeys??(process.env.NODE_ENV!=="production"&&!t),v=r.redactErrors??false,u=new Map,E=new Set,x=new Map,N=new Set,C=0,j=[],q=new Set,A=false,D=[],P=100;function K(a){return a!==null&&typeof a=="object"&&"safeParse"in a&&typeof a.safeParse=="function"&&"_def"in a&&"parse"in a&&typeof a.parse=="function"}function o(a){let R=a;if(R._typeName)return R._typeName;if(K(a)){let _=a._def;if(_?.typeName)return _.typeName.replace(/^Zod/,"").toLowerCase()}return "unknown"}function p(a){return v?"[redacted]":yt(a)}function w(a,R){if(!d)return;let _=n[a];if(!_){if(m)throw new Error(`[Directive] Unknown fact key: "${a}". Key not defined in schema.`);console.warn(`[Directive] Unknown fact key: "${a}"`);return}if(K(_)){let c=_.safeParse(R);if(!c.success){let y=R===null?"null":Array.isArray(R)?"array":typeof R,T=p(R),s=c.error?.message??c.error?.issues?.[0]?.message??"Validation failed",l=o(_);throw new Error(`[Directive] Validation failed for "${a}": expected ${l}, got ${y} ${T}. ${s}`)}return}let F=_,V=F._validators;if(!V||!Array.isArray(V)||V.length===0)return;let e=F._typeName??"unknown";for(let c=0;c<V.length;c++){let y=V[c];if(typeof y=="function"&&!y(R)){let T=R===null?"null":Array.isArray(R)?"array":typeof R,s=p(R),l="";typeof F._lastFailedIndex=="number"&&F._lastFailedIndex>=0&&(l=` (element at index ${F._lastFailedIndex} failed)`,F._lastFailedIndex=-1);let h=c===0?"":` (validator ${c+1} failed)`;throw new Error(`[Directive] Validation failed for "${a}": expected ${e}, got ${T} ${s}${h}${l}`)}}}function $(a){x.get(a)?.forEach(R=>R());}function k(){N.forEach(a=>a());}function O(a,R,_){if(A){D.push({key:a,value:R,prev:_});return}A=true;try{g?.(a,R,_),$(a),k();let F=0;for(;D.length>0;){if(++F>P)throw D.length=0,new Error(`[Directive] Infinite notification loop detected after ${P} iterations. A listener is repeatedly mutating facts that re-trigger notifications.`);let V=[...D];D.length=0;for(let e of V)g?.(e.key,e.value,e.prev),$(e.key);k();}}finally{A=false;}}function b(){if(!(C>0)){if(S&&j.length>0&&S([...j]),q.size>0){A=true;try{for(let R of q)$(R);k();let a=0;for(;D.length>0;){if(++a>P)throw D.length=0,new Error(`[Directive] Infinite notification loop detected during flush after ${P} iterations.`);let R=[...D];D.length=0;for(let _ of R)g?.(_.key,_.value,_.prev),$(_.key);k();}}finally{A=false;}}j.length=0,q.clear();}}let f={get(a){return ye(a),u.get(a)},has(a){return ye(a),u.has(a)},set(a,R){w(a,R);let _=u.get(a);Object.is(_,R)||(u.set(a,R),E.add(a),C>0?(j.push({key:a,value:R,prev:_,type:"set"}),q.add(a)):O(a,R,_));},delete(a){let R=u.get(a);u.delete(a),E.delete(a),C>0?(j.push({key:a,value:void 0,prev:R,type:"delete"}),q.add(a)):O(a,void 0,R);},batch(a){C++;try{a();}finally{C--,b();}},subscribe(a,R){for(let _ of a){let F=_;x.has(F)||x.set(F,new Set),x.get(F).add(R);}return ()=>{for(let _ of a){let F=x.get(_);F&&(F.delete(R),F.size===0&&x.delete(_));}}},subscribeAll(a){return N.add(a),()=>N.delete(a)},toObject(){let a={};for(let R of E)u.has(R)&&(a[R]=u.get(R));return a}};return f.registerKeys=a=>{for(let R of Object.keys(a))pe.has(R)||(n[R]=a[R],E.add(R));},f}function pt(r,n){let g=()=>({get:i=>Se(()=>r.get(i)),has:i=>Se(()=>r.has(i))});return new Proxy({},{get(i,t){if(t==="$store")return r;if(t==="$snapshot")return g;if(typeof t!="symbol"&&!pe.has(t))return r.get(t)},set(i,t,d){return typeof t=="symbol"||t==="$store"||t==="$snapshot"||pe.has(t)?false:(r.set(t,d),true)},deleteProperty(i,t){return typeof t=="symbol"||t==="$store"||t==="$snapshot"||pe.has(t)?false:(r.delete(t),true)},has(i,t){return t==="$store"||t==="$snapshot"?true:typeof t=="symbol"||pe.has(t)?false:r.has(t)},ownKeys(){return Object.keys(n)},getOwnPropertyDescriptor(i,t){return t==="$store"||t==="$snapshot"?{configurable:true,enumerable:false,writable:false}:{configurable:true,enumerable:true,writable:true}}})}function je(r){let n=mt(r),g=pt(n,r.schema);return {store:n,facts:g}}var pe,Fe=Z(()=>{me();pe=Object.freeze(new Set(["__proto__","constructor","prototype"]));});function Ne(){let r=[];function n(i){if(i)try{return i()}catch(t){console.error("[Directive] Plugin error:",t);return}}async function g(i){if(i)try{return await i()}catch(t){console.error("[Directive] Plugin error:",t);return}}return {register(i){r.some(t=>t.name===i.name)&&(console.warn(`[Directive] Plugin "${i.name}" is already registered, replacing...`),this.unregister(i.name)),r.push(i);},unregister(i){let t=r.findIndex(d=>d.name===i);t!==-1&&r.splice(t,1);},getPlugins(){return [...r]},async emitInit(i){for(let t of r)await g(()=>t.onInit?.(i));},emitStart(i){for(let t of r)n(()=>t.onStart?.(i));},emitStop(i){for(let t of r)n(()=>t.onStop?.(i));},emitDestroy(i){for(let t of r)n(()=>t.onDestroy?.(i));},emitFactSet(i,t,d){for(let m of r)n(()=>m.onFactSet?.(i,t,d));},emitFactDelete(i,t){for(let d of r)n(()=>d.onFactDelete?.(i,t));},emitFactsBatch(i){for(let t of r)n(()=>t.onFactsBatch?.(i));},emitDerivationCompute(i,t,d){for(let m of r)n(()=>m.onDerivationCompute?.(i,t,d));},emitDerivationInvalidate(i){for(let t of r)n(()=>t.onDerivationInvalidate?.(i));},emitReconcileStart(i){for(let t of r)n(()=>t.onReconcileStart?.(i));},emitReconcileEnd(i){for(let t of r)n(()=>t.onReconcileEnd?.(i));},emitConstraintEvaluate(i,t){for(let d of r)n(()=>d.onConstraintEvaluate?.(i,t));},emitConstraintError(i,t){for(let d of r)n(()=>d.onConstraintError?.(i,t));},emitRequirementCreated(i){for(let t of r)n(()=>t.onRequirementCreated?.(i));},emitRequirementMet(i,t){for(let d of r)n(()=>d.onRequirementMet?.(i,t));},emitRequirementCanceled(i){for(let t of r)n(()=>t.onRequirementCanceled?.(i));},emitResolverStart(i,t){for(let d of r)n(()=>d.onResolverStart?.(i,t));},emitResolverComplete(i,t,d){for(let m of r)n(()=>m.onResolverComplete?.(i,t,d));},emitResolverError(i,t,d){for(let m of r)n(()=>m.onResolverError?.(i,t,d));},emitResolverRetry(i,t,d){for(let m of r)n(()=>m.onResolverRetry?.(i,t,d));},emitResolverCancel(i,t){for(let d of r)n(()=>d.onResolverCancel?.(i,t));},emitEffectRun(i){for(let t of r)n(()=>t.onEffectRun?.(i));},emitEffectError(i,t){for(let d of r)n(()=>d.onEffectError?.(i,t));},emitSnapshot(i){for(let t of r)n(()=>t.onSnapshot?.(i));},emitTimeTravel(i,t){for(let d of r)n(()=>d.onTimeTravel?.(i,t));},emitError(i){for(let t of r)n(()=>t.onError?.(i));},emitErrorRecovery(i,t){for(let d of r)n(()=>d.onErrorRecovery?.(i,t));}}}var We=Z(()=>{});function Ve(r,n){let{backoff:g,initialDelay:S=100,maxDelay:i=3e4}=r,t;switch(g){case "none":t=S;break;case "linear":t=S*n;break;case "exponential":t=S*Math.pow(2,n-1);break;default:t=S;}return Math.max(1,Math.min(t,i))}function Le(r){let{definitions:n,facts:g,store:S,onStart:i,onComplete:t,onError:d,onRetry:m,onCancel:v,onResolutionComplete:u}=r;if(process.env.NODE_ENV!=="production")for(let[f,a]of Object.entries(n)){if(!a.resolve&&!a.resolveBatch)throw new Error(`[Directive] Resolver "${f}" must define either resolve() or resolveBatch(). Add one of these methods to handle requirements.`);if(a.batch?.enabled&&!a.resolveBatch)throw new Error(`[Directive] Resolver "${f}" has batch.enabled=true but no resolveBatch() method. Add resolveBatch() to handle batched requirements.`)}let E=new Map,x=new Map,N=1e3,C=new Map,j=new Map,q=1e3;function A(){if(x.size>N){let f=x.size-N,a=x.keys();for(let R=0;R<f;R++){let _=a.next().value;_&&x.delete(_);}}}function D(f){return typeof f=="object"&&f!==null&&"requirement"in f&&typeof f.requirement=="string"}function P(f){return typeof f=="object"&&f!==null&&"requirement"in f&&typeof f.requirement=="function"}function K(f,a){return D(f)?a.type===f.requirement:P(f)?f.requirement(a):false}function o(f){let a=f.type,R=j.get(a);if(R)for(let _ of R){let F=n[_];if(F&&K(F,f))return _}for(let[_,F]of Object.entries(n))if(K(F,f)){if(!j.has(a)){if(j.size>=q){let e=j.keys().next().value;e!==void 0&&j.delete(e);}j.set(a,[]);}let V=j.get(a);return V.includes(_)||V.push(_),_}return null}function p(f){return {facts:g,signal:f,snapshot:()=>g.$snapshot()}}async function w(f,a,R){let _=n[f];if(!_)return;let F={...Be,..._.retry},V=null;for(let e=1;e<=F.attempts;e++){if(R.signal.aborted)return;let c=E.get(a.id);c&&(c.attempt=e,c.status={state:"running",requirementId:a.id,startedAt:c.startedAt,attempt:e});try{let y=p(R.signal);if(_.resolve){let s;S.batch(()=>{s=_.resolve(a.requirement,y);});let l=_.timeout;l&&l>0?await fe(s,l,`Resolver "${f}" timed out after ${l}ms`):await s;}let T=Date.now()-(c?.startedAt??Date.now());x.set(a.id,{state:"success",requirementId:a.id,completedAt:Date.now(),duration:T}),A(),t?.(f,a,T);return}catch(y){if(V=y instanceof Error?y:new Error(String(y)),R.signal.aborted)return;if(F.shouldRetry&&!F.shouldRetry(V,e))break;if(e<F.attempts){if(R.signal.aborted)return;let T=Ve(F,e);if(m?.(f,a,e+1),await new Promise(s=>{let l=setTimeout(s,T),h=()=>{clearTimeout(l),s();};R.signal.addEventListener("abort",h,{once:true});}),R.signal.aborted)return}}}x.set(a.id,{state:"error",requirementId:a.id,error:V,failedAt:Date.now(),attempts:F.attempts}),A(),d?.(f,a,V);}async function $(f,a){let R=n[f];if(!R)return;if(!R.resolveBatch&&!R.resolveBatchWithResults){await Promise.all(a.map(T=>{let s=new AbortController;return w(f,T,s)}));return}let _={...Be,...R.retry},F={...Ke,...R.batch},V=new AbortController,e=Date.now(),c=null,y=F.timeoutMs??R.timeout;for(let T=1;T<=_.attempts;T++){if(V.signal.aborted)return;try{let s=p(V.signal),l=a.map(h=>h.requirement);if(R.resolveBatchWithResults){let h,I;if(S.batch(()=>{I=R.resolveBatchWithResults(l,s);}),y&&y>0?h=await fe(I,y,`Batch resolver "${f}" timed out after ${y}ms`):h=await I,h.length!==a.length)throw new Error(`[Directive] Batch resolver "${f}" returned ${h.length} results but expected ${a.length}. Results array must match input order.`);let M=Date.now()-e,L=!1;for(let U=0;U<a.length;U++){let H=a[U],W=h[U];if(W.success)x.set(H.id,{state:"success",requirementId:H.id,completedAt:Date.now(),duration:M}),t?.(f,H,M);else {L=!0;let z=W.error??new Error("Batch item failed");x.set(H.id,{state:"error",requirementId:H.id,error:z,failedAt:Date.now(),attempts:T}),d?.(f,H,z);}}if(!L||a.some((U,H)=>h[H]?.success))return}else {let h;S.batch(()=>{h=R.resolveBatch(l,s);}),y&&y>0?await fe(h,y,`Batch resolver "${f}" timed out after ${y}ms`):await h;let I=Date.now()-e;for(let M of a)x.set(M.id,{state:"success",requirementId:M.id,completedAt:Date.now(),duration:I}),t?.(f,M,I);return}}catch(s){if(c=s instanceof Error?s:new Error(String(s)),V.signal.aborted)return;if(_.shouldRetry&&!_.shouldRetry(c,T))break;if(T<_.attempts){let l=Ve(_,T);for(let h of a)m?.(f,h,T+1);if(await new Promise(h=>{let I=setTimeout(h,l),M=()=>{clearTimeout(I),h();};V.signal.addEventListener("abort",M,{once:true});}),V.signal.aborted)return}}}for(let T of a)x.set(T.id,{state:"error",requirementId:T.id,error:c,failedAt:Date.now(),attempts:_.attempts}),d?.(f,T,c);A();}function k(f,a){let R=n[f];if(!R)return;let _={...Ke,...R.batch};C.has(f)||C.set(f,{resolverId:f,requirements:[],timer:null});let F=C.get(f);F.requirements.push(a),F.timer&&clearTimeout(F.timer),F.timer=setTimeout(()=>{O(f);},_.windowMs);}function O(f){let a=C.get(f);if(!a||a.requirements.length===0)return;let R=[...a.requirements];a.requirements=[],a.timer=null,$(f,R).then(()=>{u?.();});}return {resolve(f){if(E.has(f.id))return;let a=o(f.requirement);if(!a){console.warn(`[Directive] No resolver found for requirement: ${f.id}`);return}let R=n[a];if(!R)return;if(R.batch?.enabled){k(a,f);return}let _=new AbortController,F=Date.now(),V={requirementId:f.id,resolverId:a,controller:_,startedAt:F,attempt:1,status:{state:"pending",requirementId:f.id,startedAt:F},originalRequirement:f};E.set(f.id,V),i?.(a,f),w(a,f,_).finally(()=>{E.delete(f.id)&&u?.();});},cancel(f){let a=E.get(f);a&&(a.controller.abort(),E.delete(f),x.set(f,{state:"canceled",requirementId:f,canceledAt:Date.now()}),A(),v?.(a.resolverId,a.originalRequirement));},cancelAll(){for(let[f]of E)this.cancel(f);for(let f of C.values())f.timer&&clearTimeout(f.timer);C.clear();},getStatus(f){let a=E.get(f);if(a)return a.status;let R=x.get(f);return R||{state:"idle"}},getInflight(){return [...E.keys()]},getInflightInfo(){return [...E.values()].map(f=>({id:f.requirementId,resolverId:f.resolverId,startedAt:f.startedAt}))},isResolving(f){return E.has(f)},processBatches(){for(let f of C.keys())O(f);},registerDefinitions(f){for(let[a,R]of Object.entries(f))n[a]=R;j.clear();}}}var Be,Ke,Ue=Z(()=>{ce();Be={attempts:1,backoff:"none",initialDelay:100,maxDelay:3e4},Ke={enabled:false,windowMs:50};});function He(r){let{config:n,facts:g,store:S,onSnapshot:i,onTimeTravel:t}=r,d=n.timeTravel??false,m=n.maxSnapshots??100,v=[],u=-1,E=1,x=false,N=false,C=[],j=null,q=-1;function A(){return S.toObject()}function D(){let o=A();return structuredClone(o)}function P(o){if(!oe(o)){console.error("[Directive] Potential prototype pollution detected in snapshot data, skipping restore");return}S.batch(()=>{for(let[p,w]of Object.entries(o)){if(p==="__proto__"||p==="constructor"||p==="prototype"){console.warn(`[Directive] Skipping dangerous key "${p}" during fact restoration`);continue}g[p]=w;}});}return {get isEnabled(){return d},get isRestoring(){return N},get isPaused(){return x},get snapshots(){return [...v]},get currentIndex(){return u},takeSnapshot(o){if(!d||x)return {id:-1,timestamp:Date.now(),facts:{},trigger:o};let p={id:E++,timestamp:Date.now(),facts:D(),trigger:o};for(u<v.length-1&&v.splice(u+1),v.push(p),u=v.length-1;v.length>m;)v.shift(),u--;return i?.(p),p},restore(o){if(d){x=true,N=true;try{P(o.facts);}finally{x=false,N=false;}}},goBack(o=1){if(!d||v.length===0)return;let p=u,w=u,$=C.find(O=>u>O.startIndex&&u<=O.endIndex);if($)w=$.startIndex;else if(C.find(b=>u===b.startIndex)){let b=C.find(f=>f.endIndex<u&&u-f.endIndex<=o);w=b?b.startIndex:Math.max(0,u-o);}else w=Math.max(0,u-o);if(p===w)return;u=w;let k=v[u];k&&(this.restore(k),t?.(p,w));},goForward(o=1){if(!d||v.length===0)return;let p=u,w=u,$=C.find(O=>u>=O.startIndex&&u<O.endIndex);if($?w=$.endIndex:w=Math.min(v.length-1,u+o),p===w)return;u=w;let k=v[u];k&&(this.restore(k),t?.(p,w));},goTo(o){if(!d)return;let p=v.findIndex(k=>k.id===o);if(p===-1){console.warn(`[Directive] Snapshot ${o} not found`);return}let w=u;u=p;let $=v[u];$&&(this.restore($),t?.(w,p));},replay(){if(!d||v.length===0)return;u=0;let o=v[0];o&&this.restore(o);},export(){return JSON.stringify({version:1,snapshots:v,currentIndex:u})},import(o){if(d)try{let p=JSON.parse(o);if(typeof p!="object"||p===null)throw new Error("Invalid time-travel data: expected object");if(p.version!==1)throw new Error(`Unsupported time-travel export version: ${p.version}`);if(!Array.isArray(p.snapshots))throw new Error("Invalid time-travel data: snapshots must be an array");if(typeof p.currentIndex!="number")throw new Error("Invalid time-travel data: currentIndex must be a number");for(let $ of p.snapshots){if(typeof $!="object"||$===null)throw new Error("Invalid snapshot: expected object");if(typeof $.id!="number"||typeof $.timestamp!="number"||typeof $.trigger!="string"||typeof $.facts!="object")throw new Error("Invalid snapshot structure");if(!oe($.facts))throw new Error("Invalid fact data: potential prototype pollution detected in nested objects")}v.length=0,v.push(...p.snapshots),u=p.currentIndex;let w=v[u];w&&this.restore(w);}catch(p){console.error("[Directive] Failed to import time-travel data:",p);}},beginChangeset(o){d&&(j=o,q=u);},endChangeset(){!d||j===null||(u>q&&C.push({label:j,startIndex:q,endIndex:u}),j=null,q=-1);},pause(){x=true;},resume(){x=false;}}}function ze(){let r={id:-1,timestamp:0,facts:{},trigger:""};return {isEnabled:false,isRestoring:false,isPaused:false,snapshots:[],currentIndex:-1,takeSnapshot:()=>r,restore:()=>{},goBack:()=>{},goForward:()=>{},goTo:()=>{},replay:()=>{},export:()=>"{}",import:()=>{},beginChangeset:()=>{},endChangeset:()=>{},pause:()=>{},resume:()=>{}}}var Ge=Z(()=>{ce();});function be(r){let n=Object.create(null),g=Object.create(null),S=Object.create(null),i=Object.create(null),t=Object.create(null),d=Object.create(null),m=new Map;for(let e of r.modules){let c=(y,T)=>{if(y){for(let s of Object.keys(y))if(ne.has(s))throw new Error(`[Directive] Security: Module "${e.id}" has dangerous key "${s}" in ${T}. This could indicate a prototype pollution attempt.`)}};if(c(e.schema,"schema"),c(e.events,"events"),c(e.derive,"derive"),c(e.effects,"effects"),c(e.constraints,"constraints"),c(e.resolvers,"resolvers"),process.env.NODE_ENV!=="production")for(let y of Object.keys(e.schema)){let T=m.get(y);if(T)throw new Error(`[Directive] Schema collision: Fact "${y}" is defined in both module "${T}" and "${e.id}". Use namespacing (e.g., "${e.id}::${y}") or merge into one module.`);m.set(y,e.id);}Object.assign(n,e.schema),e.events&&Object.assign(g,e.events),e.derive&&Object.assign(S,e.derive),e.effects&&Object.assign(i,e.effects),e.constraints&&Object.assign(t,e.constraints),e.resolvers&&Object.assign(d,e.resolvers);}if(process.env.NODE_ENV!=="production"){let e=new Set(Object.keys(S));for(let c of Object.keys(n))e.has(c)&&console.warn(`[Directive] "${c}" exists as both a fact and a derivation. This may cause unexpected dependency tracking behavior.`);}let v=Ne();for(let e of r.plugins??[])v.register(e);let u=Pe({config:r.errorBoundary,onError:e=>v.emitError(e),onRecovery:(e,c)=>v.emitErrorRecovery(e,c)}),E=()=>{},x=()=>{},N=null,{store:C,facts:j}=je({schema:n,onChange:(e,c,y)=>{v.emitFactSet(e,c,y),E(e),!N?.isRestoring&&(b.changedKeys.add(e),f());},onBatch:e=>{v.emitFactsBatch(e);let c=[];for(let y of e)c.push(y.key);if(x(c),!N?.isRestoring){for(let y of e)b.changedKeys.add(y.key);f();}}}),q=Ce({definitions:S,facts:j,onCompute:(e,c,y)=>v.emitDerivationCompute(e,c,y),onInvalidate:e=>v.emitDerivationInvalidate(e),onError:(e,c)=>{u.handleError("derivation",e,c);}});E=e=>q.invalidate(e),x=e=>q.invalidateMany(e);let A=Ie({definitions:i,facts:j,store:C,onRun:e=>v.emitEffectRun(e),onError:(e,c)=>{u.handleError("effect",e,c),v.emitEffectError(e,c);}}),D=Ee({definitions:t,facts:j,onEvaluate:(e,c)=>v.emitConstraintEvaluate(e,c),onError:(e,c)=>{u.handleError("constraint",e,c),v.emitConstraintError(e,c);}}),P=Le({definitions:d,facts:j,store:C,onStart:(e,c)=>v.emitResolverStart(e,c),onComplete:(e,c,y)=>{v.emitResolverComplete(e,c,y),v.emitRequirementMet(c,e),D.markResolved(c.fromConstraint);},onError:(e,c,y)=>{u.handleError("resolver",e,y,c),v.emitResolverError(e,c,y);},onRetry:(e,c,y)=>v.emitResolverRetry(e,c,y),onCancel:(e,c)=>{v.emitResolverCancel(e,c),v.emitRequirementCanceled(c);},onResolutionComplete:()=>{$(),f();}}),K=new Set;function o(){for(let e of K)e();}let p=r.debug?.timeTravel?He({config:r.debug,facts:j,store:C,onSnapshot:e=>{v.emitSnapshot(e),o();},onTimeTravel:(e,c)=>{v.emitTimeTravel(e,c),o();}}):ze();N=p;let w=new Set;function $(){for(let e of w)e();}let k=50,O=0,b={isRunning:false,isReconciling:false,reconcileScheduled:false,isInitializing:false,isInitialized:false,isReady:false,isDestroyed:false,changedKeys:new Set,previousRequirements:new ue,readyPromise:null,readyResolve:null};function f(){!b.isRunning||b.reconcileScheduled||b.isInitializing||(b.reconcileScheduled=true,$(),queueMicrotask(()=>{b.reconcileScheduled=false,b.isRunning&&!b.isInitializing&&a().catch(e=>{process.env.NODE_ENV!=="production"&&console.error("[Directive] Unexpected error in reconcile:",e);});}));}async function a(){if(!b.isReconciling){if(O++,O>k){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Reconcile loop exceeded ${k} iterations. This usually means resolvers are creating circular requirement chains. Check that resolvers aren't mutating facts that re-trigger their own constraints.`),O=0;return}b.isReconciling=true,$();try{b.changedKeys.size>0&&p.takeSnapshot(`facts-changed:${[...b.changedKeys].join(",")}`);let e=j.$snapshot();v.emitReconcileStart(e),await A.runEffects(b.changedKeys);let c=new Set(b.changedKeys);b.changedKeys.clear();let y=await D.evaluate(c),T=new ue;for(let M of y)T.add(M),v.emitRequirementCreated(M);let{added:s,removed:l}=T.diff(b.previousRequirements);for(let M of l)P.cancel(M.id);for(let M of s)P.resolve(M);b.previousRequirements=T;let h=P.getInflightInfo(),I={unmet:y.filter(M=>!P.isResolving(M.id)),inflight:h,completed:[],canceled:l.map(M=>({id:M.id,resolverId:h.find(L=>L.id===M.id)?.resolverId??"unknown"}))};v.emitReconcileEnd(I),b.isReady||(b.isReady=!0,b.readyResolve&&(b.readyResolve(),b.readyResolve=null));}finally{b.isReconciling=false,b.changedKeys.size>0?f():b.reconcileScheduled||(O=0),$();}}}let R=new Proxy({},{get(e,c){if(typeof c!="symbol"&&!ne.has(c))return q.get(c)},has(e,c){return typeof c=="symbol"||ne.has(c)?false:c in S},ownKeys(){return Object.keys(S)},getOwnPropertyDescriptor(e,c){if(typeof c!="symbol"&&!ne.has(c)&&c in S)return {configurable:true,enumerable:true}}}),_=new Proxy({},{get(e,c){if(typeof c!="symbol"&&!ne.has(c))return y=>{let T=g[c];T?C.batch(()=>{T(j,{type:c,...y});}):process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Unknown event type "${c}". No handler is registered for this event. Available events: ${Object.keys(g).join(", ")||"(none)"}`);}},has(e,c){return typeof c=="symbol"||ne.has(c)?false:c in g},ownKeys(){return Object.keys(g)},getOwnPropertyDescriptor(e,c){if(typeof c!="symbol"&&!ne.has(c)&&c in g)return {configurable:true,enumerable:true}}}),F={facts:j,debug:p.isEnabled?p:null,derive:R,events:_,constraints:{disable:e=>D.disable(e),enable:e=>D.enable(e)},effects:{disable:e=>A.disable(e),enable:e=>A.enable(e),isEnabled:e=>A.isEnabled(e)},start(){if(!b.isRunning){b.isRunning=true,b.isInitializing=true;for(let e of r.modules)e.init&&C.batch(()=>{e.init(j);}),e.hooks?.onStart?.(F);r.onAfterModuleInit&&C.batch(()=>{r.onAfterModuleInit();}),b.isInitializing=false,b.isInitialized=true,v.emitStart(F),f();}},stop(){if(b.isRunning){b.isRunning=false,P.cancelAll(),A.cleanupAll();for(let e of r.modules)e.hooks?.onStop?.(F);v.emitStop(F);}},destroy(){this.stop(),b.isDestroyed=true,w.clear(),K.clear(),v.emitDestroy(F);},dispatch(e){if(ne.has(e.type))return;let c=g[e.type];c?C.batch(()=>{c(j,e);}):process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Unknown event type "${e.type}". No handler is registered for this event. Available events: ${Object.keys(g).join(", ")||"(none)"}`);},read(e){return q.get(e)},subscribe(e,c){let y=[],T=[];for(let l of e)l in S?y.push(l):l in n?T.push(l):process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribe: unknown key "${l}"`);let s=[];return y.length>0&&s.push(q.subscribe(y,c)),T.length>0&&s.push(C.subscribe(T,c)),()=>{for(let l of s)l();}},watch(e,c,y){let T=y?.equalityFn?(l,h)=>y.equalityFn(l,h):(l,h)=>Object.is(l,h);if(e in S){let l=q.get(e);return q.subscribe([e],()=>{let h=q.get(e);if(!T(h,l)){let I=l;l=h,c(h,I);}})}process.env.NODE_ENV!=="production"&&(e in n||console.warn(`[Directive] watch: unknown key "${e}"`));let s=C.get(e);return C.subscribe([e],()=>{let l=C.get(e);if(!T(l,s)){let h=s;s=l,c(l,h);}})},when(e,c){return new Promise((y,T)=>{let s=C.toObject();if(e(s)){y();return}let l,h,I=()=>{l?.(),h!==void 0&&clearTimeout(h);};l=C.subscribeAll(()=>{let M=C.toObject();e(M)&&(I(),y());}),c?.timeout!==void 0&&c.timeout>0&&(h=setTimeout(()=>{I(),T(new Error(`[Directive] when: timed out after ${c.timeout}ms`));},c.timeout));})},inspect(){return {unmet:b.previousRequirements.all(),inflight:P.getInflightInfo(),constraints:D.getAllStates().map(e=>({id:e.id,active:e.lastResult??false,priority:e.priority})),resolvers:Object.fromEntries(P.getInflight().map(e=>[e,P.getStatus(e)]))}},explain(e){let y=b.previousRequirements.all().find(U=>U.id===e);if(!y)return null;let T=D.getState(y.fromConstraint),s=P.getStatus(e),l={},h=C.toObject();for(let[U,H]of Object.entries(h))l[U]=H;let I=[`Requirement "${y.requirement.type}" (id: ${y.id})`,`\u251C\u2500 Produced by constraint: ${y.fromConstraint}`,`\u251C\u2500 Constraint priority: ${T?.priority??0}`,`\u251C\u2500 Constraint active: ${T?.lastResult??"unknown"}`,`\u251C\u2500 Resolver status: ${s.state}`],M=Object.entries(y.requirement).filter(([U])=>U!=="type").map(([U,H])=>`${U}=${JSON.stringify(H)}`).join(", ");M&&I.push(`\u251C\u2500 Requirement payload: { ${M} }`);let L=Object.entries(l).slice(0,10);return L.length>0&&(I.push("\u2514\u2500 Relevant facts:"),L.forEach(([U,H],W)=>{let z=W===L.length-1?" \u2514\u2500":" \u251C\u2500",G=typeof H=="object"?JSON.stringify(H):String(H);I.push(`${z} ${U} = ${G.slice(0,50)}${G.length>50?"...":""}`);})),I.join(`
|
|
2
|
+
`)},async settle(e=5e3){let c=Date.now();for(;;){await new Promise(s=>setTimeout(s,0));let y=this.inspect();if(y.inflight.length===0&&!b.isReconciling&&!b.reconcileScheduled)return;if(Date.now()-c>e){let s=[];y.inflight.length>0&&s.push(`${y.inflight.length} resolvers inflight: ${y.inflight.map(h=>h.resolverId).join(", ")}`),b.isReconciling&&s.push("reconciliation in progress"),b.reconcileScheduled&&s.push("reconcile scheduled");let l=b.previousRequirements.all();throw l.length>0&&s.push(`${l.length} unmet requirements: ${l.map(h=>h.requirement.type).join(", ")}`),new Error(`[Directive] settle() timed out after ${e}ms. ${s.join("; ")}`)}await new Promise(s=>setTimeout(s,10));}},getSnapshot(){return {facts:C.toObject(),version:1}},getDistributableSnapshot(e={}){let{includeDerivations:c,excludeDerivations:y,includeFacts:T,ttlSeconds:s,metadata:l,includeVersion:h}=e,I={},M=Object.keys(S),L;if(c){if(L=c.filter(W=>M.includes(W)),process.env.NODE_ENV!=="production"){let W=c.filter(z=>!M.includes(z));W.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown derivation keys ignored: ${W.join(", ")}. Available: ${M.join(", ")||"(none)"}`);}}else L=M;if(y){let W=new Set(y);L=L.filter(z=>!W.has(z));}for(let W of L)try{I[W]=q.get(W);}catch(z){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] getDistributableSnapshot: Skipping derivation "${W}" due to error:`,z);}if(T&&T.length>0){let W=C.toObject(),z=Object.keys(W);if(process.env.NODE_ENV!=="production"){let G=T.filter(ee=>!(ee in W));G.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown fact keys ignored: ${G.join(", ")}. Available: ${z.join(", ")||"(none)"}`);}for(let G of T)G in W&&(I[G]=W[G]);}let U=Date.now(),H={data:I,createdAt:U};return s!==void 0&&s>0&&(H.expiresAt=U+s*1e3),h&&(H.version=Te(I)),l&&(H.metadata=l),H},watchDistributableSnapshot(e,c){let{includeDerivations:y,excludeDerivations:T}=e,s=Object.keys(S),l;if(y?l=y.filter(M=>s.includes(M)):l=s,T){let M=new Set(T);l=l.filter(L=>!M.has(L));}if(l.length===0)return process.env.NODE_ENV!=="production"&&console.warn("[Directive] watchDistributableSnapshot: No derivations to watch. Callback will never be called."),()=>{};let I=this.getDistributableSnapshot({...e,includeVersion:true}).version;return q.subscribe(l,()=>{let M=this.getDistributableSnapshot({...e,includeVersion:true});M.version!==I&&(I=M.version,c(M));})},restore(e){if(!e||typeof e!="object")throw new Error("[Directive] restore() requires a valid snapshot object");if(!e.facts||typeof e.facts!="object")throw new Error("[Directive] restore() snapshot must have a facts object");if(!oe(e))throw new Error("[Directive] restore() rejected: snapshot contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.");C.batch(()=>{for(let[c,y]of Object.entries(e.facts))ne.has(c)||C.set(c,y);});},onSettledChange(e){return w.add(e),()=>{w.delete(e);}},onTimeTravelChange(e){return K.add(e),()=>{K.delete(e);}},batch(e){C.batch(e);},get isSettled(){return this.inspect().inflight.length===0&&!b.isReconciling&&!b.reconcileScheduled},get isRunning(){return b.isRunning},get isInitialized(){return b.isInitialized},get isReady(){return b.isReady},whenReady(){return b.isReady?Promise.resolve():b.isRunning?(b.readyPromise||(b.readyPromise=new Promise(e=>{b.readyResolve=e;})),b.readyPromise):Promise.reject(new Error("[Directive] whenReady() called before start(). Call system.start() first, then await system.whenReady()."))}};function V(e){if(b.isReconciling)throw new Error(`[Directive] Cannot register module "${e.id}" during reconciliation. Wait for the current reconciliation cycle to complete.`);if(b.isDestroyed)throw new Error(`[Directive] Cannot register module "${e.id}" on a destroyed system.`);let c=(y,T)=>{if(y){for(let s of Object.keys(y))if(ne.has(s))throw new Error(`[Directive] Security: Module "${e.id}" has dangerous key "${s}" in ${T}.`)}};c(e.schema,"schema"),c(e.events,"events"),c(e.derive,"derive"),c(e.effects,"effects"),c(e.constraints,"constraints"),c(e.resolvers,"resolvers");for(let y of Object.keys(e.schema))if(y in n)throw new Error(`[Directive] Schema collision: Fact "${y}" already exists. Cannot register module "${e.id}".`);if(process.env.NODE_ENV!=="production"&&e.derive){let y=new Set(Object.keys(n));for(let T of Object.keys(e.derive))y.has(T)&&console.warn(`[Directive] "${T}" exists as both a fact and a derivation after registering module "${e.id}".`);}Object.assign(n,e.schema),e.events&&Object.assign(g,e.events),e.derive&&(Object.assign(S,e.derive),q.registerDefinitions(e.derive)),e.effects&&(Object.assign(i,e.effects),A.registerDefinitions(e.effects)),e.constraints&&(Object.assign(t,e.constraints),D.registerDefinitions(e.constraints)),e.resolvers&&(Object.assign(d,e.resolvers),P.registerDefinitions(e.resolvers)),C.registerKeys(e.schema),r.modules.push(e),e.init&&C.batch(()=>{e.init(j);}),e.hooks?.onInit?.(F),b.isRunning&&(e.hooks?.onStart?.(F),f());}F.registerModule=V,v.emitInit(F);for(let e of r.modules)e.hooks?.onInit?.(F);return F}var ne,Ye=Z(()=>{xe();Me();Oe();_e();Fe();We();ve();Ue();Ge();ce();ne=new Set(["__proto__","constructor","prototype"]);});var nt={};it(nt,{createSystem:()=>vt});function ht(r){let n=Object.keys(r),g=new Set,S=new Set,i=[],t=[];function d(m){if(g.has(m))return;if(S.has(m)){let u=t.indexOf(m),E=[...t.slice(u),m].join(" \u2192 ");throw new Error(`[Directive] Circular dependency detected: ${E}. Modules cannot have circular crossModuleDeps. Break the cycle by removing one of the cross-module references.`)}S.add(m),t.push(m);let v=r[m];if(v?.crossModuleDeps)for(let u of Object.keys(v.crossModuleDeps))n.includes(u)&&d(u);t.pop(),S.delete(m),g.add(m),i.push(m);}for(let m of n)d(m);return i}function vt(r){if("module"in r){if(!r.module)throw new Error("[Directive] createSystem requires a module. Got: "+typeof r.module);return kt(r)}let n=r;if(Array.isArray(n.modules))throw new Error(`[Directive] createSystem expects modules as an object, not an array.
|
|
3
|
+
|
|
4
|
+
Instead of:
|
|
5
|
+
createSystem({ modules: [authModule, dataModule] })
|
|
6
|
+
|
|
7
|
+
Use:
|
|
8
|
+
createSystem({ modules: { auth: authModule, data: dataModule } })
|
|
9
|
+
|
|
10
|
+
Or for a single module:
|
|
11
|
+
createSystem({ module: counterModule })`);return St(n)}function St(r){let n=r.modules,g=new Set(Object.keys(n));if(r.tickMs!==void 0&&r.tickMs<=0)throw new Error("[Directive] tickMs must be a positive number");if(process.env.NODE_ENV!=="production"){for(let[o,p]of Object.entries(n))if(p.crossModuleDeps)for(let w of Object.keys(p.crossModuleDeps))w===o?console.warn(`[Directive] Module "${o}" references itself in crossModuleDeps. Use "facts.self" to access own module's facts instead.`):g.has(w)||console.warn(`[Directive] Module "${o}" declares crossModuleDeps.${w}, but no module with namespace "${w}" exists in the system. Available modules: ${[...g].join(", ")}`);}let S,i=r.initOrder??"auto";if(Array.isArray(i)){let o=i,p=Object.keys(n).filter(w=>!o.includes(w));if(p.length>0)throw new Error(`[Directive] initOrder is missing modules: ${p.join(", ")}. All modules must be included in the explicit order.`);S=o;}else i==="declaration"?S=Object.keys(n):S=ht(n);let t=r.debug,d=r.errorBoundary;r.zeroConfig&&(t={timeTravel:process.env.NODE_ENV!=="production",maxSnapshots:100,...r.debug},d={onConstraintError:"skip",onResolverError:"skip",onEffectError:"skip",onDerivationError:"skip",...r.errorBoundary});for(let o of Object.keys(n)){if(o.includes(B))throw new Error(`[Directive] Module name "${o}" contains the reserved separator "${B}". Module names cannot contain "${B}".`);let p=n[o];if(p){for(let w of Object.keys(p.schema.facts))if(w.includes(B))throw new Error(`[Directive] Schema key "${w}" in module "${o}" contains the reserved separator "${B}". Schema keys cannot contain "${B}".`)}}let m=[];for(let o of S){let p=n[o];if(!p)continue;let w=p.crossModuleDeps&&Object.keys(p.crossModuleDeps).length>0,$=w?Object.keys(p.crossModuleDeps):[],k={};for(let[e,c]of Object.entries(p.schema.facts))k[`${o}${B}${e}`]=c;let O={};if(p.schema.derivations)for(let[e,c]of Object.entries(p.schema.derivations))O[`${o}${B}${e}`]=c;let b={};if(p.schema.events)for(let[e,c]of Object.entries(p.schema.events))b[`${o}${B}${e}`]=c;let f=p.init?e=>{let c=X(e,o);p.init(c);}:void 0,a={};if(p.derive)for(let[e,c]of Object.entries(p.derive))a[`${o}${B}${e}`]=(y,T)=>{let s=w?re(y,o,$):X(y,o),l=ke(T,o);return c(s,l)};let R={};if(p.events)for(let[e,c]of Object.entries(p.events))R[`${o}${B}${e}`]=(y,T)=>{let s=X(y,o);c(s,T);};let _={};if(p.constraints)for(let[e,c]of Object.entries(p.constraints)){let y=c;_[`${o}${B}${e}`]={...y,deps:y.deps?.map(T=>`${o}${B}${T}`),when:T=>{let s=w?re(T,o,$):X(T,o);return y.when(s)},require:typeof y.require=="function"?T=>{let s=w?re(T,o,$):X(T,o);return y.require(s)}:y.require};}let F={};if(p.resolvers)for(let[e,c]of Object.entries(p.resolvers)){let y=c;F[`${o}${B}${e}`]={...y,resolve:async(T,s)=>{let l=we(s.facts,n,()=>Object.keys(n));await y.resolve(T,{facts:l[o],signal:s.signal});}};}let V={};if(p.effects)for(let[e,c]of Object.entries(p.effects)){let y=c;V[`${o}${B}${e}`]={...y,run:(T,s)=>{let l=w?re(T,o,$):X(T,o),h=s?w?re(s,o,$):X(s,o):void 0;return y.run(l,h)},deps:y.deps?.map(T=>`${o}${B}${T}`)};}m.push({id:p.id,schema:{facts:k,derivations:O,events:b,requirements:p.schema.requirements??{}},init:f,derive:a,events:R,effects:V,constraints:_,resolvers:F,hooks:p.hooks});}process.env.NODE_ENV!=="production"&&r.tickMs&&r.tickMs>0&&(m.some(p=>p.events&&Object.keys(p.events).some(w=>w.endsWith(`${B}tick`)))||console.warn(`[Directive] tickMs is set to ${r.tickMs}ms but no module defines a "tick" event handler.`));let v=null,u=null;function E(o){for(let[p,w]of Object.entries(o)){if(J.has(p)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] initialFacts/hydrate contains blocked namespace "${p}". Skipping.`);continue}if(!g.has(p)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] initialFacts/hydrate contains unknown namespace "${p}". Available modules: ${[...g].join(", ")}`);continue}if(w&&typeof w=="object"&&!oe(w))throw new Error(`[Directive] initialFacts/hydrate for namespace "${p}" contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.`);for(let[$,k]of Object.entries(w))J.has($)||(u.facts[`${p}${B}${$}`]=k);}}u=be({modules:m.map(o=>({id:o.id,schema:o.schema.facts,requirements:o.schema.requirements,init:o.init,derive:o.derive,events:o.events,effects:o.effects,constraints:o.constraints,resolvers:o.resolvers,hooks:o.hooks})),plugins:r.plugins,debug:t,errorBoundary:d,tickMs:r.tickMs,onAfterModuleInit:()=>{r.initialFacts&&E(r.initialFacts),v&&(E(v),v=null);}});let x=new Map;for(let o of Object.keys(n)){let p=n[o];if(!p)continue;let w=[];for(let $ of Object.keys(p.schema.facts))w.push(`${o}${B}${$}`);if(p.schema.derivations)for(let $ of Object.keys(p.schema.derivations))w.push(`${o}${B}${$}`);x.set(o,w);}let N={names:null};function C(){return N.names===null&&(N.names=Object.keys(n)),N.names}let j=we(u.facts,n,C),q=bt(u.derive,n,C),A=wt(u,n,C),D=null,P=r.tickMs;return {_mode:"namespaced",facts:j,debug:u.debug,derive:q,events:A,constraints:u.constraints,effects:u.effects,get isRunning(){return u.isRunning},get isSettled(){return u.isSettled},get isInitialized(){return u.isInitialized},get isReady(){return u.isReady},whenReady:u.whenReady.bind(u),async hydrate(o){if(u.isRunning)throw new Error("[Directive] hydrate() must be called before start(). The system is already running.");let p=await o();p&&typeof p=="object"&&(v=p);},start(){if(u.start(),P&&P>0){let o=Object.keys(m[0]?.events??{}).find(p=>p.endsWith(`${B}tick`));o&&(D=setInterval(()=>{u.dispatch({type:o});},P));}},stop(){D&&(clearInterval(D),D=null),u.stop();},destroy(){this.stop(),u.destroy();},dispatch(o){u.dispatch(o);},batch:u.batch.bind(u),read(o){return u.read(se(o))},subscribe(o,p){let w=[];for(let $ of o)if($.endsWith(".*")){let k=$.slice(0,-2),O=x.get(k);O?w.push(...O):process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribe wildcard "${$}" \u2014 namespace "${k}" not found.`);}else w.push(se($));return u.subscribe(w,p)},subscribeModule(o,p){let w=x.get(o);return !w||w.length===0?(process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribeModule("${o}") \u2014 namespace not found. Available: ${[...x.keys()].join(", ")}`),()=>{}):u.subscribe(w,p)},watch(o,p,w){return u.watch(se(o),p,w)},when(o,p){return u.when(()=>o(j),p)},onSettledChange:u.onSettledChange.bind(u),onTimeTravelChange:u.onTimeTravelChange.bind(u),inspect:u.inspect.bind(u),settle:u.settle.bind(u),explain:u.explain.bind(u),getSnapshot:u.getSnapshot.bind(u),restore:u.restore.bind(u),getDistributableSnapshot(o){let p={...o,includeDerivations:o?.includeDerivations?.map(se),excludeDerivations:o?.excludeDerivations?.map(se),includeFacts:o?.includeFacts?.map(se)},w=u.getDistributableSnapshot(p),$={};for(let[k,O]of Object.entries(w.data)){let b=k.indexOf(B);if(b>0){let f=k.slice(0,b),a=k.slice(b+B.length);$[f]||($[f]={}),$[f][a]=O;}else $._root||($._root={}),$._root[k]=O;}return {...w,data:$}},watchDistributableSnapshot(o,p){let w={...o,includeDerivations:o?.includeDerivations?.map(se),excludeDerivations:o?.excludeDerivations?.map(se),includeFacts:o?.includeFacts?.map(se)};return u.watchDistributableSnapshot(w,$=>{let k={};for(let[O,b]of Object.entries($.data)){let f=O.indexOf(B);if(f>0){let a=O.slice(0,f),R=O.slice(f+B.length);k[a]||(k[a]={}),k[a][R]=b;}else k._root||(k._root={}),k._root[O]=b;}p({...$,data:k});})},registerModule(o,p){if(g.has(o))throw new Error(`[Directive] Module namespace "${o}" already exists. Cannot register a duplicate namespace.`);if(o.includes(B))throw new Error(`[Directive] Module name "${o}" contains the reserved separator "${B}".`);if(J.has(o))throw new Error(`[Directive] Module name "${o}" is a blocked property.`);for(let e of Object.keys(p.schema.facts))if(e.includes(B))throw new Error(`[Directive] Schema key "${e}" in module "${o}" contains the reserved separator "${B}".`);let w=p,$=w.crossModuleDeps&&Object.keys(w.crossModuleDeps).length>0,k=$?Object.keys(w.crossModuleDeps):[],O={};for(let[e,c]of Object.entries(w.schema.facts))O[`${o}${B}${e}`]=c;let b=w.init?e=>{let c=X(e,o);w.init(c);}:void 0,f={};if(w.derive)for(let[e,c]of Object.entries(w.derive))f[`${o}${B}${e}`]=(y,T)=>{let s=$?re(y,o,k):X(y,o),l=ke(T,o);return c(s,l)};let a={};if(w.events)for(let[e,c]of Object.entries(w.events))a[`${o}${B}${e}`]=(y,T)=>{let s=X(y,o);c(s,T);};let R={};if(w.constraints)for(let[e,c]of Object.entries(w.constraints)){let y=c;R[`${o}${B}${e}`]={...y,deps:y.deps?.map(T=>`${o}${B}${T}`),when:T=>{let s=$?re(T,o,k):X(T,o);return y.when(s)},require:typeof y.require=="function"?T=>{let s=$?re(T,o,k):X(T,o);return y.require(s)}:y.require};}let _={};if(w.resolvers)for(let[e,c]of Object.entries(w.resolvers)){let y=c;_[`${o}${B}${e}`]={...y,resolve:async(T,s)=>{let l=we(s.facts,n,C);await y.resolve(T,{facts:l[o],signal:s.signal});}};}let F={};if(w.effects)for(let[e,c]of Object.entries(w.effects)){let y=c;F[`${o}${B}${e}`]={...y,run:(T,s)=>{let l=$?re(T,o,k):X(T,o),h=s?$?re(s,o,k):X(s,o):void 0;return y.run(l,h)},deps:y.deps?.map(T=>`${o}${B}${T}`)};}g.add(o),n[o]=w,N.names=null;let V=[];for(let e of Object.keys(w.schema.facts))V.push(`${o}${B}${e}`);if(w.schema.derivations)for(let e of Object.keys(w.schema.derivations))V.push(`${o}${B}${e}`);x.set(o,V),u.registerModule({id:w.id,schema:O,requirements:w.schema.requirements??{},init:b,derive:Object.keys(f).length>0?f:void 0,events:Object.keys(a).length>0?a:void 0,effects:Object.keys(F).length>0?F:void 0,constraints:Object.keys(R).length>0?R:void 0,resolvers:Object.keys(_).length>0?_:void 0,hooks:w.hooks});}}}function se(r){if(r.includes(".")){let[n,...g]=r.split(".");return `${n}${B}${g.join(B)}`}return r}function X(r,n){let g=Je.get(r);if(g){let i=g.get(n);if(i)return i}else g=new Map,Je.set(r,g);let S=new Proxy({},{get(i,t){if(typeof t!="symbol"&&!J.has(t))return t==="$store"||t==="$snapshot"?r[t]:r[`${n}${B}${t}`]},set(i,t,d){return typeof t=="symbol"||J.has(t)?false:(r[`${n}${B}${t}`]=d,true)},has(i,t){return typeof t=="symbol"||J.has(t)?false:`${n}${B}${t}`in r},deleteProperty(i,t){return typeof t=="symbol"||J.has(t)?false:(delete r[`${n}${B}${t}`],true)}});return g.set(n,S),S}function we(r,n,g){let S=Qe.get(r);if(S)return S;let i=new Proxy({},{get(t,d){if(typeof d!="symbol"&&!J.has(d)&&Object.hasOwn(n,d))return X(r,d)},has(t,d){return typeof d=="symbol"||J.has(d)?false:Object.hasOwn(n,d)},ownKeys(){return g()},getOwnPropertyDescriptor(t,d){if(typeof d!="symbol"&&Object.hasOwn(n,d))return {configurable:true,enumerable:true}}});return Qe.set(r,i),i}function re(r,n,g){let S=`${n}:${JSON.stringify([...g].sort())}`,i=et.get(r);if(i){let v=i.get(S);if(v)return v}else i=new Map,et.set(r,i);let t=new Set(g),d=["self",...g],m=new Proxy({},{get(v,u){if(typeof u!="symbol"&&!J.has(u)){if(u==="self")return X(r,n);if(t.has(u))return X(r,u);process.env.NODE_ENV!=="production"&&typeof u=="string"&&console.warn(`[Directive] Module "${n}" accessed undeclared cross-module property "${u}". Add it to crossModuleDeps or use "facts.self.${u}" for own module facts.`);}},has(v,u){return typeof u=="symbol"||J.has(u)?false:u==="self"||t.has(u)},ownKeys(){return d},getOwnPropertyDescriptor(v,u){if(typeof u!="symbol"&&(u==="self"||t.has(u)))return {configurable:true,enumerable:true}}});return i.set(S,m),m}function ke(r,n){let g=Ze.get(r);if(g){let i=g.get(n);if(i)return i}else g=new Map,Ze.set(r,g);let S=new Proxy({},{get(i,t){if(typeof t!="symbol"&&!J.has(t))return r[`${n}${B}${t}`]},has(i,t){return typeof t=="symbol"||J.has(t)?false:`${n}${B}${t}`in r}});return g.set(n,S),S}function bt(r,n,g){let S=Xe.get(r);if(S)return S;let i=new Proxy({},{get(t,d){if(typeof d!="symbol"&&!J.has(d)&&Object.hasOwn(n,d))return ke(r,d)},has(t,d){return typeof d=="symbol"||J.has(d)?false:Object.hasOwn(n,d)},ownKeys(){return g()},getOwnPropertyDescriptor(t,d){if(typeof d!="symbol"&&Object.hasOwn(n,d))return {configurable:true,enumerable:true}}});return Xe.set(r,i),i}function wt(r,n,g){let S=tt.get(r);return S||(S=new Map,tt.set(r,S)),new Proxy({},{get(i,t){if(typeof t=="symbol"||J.has(t)||!Object.hasOwn(n,t))return;let d=S.get(t);if(d)return d;let m=new Proxy({},{get(v,u){if(typeof u!="symbol"&&!J.has(u))return E=>{r.dispatch({type:`${t}${B}${u}`,...E});}}});return S.set(t,m),m},has(i,t){return typeof t=="symbol"||J.has(t)?false:Object.hasOwn(n,t)},ownKeys(){return g()},getOwnPropertyDescriptor(i,t){if(typeof t!="symbol"&&Object.hasOwn(n,t))return {configurable:true,enumerable:true}}})}function kt(r){let n=r.module;if(!n)throw new Error("[Directive] createSystem requires a module. Got: "+typeof n);if(r.tickMs!==void 0&&r.tickMs<=0)throw new Error("[Directive] tickMs must be a positive number");if(r.initialFacts&&!oe(r.initialFacts))throw new Error("[Directive] initialFacts contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.");process.env.NODE_ENV!=="production"&&(n.crossModuleDeps&&Object.keys(n.crossModuleDeps).length>0&&console.warn("[Directive] Single module mode ignores crossModuleDeps. Use multiple modules if cross-module access is needed: createSystem({ modules: { ... } })"),r.tickMs&&r.tickMs>0&&(n.events&&"tick"in n.events||console.warn(`[Directive] tickMs is set to ${r.tickMs}ms but module has no "tick" event handler.`)));let g=r.debug,S=r.errorBoundary;r.zeroConfig&&(g={timeTravel:process.env.NODE_ENV!=="production",maxSnapshots:100,...r.debug},S={onConstraintError:"skip",onResolverError:"skip",onEffectError:"skip",onDerivationError:"skip",...r.errorBoundary});let i=null,t=null;t=be({modules:[{id:n.id,schema:n.schema.facts,requirements:n.schema.requirements,init:n.init,derive:n.derive,events:n.events,effects:n.effects,constraints:n.constraints,resolvers:n.resolvers,hooks:n.hooks}],plugins:r.plugins,debug:g,errorBoundary:S,tickMs:r.tickMs,onAfterModuleInit:()=>{if(r.initialFacts)for(let[E,x]of Object.entries(r.initialFacts))J.has(E)||(t.facts[E]=x);if(i){for(let[E,x]of Object.entries(i))J.has(E)||(t.facts[E]=x);i=null;}}});let d=new Proxy({},{get(E,x){if(typeof x!="symbol"&&!J.has(x))return N=>{t.dispatch({type:x,...N});}}}),m=null,v=r.tickMs;return {_mode:"single",facts:t.facts,debug:t.debug,derive:t.derive,events:d,constraints:t.constraints,effects:t.effects,get isRunning(){return t.isRunning},get isSettled(){return t.isSettled},get isInitialized(){return t.isInitialized},get isReady(){return t.isReady},whenReady:t.whenReady.bind(t),async hydrate(E){if(t.isRunning)throw new Error("[Directive] hydrate() must be called before start(). The system is already running.");let x=await E();x&&typeof x=="object"&&(i=x);},start(){t.start(),v&&v>0&&n.events&&"tick"in n.events&&(m=setInterval(()=>{t.dispatch({type:"tick"});},v));},stop(){m&&(clearInterval(m),m=null),t.stop();},destroy(){this.stop(),t.destroy();},dispatch(E){t.dispatch(E);},batch:t.batch.bind(t),read(E){return t.read(E)},subscribe(E,x){return t.subscribe(E,x)},watch(E,x,N){return t.watch(E,x,N)},when(E,x){return t.when(E,x)},onSettledChange:t.onSettledChange.bind(t),onTimeTravelChange:t.onTimeTravelChange.bind(t),inspect:t.inspect.bind(t),settle:t.settle.bind(t),explain:t.explain.bind(t),getSnapshot:t.getSnapshot.bind(t),restore:t.restore.bind(t),getDistributableSnapshot:t.getDistributableSnapshot.bind(t),watchDistributableSnapshot:t.watchDistributableSnapshot.bind(t),registerModule(E){t.registerModule({id:E.id,schema:E.schema.facts,requirements:E.schema.requirements,init:E.init,derive:E.derive,events:E.events,effects:E.effects,constraints:E.constraints,resolvers:E.resolvers,hooks:E.hooks});}}}var J,B,Je,Qe,Xe,Ze,et,tt,rt=Z(()=>{Ye();ce();J=Object.freeze(new Set(["__proto__","constructor","prototype"])),B="::";Je=new WeakMap,Qe=new WeakMap,Xe=new WeakMap,Ze=new WeakMap;et=new WeakMap;tt=new WeakMap;});function ln(r){let{worker:n,onFactChange:g,onDerivationChange:S,onRequirementCreated:i,onRequirementMet:t,onError:d}=r,m=new Map,v=0,u=null,E=null,x=null,N=null;n.onmessage=q=>{let A=q.data;switch(A.type){case "READY":u?.(),u=null;break;case "STARTED":E?.(),E=null;break;case "STOPPED":x?.(),x=null;break;case "DESTROYED":N?.(),N=null;break;case "FACT_CHANGED":g?.(A.key,A.value,A.prev);break;case "DERIVATION_CHANGED":S?.(A.key,A.value);break;case "REQUIREMENT_CREATED":i?.(A.requirement);break;case "REQUIREMENT_MET":t?.(A.requirementId,A.resolverId);break;case "ERROR":d?.(A.error,A.source);break;case "SNAPSHOT_RESULT":{let D=m.get(A.requestId);D&&(D.resolve(A.snapshot),m.delete(A.requestId));break}case "INSPECT_RESULT":{let D=m.get(A.requestId);D&&(D.resolve(A.inspection),m.delete(A.requestId));break}case "SETTLE_RESULT":{let D=m.get(A.requestId);D&&(A.success?D.resolve(void 0):D.reject(new Error(A.error||"Settle failed")),m.delete(A.requestId));break}}},n.onerror=q=>{d?.(q.message,"worker");};function C(q){n.postMessage(q);}function j(q){return new Promise((A,D)=>{m.set(q.requestId,{resolve:A,reject:D}),C(q);})}return {init(q){return new Promise(A=>{u=A,C({type:"INIT",config:q});})},start(){return new Promise(q=>{E=q,C({type:"START"});})},stop(){return new Promise(q=>{x=q,C({type:"STOP"});})},destroy(){return new Promise(q=>{N=q,C({type:"DESTROY"});})},setFact(q,A){C({type:"SET_FACT",key:q,value:A});},setFacts(q){C({type:"SET_FACTS",facts:q});},dispatch(q){C({type:"DISPATCH",event:q});},getSnapshot(q){let A=`snapshot-${++v}`;return j({type:"GET_SNAPSHOT",options:q,requestId:A})},inspect(){let q=`inspect-${++v}`;return j({type:"INSPECT",requestId:q})},settle(q){let A=`settle-${++v}`;return j({type:"SETTLE",timeout:q,requestId:A})},terminate(){n.terminate();}}}var Re=null;function st(){return Re||(Re=new Map),Re}function fn(r,n){st().set(r,n);}function gn(){let r=null;self.onmessage=async n=>{let g=n.data;try{switch(g.type){case "INIT":{r=await Rt(g.config),postMessage({type:"READY"});break}case "START":{r&&(r.start(),postMessage({type:"STARTED"}));break}case "STOP":{r&&(r.stop(),postMessage({type:"STOPPED"}));break}case "DESTROY":{r&&(r.destroy(),r=null,postMessage({type:"DESTROYED"}));break}case "SET_FACT":{r&&r.setFact(g.key,g.value);break}case "SET_FACTS":{r&&r.setFacts(g.facts);break}case "DISPATCH":{r&&r.dispatch(g.event);break}case "GET_SNAPSHOT":{if(r){let S=r.getSnapshot(g.options);postMessage({type:"SNAPSHOT_RESULT",requestId:g.requestId,snapshot:S});}break}case "INSPECT":{if(r){let S=r.inspect();postMessage({type:"INSPECT_RESULT",requestId:g.requestId,inspection:S});}break}case "SETTLE":{if(r)try{await r.settle(g.timeout),postMessage({type:"SETTLE_RESULT",requestId:g.requestId,success:!0});}catch(S){postMessage({type:"SETTLE_RESULT",requestId:g.requestId,success:!1,error:S instanceof Error?S.message:String(S)});}break}}}catch(S){postMessage({type:"ERROR",error:S instanceof Error?S.message:String(S),source:g.type});}};}async function Rt(r){let{createSystem:n}=await Promise.resolve().then(()=>(rt(),nt)),g=st(),S={};for(let d of r.moduleNames){let m=g.get(d);if(!m)throw new Error(`[Directive Worker] Module "${d}" not registered. Call registerWorkerModule('${d}', module) before handling messages.`);S[d]=m;}let t=n({modules:S,plugins:[{name:"__worker-tracking__",onFactSet:(d,m,v)=>{postMessage({type:"FACT_CHANGED",key:d,value:m,prev:v});},onDerivationCompute:(d,m)=>{postMessage({type:"DERIVATION_CHANGED",key:d,value:m});},onRequirementCreated:d=>{postMessage({type:"REQUIREMENT_CREATED",requirement:{...d.requirement,id:d.id}});},onRequirementMet:(d,m)=>{postMessage({type:"REQUIREMENT_MET",requirementId:d.id,resolverId:m});}}],debug:r.debug});return {start:()=>t.start(),stop:()=>t.stop(),destroy:()=>t.destroy(),setFact:(d,m)=>{t.facts[d]=m;},setFacts:d=>{let m=t.facts;if(m.$store?.batch)m.$store.batch(()=>{for(let[v,u]of Object.entries(d))m[v]=u;});else for(let[v,u]of Object.entries(d))m[v]=u;},dispatch:d=>{t.dispatch(d);},getSnapshot:d=>t.getDistributableSnapshot(d),inspect:()=>t.inspect(),settle:d=>t.settle(d)}}export{ln as createWorkerClient,st as getWorkerModuleRegistry,gn as handleWorkerMessages,fn as registerWorkerModule};//# sourceMappingURL=worker.js.map
|
|
12
|
+
//# sourceMappingURL=worker.js.map
|