@statedelta-actions/actions 0.5.0 → 0.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +120 -0
- package/LICENSE +21 -0
- package/README.md +122 -0
- package/dist/index.cjs +8 -8
- package/dist/index.d.cts +186 -38
- package/dist/index.d.ts +186 -38
- package/dist/index.js +8 -8
- package/package.json +17 -3
package/CHANGELOG.md
ADDED
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
# @statedelta-actions/actions
|
|
2
|
+
|
|
3
|
+
## 0.7.0
|
|
4
|
+
|
|
5
|
+
### Minor Changes
|
|
6
|
+
|
|
7
|
+
- fc436a7: Add sub-directives descriptor (ADR-029)
|
|
8
|
+
|
|
9
|
+
Handlers can now declare child sub-array fields via `subDirectives` —
|
|
10
|
+
feeds register validation (with `required` throw), normalize, mini-graph
|
|
11
|
+
propagation (async/interactive transitive) and analyzer walks
|
|
12
|
+
(denied-scan, capabilities). `if` and `catch` remain hardcoded with
|
|
13
|
+
their optimizations; descriptor is additive.
|
|
14
|
+
|
|
15
|
+
`HandlerDefinition` and `SubDirectiveFieldConfig` gain inspection
|
|
16
|
+
metadata exposed via `engine.handlerDefinitions`: `description`, `tags`,
|
|
17
|
+
`deprecated`, `since`, `aliasOf` on the handler; `description`,
|
|
18
|
+
`purpose`, `examples`, `tags` on sub-fields.
|
|
19
|
+
|
|
20
|
+
The analyzer's `IAnalyzableEngine` interface gains
|
|
21
|
+
`subDirectiveFieldsForGraph` (consumers implementing it for tests/mocks
|
|
22
|
+
must add the field). Bug fix bundled: denied-scan and capabilities walk
|
|
23
|
+
now recurse into `if.then`/`if.else` (previously only `catch`).
|
|
24
|
+
|
|
25
|
+
New `validate` script (`pnpm typecheck && pnpm lint`) on both packages.
|
|
26
|
+
|
|
27
|
+
## 0.6.0
|
|
28
|
+
|
|
29
|
+
### Minor Changes
|
|
30
|
+
|
|
31
|
+
- a3a818b: `HandlerDefinition` is now a discriminated union by execution mode
|
|
32
|
+
|
|
33
|
+
`HandlerDefinition<TCtx>` is `SyncHandlerDefinition<TCtx> | AsyncHandlerDefinition<TCtx> | InteractiveHandlerDefinition<TCtx>` — the `async` / `interactive` flags discriminate, and `execute` refines its return type per mode (`ApplyResult` for sync, `Promise<ApplyResult>` for async, `Generator<unknown, ApplyResult, unknown> | AsyncGenerator<unknown, ApplyResult, unknown>` for interactive). Consumers that call `handler.execute(...)` directly (tests, wrappers) — typing the handler as a subtype, or narrowing the union via the flags — no longer get the wide `ApplyResult | Promise<ApplyResult>` union for a handler they know is sync.
|
|
34
|
+
|
|
35
|
+
New exports: `HandlerBaseDefinition`, `SyncHandlerDefinition`, `AsyncHandlerDefinition`, `InteractiveHandlerDefinition`, `SyncHandlerExecute`, `AsyncHandlerExecute`, `InteractiveHandlerExecute`.
|
|
36
|
+
|
|
37
|
+
**Breaking (minor, pre-1.0):**
|
|
38
|
+
- A V2 handler that is `async` or `interactive` must now declare the `async: true` / `interactive: true` flag to satisfy the type. `{ async execute() {} }` without `async: true` no longer matches `HandlerDefinition` (it matches no subtype: sync requires a sync return, async/interactive require the flag). Runtime auto-detection via `isAsyncFunction` / `isGeneratorFunction` still works as a safety net — the type just forces the declaration to be explicit for V2.
|
|
39
|
+
- `HandlerDefinition<TCtx>["execute"]` is wider than before (it now includes the `Generator | AsyncGenerator` arm) — code that assigned `handler.execute` to `(...) => ApplyResult | Promise<ApplyResult>` needs to narrow or use a subtype. (This also fixes a latent bug: interactive handlers' `execute` previously violated the declared type silently.)
|
|
40
|
+
- V1 handlers (plain functions) and `HandlerInput<TCtx>` are unchanged.
|
|
41
|
+
|
|
42
|
+
### Patch Changes
|
|
43
|
+
|
|
44
|
+
- 26c579a: Polish published package metadata and READMEs
|
|
45
|
+
- `@statedelta-actions/core` now ships a README (was missing on npm).
|
|
46
|
+
- `@statedelta-actions/analyzer` README: fixed pervasive missing accents.
|
|
47
|
+
- `graph` and `events` READMEs: titles are now the package name (`# @statedelta-actions/graph` / `# @statedelta-actions/events`) instead of a conceptual name.
|
|
48
|
+
- All packages: added `keywords`, `homepage`, `bugs`; package.json keys reordered to a canonical layout.
|
|
49
|
+
- All packages: `CHANGELOG.md` added to `files` so it ships to npm; a `LICENSE` (MIT) file is included in the repo root and in each package.
|
|
50
|
+
|
|
51
|
+
- Updated dependencies [26c579a]
|
|
52
|
+
- @statedelta-actions/core@0.5.1
|
|
53
|
+
|
|
54
|
+
## 0.5.0
|
|
55
|
+
|
|
56
|
+
### Minor Changes
|
|
57
|
+
|
|
58
|
+
- f8c2b4a: Fail-fast register errors, controlled `action-not-found`, atomic registration, and events async/interactive modes
|
|
59
|
+
- **actions** — A missing handler for a directive type now throws at register
|
|
60
|
+
time (was a collected error) — fail-fast for typos and forgotten handlers.
|
|
61
|
+
Invoking an unknown action id returns `aborted: true, abortedBy:
|
|
62
|
+
"action-not-found"` instead of a soft failure. `isActionAsync` is exposed on
|
|
63
|
+
the engine ref handed to handlers (symmetric with `isActionInteractive`).
|
|
64
|
+
- **rules** — `register()` is atomic: it builds a staging set, delegates to the
|
|
65
|
+
ActionEngine, then indexes locally only on success. Structural errors from the
|
|
66
|
+
ActionEngine propagate as a throw with no local state mutated.
|
|
67
|
+
- **events** — `register()`/`defineEvents()` are atomic the same way.
|
|
68
|
+
Async detection is now per-listener transitive via the ActionEngine mini-graph,
|
|
69
|
+
so hybrid engines keep `processEvents`/`processEventsAsync` viable for
|
|
70
|
+
listeners whose subtree is fully sync. New `processEventsInteractive()` returns
|
|
71
|
+
a drainable iterator (sync or async generator) — pauses from `type:"pause"` or
|
|
72
|
+
an interactive handler flow via `yield*` up to the consumer; halt scoping is
|
|
73
|
+
preserved (a pause stops the listeners of that event, following events
|
|
74
|
+
continue). New `isInteractive` getter.
|
|
75
|
+
- **core** — `ActionEngineRef` gains an optional `isActionAsync?` accessor.
|
|
76
|
+
- **sdk** — re-exports the new event types/surface; barrel deps moved to
|
|
77
|
+
`dependencies` (`workspace:^`).
|
|
78
|
+
|
|
79
|
+
### Patch Changes
|
|
80
|
+
|
|
81
|
+
- Updated dependencies [f8c2b4a]
|
|
82
|
+
- @statedelta-actions/core@0.5.0
|
|
83
|
+
|
|
84
|
+
## 0.3.0
|
|
85
|
+
|
|
86
|
+
### Minor Changes
|
|
87
|
+
|
|
88
|
+
- Split types em definitions + engine em cada package; novo subpath sdk/definitions
|
|
89
|
+
- core: RegisterWarning movido pra core/types/engine.ts (tipo shared entre packages)
|
|
90
|
+
- actions: types.ts → types/definitions.ts + types/engine.ts
|
|
91
|
+
- rules: types.ts → types/definitions.ts + types/engine.ts
|
|
92
|
+
- events: types.ts → types/definitions.ts + types/engine.ts
|
|
93
|
+
- sdk: novo subpath ./definitions com re-export de definition types puros (zero runtime)
|
|
94
|
+
|
|
95
|
+
### Patch Changes
|
|
96
|
+
|
|
97
|
+
- Updated dependencies []:
|
|
98
|
+
- @statedelta-actions/core@0.3.0
|
|
99
|
+
|
|
100
|
+
## 0.2.0
|
|
101
|
+
|
|
102
|
+
### Minor Changes
|
|
103
|
+
|
|
104
|
+
- Sync all packages to 0.2.0 (match SDK version)
|
|
105
|
+
|
|
106
|
+
### Patch Changes
|
|
107
|
+
|
|
108
|
+
- Updated dependencies []:
|
|
109
|
+
- @statedelta-actions/core@0.2.0
|
|
110
|
+
|
|
111
|
+
## 0.3.0
|
|
112
|
+
|
|
113
|
+
### Minor Changes
|
|
114
|
+
|
|
115
|
+
- Sync all packages to 0.2.0 (match SDK version)
|
|
116
|
+
|
|
117
|
+
### Patch Changes
|
|
118
|
+
|
|
119
|
+
- Updated dependencies []:
|
|
120
|
+
- @statedelta-actions/core@0.3.0
|
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2026 Anderson D. Rosa
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
CHANGED
|
@@ -131,6 +131,123 @@ const handlers = {
|
|
|
131
131
|
| `execute` | Runtime | Processa a diretiva e retorna resultado |
|
|
132
132
|
| `analyze` | — | Consumido pelo `ActionAnalyzer` externo, não pelo engine |
|
|
133
133
|
| `async` (flag) | Construct | Marca handler como assíncrono (opt-in explícito) |
|
|
134
|
+
| `subDirectives` | Register | Declara campos com sub-arrays que entram no grafo |
|
|
135
|
+
|
|
136
|
+
### Sub-Directives — handlers com filhos no grafo
|
|
137
|
+
|
|
138
|
+
Handlers customizados podem ter **sub-arrays de diretivas** que participam do grafo de análise (deps, async/interactive transitivo, denied-scan, capabilities). Em vez de o engine hardcodear nomes como `then`/`else`/`catch`, o handler declara explicitamente quais campos da sua diretiva são sub-blocos:
|
|
139
|
+
|
|
140
|
+
```typescript
|
|
141
|
+
const handlers = {
|
|
142
|
+
simulate: {
|
|
143
|
+
subDirectives: {
|
|
144
|
+
directives: { required: true },
|
|
145
|
+
},
|
|
146
|
+
execute(d, frame, engine) {
|
|
147
|
+
beginTransaction(frame.ctx);
|
|
148
|
+
const r = engine.runDirectives(d.directives, frame);
|
|
149
|
+
if (!r.success) rollback(frame.ctx);
|
|
150
|
+
else commit(frame.ctx);
|
|
151
|
+
return { ok: r.success, data: r.data };
|
|
152
|
+
},
|
|
153
|
+
},
|
|
154
|
+
|
|
155
|
+
try_: {
|
|
156
|
+
subDirectives: {
|
|
157
|
+
body: { required: true },
|
|
158
|
+
catch: { required: false },
|
|
159
|
+
finally: { required: false },
|
|
160
|
+
},
|
|
161
|
+
execute(d, frame, engine) {
|
|
162
|
+
const r = engine.runDirectives(d.body, frame);
|
|
163
|
+
if (!r.success && d.catch) {
|
|
164
|
+
frame.scope.$exception = r.errors[0]?.message;
|
|
165
|
+
engine.runDirectives(d.catch, frame);
|
|
166
|
+
}
|
|
167
|
+
if (d.finally) engine.runDirectives(d.finally, frame);
|
|
168
|
+
return { ok: r.success, data: r.data };
|
|
169
|
+
},
|
|
170
|
+
},
|
|
171
|
+
};
|
|
172
|
+
```
|
|
173
|
+
|
|
174
|
+
Uso na action:
|
|
175
|
+
|
|
176
|
+
```typescript
|
|
177
|
+
engine.register([{
|
|
178
|
+
id: "checkout",
|
|
179
|
+
directives: [
|
|
180
|
+
{
|
|
181
|
+
type: "simulate",
|
|
182
|
+
directives: [ // ← entra no grafo
|
|
183
|
+
{ type: "action", id: "charge" }, // edge: checkout → charge
|
|
184
|
+
{ type: "fetchUserAsync", id: 1 }, // checkout vira async transitivo
|
|
185
|
+
],
|
|
186
|
+
},
|
|
187
|
+
],
|
|
188
|
+
}]);
|
|
189
|
+
```
|
|
190
|
+
|
|
191
|
+
**Comportamento estrutural:**
|
|
192
|
+
|
|
193
|
+
| Campo | Default | Efeito |
|
|
194
|
+
|-------|---------|--------|
|
|
195
|
+
| `required: true` | — | Campo ausente ou não-array → throw em register-time |
|
|
196
|
+
| `required: false` | ✓ | Campo ausente é tratado como `[]` silenciosamente |
|
|
197
|
+
| `graph: true` | ✓ | Sub-array participa de mini-graph e walks do analyzer |
|
|
198
|
+
| `graph: false` | — | Sub-array é validado estruturalmente mas NÃO conta como path de execução (ex: campos de metadata/preview) |
|
|
199
|
+
|
|
200
|
+
**Importante:**
|
|
201
|
+
- O descritor é **puramente estrutural** — não interfere na execução. O handler `execute` decide se, quando e como rodar os sub-blocos via `engine.runDirectives` / `runDirectivesAsync`.
|
|
202
|
+
- `if` e `catch` permanecem hardcoded — primitivas do engine com otimizações específicas. O novo descritor é **aditivo**.
|
|
203
|
+
- Sub-directives são **propagadas transitivamente**: action que usa `simulate` cujo sub-bloco invoca handler async automaticamente vira async — `engine.isActionAsync("checkout")` retorna `true`.
|
|
204
|
+
|
|
205
|
+
### Inspection metadata
|
|
206
|
+
|
|
207
|
+
Tanto o `HandlerDefinition` quanto cada `SubDirectiveFieldConfig` aceitam campos de inspeção opcionais — zero custo runtime, expostos via `engine.handlerDefinitions` accessor pra tooling, DSL JSON externo, IDE hover docs, documentação auto-gerada:
|
|
208
|
+
|
|
209
|
+
```typescript
|
|
210
|
+
const try_: HandlerDefinition = {
|
|
211
|
+
description: "Executa body; em falha executa catch; finally roda sempre.",
|
|
212
|
+
tags: ["control-flow", "error-handling"],
|
|
213
|
+
since: "0.5.0",
|
|
214
|
+
// deprecated: "use 'tryAsync' since v0.6",
|
|
215
|
+
// aliasOf: "tryAsync",
|
|
216
|
+
|
|
217
|
+
subDirectives: {
|
|
218
|
+
body: {
|
|
219
|
+
required: true,
|
|
220
|
+
purpose: "body",
|
|
221
|
+
description: "Diretivas tentadas. Falha dispara catch.",
|
|
222
|
+
examples: [[{ type: "action", id: "charge" }]],
|
|
223
|
+
tags: ["execution"],
|
|
224
|
+
},
|
|
225
|
+
catch: {
|
|
226
|
+
required: false,
|
|
227
|
+
purpose: "catch",
|
|
228
|
+
description: "Diretivas executadas em falha. scope.$exception disponível.",
|
|
229
|
+
},
|
|
230
|
+
finally: {
|
|
231
|
+
required: false,
|
|
232
|
+
purpose: "finalizer",
|
|
233
|
+
},
|
|
234
|
+
},
|
|
235
|
+
|
|
236
|
+
execute(d, frame, engine) { /* ... */ },
|
|
237
|
+
};
|
|
238
|
+
```
|
|
239
|
+
|
|
240
|
+
Campos suportados:
|
|
241
|
+
|
|
242
|
+
| Campo | Nível | Tipo | Uso típico |
|
|
243
|
+
|-------|-------|------|-----------|
|
|
244
|
+
| `description` | handler + sub-campo | `string` | Hover docs em IDE, descoberta de esquema por DSL |
|
|
245
|
+
| `tags` | handler + sub-campo | `string[]` | Categorização cruzada, filtros |
|
|
246
|
+
| `purpose` | sub-campo | `string` | Label semântico (`"body"`, `"catch"`, `"branch"`, `"finalizer"`, `"metadata"`, custom) |
|
|
247
|
+
| `examples` | sub-campo | `Directive[][]` | DSL/IDE autocomplete, docs auto-geradas |
|
|
248
|
+
| `deprecated` | handler | `boolean \| string` | Marca obsolescência, mensagem de migração |
|
|
249
|
+
| `since` | handler | `string` | Versionamento (semver ou livre) |
|
|
250
|
+
| `aliasOf` | handler | `string` | Declara alias semântico de outro handler |
|
|
134
251
|
|
|
135
252
|
### Handlers Async
|
|
136
253
|
|
|
@@ -388,6 +505,10 @@ engine.getActionDefinition("heal"); // ActionDefinition | undefined
|
|
|
388
505
|
// Campo de tipo pra dispatch de diretivas
|
|
389
506
|
engine.typeField; // string (default: "type")
|
|
390
507
|
|
|
508
|
+
// Map `type → readonly fieldNames[]` dos campos de sub-directives no grafo
|
|
509
|
+
// (HandlerDefinition.subDirectives com graph !== false; "catch" filtrado)
|
|
510
|
+
engine.subDirectiveFieldsForGraph; // ReadonlyMap<string, readonly string[]>
|
|
511
|
+
|
|
391
512
|
// Mapa de permissões de diretivas (computado no boot, imutável)
|
|
392
513
|
engine.directivePermissions; // ReadonlyMap<string, DirectivePermission>
|
|
393
514
|
|
|
@@ -598,6 +719,7 @@ import type {
|
|
|
598
719
|
HandlerDefinition,
|
|
599
720
|
HandlerAnalysis,
|
|
600
721
|
ValidationResult,
|
|
722
|
+
SubDirectiveFieldConfig,
|
|
601
723
|
HandlerInput,
|
|
602
724
|
HandlerInputMap,
|
|
603
725
|
ActionDefinition,
|
package/dist/index.cjs
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
'use strict';var core=require('@statedelta-actions/core');function Ae(s,e){let r;for(;;){let i=s.next(r);if(i.done)return i.value;r=e?e(i.value):void 0;}}async function Re(s,e){let r;for(;;){let i=await s.next(r);if(i.done)return i.value;r=e?await e(i.value):void 0;}}function Ie(s){let e=0;return ()=>{if(!(e>=s.length))return s[e++]}}var j=class{_listeners=new Map;on(e,r){let i=this._listeners.get(e);i||(i=new Set,this._listeners.set(e,i)),i.add(r);let o=false;return ()=>{o||(o=true,i.delete(r),i.size===0&&this._listeners.delete(e));}}once(e,r){let i=this.on(e,o=>{i(),r(o);});return i}emit(e,r){let i=this._listeners.get(e);if(!i||i.size===0)return;let o=[...i];for(let t=0;t<o.length;t++)try{o[t](r);}catch(n){console.error(`[SimpleEmitter] Listener error on "${e}":`,n);}}listenerCount(e){return this._listeners.get(e)?.size??0}hasListeners(e){let r=this._listeners.get(e);return r!==void 0&&r.size>0}off(e){this._listeners.delete(e);}removeAllListeners(){this._listeners.clear();}};var L=new Set(["const","let","return","throw","pause","if"]);function ue(s,e,r,i){let o=[];return X(s.directives,e,r,i,"directive",o,s.id),o}function X(s,e,r,i,o,t,n){for(let a=0;a<s.length;a++){let d=s[a],f=d[i],x=`${o}[${a}]`;if(!f){t.push(`${x}: missing type field "${i}"`);continue}if(f==="if"){let l=d.cond;typeof l!="function"&&typeof l!="boolean"&&t.push(`${x}: "if" requires cond as function or boolean`);let _=d.then;Array.isArray(_)?X(_,e,r,i,`${x}.then`,t,n):t.push(`${x}: "if" requires then as array`);let m=d.else;m!==void 0&&(Array.isArray(m)?X(m,e,r,i,`${x}.else`,t,n):t.push(`${x}.else: must be array`));continue}if(L.has(f))continue;if(!e[f])throw new Error(`Action "${n}" ${x}: no handler registered for type "${f}". Register the handler in createActionEngine({ handlers }) before registering this action.`);let C=r.get(f);if(C?.validate)try{let l=C.validate(d);l&&!l.valid&&t.push(`${x}: ${l.error??"validation failed"}`);}catch(l){t.push(`${x}: validate threw: ${l}`);}let y=d.catch;if(y&&Array.isArray(y))for(let l=0;l<y.length;l++){let m=y[l][i];if(!(m&&L.has(m))&&m&&!e[m])throw new Error(`Action "${n}" ${x}.catch[${l}]: no handler registered for type "${m}". Register the handler in createActionEngine({ handlers }) before registering this action.`)}}}function N(s,e){let r=s.length,i=new Array(r);for(let o=0;o<r;o++){let t=s[o],n=t[e],a=t,d=false,f=t.catch;if(Array.isArray(f)&&f.length>0&&(a={...a,catch:N(f,e)},d=true),n==="if"){let x=t.then;Array.isArray(x)&&x.length>0&&(a={...a,then:N(x,e)},d=true);let C=t.else;Array.isArray(C)&&C.length>0&&(a={...a,else:N(C,e)},d=true);}i[o]=d?a:t;}return i}function z(s,e,r,i,o,t,n){return {success:false,aborted:true,abortedBy:s,appliedCount:e,skippedCount:r,errors:i,processedCount:o,totalCount:t,counters:n}}function ke(s){let e=s.filledNames.has("beforeDirective"),r=s.filledNames.has("afterDirective"),i=s.filledNames.has("onDirectivesComplete");return function(t,n,a,d,f,x,C){let y=Math.min(t.length,C),l=[],_=0,m=0,{counters:p,scope:A}=n,$=n.ctx,w=[{dirs:t,i:0,len:y,topLevelIfIndex:-1}],k=0;for(;w.length>0;){let R=w[w.length-1];if(R.i>=R.len){w.pop();continue}let T=R.i++,S=R.topLevelIfIndex!==-1,b=S?R.topLevelIfIndex:T;S||(k=T+1);let h=R.dirs[T],E=h[f];if(E==="const"||E==="let"){let c=h.name;if(typeof h.resolve=="function")try{A[c]=h.resolve($,A).value;}catch(u){l.push({directiveIndex:b,error:`Binding resolve: ${u}`}),p.errors++;}else A[c]=h.value;continue}if(E==="return"){let c=k;if(typeof h.resolve=="function")try{let u=h.resolve($,A),v="value"in u?u.value:"return"in u?u.return:h.value;return {success:!0,aborted:!1,appliedCount:_,skippedCount:m,errors:l,processedCount:c,totalCount:y,counters:p,data:v}}catch(u){l.push({directiveIndex:b,error:`Control resolve: ${u}`}),p.errors++;}else return {success:true,aborted:false,appliedCount:_,skippedCount:m,errors:l,processedCount:c,totalCount:y,counters:p,data:h.value};continue}if(E==="throw"){let c=k;if(typeof h.resolve=="function")try{let u=h.resolve($,A),v="message"in u?u.message:"throw"in u?u.throw:h.message;return {success:!1,aborted:!0,abortedBy:"throw",appliedCount:_,skippedCount:m,errors:l,processedCount:c,totalCount:y,counters:p,data:v}}catch(u){l.push({directiveIndex:b,error:`Control resolve: ${u}`}),p.errors++;}else return {success:false,aborted:true,abortedBy:"throw",appliedCount:_,skippedCount:m,errors:l,processedCount:c,totalCount:y,counters:p,data:h.message};continue}if(E==="if"){let c;try{let v=h.cond;c=typeof v=="function"?!!v($,A):!!v;}catch(v){l.push({directiveIndex:b,error:`if cond: ${v}`}),p.errors++;continue}let u=c?h.then:h.else;if(Array.isArray(u)&&u.length>0){let v=Math.min(u.length,C),G=S?R.topLevelIfIndex:T;w.push({dirs:u,i:0,len:v,topLevelIfIndex:G});}continue}let g=h,I=n;if(e)try{let c=core.processIntercept(d.beforeDirective(g,n),"beforeDirective");if(c.action===core.Intercept.SKIP){m++,p.directivesSkipped++;continue}if(c.action===core.Intercept.ABORT)return z(c.abortReason,_,m,l,k===0?T:k-1,y,p);c.ctx!==void 0&&(I=n.withCtx(c.ctx)),c.directive!==void 0&&(g=c.directive);}catch(c){l.push({directiveIndex:b,error:`Hook beforeDirective: ${c}`}),p.errors++;}if(typeof g.resolve=="function")try{let c=g.resolve(I.ctx,I.scope);g={...g,...c};}catch(c){l.push({directiveIndex:b,error:`Directive resolve: ${c}`}),p.errors++;continue}let F=g[f],M=F?a[F]:void 0;if(!M){l.push({directiveIndex:b,error:`No handler for directive type: ${F??"undefined"}`}),p.errors++;continue}let D;try{D=M(g,I,x);}catch(c){D={ok:false,error:String(c)};}let H=k;if(D.ok){if(_++,p.directivesApplied++,typeof g.as=="string"&&(A[g.as]=D.data),D.halt)return {success:true,aborted:true,abortedBy:"halt",appliedCount:_,skippedCount:m,errors:l,processedCount:H,totalCount:y,counters:p,data:D.data}}else {if(D.halt)return {success:false,aborted:true,abortedBy:"halt",appliedCount:_,skippedCount:m,errors:l,processedCount:H,totalCount:y,counters:p,data:D.data};let c=g.catch;if(Array.isArray(c)&&c.length>0){A.$exception=D.error??"handler failed";let u=x.runDirectives(c,I);_+=u.appliedCount;for(let v=0;v<u.errors.length;v++)l.push(u.errors[v]);if(u.aborted)return {success:u.success,aborted:true,abortedBy:u.abortedBy,appliedCount:_,skippedCount:m,errors:l,processedCount:H,totalCount:y,counters:p,data:u.data}}else l.push({directiveIndex:b,error:D.error??"handler failed"}),p.errors++;}if(r)try{if(d.afterDirective(g,D,I)==="abort")return z("afterDirective",_,m,l,H,y,p)}catch(c){l.push({directiveIndex:b,error:`Hook afterDirective: ${c}`}),p.errors++;}}let P={success:true,aborted:false,appliedCount:_,skippedCount:m,errors:l,processedCount:y,totalCount:y,counters:p};if(i)try{d.onDirectivesComplete(P);}catch{}return P}}function Ee(s){let e=s.filledNames.has("beforeDirective"),r=s.filledNames.has("afterDirective"),i=s.filledNames.has("onDirectivesComplete");return async function(t,n,a,d,f,x,C){let y=Math.min(t.length,C),l=[],_=0,m=0,{counters:p,scope:A}=n,$=n.ctx,w=[{dirs:t,i:0,len:y,topLevelIfIndex:-1}],k=0;for(;w.length>0;){let R=w[w.length-1];if(R.i>=R.len){w.pop();continue}let T=R.i++,S=R.topLevelIfIndex!==-1,b=S?R.topLevelIfIndex:T;S||(k=T+1);let h=R.dirs[T],E=h[f];if(E==="const"||E==="let"){let c=h.name;if(typeof h.resolve=="function")try{A[c]=h.resolve($,A).value;}catch(u){l.push({directiveIndex:b,error:`Binding resolve: ${u}`}),p.errors++;}else A[c]=h.value;continue}if(E==="return"){let c=k;if(typeof h.resolve=="function")try{let u=h.resolve($,A),v="value"in u?u.value:"return"in u?u.return:h.value;return {success:!0,aborted:!1,appliedCount:_,skippedCount:m,errors:l,processedCount:c,totalCount:y,counters:p,data:v}}catch(u){l.push({directiveIndex:b,error:`Control resolve: ${u}`}),p.errors++;}else return {success:true,aborted:false,appliedCount:_,skippedCount:m,errors:l,processedCount:c,totalCount:y,counters:p,data:h.value};continue}if(E==="throw"){let c=k;if(typeof h.resolve=="function")try{let u=h.resolve($,A),v="message"in u?u.message:"throw"in u?u.throw:h.message;return {success:!1,aborted:!0,abortedBy:"throw",appliedCount:_,skippedCount:m,errors:l,processedCount:c,totalCount:y,counters:p,data:v}}catch(u){l.push({directiveIndex:b,error:`Control resolve: ${u}`}),p.errors++;}else return {success:false,aborted:true,abortedBy:"throw",appliedCount:_,skippedCount:m,errors:l,processedCount:c,totalCount:y,counters:p,data:h.message};continue}if(E==="if"){let c;try{let v=h.cond;c=typeof v=="function"?!!v($,A):!!v;}catch(v){l.push({directiveIndex:b,error:`if cond: ${v}`}),p.errors++;continue}let u=c?h.then:h.else;if(Array.isArray(u)&&u.length>0){let v=Math.min(u.length,C),G=S?R.topLevelIfIndex:T;w.push({dirs:u,i:0,len:v,topLevelIfIndex:G});}continue}let g=h,I=n;if(e)try{let c=core.processIntercept(await d.beforeDirective(g,n),"beforeDirective");if(c.action===core.Intercept.SKIP){m++,p.directivesSkipped++;continue}if(c.action===core.Intercept.ABORT)return z(c.abortReason,_,m,l,k===0?T:k-1,y,p);c.ctx!==void 0&&(I=n.withCtx(c.ctx)),c.directive!==void 0&&(g=c.directive);}catch(c){l.push({directiveIndex:b,error:`Hook beforeDirective: ${c}`}),p.errors++;}if(typeof g.resolve=="function")try{let c=g.resolve(I.ctx,I.scope);g={...g,...c};}catch(c){l.push({directiveIndex:b,error:`Directive resolve: ${c}`}),p.errors++;continue}let F=g[f],M=F?a[F]:void 0;if(!M){l.push({directiveIndex:b,error:`No handler for directive type: ${F??"undefined"}`}),p.errors++;continue}let D;try{D=await M(g,I,x);}catch(c){D={ok:false,error:String(c)};}let H=k;if(D.ok){if(_++,p.directivesApplied++,typeof g.as=="string"&&(A[g.as]=D.data),D.halt)return {success:true,aborted:true,abortedBy:"halt",appliedCount:_,skippedCount:m,errors:l,processedCount:H,totalCount:y,counters:p,data:D.data}}else {if(D.halt)return {success:false,aborted:true,abortedBy:"halt",appliedCount:_,skippedCount:m,errors:l,processedCount:H,totalCount:y,counters:p,data:D.data};let c=g.catch;if(Array.isArray(c)&&c.length>0){A.$exception=D.error??"handler failed";let u=await x.runDirectivesAsync(c,I);_+=u.appliedCount;for(let v=0;v<u.errors.length;v++)l.push(u.errors[v]);if(u.aborted)return {success:u.success,aborted:true,abortedBy:u.abortedBy,appliedCount:_,skippedCount:m,errors:l,processedCount:H,totalCount:y,counters:p,data:u.data}}else l.push({directiveIndex:b,error:D.error??"handler failed"}),p.errors++;}if(r)try{if(await d.afterDirective(g,D,I)==="abort")return z("afterDirective",_,m,l,H,y,p)}catch(c){l.push({directiveIndex:b,error:`Hook afterDirective: ${c}`}),p.errors++;}}let P={success:true,aborted:false,appliedCount:_,skippedCount:m,errors:l,processedCount:y,totalCount:y,counters:p};if(i)try{await d.onDirectivesComplete(P);}catch{}return P}}function U(s,e){return e?Ee(s):ke(s)}function B(s,e,r,i,o,t,n,a){return {success:false,aborted:true,abortedBy:s,appliedCount:e,skippedCount:r,errors:i,processedCount:o,totalCount:t,counters:n,data:a}}function fe(s){if(s===null||typeof s!="object")return null;if(typeof s.next=="function")return s;let e=s.iterator;return e!=null&&typeof e=="object"&&typeof e.next=="function"?e:null}function we(s){let e=s.filledNames.has("beforeDirective"),r=s.filledNames.has("afterDirective"),i=s.filledNames.has("onDirectivesComplete");return function*(t,n,a,d,f,x,C){let y=Math.min(t.length,C),l=[],_=0,m=0,{counters:p,scope:A}=n,$=n.ctx,w=[{dirs:t,i:0,len:y,topLevelIfIndex:-1}],k=0;for(;w.length>0;){let R=w[w.length-1];if(R.i>=R.len){w.pop();continue}let T=R.i++,S=R.topLevelIfIndex!==-1,b=S?R.topLevelIfIndex:T;S||(k=T+1);let h=R.dirs[T],E=h[f];if(E==="const"||E==="let"){let c=h.name;if(typeof h.resolve=="function")try{A[c]=h.resolve($,A).value;}catch(u){l.push({directiveIndex:b,error:`Binding resolve: ${u}`}),p.errors++;}else A[c]=h.value;continue}if(E==="return"){let c=k,u=h.value;if(typeof h.resolve=="function")try{let v=h.resolve($,A);u="value"in v?v.value:"return"in v?v.return:u;}catch(v){l.push({directiveIndex:b,error:`Control resolve: ${v}`}),p.errors++;continue}return {success:true,aborted:false,appliedCount:_,skippedCount:m,errors:l,processedCount:c,totalCount:y,counters:p,data:u}}if(E==="throw"){let c=k,u=h.message;if(typeof h.resolve=="function")try{let v=h.resolve($,A);u="message"in v?v.message:"throw"in v?v.throw:u;}catch(v){l.push({directiveIndex:b,error:`Control resolve: ${v}`}),p.errors++;continue}return B("throw",_,m,l,c,y,p,u)}if(E==="pause"){let c=k,u=yield {source:"pause",directive:h,frame:n,index:b,payload:{message:h.message}};if(u===false||u==="abort"||u==="cancel")return B("pause",_,m,l,c,y,p,u);_++,p.directivesApplied++,typeof h.as=="string"&&u!==void 0&&(A[h.as]=u);continue}if(E==="if"){let c;try{let v=h.cond;c=typeof v=="function"?!!v($,A):!!v;}catch(v){l.push({directiveIndex:b,error:`if cond: ${v}`}),p.errors++;continue}let u=c?h.then:h.else;if(Array.isArray(u)&&u.length>0){let v=Math.min(u.length,C),G=S?R.topLevelIfIndex:T;w.push({dirs:u,i:0,len:v,topLevelIfIndex:G});}continue}let g=h,I=n;if(e)try{let c=core.processIntercept(d.beforeDirective(g,n),"beforeDirective");if(c.action===core.Intercept.SKIP){m++,p.directivesSkipped++;continue}if(c.action===core.Intercept.ABORT)return B(c.abortReason,_,m,l,k===0?T:k-1,y,p);c.ctx!==void 0&&(I=n.withCtx(c.ctx)),c.directive!==void 0&&(g=c.directive);}catch(c){l.push({directiveIndex:b,error:`Hook beforeDirective: ${c}`}),p.errors++;}if(typeof g.resolve=="function")try{let c=g.resolve(I.ctx,I.scope);g={...g,...c};}catch(c){l.push({directiveIndex:b,error:`Directive resolve: ${c}`}),p.errors++;continue}let F=g[f],M=F?a[F]:void 0;if(!M){l.push({directiveIndex:b,error:`No handler for directive type: ${F??"undefined"}`}),p.errors++;continue}let D;try{let c=M(g,I,x),u=fe(c);u!==null?D=yield*u:D=c;}catch(c){D={ok:false,error:String(c)};}let H=k;if(D.ok){if(_++,p.directivesApplied++,typeof g.as=="string"&&(A[g.as]=D.data),D.halt)return {success:true,aborted:true,abortedBy:"halt",appliedCount:_,skippedCount:m,errors:l,processedCount:H,totalCount:y,counters:p,data:D.data}}else {if(D.halt)return B("halt",_,m,l,H,y,p,D.data);let c=g.catch;if(Array.isArray(c)&&c.length>0){A.$exception=D.error??"handler failed";let u=x.runDirectives(c,I);_+=u.appliedCount;for(let v=0;v<u.errors.length;v++)l.push(u.errors[v]);if(u.aborted)return {success:u.success,aborted:true,abortedBy:u.abortedBy,appliedCount:_,skippedCount:m,errors:l,processedCount:H,totalCount:y,counters:p,data:u.data}}else l.push({directiveIndex:b,error:D.error??"handler failed"}),p.errors++;}if(r)try{if(d.afterDirective(g,D,I)==="abort")return B("afterDirective",_,m,l,H,y,p)}catch(c){l.push({directiveIndex:b,error:`Hook afterDirective: ${c}`}),p.errors++;}}let P={success:true,aborted:false,appliedCount:_,skippedCount:m,errors:l,processedCount:y,totalCount:y,counters:p};if(i)try{d.onDirectivesComplete(P);}catch{}return P}}function Te(s){let e=s.filledNames.has("beforeDirective"),r=s.filledNames.has("afterDirective"),i=s.filledNames.has("onDirectivesComplete");return async function*(t,n,a,d,f,x,C){let y=Math.min(t.length,C),l=[],_=0,m=0,{counters:p,scope:A}=n,$=n.ctx,w=[{dirs:t,i:0,len:y,topLevelIfIndex:-1}],k=0;for(;w.length>0;){let R=w[w.length-1];if(R.i>=R.len){w.pop();continue}let T=R.i++,S=R.topLevelIfIndex!==-1,b=S?R.topLevelIfIndex:T;S||(k=T+1);let h=R.dirs[T],E=h[f];if(E==="const"||E==="let"){let c=h.name;if(typeof h.resolve=="function")try{A[c]=h.resolve($,A).value;}catch(u){l.push({directiveIndex:b,error:`Binding resolve: ${u}`}),p.errors++;}else A[c]=h.value;continue}if(E==="return"){let c=k,u=h.value;if(typeof h.resolve=="function")try{let v=h.resolve($,A);u="value"in v?v.value:"return"in v?v.return:u;}catch(v){l.push({directiveIndex:b,error:`Control resolve: ${v}`}),p.errors++;continue}return {success:true,aborted:false,appliedCount:_,skippedCount:m,errors:l,processedCount:c,totalCount:y,counters:p,data:u}}if(E==="throw"){let c=k,u=h.message;if(typeof h.resolve=="function")try{let v=h.resolve($,A);u="message"in v?v.message:"throw"in v?v.throw:u;}catch(v){l.push({directiveIndex:b,error:`Control resolve: ${v}`}),p.errors++;continue}return B("throw",_,m,l,c,y,p,u)}if(E==="pause"){let c=k,u=yield {source:"pause",directive:h,frame:n,index:b,payload:{message:h.message}};if(u===false||u==="abort"||u==="cancel")return B("pause",_,m,l,c,y,p,u);_++,p.directivesApplied++,typeof h.as=="string"&&u!==void 0&&(A[h.as]=u);continue}if(E==="if"){let c;try{let v=h.cond;c=typeof v=="function"?!!v($,A):!!v;}catch(v){l.push({directiveIndex:b,error:`if cond: ${v}`}),p.errors++;continue}let u=c?h.then:h.else;if(Array.isArray(u)&&u.length>0){let v=Math.min(u.length,C),G=S?R.topLevelIfIndex:T;w.push({dirs:u,i:0,len:v,topLevelIfIndex:G});}continue}let g=h,I=n;if(e)try{let c=core.processIntercept(await d.beforeDirective(g,n),"beforeDirective");if(c.action===core.Intercept.SKIP){m++,p.directivesSkipped++;continue}if(c.action===core.Intercept.ABORT)return B(c.abortReason,_,m,l,k===0?T:k-1,y,p);c.ctx!==void 0&&(I=n.withCtx(c.ctx)),c.directive!==void 0&&(g=c.directive);}catch(c){l.push({directiveIndex:b,error:`Hook beforeDirective: ${c}`}),p.errors++;}if(typeof g.resolve=="function")try{let c=g.resolve(I.ctx,I.scope);g={...g,...c};}catch(c){l.push({directiveIndex:b,error:`Directive resolve: ${c}`}),p.errors++;continue}let F=g[f],M=F?a[F]:void 0;if(!M){l.push({directiveIndex:b,error:`No handler for directive type: ${F??"undefined"}`}),p.errors++;continue}let D;try{let c=await M(g,I,x),u=fe(c);u!==null?D=yield*u:D=c;}catch(c){D={ok:false,error:String(c)};}let H=k;if(D.ok){if(_++,p.directivesApplied++,typeof g.as=="string"&&(A[g.as]=D.data),D.halt)return {success:true,aborted:true,abortedBy:"halt",appliedCount:_,skippedCount:m,errors:l,processedCount:H,totalCount:y,counters:p,data:D.data}}else {if(D.halt)return B("halt",_,m,l,H,y,p,D.data);let c=g.catch;if(Array.isArray(c)&&c.length>0){A.$exception=D.error??"handler failed";let u=await x.runDirectivesAsync(c,I);_+=u.appliedCount;for(let v=0;v<u.errors.length;v++)l.push(u.errors[v]);if(u.aborted)return {success:u.success,aborted:true,abortedBy:u.abortedBy,appliedCount:_,skippedCount:m,errors:l,processedCount:H,totalCount:y,counters:p,data:u.data}}else l.push({directiveIndex:b,error:D.error??"handler failed"}),p.errors++;}if(r)try{if(await d.afterDirective(g,D,I)==="abort")return B("afterDirective",_,m,l,H,y,p)}catch(c){l.push({directiveIndex:b,error:`Hook afterDirective: ${c}`}),p.errors++;}}let P={success:true,aborted:false,appliedCount:_,skippedCount:m,errors:l,processedCount:y,totalCount:y,counters:p};if(i)try{await d.onDirectivesComplete(P);}catch{}return P}}function Z(s,e){return e?Te(s):we(s)}function ee(s,e=s.hasAnyAsync){let{filledNames:r}=s,i=x=>r.has(x),o=x=>s.asyncNames.has(x)?"await ":"",t=e?"await ":"",n=[];for(let x of r)n.push(`const ${x} = directiveHooks.${x};`);n.push("const len = Math.min(directives.length, maxDirectives);"),n.push("const errors = []; let appliedCount = 0; let skippedCount = 0;"),n.push("const counters = frame.counters;"),n.push("for (let i = 0; i < len; i++) {"),n.push(" let directive = directives[i];"),i("beforeDirective")?(n.push(" let _df = frame;"),n.push(" try {"),n.push(` const _bd = ${o("beforeDirective")}beforeDirective(directive, frame);`),n.push(' if (_bd === "skip") { skippedCount++; counters.directivesSkipped++; continue; }'),n.push(' if (_bd === "abort") return { success: false, aborted: true, abortedBy: "beforeDirective", appliedCount, skippedCount, errors, processedCount: i, totalCount: len, counters };'),n.push(' if (typeof _bd === "object" && _bd !== null) {'),n.push(' if ("abort" in _bd) return { success: false, aborted: true, abortedBy: _bd.abort, appliedCount, skippedCount, errors, processedCount: i, totalCount: len, counters };'),n.push(' if ("ctx" in _bd) _df = frame.withCtx(_bd.ctx);'),n.push(' if ("directive" in _bd) directive = _bd.directive;'),n.push(" }"),n.push(' } catch (_e) { errors.push({ directiveIndex: i, error: "Hook beforeDirective: " + _e }); counters.errors++; }')):n.push(" const _df = frame;"),n.push(' if (typeof directive.resolve === "function") {'),n.push(" try { const _r = directive.resolve(_df.ctx); directive = Object.assign({}, directive, _r); }"),n.push(' catch (_e) { errors.push({ directiveIndex: i, error: "Directive resolve: " + _e }); counters.errors++; continue; }'),n.push(" }"),n.push(" const _type = directive[typeField];"),n.push(" const _handler = _type ? handlers[_type] : undefined;"),n.push(' if (!_handler) { errors.push({ directiveIndex: i, error: "No handler for directive type: " + (_type || "undefined") }); counters.errors++; continue; }'),n.push(" let _result;"),n.push(` try { _result = ${t}_handler(directive, _df, engine); } catch (_e) { errors.push({ directiveIndex: i, error: String(_e) }); counters.errors++; continue; }`),n.push(" if (_result.ok) { appliedCount++; counters.directivesApplied++; }"),n.push(' else { errors.push({ directiveIndex: i, error: _result.error || "handler failed" }); counters.errors++; }'),i("afterDirective")&&(n.push(" try {"),n.push(` const _ad = ${o("afterDirective")}afterDirective(directive, _result, _df);`),n.push(' if (_ad === "abort") return { success: false, aborted: true, abortedBy: "afterDirective", appliedCount, skippedCount, errors, processedCount: i + 1, totalCount: len, counters };'),n.push(' } catch (_e) { errors.push({ directiveIndex: i, error: "Hook afterDirective: " + _e }); counters.errors++; }')),n.push("}"),n.push("const _finalResult = { success: true, aborted: false, appliedCount, skippedCount, errors, processedCount: len, totalCount: len, counters };"),i("onDirectivesComplete")&&n.push(`try { ${o("onDirectivesComplete")}onDirectivesComplete(_finalResult); } catch (_e) {}`),n.push("return _finalResult;");let a=n.join(`
|
|
2
|
-
`),
|
|
3
|
-
return (${
|
|
4
|
-
${
|
|
5
|
-
})();`),isAsync:e}}function
|
|
6
|
-
${
|
|
1
|
+
'use strict';var core=require('@statedelta-actions/core');function Ie(o,e){let n;for(;;){let i=o.next(n);if(i.done)return i.value;n=e?e(i.value):void 0;}}async function Ee(o,e){let n;for(;;){let i=await o.next(n);if(i.done)return i.value;n=e?await e(i.value):void 0;}}function we(o){let e=0;return ()=>{if(!(e>=o.length))return o[e++]}}var O=class{_listeners=new Map;on(e,n){let i=this._listeners.get(e);i||(i=new Set,this._listeners.set(e,i)),i.add(n);let s=false;return ()=>{s||(s=true,i.delete(n),i.size===0&&this._listeners.delete(e));}}once(e,n){let i=this.on(e,s=>{i(),n(s);});return i}emit(e,n){let i=this._listeners.get(e);if(!i||i.size===0)return;let s=[...i];for(let t=0;t<s.length;t++)try{s[t](n);}catch(r){console.error(`[SimpleEmitter] Listener error on "${e}":`,r);}}listenerCount(e){return this._listeners.get(e)?.size??0}hasListeners(e){let n=this._listeners.get(e);return n!==void 0&&n.size>0}off(e){this._listeners.delete(e);}removeAllListeners(){this._listeners.clear();}};var N=new Set(["const","let","return","throw","pause","if"]);function le(o,e,n,i){let s=[];return q(o.directives,e,n,i,"directive",s,o.id),s}function q(o,e,n,i,s,t,r){for(let d=0;d<o.length;d++){let c=o[d],u=c[i],h=`${s}[${d}]`;if(!u){t.push(`${h}: missing type field "${i}"`);continue}if(u==="if"){let g=c.cond;typeof g!="function"&&typeof g!="boolean"&&t.push(`${h}: "if" requires cond as function or boolean`);let f=c.then;Array.isArray(f)?q(f,e,n,i,`${h}.then`,t,r):t.push(`${h}: "if" requires then as array`);let D=c.else;D!==void 0&&(Array.isArray(D)?q(D,e,n,i,`${h}.else`,t,r):t.push(`${h}.else: must be array`));continue}if(N.has(u))continue;if(!e[u])throw new Error(`Action "${r}" ${h}: no handler registered for type "${u}". Register the handler in createActionEngine({ handlers }) before registering this action.`);let C=n.get(u);if(C?.validate)try{let g=C.validate(c);g&&!g.valid&&t.push(`${h}: ${g.error??"validation failed"}`);}catch(g){t.push(`${h}: validate threw: ${g}`);}let y=c.catch;if(y&&Array.isArray(y))for(let g=0;g<y.length;g++){let D=y[g][i];if(!(D&&N.has(D))&&D&&!e[D])throw new Error(`Action "${r}" ${h}.catch[${g}]: no handler registered for type "${D}". Register the handler in createActionEngine({ handlers }) before registering this action.`)}let p=C?.subDirectives;if(p===void 0)continue;let m=Object.keys(p);for(let g=0;g<m.length;g++){let f=m[g];if(f==="catch")continue;let D=c[f];if(D===void 0){if(p[f].required)throw new Error(`Action "${r}" ${h}: handler "${u}" requires sub-directives field "${f}"`);continue}if(!Array.isArray(D))throw new Error(`Action "${r}" ${h}.${f}: must be an array of directives`);q(D,e,n,i,`${h}.${f}`,t,r);}}}var Te=new Map;function L(o,e,n=Te){let i=o.length,s=new Array(i);for(let t=0;t<i;t++){let r=o[t],d=r[e],c=r,u=false,h=r.catch;if(Array.isArray(h)&&h.length>0&&(c={...c,catch:L(h,e,n)},u=true),d==="if"){let C=r.then;Array.isArray(C)&&C.length>0&&(c={...c,then:L(C,e,n)},u=true);let y=r.else;Array.isArray(y)&&y.length>0&&(c={...c,else:L(y,e,n)},u=true);}else if(d!==void 0){let C=n.get(d);if(C!==void 0)for(let y=0;y<C.length;y++){let p=C[y],m=r[p];!Array.isArray(m)||m.length===0||(c={...c,[p]:L(m,e,n)},u=true);}}s[t]=u?c:r;}return s}function W(o,e,n,i,s,t,r){return {success:false,aborted:true,abortedBy:o,appliedCount:e,skippedCount:n,errors:i,processedCount:s,totalCount:t,counters:r}}function $e(o){let e=o.filledNames.has("beforeDirective"),n=o.filledNames.has("afterDirective"),i=o.filledNames.has("onDirectivesComplete");return function(t,r,d,c,u,h,C){let y=Math.min(t.length,C),p=[],m=0,g=0,{counters:f,scope:D}=r,$=r.ctx,w=[{dirs:t,i:0,len:y,topLevelIfIndex:-1}],I=0;for(;w.length>0;){let R=w[w.length-1];if(R.i>=R.len){w.pop();continue}let T=R.i++,S=R.topLevelIfIndex!==-1,A=S?R.topLevelIfIndex:T;S||(I=T+1);let x=R.dirs[T],E=x[u];if(E==="const"||E==="let"){let a=x.name;if(typeof x.resolve=="function")try{D[a]=x.resolve($,D).value;}catch(l){p.push({directiveIndex:A,error:`Binding resolve: ${l}`}),f.errors++;}else D[a]=x.value;continue}if(E==="return"){let a=I;if(typeof x.resolve=="function")try{let l=x.resolve($,D),v="value"in l?l.value:"return"in l?l.return:x.value;return {success:!0,aborted:!1,appliedCount:m,skippedCount:g,errors:p,processedCount:a,totalCount:y,counters:f,data:v}}catch(l){p.push({directiveIndex:A,error:`Control resolve: ${l}`}),f.errors++;}else return {success:true,aborted:false,appliedCount:m,skippedCount:g,errors:p,processedCount:a,totalCount:y,counters:f,data:x.value};continue}if(E==="throw"){let a=I;if(typeof x.resolve=="function")try{let l=x.resolve($,D),v="message"in l?l.message:"throw"in l?l.throw:x.message;return {success:!1,aborted:!0,abortedBy:"throw",appliedCount:m,skippedCount:g,errors:p,processedCount:a,totalCount:y,counters:f,data:v}}catch(l){p.push({directiveIndex:A,error:`Control resolve: ${l}`}),f.errors++;}else return {success:false,aborted:true,abortedBy:"throw",appliedCount:m,skippedCount:g,errors:p,processedCount:a,totalCount:y,counters:f,data:x.message};continue}if(E==="if"){let a;try{let v=x.cond;a=typeof v=="function"?!!v($,D):!!v;}catch(v){p.push({directiveIndex:A,error:`if cond: ${v}`}),f.errors++;continue}let l=a?x.then:x.else;if(Array.isArray(l)&&l.length>0){let v=Math.min(l.length,C),G=S?R.topLevelIfIndex:T;w.push({dirs:l,i:0,len:v,topLevelIfIndex:G});}continue}let _=x,k=r;if(e)try{let a=core.processIntercept(c.beforeDirective(_,r),"beforeDirective");if(a.action===core.Intercept.SKIP){g++,f.directivesSkipped++;continue}if(a.action===core.Intercept.ABORT)return W(a.abortReason,m,g,p,I===0?T:I-1,y,f);a.ctx!==void 0&&(k=r.withCtx(a.ctx)),a.directive!==void 0&&(_=a.directive);}catch(a){p.push({directiveIndex:A,error:`Hook beforeDirective: ${a}`}),f.errors++;}if(typeof _.resolve=="function")try{let a=_.resolve(k.ctx,k.scope);_={..._,...a};}catch(a){p.push({directiveIndex:A,error:`Directive resolve: ${a}`}),f.errors++;continue}let M=_[u],F=M?d[M]:void 0;if(!F){p.push({directiveIndex:A,error:`No handler for directive type: ${M??"undefined"}`}),f.errors++;continue}let b;try{b=F(_,k,h);}catch(a){b={ok:false,error:String(a)};}let H=I;if(b.ok){if(m++,f.directivesApplied++,typeof _.as=="string"&&(D[_.as]=b.data),b.halt)return {success:true,aborted:true,abortedBy:"halt",appliedCount:m,skippedCount:g,errors:p,processedCount:H,totalCount:y,counters:f,data:b.data}}else {if(b.halt)return {success:false,aborted:true,abortedBy:"halt",appliedCount:m,skippedCount:g,errors:p,processedCount:H,totalCount:y,counters:f,data:b.data};let a=_.catch;if(Array.isArray(a)&&a.length>0){D.$exception=b.error??"handler failed";let l=h.runDirectives(a,k);m+=l.appliedCount;for(let v=0;v<l.errors.length;v++)p.push(l.errors[v]);if(l.aborted)return {success:l.success,aborted:true,abortedBy:l.abortedBy,appliedCount:m,skippedCount:g,errors:p,processedCount:H,totalCount:y,counters:f,data:l.data}}else p.push({directiveIndex:A,error:b.error??"handler failed"}),f.errors++;}if(n)try{if(c.afterDirective(_,b,k)==="abort")return W("afterDirective",m,g,p,H,y,f)}catch(a){p.push({directiveIndex:A,error:`Hook afterDirective: ${a}`}),f.errors++;}}let P={success:true,aborted:false,appliedCount:m,skippedCount:g,errors:p,processedCount:y,totalCount:y,counters:f};if(i)try{c.onDirectivesComplete(P);}catch{}return P}}function Se(o){let e=o.filledNames.has("beforeDirective"),n=o.filledNames.has("afterDirective"),i=o.filledNames.has("onDirectivesComplete");return async function(t,r,d,c,u,h,C){let y=Math.min(t.length,C),p=[],m=0,g=0,{counters:f,scope:D}=r,$=r.ctx,w=[{dirs:t,i:0,len:y,topLevelIfIndex:-1}],I=0;for(;w.length>0;){let R=w[w.length-1];if(R.i>=R.len){w.pop();continue}let T=R.i++,S=R.topLevelIfIndex!==-1,A=S?R.topLevelIfIndex:T;S||(I=T+1);let x=R.dirs[T],E=x[u];if(E==="const"||E==="let"){let a=x.name;if(typeof x.resolve=="function")try{D[a]=x.resolve($,D).value;}catch(l){p.push({directiveIndex:A,error:`Binding resolve: ${l}`}),f.errors++;}else D[a]=x.value;continue}if(E==="return"){let a=I;if(typeof x.resolve=="function")try{let l=x.resolve($,D),v="value"in l?l.value:"return"in l?l.return:x.value;return {success:!0,aborted:!1,appliedCount:m,skippedCount:g,errors:p,processedCount:a,totalCount:y,counters:f,data:v}}catch(l){p.push({directiveIndex:A,error:`Control resolve: ${l}`}),f.errors++;}else return {success:true,aborted:false,appliedCount:m,skippedCount:g,errors:p,processedCount:a,totalCount:y,counters:f,data:x.value};continue}if(E==="throw"){let a=I;if(typeof x.resolve=="function")try{let l=x.resolve($,D),v="message"in l?l.message:"throw"in l?l.throw:x.message;return {success:!1,aborted:!0,abortedBy:"throw",appliedCount:m,skippedCount:g,errors:p,processedCount:a,totalCount:y,counters:f,data:v}}catch(l){p.push({directiveIndex:A,error:`Control resolve: ${l}`}),f.errors++;}else return {success:false,aborted:true,abortedBy:"throw",appliedCount:m,skippedCount:g,errors:p,processedCount:a,totalCount:y,counters:f,data:x.message};continue}if(E==="if"){let a;try{let v=x.cond;a=typeof v=="function"?!!v($,D):!!v;}catch(v){p.push({directiveIndex:A,error:`if cond: ${v}`}),f.errors++;continue}let l=a?x.then:x.else;if(Array.isArray(l)&&l.length>0){let v=Math.min(l.length,C),G=S?R.topLevelIfIndex:T;w.push({dirs:l,i:0,len:v,topLevelIfIndex:G});}continue}let _=x,k=r;if(e)try{let a=core.processIntercept(await c.beforeDirective(_,r),"beforeDirective");if(a.action===core.Intercept.SKIP){g++,f.directivesSkipped++;continue}if(a.action===core.Intercept.ABORT)return W(a.abortReason,m,g,p,I===0?T:I-1,y,f);a.ctx!==void 0&&(k=r.withCtx(a.ctx)),a.directive!==void 0&&(_=a.directive);}catch(a){p.push({directiveIndex:A,error:`Hook beforeDirective: ${a}`}),f.errors++;}if(typeof _.resolve=="function")try{let a=_.resolve(k.ctx,k.scope);_={..._,...a};}catch(a){p.push({directiveIndex:A,error:`Directive resolve: ${a}`}),f.errors++;continue}let M=_[u],F=M?d[M]:void 0;if(!F){p.push({directiveIndex:A,error:`No handler for directive type: ${M??"undefined"}`}),f.errors++;continue}let b;try{b=await F(_,k,h);}catch(a){b={ok:false,error:String(a)};}let H=I;if(b.ok){if(m++,f.directivesApplied++,typeof _.as=="string"&&(D[_.as]=b.data),b.halt)return {success:true,aborted:true,abortedBy:"halt",appliedCount:m,skippedCount:g,errors:p,processedCount:H,totalCount:y,counters:f,data:b.data}}else {if(b.halt)return {success:false,aborted:true,abortedBy:"halt",appliedCount:m,skippedCount:g,errors:p,processedCount:H,totalCount:y,counters:f,data:b.data};let a=_.catch;if(Array.isArray(a)&&a.length>0){D.$exception=b.error??"handler failed";let l=await h.runDirectivesAsync(a,k);m+=l.appliedCount;for(let v=0;v<l.errors.length;v++)p.push(l.errors[v]);if(l.aborted)return {success:l.success,aborted:true,abortedBy:l.abortedBy,appliedCount:m,skippedCount:g,errors:p,processedCount:H,totalCount:y,counters:f,data:l.data}}else p.push({directiveIndex:A,error:b.error??"handler failed"}),f.errors++;}if(n)try{if(await c.afterDirective(_,b,k)==="abort")return W("afterDirective",m,g,p,H,y,f)}catch(a){p.push({directiveIndex:A,error:`Hook afterDirective: ${a}`}),f.errors++;}}let P={success:true,aborted:false,appliedCount:m,skippedCount:g,errors:p,processedCount:y,totalCount:y,counters:f};if(i)try{await c.onDirectivesComplete(P);}catch{}return P}}function J(o,e){return e?Se(o):$e(o)}function B(o,e,n,i,s,t,r,d){return {success:false,aborted:true,abortedBy:o,appliedCount:e,skippedCount:n,errors:i,processedCount:s,totalCount:t,counters:r,data:d}}function pe(o){if(o===null||typeof o!="object")return null;if(typeof o.next=="function")return o;let e=o.iterator;return e!=null&&typeof e=="object"&&typeof e.next=="function"?e:null}function He(o){let e=o.filledNames.has("beforeDirective"),n=o.filledNames.has("afterDirective"),i=o.filledNames.has("onDirectivesComplete");return function*(t,r,d,c,u,h,C){let y=Math.min(t.length,C),p=[],m=0,g=0,{counters:f,scope:D}=r,$=r.ctx,w=[{dirs:t,i:0,len:y,topLevelIfIndex:-1}],I=0;for(;w.length>0;){let R=w[w.length-1];if(R.i>=R.len){w.pop();continue}let T=R.i++,S=R.topLevelIfIndex!==-1,A=S?R.topLevelIfIndex:T;S||(I=T+1);let x=R.dirs[T],E=x[u];if(E==="const"||E==="let"){let a=x.name;if(typeof x.resolve=="function")try{D[a]=x.resolve($,D).value;}catch(l){p.push({directiveIndex:A,error:`Binding resolve: ${l}`}),f.errors++;}else D[a]=x.value;continue}if(E==="return"){let a=I,l=x.value;if(typeof x.resolve=="function")try{let v=x.resolve($,D);l="value"in v?v.value:"return"in v?v.return:l;}catch(v){p.push({directiveIndex:A,error:`Control resolve: ${v}`}),f.errors++;continue}return {success:true,aborted:false,appliedCount:m,skippedCount:g,errors:p,processedCount:a,totalCount:y,counters:f,data:l}}if(E==="throw"){let a=I,l=x.message;if(typeof x.resolve=="function")try{let v=x.resolve($,D);l="message"in v?v.message:"throw"in v?v.throw:l;}catch(v){p.push({directiveIndex:A,error:`Control resolve: ${v}`}),f.errors++;continue}return B("throw",m,g,p,a,y,f,l)}if(E==="pause"){let a=I,l=yield {source:"pause",directive:x,frame:r,index:A,payload:{message:x.message}};if(l===false||l==="abort"||l==="cancel")return B("pause",m,g,p,a,y,f,l);m++,f.directivesApplied++,typeof x.as=="string"&&l!==void 0&&(D[x.as]=l);continue}if(E==="if"){let a;try{let v=x.cond;a=typeof v=="function"?!!v($,D):!!v;}catch(v){p.push({directiveIndex:A,error:`if cond: ${v}`}),f.errors++;continue}let l=a?x.then:x.else;if(Array.isArray(l)&&l.length>0){let v=Math.min(l.length,C),G=S?R.topLevelIfIndex:T;w.push({dirs:l,i:0,len:v,topLevelIfIndex:G});}continue}let _=x,k=r;if(e)try{let a=core.processIntercept(c.beforeDirective(_,r),"beforeDirective");if(a.action===core.Intercept.SKIP){g++,f.directivesSkipped++;continue}if(a.action===core.Intercept.ABORT)return B(a.abortReason,m,g,p,I===0?T:I-1,y,f);a.ctx!==void 0&&(k=r.withCtx(a.ctx)),a.directive!==void 0&&(_=a.directive);}catch(a){p.push({directiveIndex:A,error:`Hook beforeDirective: ${a}`}),f.errors++;}if(typeof _.resolve=="function")try{let a=_.resolve(k.ctx,k.scope);_={..._,...a};}catch(a){p.push({directiveIndex:A,error:`Directive resolve: ${a}`}),f.errors++;continue}let M=_[u],F=M?d[M]:void 0;if(!F){p.push({directiveIndex:A,error:`No handler for directive type: ${M??"undefined"}`}),f.errors++;continue}let b;try{let a=F(_,k,h),l=pe(a);l!==null?b=yield*l:b=a;}catch(a){b={ok:false,error:String(a)};}let H=I;if(b.ok){if(m++,f.directivesApplied++,typeof _.as=="string"&&(D[_.as]=b.data),b.halt)return {success:true,aborted:true,abortedBy:"halt",appliedCount:m,skippedCount:g,errors:p,processedCount:H,totalCount:y,counters:f,data:b.data}}else {if(b.halt)return B("halt",m,g,p,H,y,f,b.data);let a=_.catch;if(Array.isArray(a)&&a.length>0){D.$exception=b.error??"handler failed";let l=h.runDirectives(a,k);m+=l.appliedCount;for(let v=0;v<l.errors.length;v++)p.push(l.errors[v]);if(l.aborted)return {success:l.success,aborted:true,abortedBy:l.abortedBy,appliedCount:m,skippedCount:g,errors:p,processedCount:H,totalCount:y,counters:f,data:l.data}}else p.push({directiveIndex:A,error:b.error??"handler failed"}),f.errors++;}if(n)try{if(c.afterDirective(_,b,k)==="abort")return B("afterDirective",m,g,p,H,y,f)}catch(a){p.push({directiveIndex:A,error:`Hook afterDirective: ${a}`}),f.errors++;}}let P={success:true,aborted:false,appliedCount:m,skippedCount:g,errors:p,processedCount:y,totalCount:y,counters:f};if(i)try{c.onDirectivesComplete(P);}catch{}return P}}function Me(o){let e=o.filledNames.has("beforeDirective"),n=o.filledNames.has("afterDirective"),i=o.filledNames.has("onDirectivesComplete");return async function*(t,r,d,c,u,h,C){let y=Math.min(t.length,C),p=[],m=0,g=0,{counters:f,scope:D}=r,$=r.ctx,w=[{dirs:t,i:0,len:y,topLevelIfIndex:-1}],I=0;for(;w.length>0;){let R=w[w.length-1];if(R.i>=R.len){w.pop();continue}let T=R.i++,S=R.topLevelIfIndex!==-1,A=S?R.topLevelIfIndex:T;S||(I=T+1);let x=R.dirs[T],E=x[u];if(E==="const"||E==="let"){let a=x.name;if(typeof x.resolve=="function")try{D[a]=x.resolve($,D).value;}catch(l){p.push({directiveIndex:A,error:`Binding resolve: ${l}`}),f.errors++;}else D[a]=x.value;continue}if(E==="return"){let a=I,l=x.value;if(typeof x.resolve=="function")try{let v=x.resolve($,D);l="value"in v?v.value:"return"in v?v.return:l;}catch(v){p.push({directiveIndex:A,error:`Control resolve: ${v}`}),f.errors++;continue}return {success:true,aborted:false,appliedCount:m,skippedCount:g,errors:p,processedCount:a,totalCount:y,counters:f,data:l}}if(E==="throw"){let a=I,l=x.message;if(typeof x.resolve=="function")try{let v=x.resolve($,D);l="message"in v?v.message:"throw"in v?v.throw:l;}catch(v){p.push({directiveIndex:A,error:`Control resolve: ${v}`}),f.errors++;continue}return B("throw",m,g,p,a,y,f,l)}if(E==="pause"){let a=I,l=yield {source:"pause",directive:x,frame:r,index:A,payload:{message:x.message}};if(l===false||l==="abort"||l==="cancel")return B("pause",m,g,p,a,y,f,l);m++,f.directivesApplied++,typeof x.as=="string"&&l!==void 0&&(D[x.as]=l);continue}if(E==="if"){let a;try{let v=x.cond;a=typeof v=="function"?!!v($,D):!!v;}catch(v){p.push({directiveIndex:A,error:`if cond: ${v}`}),f.errors++;continue}let l=a?x.then:x.else;if(Array.isArray(l)&&l.length>0){let v=Math.min(l.length,C),G=S?R.topLevelIfIndex:T;w.push({dirs:l,i:0,len:v,topLevelIfIndex:G});}continue}let _=x,k=r;if(e)try{let a=core.processIntercept(await c.beforeDirective(_,r),"beforeDirective");if(a.action===core.Intercept.SKIP){g++,f.directivesSkipped++;continue}if(a.action===core.Intercept.ABORT)return B(a.abortReason,m,g,p,I===0?T:I-1,y,f);a.ctx!==void 0&&(k=r.withCtx(a.ctx)),a.directive!==void 0&&(_=a.directive);}catch(a){p.push({directiveIndex:A,error:`Hook beforeDirective: ${a}`}),f.errors++;}if(typeof _.resolve=="function")try{let a=_.resolve(k.ctx,k.scope);_={..._,...a};}catch(a){p.push({directiveIndex:A,error:`Directive resolve: ${a}`}),f.errors++;continue}let M=_[u],F=M?d[M]:void 0;if(!F){p.push({directiveIndex:A,error:`No handler for directive type: ${M??"undefined"}`}),f.errors++;continue}let b;try{let a=await F(_,k,h),l=pe(a);l!==null?b=yield*l:b=a;}catch(a){b={ok:false,error:String(a)};}let H=I;if(b.ok){if(m++,f.directivesApplied++,typeof _.as=="string"&&(D[_.as]=b.data),b.halt)return {success:true,aborted:true,abortedBy:"halt",appliedCount:m,skippedCount:g,errors:p,processedCount:H,totalCount:y,counters:f,data:b.data}}else {if(b.halt)return B("halt",m,g,p,H,y,f,b.data);let a=_.catch;if(Array.isArray(a)&&a.length>0){D.$exception=b.error??"handler failed";let l=await h.runDirectivesAsync(a,k);m+=l.appliedCount;for(let v=0;v<l.errors.length;v++)p.push(l.errors[v]);if(l.aborted)return {success:l.success,aborted:true,abortedBy:l.abortedBy,appliedCount:m,skippedCount:g,errors:p,processedCount:H,totalCount:y,counters:f,data:l.data}}else p.push({directiveIndex:A,error:b.error??"handler failed"}),f.errors++;}if(n)try{if(await c.afterDirective(_,b,k)==="abort")return B("afterDirective",m,g,p,H,y,f)}catch(a){p.push({directiveIndex:A,error:`Hook afterDirective: ${a}`}),f.errors++;}}let P={success:true,aborted:false,appliedCount:m,skippedCount:g,errors:p,processedCount:y,totalCount:y,counters:f};if(i)try{await c.onDirectivesComplete(P);}catch{}return P}}function ee(o,e){return e?Me(o):He(o)}function te(o,e=o.hasAnyAsync){let{filledNames:n}=o,i=h=>n.has(h),s=h=>o.asyncNames.has(h)?"await ":"",t=e?"await ":"",r=[];for(let h of n)r.push(`const ${h} = directiveHooks.${h};`);r.push("const len = Math.min(directives.length, maxDirectives);"),r.push("const errors = []; let appliedCount = 0; let skippedCount = 0;"),r.push("const counters = frame.counters;"),r.push("for (let i = 0; i < len; i++) {"),r.push(" let directive = directives[i];"),i("beforeDirective")?(r.push(" let _df = frame;"),r.push(" try {"),r.push(` const _bd = ${s("beforeDirective")}beforeDirective(directive, frame);`),r.push(' if (_bd === "skip") { skippedCount++; counters.directivesSkipped++; continue; }'),r.push(' if (_bd === "abort") return { success: false, aborted: true, abortedBy: "beforeDirective", appliedCount, skippedCount, errors, processedCount: i, totalCount: len, counters };'),r.push(' if (typeof _bd === "object" && _bd !== null) {'),r.push(' if ("abort" in _bd) return { success: false, aborted: true, abortedBy: _bd.abort, appliedCount, skippedCount, errors, processedCount: i, totalCount: len, counters };'),r.push(' if ("ctx" in _bd) _df = frame.withCtx(_bd.ctx);'),r.push(' if ("directive" in _bd) directive = _bd.directive;'),r.push(" }"),r.push(' } catch (_e) { errors.push({ directiveIndex: i, error: "Hook beforeDirective: " + _e }); counters.errors++; }')):r.push(" const _df = frame;"),r.push(' if (typeof directive.resolve === "function") {'),r.push(" try { const _r = directive.resolve(_df.ctx); directive = Object.assign({}, directive, _r); }"),r.push(' catch (_e) { errors.push({ directiveIndex: i, error: "Directive resolve: " + _e }); counters.errors++; continue; }'),r.push(" }"),r.push(" const _type = directive[typeField];"),r.push(" const _handler = _type ? handlers[_type] : undefined;"),r.push(' if (!_handler) { errors.push({ directiveIndex: i, error: "No handler for directive type: " + (_type || "undefined") }); counters.errors++; continue; }'),r.push(" let _result;"),r.push(` try { _result = ${t}_handler(directive, _df, engine); } catch (_e) { errors.push({ directiveIndex: i, error: String(_e) }); counters.errors++; continue; }`),r.push(" if (_result.ok) { appliedCount++; counters.directivesApplied++; }"),r.push(' else { errors.push({ directiveIndex: i, error: _result.error || "handler failed" }); counters.errors++; }'),i("afterDirective")&&(r.push(" try {"),r.push(` const _ad = ${s("afterDirective")}afterDirective(directive, _result, _df);`),r.push(' if (_ad === "abort") return { success: false, aborted: true, abortedBy: "afterDirective", appliedCount, skippedCount, errors, processedCount: i + 1, totalCount: len, counters };'),r.push(' } catch (_e) { errors.push({ directiveIndex: i, error: "Hook afterDirective: " + _e }); counters.errors++; }')),r.push("}"),r.push("const _finalResult = { success: true, aborted: false, appliedCount, skippedCount, errors, processedCount: len, totalCount: len, counters };"),i("onDirectivesComplete")&&r.push(`try { ${s("onDirectivesComplete")}onDirectivesComplete(_finalResult); } catch (_e) {}`),r.push("return _finalResult;");let d=r.join(`
|
|
2
|
+
`),c=e?"async ":"";return {fn:new Function("directives","frame","handlers","directiveHooks","typeField","engine","maxDirectives",`"use strict";
|
|
3
|
+
return (${c}() => {
|
|
4
|
+
${d}
|
|
5
|
+
})();`),isAsync:e}}function re(o,e,n){return `return{success:false,aborted:true,abortedBy:${o},appliedCount,skippedCount,errors,processedCount:${e},totalCount:${n},counters};`}function Pe(o,e){return `return{success:true,aborted:true,abortedBy:"halt",appliedCount,skippedCount,errors,processedCount:${o},totalCount:${e},counters,data:_result.data};`}function Fe(o,e){return `return{success:false,aborted:true,abortedBy:"halt",appliedCount,skippedCount,errors,processedCount:${o},totalCount:${e},counters,data:_result.data};`}function Be(o,e,n,i){let s=JSON.stringify(e.name);typeof e.resolve=="function"?(o.push("try{"),o.push(`scope[${s}]=${n}.resolve(ctx,scope).value;`),o.push(`}catch(_e){errors.push({directiveIndex:${i},error:"Binding resolve: "+_e});counters.errors++;}`)):o.push(`scope[${s}]=${n}.value;`);}function Ge(o,e,n,i,s,t){typeof e.resolve=="function"?(o.push("try{"),o.push(`const _rv=${n}.resolve(ctx,scope);`),o.push(`return{success:true,aborted:false,appliedCount,skippedCount,errors,processedCount:${s},totalCount:${t},counters,data:"value" in _rv?_rv.value:"return" in _rv?_rv.return:${n}.value};`),o.push(`}catch(_e){errors.push({directiveIndex:${i},error:"Control resolve: "+_e});counters.errors++;}`)):o.push(`return{success:true,aborted:false,appliedCount,skippedCount,errors,processedCount:${s},totalCount:${t},counters,data:${n}.value};`);}function Le(o,e,n,i,s,t){typeof e.resolve=="function"?(o.push("try{"),o.push(`const _rv=${n}.resolve(ctx,scope);`),o.push(`return{success:false,aborted:true,abortedBy:"throw",appliedCount,skippedCount,errors,processedCount:${s},totalCount:${t},counters,data:"message" in _rv?_rv.message:"throw" in _rv?_rv.throw:${n}.message};`),o.push(`}catch(_e){errors.push({directiveIndex:${i},error:"Control resolve: "+_e});counters.errors++;}`)):o.push(`return{success:false,aborted:true,abortedBy:"throw",appliedCount,skippedCount,errors,processedCount:${s},totalCount:${t},counters,data:${n}.message};`);}function Ne(o,e,n,i,s,t){let r=typeof e.as=="string",d=r?JSON.stringify(e.as):"";o.push(`{const _ack=yield{source:"pause",directive:${n},frame,index:${i},payload:{message:${n}.message}};`),o.push(`if(_ack===false||_ack==="abort"||_ack==="cancel")return{success:false,aborted:true,abortedBy:"pause",appliedCount,skippedCount,errors,processedCount:${s},totalCount:${t},counters,data:_ack};`),o.push("appliedCount++;counters.directivesApplied++;"),r&&o.push(`if(_ack!==undefined)scope[${d}]=_ack;`),o.push("}");}function je(o,e,n,i,s){let{L:t,total:r,typeField:d,handlerVars:c,hasBefore:u,hasAfter:h,awBefore:C,awAfter:y,awHandler:p,actionIsAsync:m,actionIsInteractive:g,interactiveHandlerSet:f}=s,D=o[d],$=c.get(D),w=typeof o.resolve=="function",I=typeof o.as=="string",P=Array.isArray(o.catch)&&o.catch.length>0,R=I?JSON.stringify(o.as):"",T=g&&f.has(D),S=s.blockCounter.n++;t.push(`_b${S}:{`);let A=u||w,x=u;A&&t.push(`let _dir=${e};`),x&&t.push("let _df=frame;"),u&&(t.push("try{"),t.push(`const _bd=${C}_hookBefore(${e},frame);`),t.push(`if(_bd==="skip"){skippedCount++;counters.directivesSkipped++;break _b${S};}`),t.push(`if(_bd==="abort")${re('"beforeDirective"',i-1,r)}`),t.push('if(typeof _bd==="object"&&_bd!==null){'),t.push(`if("abort" in _bd)${re("_bd.abort",i-1,r)}`),t.push('if("ctx" in _bd)_df=frame.withCtx(_bd.ctx);'),t.push('if("directive" in _bd)_dir=_bd.directive;'),t.push("}"),t.push(`}catch(_e){errors.push({directiveIndex:${n},error:"Hook beforeDirective: "+_e});counters.errors++;}`)),u?(t.push('if(typeof _dir.resolve==="function"){'),t.push("try{const _r=_dir.resolve(_df.ctx,scope);_dir=Object.assign({},_dir,_r);}"),t.push(`catch(_e){errors.push({directiveIndex:${n},error:"Directive resolve: "+_e});counters.errors++;break _b${S};}}`)):w&&(t.push(`try{const _r=${e}.resolve(ctx,scope);_dir=Object.assign({},${e},_r);}`),t.push(`catch(_e){errors.push({directiveIndex:${n},error:"Directive resolve: "+_e});counters.errors++;break _b${S};}`));let E=A?"_dir":e,_=x?"_df":"frame";if(t.push("let _result;"),T?(t.push(`try{_result=yield* ${$}(${E},${_},$.engine);}`),t.push("catch(_e){_result={ok:false,error:String(_e)};}")):g?(t.push(`try{_result=${p}${$}(${E},${_},$.engine);if(_result&&_result.iterator)_result=yield* _result.iterator;}`),t.push("catch(_e){_result={ok:false,error:String(_e)};}")):(t.push(`try{_result=${p}${$}(${E},${_},$.engine);}`),t.push("catch(_e){_result={ok:false,error:String(_e)};}")),t.push("if(_result.ok){"),t.push("appliedCount++;counters.directivesApplied++;"),I&&t.push(`scope[${R}]=_result.data;`),t.push(`if(_result.halt)${Pe(i,r)}`),t.push("}else{"),t.push(`if(_result.halt)${Fe(i,r)}`),P){t.push('scope.$exception=_result.error||"handler failed";');let k=m?"$.runner":"$.runnerSync";t.push(`const _cr=${p}${k}(${e}.catch,${_});`),t.push("appliedCount+=_cr.appliedCount;"),t.push("for(let _j=0;_j<_cr.errors.length;_j++)errors.push(_cr.errors[_j]);"),t.push(`if(_cr.aborted)return{success:_cr.success,aborted:true,abortedBy:_cr.abortedBy,appliedCount,skippedCount,errors,processedCount:${i},totalCount:${r},counters,data:_cr.data};`);}else t.push(`errors.push({directiveIndex:${n},error:_result.error||"handler failed"});counters.errors++;`);t.push("}"),h&&(t.push("try{"),t.push(`const _ad=${y}_hookAfter(${E},_result,${_});`),t.push(`if(_ad==="abort")${re('"afterDirective"',i,r)}`),t.push(`}catch(_e){errors.push({directiveIndex:${n},error:"Hook afterDirective: "+_e});counters.errors++;}`)),t.push("}");}function Oe(o,e,n,i,s,t){let{L:r}=t,d=o.cond,c=typeof d=="boolean";r.push("{"),c?r.push(`if(${d?"true":"false"}){`):(r.push("let _cond=false,_condOk=true;"),r.push(`try{const _c=${e}.cond;_cond=typeof _c==="function"?!!_c(ctx,scope):!!_c;}`),r.push(`catch(_e){errors.push({directiveIndex:${n},error:"if cond: "+_e});counters.errors++;_condOk=false;}`),r.push("if(_condOk){"),r.push("if(_cond){"));let u=o.then;Array.isArray(u)&&u.length>0&&ne(u,`${e}.then`,i,s,t),r.push("}");let h=o.else;Array.isArray(h)&&h.length>0&&(r.push("else{"),ne(h,`${e}.else`,i,s,t),r.push("}")),c||r.push("}"),r.push("}");}function ne(o,e,n,i,s){let t=n!==-1;for(let r=0;r<o.length;r++){let d=o[r],c=`${e}[${r}]`,u=t?n:r,h=t?i:r+1;switch(d[s.typeField]){case "const":case "let":Be(s.L,d,c,u);break;case "return":Ge(s.L,d,c,u,h,s.total);break;case "throw":Le(s.L,d,c,u,h,s.total);break;case "pause":Ne(s.L,d,c,u,h,s.total);break;case "if":{let y=t?n:r,p=t?i:r+1;Oe(d,c,u,y,p,s);break}default:je(d,c,u,h,s);break}}}function ie(o,e,n){for(let i of o){let s=i[e];if(s&&!N.has(s)&&n.add(s),s==="if"){let t=i.then;Array.isArray(t)&&t.length>0&&ie(t,e,n);let r=i.else;Array.isArray(r)&&r.length>0&&ie(r,e,n);}}}var he=new Set;function se(o,e,n,i=he,s,t=false,r=he){let d=[],c=o.length,{filledNames:u,hasAnyAsync:h,asyncNames:C}=e,y=u.has("beforeDirective"),p=u.has("afterDirective"),m=u.has("onDirectivesComplete"),g=s!==void 0?s:Q(o,i,n),f=h||g,D=f?"await ":"",$=C.has("beforeDirective")?"await ":"",w=C.has("afterDirective")?"await ":"",I=C.has("onDirectivesComplete")?"await ":"",P=new Set;ie(o,n,P);let R=new Map,T=0;for(let k of P)R.set(k,`_h${T++}`);d.push("const counters=frame.counters;"),d.push("const ctx=frame.ctx;"),d.push("const errors=[];"),d.push("let appliedCount=0;"),d.push("let skippedCount=0;");for(let[k,M]of R)d.push(`const ${M}=$.h[${JSON.stringify(k)}];`);y&&d.push("const _hookBefore=$.hooks.beforeDirective;"),p&&d.push("const _hookAfter=$.hooks.afterDirective;"),ne(o,"$.d",-1,0,{L:d,total:c,typeField:n,handlerVars:R,hasBefore:y,hasAfter:p,awBefore:$,awAfter:w,awHandler:D,actionIsAsync:f,actionIsInteractive:t,interactiveHandlerSet:r,blockCounter:{n:0}}),d.push(`const _finalResult={success:true,aborted:false,appliedCount,skippedCount,errors,processedCount:${c},totalCount:${c},counters};`),m&&d.push(`try{${I}$.hooks.onDirectivesComplete(_finalResult);}catch(_e){}`),d.push("return _finalResult;");let x=`{
|
|
6
|
+
${d.join(`
|
|
7
7
|
`)}
|
|
8
|
-
}`,E;return t?E=`(${
|
|
9
|
-
return ${E};`),isAsync:p,isInteractive:t}}function V(s,e,r){for(let i of s){let o=i[r];if(o&&e.has(o))return true;if(o==="if"){let n=i.then;if(Array.isArray(n)&&n.length>0&&V(n,e,r))return true;let a=i.else;if(Array.isArray(a)&&a.length>0&&V(a,e,r))return true}let t=i.catch;if(Array.isArray(t)&&t.length>0&&V(t,e,r))return true}return false}function se(s,e,r){return {success:false,aborted:false,appliedCount:0,skippedCount:0,processedCount:0,totalCount:0,errors:[{directiveIndex:-1,error:e}],counters:s,...r}}function ve(s,e){return se(e,`Action not found: "${s}"`,{aborted:true,abortedBy:"action-not-found"})}function he(s,e,r){return se(r,`Max depth ${e} exceeded invoking "${s}"`,{aborted:true,abortedBy:"maxDepth"})}function ye(s,e){return se(e,`Action "${s}" is private (sub-action). Can only be invoked from within its parent scope.`)}function W(s,e){return {success:true,aborted:false,appliedCount:0,skippedCount:0,processedCount:0,totalCount:0,errors:[],data:s,counters:e}}function Le(s){return typeof s=="object"&&s!==null&&"execute"in s}function xe(s){let e=Object.create(null),r=new Map;for(let i of Object.keys(s)){let o=s[i];Le(o)?(e[i]=o.execute,r.set(i,o)):(e[i]=o,r.set(i,{execute:o}));}return {handlers:e,definitions:r}}function me(s,e){if(s==="*")return true;if(!s.includes("*"))return s===e;let r=s.replace(/[.+^${}()|[\]\\]/g,"\\$&");return new RegExp("^"+r.replace(/\*/g,".*")+"$").test(e)}function _e(s){return typeof s=="string"?{pattern:s}:s}function ge(s,e,r){let i=new Map;if(!e&&!r){for(let o of s)i.set(o,{status:"available"});return i}if(e){let o=e.map(_e);for(let t of s){let n=o.some(a=>me(a.pattern,t));i.set(t,{status:n?"available":"denied"});}}else {let o=r.map(_e);for(let t of s){let n=o.find(a=>me(a.pattern,t));n?i.set(t,{status:"denied",reason:n.reason,source:n.source}):i.set(t,{status:"available"});}}return i}function Ce(s){let{typeField:e,asyncHandlerSet:r,interactiveHandlerSet:i}=s,o=new Map,t=new Set,n=new Set,a=new Set,d=new Set;return {upsert(f,x,C){o.set(f,Ne(x,e)),Y(x,r,e)?t.add(f):t.delete(f),C||Q(x,i,e)?n.add(f):n.delete(f);},remove(f){o.delete(f),t.delete(f),n.delete(f);},recompute(){a=De(o,t),d=De(o,n);},isAsync(f){return a.has(f)},isInteractive(f){return d.has(f)},has(f){return o.has(f)}}}function Ne(s,e){let r=new Set;return J(s,e,r),r}function J(s,e,r){for(let i of s){i[e]==="action"&&typeof i.id=="string"&&r.add(i.id);let o=i.catch;if(Array.isArray(o)&&o.length>0&&J(o,e,r),i[e]==="if"){let t=i.then;Array.isArray(t)&&t.length>0&&J(t,e,r);let n=i.else;Array.isArray(n)&&n.length>0&&J(n,e,r);}}}function Y(s,e,r){for(let i of s){let o=i[r];if(o&&e.has(o))return true;let t=i.catch;if(Array.isArray(t)&&t.length>0&&Y(t,e,r))return true;if(o==="if"){let n=i.then;if(Array.isArray(n)&&n.length>0&&Y(n,e,r))return true;let a=i.else;if(Array.isArray(a)&&a.length>0&&Y(a,e,r))return true}}return false}function Q(s,e,r){for(let i of s){let o=i[r];if(o==="pause"||o&&e.has(o))return true;let t=i.catch;if(Array.isArray(t)&&t.length>0&&Q(t,e,r))return true;if(o==="if"){let n=i.then;if(Array.isArray(n)&&n.length>0&&Q(n,e,r))return true;let a=i.else;if(Array.isArray(a)&&a.length>0&&Q(a,e,r))return true}}return false}function O(s,e){for(let r of s){let i=r[e];if(i==="pause")return true;let o=r.catch;if(Array.isArray(o)&&o.length>0&&O(o,e))return true;if(i==="if"){let t=r.then;if(Array.isArray(t)&&t.length>0&&O(t,e))return true;let n=r.else;if(Array.isArray(n)&&n.length>0&&O(n,e))return true}}return false}function De(s,e){let r=new Set(e),i=true;for(;i;){i=false;for(let[o,t]of s)if(!r.has(o)){for(let n of t)if(r.has(n)){r.add(o),i=true;break}}}return r}var Ue=8,qe="type",ce={maxDepth:10,maxRules:1e4,maxDirectives:1e5},ae=class{_directiveExecutor;_mode;_ctx;_requestedMode;_threshold;_limits;_typeField;_handlers;_definitions;_directiveHooks;_directiveAnalysis;_asyncHandlerSet;_interactiveHandlerSet;_isAsync;_isInteractive;_directivePermissions;_miniGraph;_interactiveExecutor;_beforeAction;_afterAction;_registry=new Map;_emitter=new j;_batchDepth=0;_batchErrors=[];_batchWarnings=[];_batchActions=[];_batchRegistered=[];_registeredIds=new Set;_directiveRunner;_directiveRunnerSync;_engineRef;constructor(e){this._requestedMode=e.mode??"auto",this._threshold=e.autoJitThreshold??Ue,this._typeField=e.typeField??qe,this._limits={maxDepth:e.limits?.maxDepth??ce.maxDepth,maxRules:e.limits?.maxRules??ce.maxRules,maxDirectives:e.limits?.maxDirectives??ce.maxDirectives};let{handlers:r,definitions:i}=xe(e.handlers);for(let a of Object.keys(e.handlers))if(L.has(a))throw new Error(`Handler type "${a}" is reserved for engine-internal directives`);if(e.allowedDirectives&&e.blockedDirectives)throw new Error("allowedDirectives and blockedDirectives are mutually exclusive. Provide one or neither.");this._handlers=r,this._definitions=i,this._directivePermissions=ge(Object.keys(r),e.allowedDirectives,e.blockedDirectives),this._directiveHooks=e.directiveHooks??{},this._beforeAction=e.actionHooks?.beforeAction??null,this._afterAction=e.actionHooks?.afterAction??null,this._directiveAnalysis=core.analyzeSlots(this._directiveHooks,core.DIRECTIVE_SLOT_NAMES);let o=new Set,t=new Set;for(let[a,d]of this._definitions)(d.async===true||core.isAsyncFunction(d.execute))&&o.add(a),(d.interactive===true||core.isGeneratorFunction(d.execute))&&t.add(a);if(this._asyncHandlerSet=o,this._interactiveHandlerSet=t,this._isInteractive=e.interactive!==void 0,!this._isInteractive&&t.size>0){let a=Array.from(t).join(", ");throw new Error(`Handler(s) [${a}] are interactive but engine has no \`interactive\` config. Add \`interactive: {}\` to enable interactive mode.`)}this._isAsync=this._directiveAnalysis.hasAnyAsync||o.size>0,this._miniGraph=Ce({typeField:this._typeField,asyncHandlerSet:o,interactiveHandlerSet:t}),this._engineRef={runDirectives:(a,d)=>this._executeDirectives(a,d),runDirectivesAsync:(a,d)=>this._executeDirectivesAsync(a,d),invoke:(a,d,f)=>this._invokeInternal(a,d,f),invokeAsync:(a,d,f)=>this._invokeInternalAsync(a,d,f),isActionAsync:a=>this._miniGraph.has(a)?this._miniGraph.isAsync(a):void 0,isActionInteractive:a=>this._miniGraph.has(a)?this._miniGraph.isInteractive(a):void 0,invokeInteractive:(a,d,f)=>this._invokeInteractiveInternal(a,d,f),evaluateRules:()=>{throw new Error("evaluateRules() not available in ActionEngine context. Use createRuleEngine().")},evaluateRulesAsync:()=>{throw new Error("evaluateRulesAsync() not available in ActionEngine context. Use createRuleEngine().")}},this._directiveRunner=(a,d)=>this._directiveExecutor(a,d,this._handlers,this._directiveHooks,this._typeField,this._engineRef,this._limits.maxDirectives);let n=U(this._directiveAnalysis,false);this._directiveRunnerSync=(a,d)=>n(a,d,this._handlers,this._directiveHooks,this._typeField,this._engineRef,this._limits.maxDirectives),this._requestedMode==="jit"?(this._directiveExecutor=this._buildJitDirectiveExecutor(),this._mode="jit"):this._isAsync?(this._directiveExecutor=U(this._directiveAnalysis,true),this._mode="interpret"):(this._directiveExecutor=n,this._mode="interpret"),this._interactiveExecutor=this._isInteractive?this._isAsync?Z(this._directiveAnalysis,true):Z(this._directiveAnalysis,false):null;}register(e){let r=[],i=[],o=[],t=[];for(let a of e){if(!a.id){i.push({actionId:"",error:"Action must have an id"});continue}if(!this._isInteractive&&O(a.directives,this._typeField)){i.push({actionId:a.id,error:'Action uses directive type:"pause" but engine has no `interactive` config. Add `interactive: {}` to enable.'});continue}let d=ue(a,this._handlers,this._definitions,this._typeField);if(d.length>0){for(let f of d)i.push({actionId:a.id,error:f});continue}t.push(a);}for(let a of t){let d=N(a.directives,this._typeField),f={definition:a,directives:d,compiled:null,invokeCount:0};this._registry.set(a.id,f),this._registeredIds.add(a.id),this._miniGraph.upsert(a.id,d,a.interactive===true),r.push(a.id);}if(this._batchDepth>0){this._batchErrors.push(...i),this._batchWarnings.push(...o);for(let a of t)this._batchActions.push(a);return this._batchRegistered.push(...r),{registered:r,errors:i,warnings:o}}t.length>0&&(this._miniGraph.recompute(),this._invalidateAndMaybeRecompile());let n={registered:r,errors:i,warnings:o};return r.length>0&&this._emitter.emit("register",{actions:t,result:n,registered:r}),n}unregister(e){let r=this._registry.delete(e);r&&(this._registeredIds.delete(e),this._miniGraph.remove(e));let i=e+"/",o=[];for(let t of this._registry.keys())t.startsWith(i)&&(this._registry.delete(t),this._registeredIds.delete(t),this._miniGraph.remove(t),o.push(t));return r&&(this._miniGraph.recompute(),this._invalidateAndMaybeRecompile(),this._emitter.emit("unregister",{id:e,cascaded:o})),r}invoke(e,r,i){if(this._miniGraph.isInteractive(e))throw new Error(`Cannot call invoke("${e}") \u2014 action is interactive (transitively). Use invokeInteractive() instead.`);if(this._miniGraph.isAsync(e))throw new Error(`Cannot call invoke("${e}") \u2014 action is async (transitively). Use invokeAsync() instead.`);if(this._directiveAnalysis.hasAnyAsync)throw new Error(`Cannot call invoke("${e}") \u2014 engine has async directive hooks. Use invokeAsync() instead.`);let o=i!==void 0?i:this._requireCtx(),t=core.createRootFrame(o,this._limits);return this._invokeInternal(e,r,t)}async invokeAsync(e,r,i){if(this._miniGraph.isInteractive(e))throw new Error(`Cannot call invokeAsync("${e}") \u2014 action is interactive (transitively). Use invokeInteractive() instead.`);let o=i!==void 0?i:this._requireCtx(),t=core.createRootFrame(o,this._limits);return this._invokeInternalAsync(e,r,t)}setContext(e){this._ctx=e;}context(e,r){let i=this._ctx;this._ctx=e;try{return r()}finally{this._ctx=i;}}beginBatch(){this._batchDepth++,this._batchDepth===1&&(this._batchErrors=[],this._batchWarnings=[],this._batchActions=[],this._batchRegistered=[]);}endBatch(){if(this._batchDepth<=0)throw new Error("endBatch() called without matching beginBatch()");if(this._batchDepth--,this._batchDepth>0)return {registered:[],errors:[],warnings:[]};let e={registered:this._batchRegistered,errors:this._batchErrors,warnings:this._batchWarnings};return this._batchRegistered.length>0&&(this._miniGraph.recompute(),this._invalidateAndMaybeRecompile()),this._batchRegistered.length>0&&this._emitter.emit("register",{actions:this._batchActions,result:e,registered:this._batchRegistered}),e}on(e,r){return this._emitter.on(e,r)}get handlerDefinitions(){return this._definitions}get registeredIds(){return this._registeredIds}getActionDefinition(e){return this._registry.get(e)?.definition}get typeField(){return this._typeField}get directivePermissions(){return this._directivePermissions}get isAsync(){return this._isAsync}get isInteractive(){return this._isInteractive}isActionAsync(e){if(this._miniGraph.has(e))return this._miniGraph.isAsync(e)}isActionInteractive(e){if(this._miniGraph.has(e))return this._miniGraph.isInteractive(e)}invokeInteractive(e,r,i){if(!this._isInteractive||this._interactiveExecutor===null)throw new Error("Cannot call invokeInteractive() \u2014 engine has no `interactive` config. Add `interactive: {}` to enable.");let o=i!==void 0?i:this._requireCtx(),t=core.createRootFrame(o,this._limits);return this._invokeInteractiveInternal(e,r,t)}_invokeInteractiveInternal(e,r,i){let o=this._prepareInvoke(e,r,i);if("success"in o)return be(o,this._isAsync);let{stored:t,childFrame:n,childScope:a}=o;if(this._beforeAction!==null){let f=this._beforeAction(e,r,n);if(f?.skip)return be(W(f.data,n.counters),this._isAsync)}let d;if(t.compiled&&t.compiled.isInteractive)d=t.compiled.fn(n,n.scope,t.compiled.$);else {let f=this._interactiveExecutor;d=f(t.directives,n,this._handlers,this._directiveHooks,this._typeField,this._engineRef,this._limits.maxDirectives);}return Ve(d,e,r,n,this._afterAction,this._isAsync)}get compilationMode(){return this._mode}get directiveHookSlots(){return this._directiveAnalysis.filledNames}get asyncSlots(){return this._directiveAnalysis.asyncNames}compile(){if(this._requestedMode!=="interpret"){this._mode!=="jit"&&this._promote();for(let[e,r]of this._registry)r.compiled||(r.compiled=this._compileAction(e,r.directives));}}_invokeInternal(e,r,i){let o=this._prepareInvoke(e,r,i);if("success"in o)return o;let{stored:t,childFrame:n,childScope:a}=o;if(this._beforeAction!==null){let f=this._beforeAction(e,r,n);if(f?.skip)return W(f.data,n.counters)}let d;if(t.compiled?d=t.compiled.fn(n,a,t.compiled.$):this._isAsync&&!this._miniGraph.isAsync(e)?(t.compiled=this._compileAction(e,t.directives),d=t.compiled.fn(n,a,t.compiled.$)):(d=this._directiveRunner(t.directives,n),this._maybeAutoPromote(t)),this._afterAction!==null){let f=this._afterAction(e,r,d,n);f!==void 0&&(d=f);}return d}async _invokeInternalAsync(e,r,i){let o=this._prepareInvoke(e,r,i);if("success"in o)return o;let{stored:t,childFrame:n,childScope:a}=o;if(this._beforeAction!==null){let f=this._beforeAction(e,r,n);if(f?.skip)return W(f.data,n.counters)}let d;if(t.compiled?d=await t.compiled.fn(n,a,t.compiled.$):(d=await this._directiveRunner(t.directives,n),this._maybeAutoPromote(t)),this._afterAction!==null){let f=this._afterAction(e,r,d,n);f!==void 0&&(d=f);}return d}_prepareInvoke(e,r,i){let o=this._registry.get(e);if(!o)return ve(e,i.counters);if(e.includes("/")&&!this._isAccessible(e,i))return ye(e,i.counters);if(i.depth>=i.limits.maxDepth)return he(e,i.limits.maxDepth,i.counters);let t=Object.create(i.scope);r&&Object.assign(t,r);let n=i.child("action:"+e,0,e).withScope(t);return {stored:o,childFrame:n,childScope:t}}_maybeAutoPromote(e){this._requestedMode==="auto"&&++e.invokeCount>=this._threshold&&(e.compiled=this._compileAction(e.definition.id,e.directives),this._mode!=="jit"&&this._promote());}_executeDirectives(e,r){return this._directiveExecutor(e,r,this._handlers,this._directiveHooks,this._typeField,this._engineRef,this._limits.maxDirectives)}async _executeDirectivesAsync(e,r){return this._directiveExecutor(e,r,this._handlers,this._directiveHooks,this._typeField,this._engineRef,this._limits.maxDirectives)}_compileAction(e,r){let i=this._miniGraph.isAsync(e),o=this._miniGraph.isInteractive(e),{fn:t,isAsync:n,isInteractive:a}=ie(r,this._directiveAnalysis,this._typeField,this._asyncHandlerSet,i,o,this._interactiveHandlerSet),d={d:r,h:this._handlers,hooks:this._directiveHooks,engine:this._engineRef,runner:this._directiveRunner,runnerSync:this._directiveRunnerSync};return {fn:t,$:d,isAsync:n,isInteractive:a}}_isAccessible(e,r){let o="action:"+e.slice(0,e.lastIndexOf("/"));return r.path.includes(o)}_requireCtx(){if(this._ctx===void 0)throw new Error("No context set. Pass ctx to invoke(id, params, ctx), call setContext(ctx), or use context(ctx, fn).");return this._ctx}_promote(){this._directiveExecutor=this._buildJitDirectiveExecutor(),this._mode="jit";}_buildJitDirectiveExecutor(){let{fn:e}=ee(this._directiveAnalysis,this._isAsync);return e}_invalidateAndMaybeRecompile(){for(let e of this._registry.values())e.compiled=null;if(this._requestedMode==="jit")for(let[e,r]of this._registry)r.compiled=this._compileAction(e,r.directives);}};function be(s,e){return e?{next:()=>Promise.resolve({value:s,done:true}),return:()=>Promise.resolve({value:s,done:true}),throw:o=>Promise.reject(o),[Symbol.asyncIterator](){return this}}:{next:()=>({value:s,done:true}),return:()=>({value:s,done:true}),throw:i=>{throw i},[Symbol.iterator](){return this}}}function Ve(s,e,r,i,o,t){if(t){let d=s;return {async next(x){let C=await d.next(x);if(C.done){let y=C.value;if(o!==null){let l=o(e,r,y,i);l!==void 0&&(y=l);}return {value:y,done:true}}return {value:C.value,done:false}},async return(){let x=await d.return(void 0),C=x.value;if(x.done&&o!==null){let y=o(e,r,C,i);y!==void 0&&(C=y);}return {value:C,done:true}},async throw(x){let C=await d.throw(x);if(C.done){let y=C.value;if(o!==null){let l=o(e,r,y,i);l!==void 0&&(y=l);}return {value:y,done:true}}return {value:C.value,done:false}},[Symbol.asyncIterator](){return this}}}let n=s;return {next(d){let f=n.next(d);if(f.done){let x=f.value;if(o!==null){let C=o(e,r,x,i);C!==void 0&&(x=C);}return {value:x,done:true}}return {value:f.value,done:false}},return(){let d=n.return(void 0),f=d.value;if(d.done&&o!==null){let x=o(e,r,f,i);x!==void 0&&(f=x);}return {value:f,done:true}},throw(d){let f=n.throw(d);if(f.done){let x=f.value;if(o!==null){let C=o(e,r,x,i);C!==void 0&&(x=C);}return {value:x,done:true}}return {value:f.value,done:false}},[Symbol.iterator](){return this}}}function We(s){return new ae(s)}exports.RESERVED_TYPES=L;exports.SimpleEmitter=j;exports.buildActionExecutor=ie;exports.buildDirectiveExecutor=ee;exports.createActionEngine=We;exports.createDirectiveInterpreter=U;exports.drainAsync=Re;exports.drainSync=Ae;exports.normalizeDirectives=N;exports.replayResponder=Ie;
|
|
8
|
+
}`,E;return t?E=`(${f?"async function*()":"function*()"}${x})()`:E=`(${f?"async ()=>":"()=>"}${x})()`,{fn:new Function("frame","scope","$",`"use strict";
|
|
9
|
+
return ${E};`),isAsync:f,isInteractive:t}}function Q(o,e,n){for(let i of o){let s=i[n];if(s&&e.has(s))return true;if(s==="if"){let r=i.then;if(Array.isArray(r)&&r.length>0&&Q(r,e,n))return true;let d=i.else;if(Array.isArray(d)&&d.length>0&&Q(d,e,n))return true}let t=i.catch;if(Array.isArray(t)&&t.length>0&&Q(t,e,n))return true}return false}function oe(o,e,n){return {success:false,aborted:false,appliedCount:0,skippedCount:0,processedCount:0,totalCount:0,errors:[{directiveIndex:-1,error:e}],counters:o,...n}}function ve(o,e){return oe(e,`Action not found: "${o}"`,{aborted:true,abortedBy:"action-not-found"})}function ye(o,e,n){return oe(n,`Max depth ${e} exceeded invoking "${o}"`,{aborted:true,abortedBy:"maxDepth"})}function xe(o,e){return oe(e,`Action "${o}" is private (sub-action). Can only be invoked from within its parent scope.`)}function X(o,e){return {success:true,aborted:false,appliedCount:0,skippedCount:0,processedCount:0,totalCount:0,errors:[],data:o,counters:e}}function Ke(o){return typeof o=="object"&&o!==null&&"execute"in o}function ge(o){let e=new Map;for(let[n,i]of o){let s=i.subDirectives;if(!s)continue;let t=Object.keys(s);if(t.length===0)continue;let r=null;for(let d=0;d<t.length;d++){let c=t[d];c!=="catch"&&s[c].graph!==false&&(r===null&&(r=[]),r.push(c));}r!==null&&e.set(n,r);}return e}function me(o){let e=new Map;for(let[n,i]of o){let s=i.subDirectives;if(!s)continue;let t=Object.keys(s);if(t.length===0)continue;let r=null;for(let d=0;d<t.length;d++){let c=t[d];c!=="catch"&&(r===null&&(r=[]),r.push(c));}r!==null&&e.set(n,r);}return e}function _e(o){let e=Object.create(null),n=new Map;for(let i of Object.keys(o)){let s=o[i];Ke(s)?(e[i]=s.execute,n.set(i,s)):(e[i]=s,n.set(i,{execute:s}));}return {handlers:e,definitions:n}}function De(o,e){if(o==="*")return true;if(!o.includes("*"))return o===e;let n=o.replace(/[.+^${}()|[\]\\]/g,"\\$&");return new RegExp("^"+n.replace(/\*/g,".*")+"$").test(e)}function Ce(o){return typeof o=="string"?{pattern:o}:o}function be(o,e,n){let i=new Map;if(!e&&!n){for(let s of o)i.set(s,{status:"available"});return i}if(e){let s=e.map(Ce);for(let t of o){let r=s.some(d=>De(d.pattern,t));i.set(t,{status:r?"available":"denied"});}}else {let s=n.map(Ce);for(let t of o){let r=s.find(d=>De(d.pattern,t));r?i.set(t,{status:"denied",reason:r.reason,source:r.source}):i.set(t,{status:"available"});}}return i}function Re(o){let{typeField:e,asyncHandlerSet:n,interactiveHandlerSet:i,subDirectiveFieldsForGraph:s}=o,t=new Map,r=new Set,d=new Set,c=new Set,u=new Set;return {upsert(h,C,y){t.set(h,Ue(C,e,s)),U(C,n,e,s)?r.add(h):r.delete(h),y||z(C,i,e,s)?d.add(h):d.delete(h);},remove(h){t.delete(h),r.delete(h),d.delete(h);},recompute(){c=Ae(t,r),u=Ae(t,d);},isAsync(h){return c.has(h)},isInteractive(h){return u.has(h)},has(h){return t.has(h)}}}var Z=new Map;function Ue(o,e,n=Z){let i=new Set;return K(o,e,n,i),i}function K(o,e,n,i){for(let s of o){let t=s[e];t==="action"&&typeof s.id=="string"&&i.add(s.id);let r=s.catch;if(Array.isArray(r)&&r.length>0&&K(r,e,n,i),t==="if"){let c=s.then;Array.isArray(c)&&c.length>0&&K(c,e,n,i);let u=s.else;Array.isArray(u)&&u.length>0&&K(u,e,n,i);continue}if(t===void 0)continue;let d=n.get(t);if(d!==void 0)for(let c=0;c<d.length;c++){let u=s[d[c]];!Array.isArray(u)||u.length===0||K(u,e,n,i);}}}function U(o,e,n,i=Z){for(let s of o){let t=s[n];if(t!==void 0&&e.has(t))return true;let r=s.catch;if(Array.isArray(r)&&r.length>0&&U(r,e,n,i))return true;if(t==="if"){let c=s.then;if(Array.isArray(c)&&c.length>0&&U(c,e,n,i))return true;let u=s.else;if(Array.isArray(u)&&u.length>0&&U(u,e,n,i))return true;continue}if(t===void 0)continue;let d=i.get(t);if(d!==void 0)for(let c=0;c<d.length;c++){let u=s[d[c]];if(!(!Array.isArray(u)||u.length===0)&&U(u,e,n,i))return true}}return false}function z(o,e,n,i=Z){for(let s of o){let t=s[n];if(t==="pause"||t!==void 0&&e.has(t))return true;let r=s.catch;if(Array.isArray(r)&&r.length>0&&z(r,e,n,i))return true;if(t==="if"){let c=s.then;if(Array.isArray(c)&&c.length>0&&z(c,e,n,i))return true;let u=s.else;if(Array.isArray(u)&&u.length>0&&z(u,e,n,i))return true;continue}if(t===void 0)continue;let d=i.get(t);if(d!==void 0)for(let c=0;c<d.length;c++){let u=s[d[c]];if(!(!Array.isArray(u)||u.length===0)&&z(u,e,n,i))return true}}return false}function j(o,e,n=Z){for(let i of o){let s=i[e];if(s==="pause")return true;let t=i.catch;if(Array.isArray(t)&&t.length>0&&j(t,e,n))return true;if(s==="if"){let d=i.then;if(Array.isArray(d)&&d.length>0&&j(d,e,n))return true;let c=i.else;if(Array.isArray(c)&&c.length>0&&j(c,e,n))return true;continue}if(s===void 0)continue;let r=n.get(s);if(r!==void 0)for(let d=0;d<r.length;d++){let c=i[r[d]];if(!(!Array.isArray(c)||c.length===0)&&j(c,e,n))return true}}return false}function Ae(o,e){let n=new Set(e),i=true;for(;i;){i=false;for(let[s,t]of o)if(!n.has(s)){for(let r of t)if(n.has(r)){n.add(s),i=true;break}}}return n}var Je=8,Ye="type",ae={maxDepth:10,maxRules:1e4,maxDirectives:1e5},ue=class{_directiveExecutor;_mode;_ctx;_requestedMode;_threshold;_limits;_typeField;_handlers;_definitions;_directiveHooks;_directiveAnalysis;_asyncHandlerSet;_interactiveHandlerSet;_isAsync;_isInteractive;_directivePermissions;_subDirectiveFieldsForGraph;_subDirectiveFieldsAll;_miniGraph;_interactiveExecutor;_beforeAction;_afterAction;_registry=new Map;_emitter=new O;_batchDepth=0;_batchErrors=[];_batchWarnings=[];_batchActions=[];_batchRegistered=[];_registeredIds=new Set;_directiveRunner;_directiveRunnerSync;_engineRef;constructor(e){this._requestedMode=e.mode??"auto",this._threshold=e.autoJitThreshold??Je,this._typeField=e.typeField??Ye,this._limits={maxDepth:e.limits?.maxDepth??ae.maxDepth,maxRules:e.limits?.maxRules??ae.maxRules,maxDirectives:e.limits?.maxDirectives??ae.maxDirectives};let{handlers:n,definitions:i}=_e(e.handlers);for(let c of Object.keys(e.handlers))if(N.has(c))throw new Error(`Handler type "${c}" is reserved for engine-internal directives`);if(e.allowedDirectives&&e.blockedDirectives)throw new Error("allowedDirectives and blockedDirectives are mutually exclusive. Provide one or neither.");this._handlers=n,this._definitions=i,this._directivePermissions=be(Object.keys(n),e.allowedDirectives,e.blockedDirectives),this._directiveHooks=e.directiveHooks??{},this._beforeAction=e.actionHooks?.beforeAction??null,this._afterAction=e.actionHooks?.afterAction??null,this._directiveAnalysis=core.analyzeSlots(this._directiveHooks,core.DIRECTIVE_SLOT_NAMES);let s=new Set,t=new Set;for(let[c,u]of this._definitions)(u.async===true||core.isAsyncFunction(u.execute))&&s.add(c),(u.interactive===true||core.isGeneratorFunction(u.execute))&&t.add(c);if(this._asyncHandlerSet=s,this._interactiveHandlerSet=t,this._isInteractive=e.interactive!==void 0,!this._isInteractive&&t.size>0){let c=Array.from(t).join(", ");throw new Error(`Handler(s) [${c}] are interactive but engine has no \`interactive\` config. Add \`interactive: {}\` to enable interactive mode.`)}this._isAsync=this._directiveAnalysis.hasAnyAsync||s.size>0;let r=ge(this._definitions);this._subDirectiveFieldsForGraph=r,this._subDirectiveFieldsAll=me(this._definitions),this._miniGraph=Re({typeField:this._typeField,asyncHandlerSet:s,interactiveHandlerSet:t,subDirectiveFieldsForGraph:r}),this._engineRef={runDirectives:(c,u)=>this._executeDirectives(c,u),runDirectivesAsync:(c,u)=>this._executeDirectivesAsync(c,u),invoke:(c,u,h)=>this._invokeInternal(c,u,h),invokeAsync:(c,u,h)=>this._invokeInternalAsync(c,u,h),isActionAsync:c=>this._miniGraph.has(c)?this._miniGraph.isAsync(c):void 0,isActionInteractive:c=>this._miniGraph.has(c)?this._miniGraph.isInteractive(c):void 0,invokeInteractive:(c,u,h)=>this._invokeInteractiveInternal(c,u,h),evaluateRules:()=>{throw new Error("evaluateRules() not available in ActionEngine context. Use createRuleEngine().")},evaluateRulesAsync:()=>{throw new Error("evaluateRulesAsync() not available in ActionEngine context. Use createRuleEngine().")}},this._directiveRunner=(c,u)=>this._directiveExecutor(c,u,this._handlers,this._directiveHooks,this._typeField,this._engineRef,this._limits.maxDirectives);let d=J(this._directiveAnalysis,false);this._directiveRunnerSync=(c,u)=>d(c,u,this._handlers,this._directiveHooks,this._typeField,this._engineRef,this._limits.maxDirectives),this._requestedMode==="jit"?(this._directiveExecutor=this._buildJitDirectiveExecutor(),this._mode="jit"):this._isAsync?(this._directiveExecutor=J(this._directiveAnalysis,true),this._mode="interpret"):(this._directiveExecutor=d,this._mode="interpret"),this._interactiveExecutor=this._isInteractive?this._isAsync?ee(this._directiveAnalysis,true):ee(this._directiveAnalysis,false):null;}register(e){let n=[],i=[],s=[],t=[];for(let d of e){if(!d.id){i.push({actionId:"",error:"Action must have an id"});continue}if(!this._isInteractive&&j(d.directives,this._typeField,this._subDirectiveFieldsForGraph)){i.push({actionId:d.id,error:'Action uses directive type:"pause" but engine has no `interactive` config. Add `interactive: {}` to enable.'});continue}let c=le(d,this._handlers,this._definitions,this._typeField);if(c.length>0){for(let u of c)i.push({actionId:d.id,error:u});continue}t.push(d);}for(let d of t){let c=L(d.directives,this._typeField,this._subDirectiveFieldsAll),u={definition:d,directives:c,compiled:null,invokeCount:0};this._registry.set(d.id,u),this._registeredIds.add(d.id),this._miniGraph.upsert(d.id,c,d.interactive===true),n.push(d.id);}if(this._batchDepth>0){this._batchErrors.push(...i),this._batchWarnings.push(...s);for(let d of t)this._batchActions.push(d);return this._batchRegistered.push(...n),{registered:n,errors:i,warnings:s}}t.length>0&&(this._miniGraph.recompute(),this._invalidateAndMaybeRecompile());let r={registered:n,errors:i,warnings:s};return n.length>0&&this._emitter.emit("register",{actions:t,result:r,registered:n}),r}unregister(e){let n=this._registry.delete(e);n&&(this._registeredIds.delete(e),this._miniGraph.remove(e));let i=e+"/",s=[];for(let t of this._registry.keys())t.startsWith(i)&&(this._registry.delete(t),this._registeredIds.delete(t),this._miniGraph.remove(t),s.push(t));return n&&(this._miniGraph.recompute(),this._invalidateAndMaybeRecompile(),this._emitter.emit("unregister",{id:e,cascaded:s})),n}invoke(e,n,i){if(this._miniGraph.isInteractive(e))throw new Error(`Cannot call invoke("${e}") \u2014 action is interactive (transitively). Use invokeInteractive() instead.`);if(this._miniGraph.isAsync(e))throw new Error(`Cannot call invoke("${e}") \u2014 action is async (transitively). Use invokeAsync() instead.`);if(this._directiveAnalysis.hasAnyAsync)throw new Error(`Cannot call invoke("${e}") \u2014 engine has async directive hooks. Use invokeAsync() instead.`);let s=i!==void 0?i:this._requireCtx(),t=core.createRootFrame(s,this._limits);return this._invokeInternal(e,n,t)}async invokeAsync(e,n,i){if(this._miniGraph.isInteractive(e))throw new Error(`Cannot call invokeAsync("${e}") \u2014 action is interactive (transitively). Use invokeInteractive() instead.`);let s=i!==void 0?i:this._requireCtx(),t=core.createRootFrame(s,this._limits);return this._invokeInternalAsync(e,n,t)}setContext(e){this._ctx=e;}context(e,n){let i=this._ctx;this._ctx=e;try{return n()}finally{this._ctx=i;}}beginBatch(){this._batchDepth++,this._batchDepth===1&&(this._batchErrors=[],this._batchWarnings=[],this._batchActions=[],this._batchRegistered=[]);}endBatch(){if(this._batchDepth<=0)throw new Error("endBatch() called without matching beginBatch()");if(this._batchDepth--,this._batchDepth>0)return {registered:[],errors:[],warnings:[]};let e={registered:this._batchRegistered,errors:this._batchErrors,warnings:this._batchWarnings};return this._batchRegistered.length>0&&(this._miniGraph.recompute(),this._invalidateAndMaybeRecompile()),this._batchRegistered.length>0&&this._emitter.emit("register",{actions:this._batchActions,result:e,registered:this._batchRegistered}),e}on(e,n){return this._emitter.on(e,n)}get handlerDefinitions(){return this._definitions}get registeredIds(){return this._registeredIds}getActionDefinition(e){return this._registry.get(e)?.definition}get typeField(){return this._typeField}get subDirectiveFieldsForGraph(){return this._subDirectiveFieldsForGraph}get directivePermissions(){return this._directivePermissions}get isAsync(){return this._isAsync}get isInteractive(){return this._isInteractive}isActionAsync(e){if(this._miniGraph.has(e))return this._miniGraph.isAsync(e)}isActionInteractive(e){if(this._miniGraph.has(e))return this._miniGraph.isInteractive(e)}invokeInteractive(e,n,i){if(!this._isInteractive||this._interactiveExecutor===null)throw new Error("Cannot call invokeInteractive() \u2014 engine has no `interactive` config. Add `interactive: {}` to enable.");let s=i!==void 0?i:this._requireCtx(),t=core.createRootFrame(s,this._limits);return this._invokeInteractiveInternal(e,n,t)}_invokeInteractiveInternal(e,n,i){let s=this._prepareInvoke(e,n,i);if("success"in s)return ke(s,this._isAsync);let{stored:t,childFrame:r,childScope:d}=s;if(this._beforeAction!==null){let u=this._beforeAction(e,n,r);if(u?.skip)return ke(X(u.data,r.counters),this._isAsync)}let c;if(t.compiled&&t.compiled.isInteractive)c=t.compiled.fn(r,r.scope,t.compiled.$);else {let u=this._interactiveExecutor;c=u(t.directives,r,this._handlers,this._directiveHooks,this._typeField,this._engineRef,this._limits.maxDirectives);}return Qe(c,e,n,r,this._afterAction,this._isAsync)}get compilationMode(){return this._mode}get directiveHookSlots(){return this._directiveAnalysis.filledNames}get asyncSlots(){return this._directiveAnalysis.asyncNames}compile(){if(this._requestedMode!=="interpret"){this._mode!=="jit"&&this._promote();for(let[e,n]of this._registry)n.compiled||(n.compiled=this._compileAction(e,n.directives));}}_invokeInternal(e,n,i){let s=this._prepareInvoke(e,n,i);if("success"in s)return s;let{stored:t,childFrame:r,childScope:d}=s;if(this._beforeAction!==null){let u=this._beforeAction(e,n,r);if(u?.skip)return X(u.data,r.counters)}let c;if(t.compiled?c=t.compiled.fn(r,d,t.compiled.$):this._isAsync&&!this._miniGraph.isAsync(e)?(t.compiled=this._compileAction(e,t.directives),c=t.compiled.fn(r,d,t.compiled.$)):(c=this._directiveRunner(t.directives,r),this._maybeAutoPromote(t)),this._afterAction!==null){let u=this._afterAction(e,n,c,r);u!==void 0&&(c=u);}return c}async _invokeInternalAsync(e,n,i){let s=this._prepareInvoke(e,n,i);if("success"in s)return s;let{stored:t,childFrame:r,childScope:d}=s;if(this._beforeAction!==null){let u=this._beforeAction(e,n,r);if(u?.skip)return X(u.data,r.counters)}let c;if(t.compiled?c=await t.compiled.fn(r,d,t.compiled.$):(c=await this._directiveRunner(t.directives,r),this._maybeAutoPromote(t)),this._afterAction!==null){let u=this._afterAction(e,n,c,r);u!==void 0&&(c=u);}return c}_prepareInvoke(e,n,i){let s=this._registry.get(e);if(!s)return ve(e,i.counters);if(e.includes("/")&&!this._isAccessible(e,i))return xe(e,i.counters);if(i.depth>=i.limits.maxDepth)return ye(e,i.limits.maxDepth,i.counters);let t=Object.create(i.scope);n&&Object.assign(t,n);let r=i.child("action:"+e,0,e).withScope(t);return {stored:s,childFrame:r,childScope:t}}_maybeAutoPromote(e){this._requestedMode==="auto"&&++e.invokeCount>=this._threshold&&(e.compiled=this._compileAction(e.definition.id,e.directives),this._mode!=="jit"&&this._promote());}_executeDirectives(e,n){return this._directiveExecutor(e,n,this._handlers,this._directiveHooks,this._typeField,this._engineRef,this._limits.maxDirectives)}async _executeDirectivesAsync(e,n){return this._directiveExecutor(e,n,this._handlers,this._directiveHooks,this._typeField,this._engineRef,this._limits.maxDirectives)}_compileAction(e,n){let i=this._miniGraph.isAsync(e),s=this._miniGraph.isInteractive(e),{fn:t,isAsync:r,isInteractive:d}=se(n,this._directiveAnalysis,this._typeField,this._asyncHandlerSet,i,s,this._interactiveHandlerSet),c={d:n,h:this._handlers,hooks:this._directiveHooks,engine:this._engineRef,runner:this._directiveRunner,runnerSync:this._directiveRunnerSync};return {fn:t,$:c,isAsync:r,isInteractive:d}}_isAccessible(e,n){let s="action:"+e.slice(0,e.lastIndexOf("/"));return n.path.includes(s)}_requireCtx(){if(this._ctx===void 0)throw new Error("No context set. Pass ctx to invoke(id, params, ctx), call setContext(ctx), or use context(ctx, fn).");return this._ctx}_promote(){this._directiveExecutor=this._buildJitDirectiveExecutor(),this._mode="jit";}_buildJitDirectiveExecutor(){let{fn:e}=te(this._directiveAnalysis,this._isAsync);return e}_invalidateAndMaybeRecompile(){for(let e of this._registry.values())e.compiled=null;if(this._requestedMode==="jit")for(let[e,n]of this._registry)n.compiled=this._compileAction(e,n.directives);}};function ke(o,e){return e?{next:()=>Promise.resolve({value:o,done:true}),return:()=>Promise.resolve({value:o,done:true}),throw:s=>Promise.reject(s),[Symbol.asyncIterator](){return this}}:{next:()=>({value:o,done:true}),return:()=>({value:o,done:true}),throw:i=>{throw i},[Symbol.iterator](){return this}}}function Qe(o,e,n,i,s,t){if(t){let c=o;return {async next(h){let C=await c.next(h);if(C.done){let y=C.value;if(s!==null){let p=s(e,n,y,i);p!==void 0&&(y=p);}return {value:y,done:true}}return {value:C.value,done:false}},async return(){let h=await c.return(void 0),C=h.value;if(h.done&&s!==null){let y=s(e,n,C,i);y!==void 0&&(C=y);}return {value:C,done:true}},async throw(h){let C=await c.throw(h);if(C.done){let y=C.value;if(s!==null){let p=s(e,n,y,i);p!==void 0&&(y=p);}return {value:y,done:true}}return {value:C.value,done:false}},[Symbol.asyncIterator](){return this}}}let r=o;return {next(c){let u=r.next(c);if(u.done){let h=u.value;if(s!==null){let C=s(e,n,h,i);C!==void 0&&(h=C);}return {value:h,done:true}}return {value:u.value,done:false}},return(){let c=r.return(void 0),u=c.value;if(c.done&&s!==null){let h=s(e,n,u,i);h!==void 0&&(u=h);}return {value:u,done:true}},throw(c){let u=r.throw(c);if(u.done){let h=u.value;if(s!==null){let C=s(e,n,h,i);C!==void 0&&(h=C);}return {value:h,done:true}}return {value:u.value,done:false}},[Symbol.iterator](){return this}}}function Xe(o){return new ue(o)}exports.RESERVED_TYPES=N;exports.SimpleEmitter=O;exports.buildActionExecutor=se;exports.buildDirectiveExecutor=te;exports.createActionEngine=Xe;exports.createDirectiveInterpreter=J;exports.drainAsync=Ee;exports.drainSync=Ie;exports.normalizeDirectives=L;exports.replayResponder=we;
|