footprintjs 0.11.0 → 0.12.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/CLAUDE.md CHANGED
@@ -64,16 +64,25 @@ scope.setValue('key', value) // tracked write
64
64
  scope.updateValue('key', partial) // deep merge
65
65
  scope.deleteValue('key') // tracked delete
66
66
  scope.getArgs<T>() // frozen readonly input (NOT tracked)
67
+ scope.getEnv() // frozen execution environment (NOT tracked)
67
68
  scope.attachRecorder(recorder) // plug observer
68
69
  ```
69
70
 
70
- **IMPORTANT:** `getValue`/`setValue` are tracked. `getArgs()` is NOT tracked and returns frozen input.
71
+ **Three access tiers:**
72
+ - `getValue`/`setValue` — mutable shared state, tracked in narrative
73
+ - `getArgs()` — frozen business input from `run({ input })`, NOT tracked
74
+ - `getEnv()` — frozen infrastructure context from `run({ env })`, NOT tracked. Returns `ExecutionEnv { signal?, timeoutMs?, traceId? }`. Auto-inherited by subflows. Closed type — not extensible.
71
75
 
72
76
  ### Executor
73
77
 
74
78
  ```typescript
75
79
  const executor = new FlowChartExecutor(chart);
76
- await executor.run({ input: data, timeoutMs: 5000, signal: abortSignal });
80
+ await executor.run({
81
+ input: data,
82
+ timeoutMs: 5000,
83
+ signal: abortSignal,
84
+ env: { traceId: 'req-123', signal: abortSignal, timeoutMs: 5000 },
85
+ });
77
86
 
78
87
  executor.getNarrative() // combined flow + data narrative
79
88
  executor.getNarrativeEntries() // structured entries with type/depth/stageName
@@ -114,6 +123,7 @@ Both use `{ id, hooks } → dispatcher → error isolation → attach/detach`. I
114
123
  - Never use deprecated `CombinedNarrativeBuilder` — use `CombinedNarrativeRecorder`
115
124
  - Don't extract shared base for Recorder/FlowRecorder — two instances = coincidence
116
125
  - Don't use `getArgs()` for tracked data — use `getValue()`/`setValue()`
126
+ - Don't put infrastructure data (signal, traceId) in `getArgs()` — use `getEnv()` via `run({ env })`
117
127
  - Don't manually create `CombinedNarrativeRecorder` — `setEnableNarrative()` handles it
118
128
 
119
129
  ## Build & Test
package/dist/esm/index.js CHANGED
@@ -39,4 +39,4 @@ export { normalizeSchema, zodToJsonSchema } from './lib/contract';
39
39
  export { generateOpenAPI } from './lib/contract';
40
40
  export { detectSchema, isValidatable, isZod } from './lib/schema';
41
41
  export { InputValidationError, validateAgainstSchema, validateOrThrow } from './lib/schema';
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7OztHQVNHO0FBT0gsT0FBTyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU1RCwrRUFBK0U7QUFDL0UsdUNBQXVDO0FBQ3ZDLCtFQUErRTtBQUUvRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFakQsK0VBQStFO0FBQy9FLDBDQUEwQztBQUMxQywrRUFBK0U7QUFFL0UsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUUxQyxZQUFZO0FBQ1osT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUM3QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQzVDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQWFoRCw4QkFBOEI7QUFDOUIsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBT2pELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQVV4RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFJckQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLGVBQWUsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUlqRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDcEQsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQzdELE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUM5RCxPQUFPLEVBQUUsZ0NBQWdDLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDaEUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ3hELE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUM3RCxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDM0QsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBb0I3RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDaEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxlQUFlLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFPakQsT0FBTyxFQUFFLFlBQVksRUFBRSxhQUFhLEVBQUUsS0FBSyxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxxQkFBcUIsRUFBRSxlQUFlLEVBQUUsTUFBTSxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEZvb3RQcmludCDigJQgUHVibGljIEFQSVxuICpcbiAqIENvbm5lY3RlZCBjYXVzYWwgdHJhY2UgbGlicmFyeSBmb3IgTExNIHBpcGVsaW5lcy5cbiAqIEJ1aWxkcyBmbG93Y2hhcnRzLCBleGVjdXRlcyB0aGVtIHZpYSBERlMgdHJhdmVyc2FsLCBhbmQgY2FwdHVyZXNcbiAqIGV2ZXJ5IHN0YWdlJ3MgY29udGV4dCAoc3RhdGUsIGRlY2lzaW9ucywgZXJyb3JzKSBpbiBhbiBhdWRpdGFibGUgdHJhY2UuXG4gKlxuICogRm9yIGFkdmFuY2VkL2ludGVybmFsIEFQSXMgKG1lbW9yeSBwcmltaXRpdmVzLCBlbmdpbmUgaGFuZGxlcnMsIHByb3ZpZGVycyksXG4gKiBpbXBvcnQgZnJvbSAnZm9vdHByaW50L2FkdmFuY2VkJy5cbiAqL1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBCdWlsZGVyIOKAlCBGbG93Y2hhcnQgY29uc3RydWN0aW9uXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCB0eXBlIHsgRmxvd0NoYXJ0LCBQaXBlbGluZVN0YWdlRnVuY3Rpb24gYXMgU3RhZ2VIYW5kbGVyLCBTdHJlYW1IYW5kbGVycyB9IGZyb20gJy4vbGliL2J1aWxkZXInO1xuZXhwb3J0IHsgZmxvd0NoYXJ0LCBGbG93Q2hhcnRCdWlsZGVyIH0gZnJvbSAnLi9saWIvYnVpbGRlcic7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFJ1bm5lciDigJQgRXhlY3V0aW9uIGNvbnZlbmllbmNlIGxheWVyXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCB7IEZsb3dDaGFydEV4ZWN1dG9yIH0gZnJvbSAnLi9saWIvcnVubmVyJztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gU2NvcGUg4oCUIFBlci1zdGFnZSBmYWNhZGVzIGFuZCByZWNvcmRlcnNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IHsgU2NvcGVGYWNhZGUgfSBmcm9tICcuL2xpYi9zY29wZSc7XG5cbi8vIFJlY29yZGVyc1xuZXhwb3J0IHsgTWV0cmljUmVjb3JkZXIgfSBmcm9tICcuL2xpYi9zY29wZSc7XG5leHBvcnQgeyBEZWJ1Z1JlY29yZGVyIH0gZnJvbSAnLi9saWIvc2NvcGUnO1xuZXhwb3J0IHsgTmFycmF0aXZlUmVjb3JkZXIgfSBmcm9tICcuL2xpYi9zY29wZSc7XG5cbi8vIFJlY29yZGVyIGludGVyZmFjZSBhbmQgY29yZSBldmVudCB0eXBlcyAobmVlZGVkIHRvIGltcGxlbWVudCBjdXN0b20gUmVjb3JkZXIpXG5leHBvcnQgdHlwZSB7XG4gIENvbW1pdEV2ZW50LFxuICBFcnJvckV2ZW50LFxuICBSZWFkRXZlbnQsXG4gIFJlY29yZGVyLFxuICBSZWRhY3Rpb25Qb2xpY3ksXG4gIFJlZGFjdGlvblJlcG9ydCxcbiAgV3JpdGVFdmVudCxcbn0gZnJvbSAnLi9saWIvc2NvcGUnO1xuXG4vLyBab2QtYmFzZWQgc2NvcGUgZGVmaW5pdGlvbnNcbmV4cG9ydCB7IGRlZmluZVNjb3BlRnJvbVpvZCB9IGZyb20gJy4vbGliL3Njb3BlJztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gRW5naW5lIOKAlCBOYXJyYXRpdmUgKGNvbW1vbmx5IHVzZWQpXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCB0eXBlIHsgQ29tYmluZWROYXJyYXRpdmVFbnRyeSB9IGZyb20gJy4vbGliL2VuZ2luZSc7XG5leHBvcnQgeyBDb21iaW5lZE5hcnJhdGl2ZUJ1aWxkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuXG4vLyBGbG93UmVjb3JkZXIg4oCUIFBsdWdnYWJsZSBvYnNlcnZlciBmb3IgY29udHJvbCBmbG93IGV2ZW50cyAobWlycm9ycyBzY29wZSBSZWNvcmRlcilcbmV4cG9ydCB0eXBlIHtcbiAgRmxvd0Vycm9yRXZlbnQsXG4gIEZsb3dMb29wRXZlbnQsXG4gIEZsb3dSZWNvcmRlcixcbiAgRmxvd1N1YmZsb3dFdmVudCxcbiAgRmxvd1N1YmZsb3dSZWdpc3RlcmVkRXZlbnQsXG59IGZyb20gJy4vbGliL2VuZ2luZSc7XG5leHBvcnQgeyBOYXJyYXRpdmVGbG93UmVjb3JkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuXG4vLyBTdHJ1Y3R1cmVkIGVycm9yIGV4dHJhY3Rpb24g4oCUIHByZXNlcnZlcyBmaWVsZC1sZXZlbCBkZXRhaWxzIHRocm91Z2ggdGhlIHBpcGVsaW5lXG5leHBvcnQgdHlwZSB7IFN0cnVjdHVyZWRFcnJvckluZm8gfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuZXhwb3J0IHsgZXh0cmFjdEVycm9ySW5mbywgZm9ybWF0RXJyb3JJbmZvIH0gZnJvbSAnLi9saWIvZW5naW5lJztcblxuLy8gQnVpbHQtaW4gRmxvd1JlY29yZGVyIHN0cmF0ZWdpZXMgKHRyZWUtc2hha2VhYmxlIOKAlCBpbXBvcnQgb25seSB3aGF0IHlvdSB1c2UpXG5leHBvcnQgdHlwZSB7IE1hbmlmZXN0RW50cnkgfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuZXhwb3J0IHsgTWFuaWZlc3RGbG93UmVjb3JkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuZXhwb3J0IHsgQWRhcHRpdmVOYXJyYXRpdmVGbG93UmVjb3JkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuZXhwb3J0IHsgTWlsZXN0b25lTmFycmF0aXZlRmxvd1JlY29yZGVyIH0gZnJvbSAnLi9saWIvZW5naW5lJztcbmV4cG9ydCB7IFByb2dyZXNzaXZlTmFycmF0aXZlRmxvd1JlY29yZGVyIH0gZnJvbSAnLi9saWIvZW5naW5lJztcbmV4cG9ydCB7IFJMRU5hcnJhdGl2ZUZsb3dSZWNvcmRlciB9IGZyb20gJy4vbGliL2VuZ2luZSc7XG5leHBvcnQgeyBTZXBhcmF0ZU5hcnJhdGl2ZUZsb3dSZWNvcmRlciB9IGZyb20gJy4vbGliL2VuZ2luZSc7XG5leHBvcnQgeyBTaWxlbnROYXJyYXRpdmVGbG93UmVjb3JkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuZXhwb3J0IHsgV2luZG93ZWROYXJyYXRpdmVGbG93UmVjb3JkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBNZW1vcnkg4oCUIFNjb3BlRmFjdG9yeSB0eXBlIChuZWVkZWQgZm9yIEZsb3dDaGFydEV4ZWN1dG9yIGNvbnN0cnVjdG9yKVxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG5leHBvcnQgdHlwZSB7IFJ1bk9wdGlvbnMgfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuZXhwb3J0IHR5cGUgeyBTY29wZUZhY3RvcnkgfSBmcm9tICcuL2xpYi9tZW1vcnknO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBDb250cmFjdCDigJQgSS9PIGJvdW5kYXJ5LCBzY2hlbWFzLCBhbmQgT3BlbkFQSSBnZW5lcmF0aW9uXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCB0eXBlIHtcbiAgRmxvd0NoYXJ0Q29udHJhY3QsXG4gIEZsb3dDaGFydENvbnRyYWN0T3B0aW9ucyxcbiAgSnNvblNjaGVtYSxcbiAgT3BlbkFQSU9wdGlvbnMsXG4gIE9wZW5BUElTcGVjLFxufSBmcm9tICcuL2xpYi9jb250cmFjdCc7XG5leHBvcnQgeyBkZWZpbmVDb250cmFjdCB9IGZyb20gJy4vbGliL2NvbnRyYWN0JztcbmV4cG9ydCB7IG5vcm1hbGl6ZVNjaGVtYSwgem9kVG9Kc29uU2NoZW1hIH0gZnJvbSAnLi9saWIvY29udHJhY3QnO1xuZXhwb3J0IHsgZ2VuZXJhdGVPcGVuQVBJIH0gZnJvbSAnLi9saWIvY29udHJhY3QnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBTY2hlbWEg4oCUIFVuaWZpZWQgZGV0ZWN0aW9uLCB2YWxpZGF0aW9uLCBhbmQgc3RydWN0dXJlZCBlcnJvcnNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IHR5cGUgeyBTY2hlbWFLaW5kLCBWYWxpZGF0aW9uSXNzdWUsIFZhbGlkYXRpb25SZXN1bHQgfSBmcm9tICcuL2xpYi9zY2hlbWEnO1xuZXhwb3J0IHsgZGV0ZWN0U2NoZW1hLCBpc1ZhbGlkYXRhYmxlLCBpc1pvZCB9IGZyb20gJy4vbGliL3NjaGVtYSc7XG5leHBvcnQgeyBJbnB1dFZhbGlkYXRpb25FcnJvciwgdmFsaWRhdGVBZ2FpbnN0U2NoZW1hLCB2YWxpZGF0ZU9yVGhyb3cgfSBmcm9tICcuL2xpYi9zY2hlbWEnO1xuIl19
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7OztHQVNHO0FBT0gsT0FBTyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU1RCwrRUFBK0U7QUFDL0UsdUNBQXVDO0FBQ3ZDLCtFQUErRTtBQUUvRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFakQsK0VBQStFO0FBQy9FLDBDQUEwQztBQUMxQywrRUFBK0U7QUFFL0UsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUUxQyxZQUFZO0FBQ1osT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUM3QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQzVDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQWFoRCw4QkFBOEI7QUFDOUIsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBT2pELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQVV4RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFJckQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLGVBQWUsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUlqRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDcEQsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQzdELE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUM5RCxPQUFPLEVBQUUsZ0NBQWdDLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDaEUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ3hELE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUM3RCxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDM0QsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBb0I3RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDaEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxlQUFlLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFPakQsT0FBTyxFQUFFLFlBQVksRUFBRSxhQUFhLEVBQUUsS0FBSyxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxxQkFBcUIsRUFBRSxlQUFlLEVBQUUsTUFBTSxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEZvb3RQcmludCDigJQgUHVibGljIEFQSVxuICpcbiAqIENvbm5lY3RlZCBjYXVzYWwgdHJhY2UgbGlicmFyeSBmb3IgTExNIHBpcGVsaW5lcy5cbiAqIEJ1aWxkcyBmbG93Y2hhcnRzLCBleGVjdXRlcyB0aGVtIHZpYSBERlMgdHJhdmVyc2FsLCBhbmQgY2FwdHVyZXNcbiAqIGV2ZXJ5IHN0YWdlJ3MgY29udGV4dCAoc3RhdGUsIGRlY2lzaW9ucywgZXJyb3JzKSBpbiBhbiBhdWRpdGFibGUgdHJhY2UuXG4gKlxuICogRm9yIGFkdmFuY2VkL2ludGVybmFsIEFQSXMgKG1lbW9yeSBwcmltaXRpdmVzLCBlbmdpbmUgaGFuZGxlcnMsIHByb3ZpZGVycyksXG4gKiBpbXBvcnQgZnJvbSAnZm9vdHByaW50L2FkdmFuY2VkJy5cbiAqL1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBCdWlsZGVyIOKAlCBGbG93Y2hhcnQgY29uc3RydWN0aW9uXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCB0eXBlIHsgRmxvd0NoYXJ0LCBQaXBlbGluZVN0YWdlRnVuY3Rpb24gYXMgU3RhZ2VIYW5kbGVyLCBTdHJlYW1IYW5kbGVycyB9IGZyb20gJy4vbGliL2J1aWxkZXInO1xuZXhwb3J0IHsgZmxvd0NoYXJ0LCBGbG93Q2hhcnRCdWlsZGVyIH0gZnJvbSAnLi9saWIvYnVpbGRlcic7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFJ1bm5lciDigJQgRXhlY3V0aW9uIGNvbnZlbmllbmNlIGxheWVyXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCB7IEZsb3dDaGFydEV4ZWN1dG9yIH0gZnJvbSAnLi9saWIvcnVubmVyJztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gU2NvcGUg4oCUIFBlci1zdGFnZSBmYWNhZGVzIGFuZCByZWNvcmRlcnNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IHsgU2NvcGVGYWNhZGUgfSBmcm9tICcuL2xpYi9zY29wZSc7XG5cbi8vIFJlY29yZGVyc1xuZXhwb3J0IHsgTWV0cmljUmVjb3JkZXIgfSBmcm9tICcuL2xpYi9zY29wZSc7XG5leHBvcnQgeyBEZWJ1Z1JlY29yZGVyIH0gZnJvbSAnLi9saWIvc2NvcGUnO1xuZXhwb3J0IHsgTmFycmF0aXZlUmVjb3JkZXIgfSBmcm9tICcuL2xpYi9zY29wZSc7XG5cbi8vIFJlY29yZGVyIGludGVyZmFjZSBhbmQgY29yZSBldmVudCB0eXBlcyAobmVlZGVkIHRvIGltcGxlbWVudCBjdXN0b20gUmVjb3JkZXIpXG5leHBvcnQgdHlwZSB7XG4gIENvbW1pdEV2ZW50LFxuICBFcnJvckV2ZW50LFxuICBSZWFkRXZlbnQsXG4gIFJlY29yZGVyLFxuICBSZWRhY3Rpb25Qb2xpY3ksXG4gIFJlZGFjdGlvblJlcG9ydCxcbiAgV3JpdGVFdmVudCxcbn0gZnJvbSAnLi9saWIvc2NvcGUnO1xuXG4vLyBab2QtYmFzZWQgc2NvcGUgZGVmaW5pdGlvbnNcbmV4cG9ydCB7IGRlZmluZVNjb3BlRnJvbVpvZCB9IGZyb20gJy4vbGliL3Njb3BlJztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gRW5naW5lIOKAlCBOYXJyYXRpdmUgKGNvbW1vbmx5IHVzZWQpXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCB0eXBlIHsgQ29tYmluZWROYXJyYXRpdmVFbnRyeSB9IGZyb20gJy4vbGliL2VuZ2luZSc7XG5leHBvcnQgeyBDb21iaW5lZE5hcnJhdGl2ZUJ1aWxkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuXG4vLyBGbG93UmVjb3JkZXIg4oCUIFBsdWdnYWJsZSBvYnNlcnZlciBmb3IgY29udHJvbCBmbG93IGV2ZW50cyAobWlycm9ycyBzY29wZSBSZWNvcmRlcilcbmV4cG9ydCB0eXBlIHtcbiAgRmxvd0Vycm9yRXZlbnQsXG4gIEZsb3dMb29wRXZlbnQsXG4gIEZsb3dSZWNvcmRlcixcbiAgRmxvd1N1YmZsb3dFdmVudCxcbiAgRmxvd1N1YmZsb3dSZWdpc3RlcmVkRXZlbnQsXG59IGZyb20gJy4vbGliL2VuZ2luZSc7XG5leHBvcnQgeyBOYXJyYXRpdmVGbG93UmVjb3JkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuXG4vLyBTdHJ1Y3R1cmVkIGVycm9yIGV4dHJhY3Rpb24g4oCUIHByZXNlcnZlcyBmaWVsZC1sZXZlbCBkZXRhaWxzIHRocm91Z2ggdGhlIHBpcGVsaW5lXG5leHBvcnQgdHlwZSB7IFN0cnVjdHVyZWRFcnJvckluZm8gfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuZXhwb3J0IHsgZXh0cmFjdEVycm9ySW5mbywgZm9ybWF0RXJyb3JJbmZvIH0gZnJvbSAnLi9saWIvZW5naW5lJztcblxuLy8gQnVpbHQtaW4gRmxvd1JlY29yZGVyIHN0cmF0ZWdpZXMgKHRyZWUtc2hha2VhYmxlIOKAlCBpbXBvcnQgb25seSB3aGF0IHlvdSB1c2UpXG5leHBvcnQgdHlwZSB7IE1hbmlmZXN0RW50cnkgfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuZXhwb3J0IHsgTWFuaWZlc3RGbG93UmVjb3JkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuZXhwb3J0IHsgQWRhcHRpdmVOYXJyYXRpdmVGbG93UmVjb3JkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuZXhwb3J0IHsgTWlsZXN0b25lTmFycmF0aXZlRmxvd1JlY29yZGVyIH0gZnJvbSAnLi9saWIvZW5naW5lJztcbmV4cG9ydCB7IFByb2dyZXNzaXZlTmFycmF0aXZlRmxvd1JlY29yZGVyIH0gZnJvbSAnLi9saWIvZW5naW5lJztcbmV4cG9ydCB7IFJMRU5hcnJhdGl2ZUZsb3dSZWNvcmRlciB9IGZyb20gJy4vbGliL2VuZ2luZSc7XG5leHBvcnQgeyBTZXBhcmF0ZU5hcnJhdGl2ZUZsb3dSZWNvcmRlciB9IGZyb20gJy4vbGliL2VuZ2luZSc7XG5leHBvcnQgeyBTaWxlbnROYXJyYXRpdmVGbG93UmVjb3JkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuZXhwb3J0IHsgV2luZG93ZWROYXJyYXRpdmVGbG93UmVjb3JkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBNZW1vcnkg4oCUIFNjb3BlRmFjdG9yeSB0eXBlIChuZWVkZWQgZm9yIEZsb3dDaGFydEV4ZWN1dG9yIGNvbnN0cnVjdG9yKVxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG5leHBvcnQgdHlwZSB7IEV4ZWN1dGlvbkVudiwgUnVuT3B0aW9ucyB9IGZyb20gJy4vbGliL2VuZ2luZSc7XG5leHBvcnQgdHlwZSB7IFNjb3BlRmFjdG9yeSB9IGZyb20gJy4vbGliL21lbW9yeSc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIENvbnRyYWN0IOKAlCBJL08gYm91bmRhcnksIHNjaGVtYXMsIGFuZCBPcGVuQVBJIGdlbmVyYXRpb25cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IHR5cGUge1xuICBGbG93Q2hhcnRDb250cmFjdCxcbiAgRmxvd0NoYXJ0Q29udHJhY3RPcHRpb25zLFxuICBKc29uU2NoZW1hLFxuICBPcGVuQVBJT3B0aW9ucyxcbiAgT3BlbkFQSVNwZWMsXG59IGZyb20gJy4vbGliL2NvbnRyYWN0JztcbmV4cG9ydCB7IGRlZmluZUNvbnRyYWN0IH0gZnJvbSAnLi9saWIvY29udHJhY3QnO1xuZXhwb3J0IHsgbm9ybWFsaXplU2NoZW1hLCB6b2RUb0pzb25TY2hlbWEgfSBmcm9tICcuL2xpYi9jb250cmFjdCc7XG5leHBvcnQgeyBnZW5lcmF0ZU9wZW5BUEkgfSBmcm9tICcuL2xpYi9jb250cmFjdCc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFNjaGVtYSDigJQgVW5pZmllZCBkZXRlY3Rpb24sIHZhbGlkYXRpb24sIGFuZCBzdHJ1Y3R1cmVkIGVycm9yc1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG5leHBvcnQgdHlwZSB7IFNjaGVtYUtpbmQsIFZhbGlkYXRpb25Jc3N1ZSwgVmFsaWRhdGlvblJlc3VsdCB9IGZyb20gJy4vbGliL3NjaGVtYSc7XG5leHBvcnQgeyBkZXRlY3RTY2hlbWEsIGlzVmFsaWRhdGFibGUsIGlzWm9kIH0gZnJvbSAnLi9saWIvc2NoZW1hJztcbmV4cG9ydCB7IElucHV0VmFsaWRhdGlvbkVycm9yLCB2YWxpZGF0ZUFnYWluc3RTY2hlbWEsIHZhbGlkYXRlT3JUaHJvdyB9IGZyb20gJy4vbGliL3NjaGVtYSc7XG4iXX0=
@@ -15,7 +15,7 @@ export class StageRunner {
15
15
  async run(node, stageFunc, context, breakFn) {
16
16
  var _a, _b, _c, _d, _e, _f;
17
17
  // Create scope via ScopeFactory — each stage gets its own scope instance
18
- const rawScope = this.deps.ScopeFactory(context, node.name, this.deps.readOnlyContext);
18
+ const rawScope = this.deps.ScopeFactory(context, node.name, this.deps.readOnlyContext, this.deps.executionEnv);
19
19
  // Wrap scope with protection to intercept direct property assignments
20
20
  const scope = createProtectedScope(rawScope, {
21
21
  mode: this.deps.scopeProtectionMode,
@@ -83,4 +83,4 @@ function raceAbort(promise, signal) {
83
83
  });
84
84
  });
85
85
  }
86
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"StageRunner.js","sourceRoot":"","sources":["../../../../../src/lib/engine/handlers/StageRunner.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * StageRunner — Executes individual stage functions.\n *\n * Responsibilities:\n * - Create scope via ScopeFactory for each stage\n * - Apply scope protection (createProtectedScope) to intercept direct assignments\n * - Handle streaming stages (onStart, onToken, onEnd lifecycle)\n * - Sync+async safety: only await real Promises (instanceof check)\n */\n\nimport type { StageContext } from '../../memory/StageContext';\nimport { createProtectedScope } from '../../scope/protection/createProtectedScope';\nimport type { StageNode } from '../graph/StageNode';\nimport type { HandlerDeps, StageFunction, StreamCallback } from '../types';\n\nexport class StageRunner<TOut = any, TScope = any> {\n  constructor(private readonly deps: HandlerDeps<TOut, TScope>) {}\n\n  async run(\n    node: StageNode<TOut, TScope>,\n    stageFunc: StageFunction<TOut, TScope>,\n    context: StageContext,\n    breakFn: () => void,\n  ): Promise<TOut> {\n    // Create scope via ScopeFactory — each stage gets its own scope instance\n    const rawScope = this.deps.ScopeFactory(context, node.name, this.deps.readOnlyContext);\n\n    // Wrap scope with protection to intercept direct property assignments\n    const scope = createProtectedScope(rawScope as object, {\n      mode: this.deps.scopeProtectionMode,\n      stageName: node.name,\n    }) as TScope;\n\n    // Set up streaming callback if this is a streaming stage\n    let streamCallback: StreamCallback | undefined;\n    let accumulatedText = '';\n\n    if (node.isStreaming) {\n      const streamId = node.streamId ?? node.name;\n      streamCallback = (token: string) => {\n        accumulatedText += token;\n        this.deps.streamHandlers?.onToken?.(streamId, token);\n      };\n      this.deps.streamHandlers?.onStart?.(streamId);\n    }\n\n    // Notify recorders of stage start (if scope supports it)\n    if (rawScope && typeof (rawScope as any).notifyStageStart === 'function') {\n      (rawScope as any).notifyStageStart();\n    }\n\n    // Execute the stage function\n    const output = stageFunc(scope, breakFn, streamCallback);\n\n    // Sync+async safety: only await real Promises to avoid thenable assimilation\n    let result: TOut;\n    if (output instanceof Promise) {\n      // Race against AbortSignal if provided\n      if (this.deps.signal) {\n        result = await raceAbort(output, this.deps.signal);\n      } else {\n        result = await output;\n      }\n    } else {\n      result = output;\n    }\n\n    // Notify recorders of stage end (if scope supports it)\n    if (rawScope && typeof (rawScope as any).notifyStageEnd === 'function') {\n      (rawScope as any).notifyStageEnd();\n    }\n\n    // Call onEnd lifecycle hook for streaming stages\n    if (node.isStreaming) {\n      const streamId = node.streamId ?? node.name;\n      this.deps.streamHandlers?.onEnd?.(streamId, accumulatedText);\n    }\n\n    return result;\n  }\n}\n\n/** Race a promise against an AbortSignal. Rejects with the signal's reason on abort. */\nfunction raceAbort<T>(promise: Promise<T>, signal: AbortSignal): Promise<T> {\n  if (signal.aborted) {\n    return Promise.reject(signal.reason instanceof Error ? signal.reason : new Error(signal.reason ?? 'Aborted'));\n  }\n  return new Promise<T>((resolve, reject) => {\n    const onAbort = () =>\n      reject(signal.reason instanceof Error ? signal.reason : new Error(signal.reason ?? 'Aborted'));\n    signal.addEventListener('abort', onAbort, { once: true });\n    promise.then(\n      (val) => {\n        signal.removeEventListener('abort', onAbort);\n        resolve(val);\n      },\n      (err) => {\n        signal.removeEventListener('abort', onAbort);\n        reject(err);\n      },\n    );\n  });\n}\n"]}
86
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"StageRunner.js","sourceRoot":"","sources":["../../../../../src/lib/engine/handlers/StageRunner.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAGH,OAAO,EAAE,oBAAoB,EAAE,MAAM,6CAA6C,CAAC;AAInF,MAAM,OAAO,WAAW;IACtB,YAA6B,IAA+B;QAA/B,SAAI,GAAJ,IAAI,CAA2B;IAAG,CAAC;IAEhE,KAAK,CAAC,GAAG,CACP,IAA6B,EAC7B,SAAsC,EACtC,OAAqB,EACrB,OAAmB;;QAEnB,yEAAyE;QACzE,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAE/G,sEAAsE;QACtE,MAAM,KAAK,GAAG,oBAAoB,CAAC,QAAkB,EAAE;YACrD,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,mBAAmB;YACnC,SAAS,EAAE,IAAI,CAAC,IAAI;SACrB,CAAW,CAAC;QAEb,yDAAyD;QACzD,IAAI,cAA0C,CAAC;QAC/C,IAAI,eAAe,GAAG,EAAE,CAAC;QAEzB,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,MAAM,QAAQ,GAAG,MAAA,IAAI,CAAC,QAAQ,mCAAI,IAAI,CAAC,IAAI,CAAC;YAC5C,cAAc,GAAG,CAAC,KAAa,EAAE,EAAE;;gBACjC,eAAe,IAAI,KAAK,CAAC;gBACzB,MAAA,MAAA,IAAI,CAAC,IAAI,CAAC,cAAc,0CAAE,OAAO,mDAAG,QAAQ,EAAE,KAAK,CAAC,CAAC;YACvD,CAAC,CAAC;YACF,MAAA,MAAA,IAAI,CAAC,IAAI,CAAC,cAAc,0CAAE,OAAO,mDAAG,QAAQ,CAAC,CAAC;QAChD,CAAC;QAED,yDAAyD;QACzD,IAAI,QAAQ,IAAI,OAAQ,QAAgB,CAAC,gBAAgB,KAAK,UAAU,EAAE,CAAC;YACxE,QAAgB,CAAC,gBAAgB,EAAE,CAAC;QACvC,CAAC;QAED,6BAA6B;QAC7B,MAAM,MAAM,GAAG,SAAS,CAAC,KAAK,EAAE,OAAO,EAAE,cAAc,CAAC,CAAC;QAEzD,6EAA6E;QAC7E,IAAI,MAAY,CAAC;QACjB,IAAI,MAAM,YAAY,OAAO,EAAE,CAAC;YAC9B,uCAAuC;YACvC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;gBACrB,MAAM,GAAG,MAAM,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACrD,CAAC;iBAAM,CAAC;gBACN,MAAM,GAAG,MAAM,MAAM,CAAC;YACxB,CAAC;QACH,CAAC;aAAM,CAAC;YACN,MAAM,GAAG,MAAM,CAAC;QAClB,CAAC;QAED,uDAAuD;QACvD,IAAI,QAAQ,IAAI,OAAQ,QAAgB,CAAC,cAAc,KAAK,UAAU,EAAE,CAAC;YACtE,QAAgB,CAAC,cAAc,EAAE,CAAC;QACrC,CAAC;QAED,iDAAiD;QACjD,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,MAAM,QAAQ,GAAG,MAAA,IAAI,CAAC,QAAQ,mCAAI,IAAI,CAAC,IAAI,CAAC;YAC5C,MAAA,MAAA,IAAI,CAAC,IAAI,CAAC,cAAc,0CAAE,KAAK,mDAAG,QAAQ,EAAE,eAAe,CAAC,CAAC;QAC/D,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;CACF;AAED,wFAAwF;AACxF,SAAS,SAAS,CAAI,OAAmB,EAAE,MAAmB;;IAC5D,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;QACnB,OAAO,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,YAAY,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAA,MAAM,CAAC,MAAM,mCAAI,SAAS,CAAC,CAAC,CAAC;IAChH,CAAC;IACD,OAAO,IAAI,OAAO,CAAI,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACxC,MAAM,OAAO,GAAG,GAAG,EAAE,WACnB,OAAA,MAAM,CAAC,MAAM,CAAC,MAAM,YAAY,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAA,MAAM,CAAC,MAAM,mCAAI,SAAS,CAAC,CAAC,CAAA,EAAA,CAAC;QACjG,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;QAC1D,OAAO,CAAC,IAAI,CACV,CAAC,GAAG,EAAE,EAAE;YACN,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;YAC7C,OAAO,CAAC,GAAG,CAAC,CAAC;QACf,CAAC,EACD,CAAC,GAAG,EAAE,EAAE;YACN,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;YAC7C,MAAM,CAAC,GAAG,CAAC,CAAC;QACd,CAAC,CACF,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC","sourcesContent":["/**\n * StageRunner — Executes individual stage functions.\n *\n * Responsibilities:\n * - Create scope via ScopeFactory for each stage\n * - Apply scope protection (createProtectedScope) to intercept direct assignments\n * - Handle streaming stages (onStart, onToken, onEnd lifecycle)\n * - Sync+async safety: only await real Promises (instanceof check)\n */\n\nimport type { StageContext } from '../../memory/StageContext';\nimport { createProtectedScope } from '../../scope/protection/createProtectedScope';\nimport type { StageNode } from '../graph/StageNode';\nimport type { HandlerDeps, StageFunction, StreamCallback } from '../types';\n\nexport class StageRunner<TOut = any, TScope = any> {\n  constructor(private readonly deps: HandlerDeps<TOut, TScope>) {}\n\n  async run(\n    node: StageNode<TOut, TScope>,\n    stageFunc: StageFunction<TOut, TScope>,\n    context: StageContext,\n    breakFn: () => void,\n  ): Promise<TOut> {\n    // Create scope via ScopeFactory — each stage gets its own scope instance\n    const rawScope = this.deps.ScopeFactory(context, node.name, this.deps.readOnlyContext, this.deps.executionEnv);\n\n    // Wrap scope with protection to intercept direct property assignments\n    const scope = createProtectedScope(rawScope as object, {\n      mode: this.deps.scopeProtectionMode,\n      stageName: node.name,\n    }) as TScope;\n\n    // Set up streaming callback if this is a streaming stage\n    let streamCallback: StreamCallback | undefined;\n    let accumulatedText = '';\n\n    if (node.isStreaming) {\n      const streamId = node.streamId ?? node.name;\n      streamCallback = (token: string) => {\n        accumulatedText += token;\n        this.deps.streamHandlers?.onToken?.(streamId, token);\n      };\n      this.deps.streamHandlers?.onStart?.(streamId);\n    }\n\n    // Notify recorders of stage start (if scope supports it)\n    if (rawScope && typeof (rawScope as any).notifyStageStart === 'function') {\n      (rawScope as any).notifyStageStart();\n    }\n\n    // Execute the stage function\n    const output = stageFunc(scope, breakFn, streamCallback);\n\n    // Sync+async safety: only await real Promises to avoid thenable assimilation\n    let result: TOut;\n    if (output instanceof Promise) {\n      // Race against AbortSignal if provided\n      if (this.deps.signal) {\n        result = await raceAbort(output, this.deps.signal);\n      } else {\n        result = await output;\n      }\n    } else {\n      result = output;\n    }\n\n    // Notify recorders of stage end (if scope supports it)\n    if (rawScope && typeof (rawScope as any).notifyStageEnd === 'function') {\n      (rawScope as any).notifyStageEnd();\n    }\n\n    // Call onEnd lifecycle hook for streaming stages\n    if (node.isStreaming) {\n      const streamId = node.streamId ?? node.name;\n      this.deps.streamHandlers?.onEnd?.(streamId, accumulatedText);\n    }\n\n    return result;\n  }\n}\n\n/** Race a promise against an AbortSignal. Rejects with the signal's reason on abort. */\nfunction raceAbort<T>(promise: Promise<T>, signal: AbortSignal): Promise<T> {\n  if (signal.aborted) {\n    return Promise.reject(signal.reason instanceof Error ? signal.reason : new Error(signal.reason ?? 'Aborted'));\n  }\n  return new Promise<T>((resolve, reject) => {\n    const onAbort = () =>\n      reject(signal.reason instanceof Error ? signal.reason : new Error(signal.reason ?? 'Aborted'));\n    signal.addEventListener('abort', onAbort, { once: true });\n    promise.then(\n      (val) => {\n        signal.removeEventListener('abort', onAbort);\n        resolve(val);\n      },\n      (err) => {\n        signal.removeEventListener('abort', onAbort);\n        reject(err);\n      },\n    );\n  });\n}\n"]}
@@ -46,6 +46,7 @@ export function createSubflowHandlerDeps(parentDeps, subflowRuntime, mappedInput
46
46
  scopeProtectionMode: parentDeps.scopeProtectionMode,
47
47
  executionRuntime: subflowRuntime,
48
48
  readOnlyContext: mappedInput,
49
+ executionEnv: parentDeps.executionEnv, // inherited — like process.env
49
50
  narrativeGenerator: parentDeps.narrativeGenerator,
50
51
  logger: parentDeps.logger,
51
52
  };
@@ -110,4 +111,4 @@ export function applyOutputMapping(subflowOutput, parentScope, parentContext, op
110
111
  }
111
112
  return mappedOutput;
112
113
  }
113
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SubflowInputMapper.js","sourceRoot":"","sources":["../../../../../src/lib/engine/handlers/SubflowInputMapper.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * SubflowInputMapper — Pure functions for subflow data contracts.\n *\n * Mental model: Subflow = Pure Function\n * - Isolated scope (own GlobalStore)\n * - Explicit inputs via inputMapper\n * - Explicit outputs via outputMapper\n *\n * | Scenario        | Behavior                                  |\n * |-----------------|-------------------------------------------|\n * | No inputMapper  | Subflow starts with empty scope           |\n * | No outputMapper | Subflow scope changes discarded           |\n * | Both present    | Full data contract (args in, results out) |\n * | Neither present | Complete isolation (side effects only)    |\n */\n\nimport type { StageContext } from '../../memory/StageContext';\nimport type { HandlerDeps, IExecutionRuntime, SubflowMountOptions } from '../types';\n\n/** Extract values from parent scope using inputMapper. */\nexport function extractParentScopeValues<TParentScope, TSubflowInput>(\n  parentScope: TParentScope,\n  options?: SubflowMountOptions<TParentScope, TSubflowInput>,\n): TSubflowInput | Record<string, unknown> {\n  if (!options?.inputMapper) {\n    return {};\n  }\n\n  const result = options.inputMapper(parentScope);\n  if (result === null || result === undefined) {\n    return {};\n  }\n\n  return result;\n}\n\n/**\n * Get the initial scope values for a subflow.\n * Always isolated — only inputMapper values are included.\n */\nexport function getInitialScopeValues<TParentScope, TSubflowInput>(\n  parentScope: TParentScope,\n  options?: SubflowMountOptions<TParentScope, TSubflowInput>,\n): Record<string, unknown> {\n  return extractParentScopeValues(parentScope, options) as Record<string, unknown>;\n}\n\n/**\n * Create a new HandlerDeps for subflow execution.\n * Key: sets readOnlyContext to mapped input so StageRunner passes it to ScopeFactory.\n */\nexport function createSubflowHandlerDeps<TOut = any, TScope = any>(\n  parentDeps: HandlerDeps<TOut, TScope>,\n  subflowRuntime: IExecutionRuntime,\n  mappedInput: Record<string, unknown>,\n): HandlerDeps<TOut, TScope> {\n  return {\n    stageMap: parentDeps.stageMap,\n    root: parentDeps.root,\n    ScopeFactory: parentDeps.ScopeFactory,\n    subflows: parentDeps.subflows,\n    throttlingErrorChecker: parentDeps.throttlingErrorChecker,\n    streamHandlers: parentDeps.streamHandlers,\n    scopeProtectionMode: parentDeps.scopeProtectionMode,\n    executionRuntime: subflowRuntime,\n    readOnlyContext: mappedInput,\n    narrativeGenerator: parentDeps.narrativeGenerator,\n    logger: parentDeps.logger,\n  };\n}\n\n/**\n * Seed the subflow's GlobalStore with initial values.\n * Called before subflow execution to make inputMapper values available.\n */\nexport function seedSubflowGlobalStore(\n  subflowRuntime: IExecutionRuntime,\n  initialValues: Record<string, unknown>,\n): void {\n  const rootContext = subflowRuntime.rootStageContext;\n\n  for (const [key, value] of Object.entries(initialValues)) {\n    if (typeof value === 'object' && value !== null && !Array.isArray(value)) {\n      for (const [nestedKey, nestedValue] of Object.entries(value as Record<string, unknown>)) {\n        rootContext.setObject([key], nestedKey, nestedValue);\n      }\n    } else {\n      rootContext.setGlobal(key, value);\n    }\n  }\n\n  rootContext.commit();\n}\n\n/**\n * Apply output mapping after subflow completion.\n * Writes mapped values back to parent scope using merge semantics:\n * arrays are appended, objects are shallow-merged, scalars are replaced.\n */\nexport function applyOutputMapping<TParentScope, TSubflowOutput>(\n  subflowOutput: TSubflowOutput,\n  parentScope: TParentScope,\n  parentContext: StageContext,\n  options?: SubflowMountOptions<TParentScope, any, TSubflowOutput>,\n): Record<string, unknown> | undefined {\n  if (!options?.outputMapper) {\n    return undefined;\n  }\n\n  const mappedOutput = options.outputMapper(subflowOutput, parentScope);\n\n  if (mappedOutput === null || mappedOutput === undefined) {\n    return undefined;\n  }\n\n  for (const [key, value] of Object.entries(mappedOutput)) {\n    if (typeof value === 'object' && value !== null && !Array.isArray(value)) {\n      for (const [nestedKey, nestedValue] of Object.entries(value as Record<string, unknown>)) {\n        if (Array.isArray(nestedValue)) {\n          parentContext.appendToArray([key], nestedKey, nestedValue);\n        } else if (typeof nestedValue === 'object' && nestedValue !== null) {\n          parentContext.mergeObject([key], nestedKey, nestedValue as Record<string, unknown>);\n        } else {\n          parentContext.setObject([key], nestedKey, nestedValue);\n        }\n      }\n    } else if (Array.isArray(value)) {\n      const existing = parentContext.getGlobal(key);\n      if (Array.isArray(existing)) {\n        parentContext.setGlobal(key, [...existing, ...value]);\n      } else {\n        parentContext.setGlobal(key, value);\n      }\n    } else {\n      parentContext.setGlobal(key, value);\n    }\n  }\n\n  return mappedOutput;\n}\n"]}
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SubflowInputMapper.js","sourceRoot":"","sources":["../../../../../src/lib/engine/handlers/SubflowInputMapper.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * SubflowInputMapper — Pure functions for subflow data contracts.\n *\n * Mental model: Subflow = Pure Function\n * - Isolated scope (own GlobalStore)\n * - Explicit inputs via inputMapper\n * - Explicit outputs via outputMapper\n *\n * | Scenario        | Behavior                                  |\n * |-----------------|-------------------------------------------|\n * | No inputMapper  | Subflow starts with empty scope           |\n * | No outputMapper | Subflow scope changes discarded           |\n * | Both present    | Full data contract (args in, results out) |\n * | Neither present | Complete isolation (side effects only)    |\n */\n\nimport type { StageContext } from '../../memory/StageContext';\nimport type { HandlerDeps, IExecutionRuntime, SubflowMountOptions } from '../types';\n\n/** Extract values from parent scope using inputMapper. */\nexport function extractParentScopeValues<TParentScope, TSubflowInput>(\n  parentScope: TParentScope,\n  options?: SubflowMountOptions<TParentScope, TSubflowInput>,\n): TSubflowInput | Record<string, unknown> {\n  if (!options?.inputMapper) {\n    return {};\n  }\n\n  const result = options.inputMapper(parentScope);\n  if (result === null || result === undefined) {\n    return {};\n  }\n\n  return result;\n}\n\n/**\n * Get the initial scope values for a subflow.\n * Always isolated — only inputMapper values are included.\n */\nexport function getInitialScopeValues<TParentScope, TSubflowInput>(\n  parentScope: TParentScope,\n  options?: SubflowMountOptions<TParentScope, TSubflowInput>,\n): Record<string, unknown> {\n  return extractParentScopeValues(parentScope, options) as Record<string, unknown>;\n}\n\n/**\n * Create a new HandlerDeps for subflow execution.\n * Key: sets readOnlyContext to mapped input so StageRunner passes it to ScopeFactory.\n */\nexport function createSubflowHandlerDeps<TOut = any, TScope = any>(\n  parentDeps: HandlerDeps<TOut, TScope>,\n  subflowRuntime: IExecutionRuntime,\n  mappedInput: Record<string, unknown>,\n): HandlerDeps<TOut, TScope> {\n  return {\n    stageMap: parentDeps.stageMap,\n    root: parentDeps.root,\n    ScopeFactory: parentDeps.ScopeFactory,\n    subflows: parentDeps.subflows,\n    throttlingErrorChecker: parentDeps.throttlingErrorChecker,\n    streamHandlers: parentDeps.streamHandlers,\n    scopeProtectionMode: parentDeps.scopeProtectionMode,\n    executionRuntime: subflowRuntime,\n    readOnlyContext: mappedInput,\n    executionEnv: parentDeps.executionEnv, // inherited — like process.env\n    narrativeGenerator: parentDeps.narrativeGenerator,\n    logger: parentDeps.logger,\n  };\n}\n\n/**\n * Seed the subflow's GlobalStore with initial values.\n * Called before subflow execution to make inputMapper values available.\n */\nexport function seedSubflowGlobalStore(\n  subflowRuntime: IExecutionRuntime,\n  initialValues: Record<string, unknown>,\n): void {\n  const rootContext = subflowRuntime.rootStageContext;\n\n  for (const [key, value] of Object.entries(initialValues)) {\n    if (typeof value === 'object' && value !== null && !Array.isArray(value)) {\n      for (const [nestedKey, nestedValue] of Object.entries(value as Record<string, unknown>)) {\n        rootContext.setObject([key], nestedKey, nestedValue);\n      }\n    } else {\n      rootContext.setGlobal(key, value);\n    }\n  }\n\n  rootContext.commit();\n}\n\n/**\n * Apply output mapping after subflow completion.\n * Writes mapped values back to parent scope using merge semantics:\n * arrays are appended, objects are shallow-merged, scalars are replaced.\n */\nexport function applyOutputMapping<TParentScope, TSubflowOutput>(\n  subflowOutput: TSubflowOutput,\n  parentScope: TParentScope,\n  parentContext: StageContext,\n  options?: SubflowMountOptions<TParentScope, any, TSubflowOutput>,\n): Record<string, unknown> | undefined {\n  if (!options?.outputMapper) {\n    return undefined;\n  }\n\n  const mappedOutput = options.outputMapper(subflowOutput, parentScope);\n\n  if (mappedOutput === null || mappedOutput === undefined) {\n    return undefined;\n  }\n\n  for (const [key, value] of Object.entries(mappedOutput)) {\n    if (typeof value === 'object' && value !== null && !Array.isArray(value)) {\n      for (const [nestedKey, nestedValue] of Object.entries(value as Record<string, unknown>)) {\n        if (Array.isArray(nestedValue)) {\n          parentContext.appendToArray([key], nestedKey, nestedValue);\n        } else if (typeof nestedValue === 'object' && nestedValue !== null) {\n          parentContext.mergeObject([key], nestedKey, nestedValue as Record<string, unknown>);\n        } else {\n          parentContext.setObject([key], nestedKey, nestedValue);\n        }\n      }\n    } else if (Array.isArray(value)) {\n      const existing = parentContext.getGlobal(key);\n      if (Array.isArray(existing)) {\n        parentContext.setGlobal(key, [...existing, ...value]);\n      } else {\n        parentContext.setGlobal(key, value);\n      }\n    } else {\n      parentContext.setGlobal(key, value);\n    }\n  }\n\n  return mappedOutput;\n}\n"]}
@@ -91,6 +91,7 @@ export class FlowchartTraverser {
91
91
  streamHandlers: opts.streamHandlers,
92
92
  scopeProtectionMode: (_a = opts.scopeProtectionMode) !== null && _a !== void 0 ? _a : 'error',
93
93
  readOnlyContext: opts.readOnlyContext,
94
+ executionEnv: opts.executionEnv,
94
95
  narrativeGenerator: this.narrativeGenerator,
95
96
  logger: this.logger,
96
97
  signal: opts.signal,
@@ -467,4 +468,4 @@ export class FlowchartTraverser {
467
468
  }
468
469
  }
469
470
  }
470
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FlowchartTraverser.js","sourceRoot":"","sources":["../../../../../src/lib/engine/traversal/FlowchartTraverser.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * FlowchartTraverser — Pre-order DFS traversal of StageNode graph.\n *\n * Unified traversal algorithm for all node shapes:\n *   const pre = await prep();\n *   const [x, y] = await Promise.all([fx(pre), fy(pre)]);\n *   return await next(x, y);\n *\n * For each node, executeNode follows 7 phases:\n *   0. CLASSIFY  — subflow detection, early delegation\n *   1. VALIDATE  — node invariants, role markers\n *   2. EXECUTE   — run stage fn, commit, break check\n *   3. DYNAMIC   — StageNode return detection, subflow auto-registration, structure updates\n *   4. CHILDREN  — fork/selector/decider dispatch\n *   5. CONTINUE  — dynamic next / linear next resolution\n *   6. LEAF      — no continuation, return output\n *\n * Break semantics: If a stage calls breakFn(), commit and STOP.\n * Patch model: Stage writes into local patch; commitPatch() after return or throw.\n */\n\nimport type { StageContext } from '../../memory/StageContext';\nimport type { ScopeProtectionMode } from '../../scope/protection/types';\nimport { isStageNodeReturn } from '../graph/StageNode';\nimport { ChildrenExecutor } from '../handlers/ChildrenExecutor';\nimport { ContinuationResolver } from '../handlers/ContinuationResolver';\nimport { DeciderHandler } from '../handlers/DeciderHandler';\nimport { ExtractorRunner } from '../handlers/ExtractorRunner';\nimport { NodeResolver } from '../handlers/NodeResolver';\nimport { RuntimeStructureManager } from '../handlers/RuntimeStructureManager';\nimport { SelectorHandler } from '../handlers/SelectorHandler';\nimport { StageRunner } from '../handlers/StageRunner';\nimport { SubflowExecutor } from '../handlers/SubflowExecutor';\nimport { FlowRecorderDispatcher } from '../narrative/FlowRecorderDispatcher';\nimport { NarrativeFlowRecorder } from '../narrative/NarrativeFlowRecorder';\nimport { NullControlFlowNarrativeGenerator } from '../narrative/NullControlFlowNarrativeGenerator';\nimport type { FlowRecorder, IControlFlowNarrative } from '../narrative/types';\nimport type {\n  ExtractorError,\n  HandlerDeps,\n  IExecutionRuntime,\n  ILogger,\n  NodeResultType,\n  ScopeFactory,\n  SerializedPipelineStructure,\n  StageFunction,\n  StageNode,\n  StreamHandlers,\n  SubflowResult,\n  TraversalExtractor,\n  TraversalResult,\n} from '../types';\n\nexport interface TraverserOptions<TOut = any, TScope = any> {\n  root: StageNode<TOut, TScope>;\n  stageMap: Map<string, StageFunction<TOut, TScope>>;\n  scopeFactory: ScopeFactory<TScope>;\n  executionRuntime: IExecutionRuntime;\n  readOnlyContext?: unknown;\n  throttlingErrorChecker?: (error: unknown) => boolean;\n  streamHandlers?: StreamHandlers;\n  extractor?: TraversalExtractor;\n  scopeProtectionMode?: ScopeProtectionMode;\n  subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  enrichSnapshots?: boolean;\n  narrativeEnabled?: boolean;\n  buildTimeStructure?: SerializedPipelineStructure;\n  logger: ILogger;\n  signal?: AbortSignal;\n  /** Pre-configured FlowRecorders to attach when narrative is enabled. */\n  flowRecorders?: FlowRecorder[];\n}\n\nexport class FlowchartTraverser<TOut = any, TScope = any> {\n  private readonly root: StageNode<TOut, TScope>;\n  private stageMap: Map<string, StageFunction<TOut, TScope>>;\n  private readonly executionRuntime: IExecutionRuntime;\n  private subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  private readonly logger: ILogger;\n  private readonly signal?: AbortSignal;\n\n  // Handler modules\n  private readonly nodeResolver: NodeResolver<TOut, TScope>;\n  private readonly childrenExecutor: ChildrenExecutor<TOut, TScope>;\n  private readonly subflowExecutor: SubflowExecutor<TOut, TScope>;\n  private readonly stageRunner: StageRunner<TOut, TScope>;\n  private readonly continuationResolver: ContinuationResolver<TOut, TScope>;\n  private readonly deciderHandler: DeciderHandler<TOut, TScope>;\n  private readonly selectorHandler: SelectorHandler<TOut, TScope>;\n  private readonly structureManager: RuntimeStructureManager;\n  private readonly extractorRunner: ExtractorRunner<TOut, TScope>;\n  private readonly narrativeGenerator: IControlFlowNarrative;\n  private readonly flowRecorderDispatcher: FlowRecorderDispatcher | undefined;\n\n  // Execution state\n  private subflowResults: Map<string, SubflowResult> = new Map();\n\n  constructor(opts: TraverserOptions<TOut, TScope>) {\n    this.root = opts.root;\n    this.stageMap = opts.stageMap;\n    this.executionRuntime = opts.executionRuntime;\n    this.subflows = opts.subflows;\n    this.logger = opts.logger;\n    this.signal = opts.signal;\n\n    // Structure manager (deep-clones build-time structure)\n    this.structureManager = new RuntimeStructureManager();\n    this.structureManager.init(opts.buildTimeStructure);\n\n    // Extractor runner\n    this.extractorRunner = new ExtractorRunner(\n      opts.extractor,\n      opts.enrichSnapshots ?? false,\n      this.executionRuntime,\n      this.logger,\n    );\n\n    // Narrative generator\n    // When narrative is enabled with FlowRecorders, use FlowRecorderDispatcher.\n    // When narrative is enabled without FlowRecorders, use legacy ControlFlowNarrativeGenerator.\n    // When disabled, use NullControlFlowNarrativeGenerator (zero-cost).\n    if (opts.narrativeEnabled) {\n      const dispatcher = new FlowRecorderDispatcher();\n      this.flowRecorderDispatcher = dispatcher;\n\n      // If custom FlowRecorders are provided, use them; otherwise attach default NarrativeFlowRecorder\n      if (opts.flowRecorders && opts.flowRecorders.length > 0) {\n        for (const recorder of opts.flowRecorders) {\n          dispatcher.attach(recorder);\n        }\n      } else {\n        dispatcher.attach(new NarrativeFlowRecorder());\n      }\n\n      this.narrativeGenerator = dispatcher;\n    } else {\n      this.narrativeGenerator = new NullControlFlowNarrativeGenerator();\n    }\n\n    // Build shared deps bag\n    const deps = this.createDeps(opts);\n\n    // Initialize handler modules\n    this.nodeResolver = new NodeResolver(deps);\n    this.childrenExecutor = new ChildrenExecutor(deps, this.executeNode.bind(this));\n    this.stageRunner = new StageRunner(deps);\n    this.continuationResolver = new ContinuationResolver(deps, this.nodeResolver, (nodeId, count) =>\n      this.structureManager.updateIterationCount(nodeId, count),\n    );\n    this.deciderHandler = new DeciderHandler(deps);\n    this.selectorHandler = new SelectorHandler(deps, this.childrenExecutor);\n    this.subflowExecutor = new SubflowExecutor(\n      deps,\n      this.nodeResolver,\n      this.executeStage.bind(this),\n      this.extractorRunner.callExtractor.bind(this.extractorRunner),\n      this.getStageFn.bind(this),\n    );\n  }\n\n  private createDeps(opts: TraverserOptions<TOut, TScope>): HandlerDeps<TOut, TScope> {\n    return {\n      stageMap: this.stageMap,\n      root: this.root,\n      executionRuntime: this.executionRuntime,\n      ScopeFactory: opts.scopeFactory,\n      subflows: this.subflows,\n      throttlingErrorChecker: opts.throttlingErrorChecker,\n      streamHandlers: opts.streamHandlers,\n      scopeProtectionMode: opts.scopeProtectionMode ?? 'error',\n      readOnlyContext: opts.readOnlyContext,\n      narrativeGenerator: this.narrativeGenerator,\n      logger: this.logger,\n      signal: opts.signal,\n    };\n  }\n\n  // ─────────────────────── Public API ───────────────────────\n\n  async execute(): Promise<TraversalResult> {\n    const context = this.executionRuntime.rootStageContext;\n    return await this.executeNode(this.root, context, { shouldBreak: false }, '');\n  }\n\n  getRuntimeStructure(): SerializedPipelineStructure | undefined {\n    return this.structureManager.getStructure();\n  }\n\n  getSnapshot() {\n    return this.executionRuntime.getSnapshot();\n  }\n\n  getRuntime() {\n    return this.executionRuntime;\n  }\n\n  setRootObject(path: string[], key: string, value: unknown) {\n    this.executionRuntime.setRootObject(path, key, value);\n  }\n\n  getBranchIds() {\n    return this.executionRuntime.getPipelines();\n  }\n\n  getRuntimeRoot(): StageNode {\n    return this.root;\n  }\n\n  getSubflowResults(): Map<string, SubflowResult> {\n    return this.subflowResults;\n  }\n\n  getExtractedResults<TResult = unknown>(): Map<string, TResult> {\n    return this.extractorRunner.getExtractedResults() as Map<string, TResult>;\n  }\n\n  getExtractorErrors(): ExtractorError[] {\n    return this.extractorRunner.getExtractorErrors();\n  }\n\n  getNarrative(): string[] {\n    return this.narrativeGenerator.getSentences();\n  }\n\n  /** Returns the FlowRecorderDispatcher, or undefined if narrative is disabled. */\n  getFlowRecorderDispatcher(): FlowRecorderDispatcher | undefined {\n    return this.flowRecorderDispatcher;\n  }\n\n  // ─────────────────────── Core Traversal ───────────────────────\n\n  private getStageFn(node: StageNode<TOut, TScope>): StageFunction<TOut, TScope> | undefined {\n    if (typeof node.fn === 'function') return node.fn as StageFunction<TOut, TScope>;\n    return this.stageMap.get(node.name);\n  }\n\n  private async executeStage(\n    node: StageNode<TOut, TScope>,\n    stageFunc: StageFunction<TOut, TScope>,\n    context: StageContext,\n    breakFn: () => void,\n  ) {\n    return this.stageRunner.run(node, stageFunc, context, breakFn);\n  }\n\n  /**\n   * Pre-order DFS traversal — the core algorithm.\n   * Each call processes one node through all 7 phases.\n   */\n  private async executeNode(\n    node: StageNode<TOut, TScope>,\n    context: StageContext,\n    breakFlag: { shouldBreak: boolean },\n    branchPath?: string,\n  ): Promise<any> {\n    // Attach builder metadata to context for snapshot enrichment\n    if (node.description) context.description = node.description;\n    if (node.isSubflowRoot && node.subflowId) context.subflowId = node.subflowId;\n\n    // ─── Phase 0: CLASSIFY — subflow detection ───\n    if (node.isSubflowRoot && node.subflowId) {\n      const resolvedNode = this.nodeResolver.resolveSubflowReference(node);\n      const previousSubflowId = this.extractorRunner.currentSubflowId;\n      this.extractorRunner.currentSubflowId = node.subflowId;\n\n      let subflowOutput: any;\n      try {\n        subflowOutput = await this.subflowExecutor.executeSubflow(\n          resolvedNode,\n          context,\n          breakFlag,\n          branchPath,\n          this.subflowResults,\n        );\n      } finally {\n        this.extractorRunner.currentSubflowId = previousSubflowId;\n      }\n\n      const isReferenceBasedSubflow = resolvedNode !== node;\n      const hasChildren = Boolean(node.children && node.children.length > 0);\n      const shouldExecuteContinuation = isReferenceBasedSubflow || hasChildren;\n\n      if (node.next && shouldExecuteContinuation) {\n        const nextCtx = context.createNext(branchPath as string, node.next.name);\n        return await this.executeNode(node.next, nextCtx, breakFlag, branchPath);\n      }\n\n      return subflowOutput;\n    }\n\n    const stageFunc = this.getStageFn(node);\n    const hasStageFunction = Boolean(stageFunc);\n    const isScopeBasedDecider = Boolean(node.deciderFn);\n    const isScopeBasedSelector = Boolean(node.selectorFn);\n    const isDeciderNode = isScopeBasedDecider;\n    const hasChildren = Boolean(node.children?.length);\n    const hasNext = Boolean(node.next);\n    const originalNext = node.next;\n\n    // ─── Phase 1: VALIDATE — node invariants ───\n    if (!hasStageFunction && !isDeciderNode && !isScopeBasedSelector && !hasChildren) {\n      const errorMessage = `Node '${node.name}' must define: embedded fn OR a stageMap entry OR have children/decider`;\n      this.logger.error(`Error in pipeline (${branchPath}) stage [${node.name}]:`, { error: errorMessage });\n      throw new Error(errorMessage);\n    }\n    if (isDeciderNode && !hasChildren) {\n      const errorMessage = 'Decider node needs to have children to execute';\n      this.logger.error(`Error in pipeline (${branchPath}) stage [${node.name}]:`, { error: errorMessage });\n      throw new Error(errorMessage);\n    }\n    if (isScopeBasedSelector && !hasChildren) {\n      const errorMessage = 'Selector node needs to have children to execute';\n      this.logger.error(`Error in pipeline (${branchPath}) stage [${node.name}]:`, { error: errorMessage });\n      throw new Error(errorMessage);\n    }\n\n    // Role markers for debug panels\n    if (!hasStageFunction) {\n      if (isDeciderNode) context.setAsDecider();\n      else if (hasChildren) context.setAsFork();\n    }\n\n    const breakFn = () => (breakFlag.shouldBreak = true);\n\n    // ─── Phase 2a: SELECTOR — scope-based multi-choice ───\n    if (isScopeBasedSelector) {\n      const previousForkId = this.extractorRunner.currentForkId;\n      this.extractorRunner.currentForkId = node.id;\n\n      try {\n        const selectorResult = await this.selectorHandler.handleScopeBased(\n          node,\n          stageFunc!,\n          context,\n          breakFlag,\n          branchPath,\n          this.executeStage.bind(this),\n          this.executeNode.bind(this),\n          this.extractorRunner.callExtractor.bind(this.extractorRunner),\n          this.extractorRunner.getStagePath.bind(this.extractorRunner),\n        );\n\n        if (hasNext) {\n          const nextCtx = context.createNext(branchPath as string, node.next!.name);\n          return await this.executeNode(node.next!, nextCtx, breakFlag, branchPath);\n        }\n        return selectorResult;\n      } finally {\n        this.extractorRunner.currentForkId = previousForkId;\n      }\n    }\n\n    // ─── Phase 2b: DECIDER — scope-based single-choice conditional branch ───\n    if (isDeciderNode) {\n      const deciderResult = await this.deciderHandler.handleScopeBased(\n        node,\n        stageFunc!,\n        context,\n        breakFlag,\n        branchPath,\n        this.executeStage.bind(this),\n        this.executeNode.bind(this),\n        this.extractorRunner.callExtractor.bind(this.extractorRunner),\n        this.extractorRunner.getStagePath.bind(this.extractorRunner),\n      );\n\n      // After branch execution, follow decider's own next (e.g., loopTo target)\n      if (hasNext && !breakFlag.shouldBreak) {\n        const nextNode = originalNext!;\n        const isLoopRef =\n          !this.getStageFn(nextNode) &&\n          !nextNode.children?.length &&\n          !nextNode.deciderFn &&\n          !nextNode.selectorFn &&\n          !nextNode.isSubflowRoot;\n\n        if (isLoopRef) {\n          return this.continuationResolver.resolve(\n            nextNode,\n            node,\n            context,\n            breakFlag,\n            branchPath,\n            this.executeNode.bind(this),\n          );\n        }\n\n        this.narrativeGenerator.onNext(node.name, nextNode.name, nextNode.description);\n        const nextCtx = context.createNext(branchPath as string, nextNode.name);\n        return await this.executeNode(nextNode, nextCtx, breakFlag, branchPath);\n      }\n\n      return deciderResult;\n    }\n\n    // ─── Abort check — cooperative cancellation ───\n    if (this.signal?.aborted) {\n      const reason =\n        this.signal.reason instanceof Error ? this.signal.reason : new Error(this.signal.reason ?? 'Aborted');\n      throw reason;\n    }\n\n    // ─── Phase 3: EXECUTE — run stage function ───\n    let stageOutput: TOut | undefined;\n    let dynamicNext: StageNode<TOut, TScope> | undefined;\n\n    if (stageFunc) {\n      try {\n        stageOutput = await this.executeStage(node, stageFunc, context, breakFn);\n      } catch (error: any) {\n        context.commit();\n        this.extractorRunner.callExtractor(\n          node,\n          context,\n          this.extractorRunner.getStagePath(node, branchPath, context.stageName),\n          undefined,\n          { type: 'stageExecutionError', message: error.toString() },\n        );\n        this.narrativeGenerator.onError(node.name, error.toString(), error);\n        this.logger.error(`Error in pipeline (${branchPath}) stage [${node.name}]:`, { error });\n        context.addError('stageExecutionError', error.toString());\n        throw error;\n      }\n      context.commit();\n      this.extractorRunner.callExtractor(\n        node,\n        context,\n        this.extractorRunner.getStagePath(node, branchPath, context.stageName),\n        stageOutput,\n      );\n      this.narrativeGenerator.onStageExecuted(node.name, node.description);\n\n      if (breakFlag.shouldBreak) {\n        this.narrativeGenerator.onBreak(node.name);\n        this.logger.info(`Execution stopped in pipeline (${branchPath}) after ${node.name} due to break condition.`);\n        return stageOutput;\n      }\n\n      // ─── Phase 4: DYNAMIC — StageNode return detection ───\n      if (stageOutput && typeof stageOutput === 'object' && isStageNodeReturn(stageOutput)) {\n        const dynamicNode = stageOutput as StageNode<TOut, TScope>;\n        context.addLog('isDynamic', true);\n        context.addLog('dynamicPattern', 'StageNodeReturn');\n\n        // Dynamic subflow auto-registration\n        if (dynamicNode.isSubflowRoot && dynamicNode.subflowDef && dynamicNode.subflowId) {\n          context.addLog('dynamicPattern', 'dynamicSubflow');\n          context.addLog('dynamicSubflowId', dynamicNode.subflowId);\n          this.autoRegisterSubflowDef(dynamicNode.subflowId, dynamicNode.subflowDef, node.id);\n\n          node.isSubflowRoot = true;\n          node.subflowId = dynamicNode.subflowId;\n          node.subflowName = dynamicNode.subflowName;\n          node.subflowMountOptions = dynamicNode.subflowMountOptions;\n\n          this.structureManager.updateDynamicSubflow(\n            node.id,\n            dynamicNode.subflowId!,\n            dynamicNode.subflowName,\n            dynamicNode.subflowDef?.buildTimeStructure,\n          );\n\n          return await this.executeNode(node, context, breakFlag, branchPath);\n        }\n\n        // Check children for subflowDef\n        if (dynamicNode.children) {\n          for (const child of dynamicNode.children) {\n            if (child.isSubflowRoot && child.subflowDef && child.subflowId) {\n              this.autoRegisterSubflowDef(child.subflowId, child.subflowDef, child.id);\n              this.structureManager.updateDynamicSubflow(\n                child.id,\n                child.subflowId!,\n                child.subflowName,\n                child.subflowDef?.buildTimeStructure,\n              );\n            }\n          }\n        }\n\n        // Dynamic children (fork pattern)\n        if (dynamicNode.children && dynamicNode.children.length > 0) {\n          node.children = dynamicNode.children;\n          context.addLog('dynamicChildCount', dynamicNode.children.length);\n          context.addLog(\n            'dynamicChildIds',\n            dynamicNode.children.map((c) => c.id),\n          );\n\n          this.structureManager.updateDynamicChildren(\n            node.id,\n            dynamicNode.children,\n            Boolean(dynamicNode.nextNodeSelector),\n            Boolean(dynamicNode.deciderFn),\n          );\n\n          if (typeof dynamicNode.nextNodeSelector === 'function') {\n            node.nextNodeSelector = dynamicNode.nextNodeSelector;\n            context.addLog('hasSelector', true);\n          }\n        }\n\n        // Dynamic next (linear continuation)\n        if (dynamicNode.next) {\n          dynamicNext = dynamicNode.next;\n          this.structureManager.updateDynamicNext(node.id, dynamicNode.next);\n          node.next = dynamicNode.next;\n          context.addLog('hasDynamicNext', true);\n        }\n\n        stageOutput = undefined;\n      }\n\n      // Restore original next to avoid stale reference on loop revisit\n      if (dynamicNext) {\n        node.next = originalNext;\n      }\n    }\n\n    // ─── Phase 5: CHILDREN — fork dispatch ───\n    const hasChildrenAfterStage = Boolean(node.children?.length);\n\n    if (hasChildrenAfterStage) {\n      context.addLog('totalChildren', node.children?.length);\n      context.addLog('orderOfExecution', 'ChildrenAfterStage');\n\n      let nodeChildrenResults: Record<string, NodeResultType>;\n\n      if (node.nextNodeSelector) {\n        const previousForkId = this.extractorRunner.currentForkId;\n        this.extractorRunner.currentForkId = node.id;\n        try {\n          nodeChildrenResults = await this.childrenExecutor.executeSelectedChildren(\n            node.nextNodeSelector,\n            node.children!,\n            stageOutput,\n            context,\n            branchPath as string,\n          );\n        } finally {\n          this.extractorRunner.currentForkId = previousForkId;\n        }\n      } else {\n        const childCount = node.children?.length ?? 0;\n        const childNames = node.children?.map((c) => c.name).join(', ');\n        context.addFlowDebugMessage('children', `Executing all ${childCount} children in parallel: ${childNames}`, {\n          count: childCount,\n          targetStage: node.children?.map((c) => c.name),\n        });\n\n        const previousForkId = this.extractorRunner.currentForkId;\n        this.extractorRunner.currentForkId = node.id;\n        try {\n          nodeChildrenResults = await this.childrenExecutor.executeNodeChildren(node, context, undefined, branchPath);\n        } finally {\n          this.extractorRunner.currentForkId = previousForkId;\n        }\n      }\n\n      // Fork-only: return bundle\n      if (!hasNext && !dynamicNext) {\n        return nodeChildrenResults!;\n      }\n\n      // Capture dynamic children as synthetic subflow result for UI\n      const isDynamic = context.debug?.logContext?.isDynamic;\n      if (isDynamic && node.children && node.children.length > 0) {\n        this.captureDynamicChildrenResult(node, context);\n      }\n    }\n\n    // ─── Phase 6: CONTINUE — dynamic next / linear next ───\n    if (dynamicNext) {\n      return this.continuationResolver.resolve(\n        dynamicNext,\n        node,\n        context,\n        breakFlag,\n        branchPath,\n        this.executeNode.bind(this),\n      );\n    }\n\n    if (hasNext) {\n      const nextNode = originalNext!;\n\n      // Detect loop reference nodes created by loopTo() — marked with isLoopRef flag.\n      // Route through ContinuationResolver for proper ID resolution, iteration\n      // tracking, and narrative generation.\n      const isLoopReference = nextNode.isLoopRef;\n\n      if (isLoopReference) {\n        return this.continuationResolver.resolve(\n          nextNode,\n          node,\n          context,\n          breakFlag,\n          branchPath,\n          this.executeNode.bind(this),\n        );\n      }\n\n      this.narrativeGenerator.onNext(node.name, nextNode.name, nextNode.description);\n      context.addFlowDebugMessage('next', `Moving to ${nextNode.name} stage`, {\n        targetStage: nextNode.name,\n      });\n      const nextCtx = context.createNext(branchPath as string, nextNode.name);\n      return await this.executeNode(nextNode, nextCtx, breakFlag, branchPath);\n    }\n\n    // ─── Phase 7: LEAF — no continuation ───\n    return stageOutput;\n  }\n\n  // ─────────────────────── Private Helpers ───────────────────────\n\n  private captureDynamicChildrenResult(node: StageNode<TOut, TScope>, context: StageContext): void {\n    const parentStageId = context.getStageId();\n\n    const childStructure: any = {\n      id: `${node.id}-children`,\n      name: 'Dynamic Children',\n      type: 'fork',\n      children: node.children!.map((c) => ({\n        id: c.id,\n        name: c.name,\n        type: 'stage',\n      })),\n    };\n\n    const childStages: Record<string, unknown> = {};\n    if (context.children) {\n      for (const childCtx of context.children) {\n        const snapshot = childCtx.getSnapshot();\n        childStages[snapshot.name || snapshot.id] = {\n          name: snapshot.name,\n          output: snapshot.logs,\n          errors: snapshot.errors,\n          metrics: snapshot.metrics,\n          status: snapshot.errors && Object.keys(snapshot.errors).length > 0 ? 'error' : 'success',\n        };\n      }\n    }\n\n    this.subflowResults.set(node.id, {\n      subflowId: node.id,\n      subflowName: node.name,\n      treeContext: {\n        globalContext: {},\n        stageContexts: childStages as unknown as Record<string, unknown>,\n        history: [],\n      },\n      parentStageId,\n      pipelineStructure: childStructure,\n    });\n  }\n\n  private autoRegisterSubflowDef(\n    subflowId: string,\n    subflowDef: NonNullable<StageNode['subflowDef']>,\n    mountNodeId?: string,\n  ): void {\n    let subflowsDict = this.subflows;\n    if (!subflowsDict) {\n      subflowsDict = {};\n      this.subflows = subflowsDict;\n    }\n\n    // First-write-wins\n    const isNewRegistration = !subflowsDict[subflowId];\n    if (isNewRegistration) {\n      subflowsDict[subflowId] = {\n        root: subflowDef.root as StageNode<TOut, TScope>,\n        ...(subflowDef.buildTimeStructure ? { buildTimeStructure: subflowDef.buildTimeStructure } : {}),\n      } as any;\n    }\n\n    // Merge stageMap entries (parent entries preserved)\n    if (subflowDef.stageMap) {\n      for (const [key, fn] of Array.from(subflowDef.stageMap.entries())) {\n        if (!this.stageMap.has(key)) {\n          this.stageMap.set(key, fn as StageFunction<TOut, TScope>);\n        }\n      }\n    }\n\n    // Merge nested subflows\n    if (subflowDef.subflows) {\n      for (const [key, def] of Object.entries(subflowDef.subflows)) {\n        if (!subflowsDict[key]) {\n          subflowsDict[key] = def as { root: StageNode<TOut, TScope> };\n        }\n      }\n    }\n\n    if (mountNodeId) {\n      this.structureManager.updateDynamicSubflow(\n        mountNodeId,\n        subflowId,\n        subflowDef.root?.subflowName || subflowDef.root?.name,\n        subflowDef.buildTimeStructure,\n      );\n    }\n\n    // Notify FlowRecorders only on first registration (matches first-write-wins)\n    if (isNewRegistration) {\n      const subflowName = subflowDef.root?.subflowName || subflowDef.root?.name || subflowId;\n      this.narrativeGenerator.onSubflowRegistered(\n        subflowId,\n        subflowName,\n        subflowDef.root?.description,\n        subflowDef.buildTimeStructure,\n      );\n    }\n  }\n}\n"]}
471
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FlowchartTraverser.js","sourceRoot":"","sources":["../../../../../src/lib/engine/traversal/FlowchartTraverser.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * FlowchartTraverser — Pre-order DFS traversal of StageNode graph.\n *\n * Unified traversal algorithm for all node shapes:\n *   const pre = await prep();\n *   const [x, y] = await Promise.all([fx(pre), fy(pre)]);\n *   return await next(x, y);\n *\n * For each node, executeNode follows 7 phases:\n *   0. CLASSIFY  — subflow detection, early delegation\n *   1. VALIDATE  — node invariants, role markers\n *   2. EXECUTE   — run stage fn, commit, break check\n *   3. DYNAMIC   — StageNode return detection, subflow auto-registration, structure updates\n *   4. CHILDREN  — fork/selector/decider dispatch\n *   5. CONTINUE  — dynamic next / linear next resolution\n *   6. LEAF      — no continuation, return output\n *\n * Break semantics: If a stage calls breakFn(), commit and STOP.\n * Patch model: Stage writes into local patch; commitPatch() after return or throw.\n */\n\nimport type { StageContext } from '../../memory/StageContext';\nimport type { ScopeProtectionMode } from '../../scope/protection/types';\nimport { isStageNodeReturn } from '../graph/StageNode';\nimport { ChildrenExecutor } from '../handlers/ChildrenExecutor';\nimport { ContinuationResolver } from '../handlers/ContinuationResolver';\nimport { DeciderHandler } from '../handlers/DeciderHandler';\nimport { ExtractorRunner } from '../handlers/ExtractorRunner';\nimport { NodeResolver } from '../handlers/NodeResolver';\nimport { RuntimeStructureManager } from '../handlers/RuntimeStructureManager';\nimport { SelectorHandler } from '../handlers/SelectorHandler';\nimport { StageRunner } from '../handlers/StageRunner';\nimport { SubflowExecutor } from '../handlers/SubflowExecutor';\nimport { FlowRecorderDispatcher } from '../narrative/FlowRecorderDispatcher';\nimport { NarrativeFlowRecorder } from '../narrative/NarrativeFlowRecorder';\nimport { NullControlFlowNarrativeGenerator } from '../narrative/NullControlFlowNarrativeGenerator';\nimport type { FlowRecorder, IControlFlowNarrative } from '../narrative/types';\nimport type {\n  ExtractorError,\n  HandlerDeps,\n  IExecutionRuntime,\n  ILogger,\n  NodeResultType,\n  ScopeFactory,\n  SerializedPipelineStructure,\n  StageFunction,\n  StageNode,\n  StreamHandlers,\n  SubflowResult,\n  TraversalExtractor,\n  TraversalResult,\n} from '../types';\n\nexport interface TraverserOptions<TOut = any, TScope = any> {\n  root: StageNode<TOut, TScope>;\n  stageMap: Map<string, StageFunction<TOut, TScope>>;\n  scopeFactory: ScopeFactory<TScope>;\n  executionRuntime: IExecutionRuntime;\n  readOnlyContext?: unknown;\n  /** Execution environment — propagates to subflows automatically. */\n  executionEnv?: import('../../engine/types').ExecutionEnv;\n  throttlingErrorChecker?: (error: unknown) => boolean;\n  streamHandlers?: StreamHandlers;\n  extractor?: TraversalExtractor;\n  scopeProtectionMode?: ScopeProtectionMode;\n  subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  enrichSnapshots?: boolean;\n  narrativeEnabled?: boolean;\n  buildTimeStructure?: SerializedPipelineStructure;\n  logger: ILogger;\n  signal?: AbortSignal;\n  /** Pre-configured FlowRecorders to attach when narrative is enabled. */\n  flowRecorders?: FlowRecorder[];\n}\n\nexport class FlowchartTraverser<TOut = any, TScope = any> {\n  private readonly root: StageNode<TOut, TScope>;\n  private stageMap: Map<string, StageFunction<TOut, TScope>>;\n  private readonly executionRuntime: IExecutionRuntime;\n  private subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  private readonly logger: ILogger;\n  private readonly signal?: AbortSignal;\n\n  // Handler modules\n  private readonly nodeResolver: NodeResolver<TOut, TScope>;\n  private readonly childrenExecutor: ChildrenExecutor<TOut, TScope>;\n  private readonly subflowExecutor: SubflowExecutor<TOut, TScope>;\n  private readonly stageRunner: StageRunner<TOut, TScope>;\n  private readonly continuationResolver: ContinuationResolver<TOut, TScope>;\n  private readonly deciderHandler: DeciderHandler<TOut, TScope>;\n  private readonly selectorHandler: SelectorHandler<TOut, TScope>;\n  private readonly structureManager: RuntimeStructureManager;\n  private readonly extractorRunner: ExtractorRunner<TOut, TScope>;\n  private readonly narrativeGenerator: IControlFlowNarrative;\n  private readonly flowRecorderDispatcher: FlowRecorderDispatcher | undefined;\n\n  // Execution state\n  private subflowResults: Map<string, SubflowResult> = new Map();\n\n  constructor(opts: TraverserOptions<TOut, TScope>) {\n    this.root = opts.root;\n    this.stageMap = opts.stageMap;\n    this.executionRuntime = opts.executionRuntime;\n    this.subflows = opts.subflows;\n    this.logger = opts.logger;\n    this.signal = opts.signal;\n\n    // Structure manager (deep-clones build-time structure)\n    this.structureManager = new RuntimeStructureManager();\n    this.structureManager.init(opts.buildTimeStructure);\n\n    // Extractor runner\n    this.extractorRunner = new ExtractorRunner(\n      opts.extractor,\n      opts.enrichSnapshots ?? false,\n      this.executionRuntime,\n      this.logger,\n    );\n\n    // Narrative generator\n    // When narrative is enabled with FlowRecorders, use FlowRecorderDispatcher.\n    // When narrative is enabled without FlowRecorders, use legacy ControlFlowNarrativeGenerator.\n    // When disabled, use NullControlFlowNarrativeGenerator (zero-cost).\n    if (opts.narrativeEnabled) {\n      const dispatcher = new FlowRecorderDispatcher();\n      this.flowRecorderDispatcher = dispatcher;\n\n      // If custom FlowRecorders are provided, use them; otherwise attach default NarrativeFlowRecorder\n      if (opts.flowRecorders && opts.flowRecorders.length > 0) {\n        for (const recorder of opts.flowRecorders) {\n          dispatcher.attach(recorder);\n        }\n      } else {\n        dispatcher.attach(new NarrativeFlowRecorder());\n      }\n\n      this.narrativeGenerator = dispatcher;\n    } else {\n      this.narrativeGenerator = new NullControlFlowNarrativeGenerator();\n    }\n\n    // Build shared deps bag\n    const deps = this.createDeps(opts);\n\n    // Initialize handler modules\n    this.nodeResolver = new NodeResolver(deps);\n    this.childrenExecutor = new ChildrenExecutor(deps, this.executeNode.bind(this));\n    this.stageRunner = new StageRunner(deps);\n    this.continuationResolver = new ContinuationResolver(deps, this.nodeResolver, (nodeId, count) =>\n      this.structureManager.updateIterationCount(nodeId, count),\n    );\n    this.deciderHandler = new DeciderHandler(deps);\n    this.selectorHandler = new SelectorHandler(deps, this.childrenExecutor);\n    this.subflowExecutor = new SubflowExecutor(\n      deps,\n      this.nodeResolver,\n      this.executeStage.bind(this),\n      this.extractorRunner.callExtractor.bind(this.extractorRunner),\n      this.getStageFn.bind(this),\n    );\n  }\n\n  private createDeps(opts: TraverserOptions<TOut, TScope>): HandlerDeps<TOut, TScope> {\n    return {\n      stageMap: this.stageMap,\n      root: this.root,\n      executionRuntime: this.executionRuntime,\n      ScopeFactory: opts.scopeFactory,\n      subflows: this.subflows,\n      throttlingErrorChecker: opts.throttlingErrorChecker,\n      streamHandlers: opts.streamHandlers,\n      scopeProtectionMode: opts.scopeProtectionMode ?? 'error',\n      readOnlyContext: opts.readOnlyContext,\n      executionEnv: opts.executionEnv,\n      narrativeGenerator: this.narrativeGenerator,\n      logger: this.logger,\n      signal: opts.signal,\n    };\n  }\n\n  // ─────────────────────── Public API ───────────────────────\n\n  async execute(): Promise<TraversalResult> {\n    const context = this.executionRuntime.rootStageContext;\n    return await this.executeNode(this.root, context, { shouldBreak: false }, '');\n  }\n\n  getRuntimeStructure(): SerializedPipelineStructure | undefined {\n    return this.structureManager.getStructure();\n  }\n\n  getSnapshot() {\n    return this.executionRuntime.getSnapshot();\n  }\n\n  getRuntime() {\n    return this.executionRuntime;\n  }\n\n  setRootObject(path: string[], key: string, value: unknown) {\n    this.executionRuntime.setRootObject(path, key, value);\n  }\n\n  getBranchIds() {\n    return this.executionRuntime.getPipelines();\n  }\n\n  getRuntimeRoot(): StageNode {\n    return this.root;\n  }\n\n  getSubflowResults(): Map<string, SubflowResult> {\n    return this.subflowResults;\n  }\n\n  getExtractedResults<TResult = unknown>(): Map<string, TResult> {\n    return this.extractorRunner.getExtractedResults() as Map<string, TResult>;\n  }\n\n  getExtractorErrors(): ExtractorError[] {\n    return this.extractorRunner.getExtractorErrors();\n  }\n\n  getNarrative(): string[] {\n    return this.narrativeGenerator.getSentences();\n  }\n\n  /** Returns the FlowRecorderDispatcher, or undefined if narrative is disabled. */\n  getFlowRecorderDispatcher(): FlowRecorderDispatcher | undefined {\n    return this.flowRecorderDispatcher;\n  }\n\n  // ─────────────────────── Core Traversal ───────────────────────\n\n  private getStageFn(node: StageNode<TOut, TScope>): StageFunction<TOut, TScope> | undefined {\n    if (typeof node.fn === 'function') return node.fn as StageFunction<TOut, TScope>;\n    return this.stageMap.get(node.name);\n  }\n\n  private async executeStage(\n    node: StageNode<TOut, TScope>,\n    stageFunc: StageFunction<TOut, TScope>,\n    context: StageContext,\n    breakFn: () => void,\n  ) {\n    return this.stageRunner.run(node, stageFunc, context, breakFn);\n  }\n\n  /**\n   * Pre-order DFS traversal — the core algorithm.\n   * Each call processes one node through all 7 phases.\n   */\n  private async executeNode(\n    node: StageNode<TOut, TScope>,\n    context: StageContext,\n    breakFlag: { shouldBreak: boolean },\n    branchPath?: string,\n  ): Promise<any> {\n    // Attach builder metadata to context for snapshot enrichment\n    if (node.description) context.description = node.description;\n    if (node.isSubflowRoot && node.subflowId) context.subflowId = node.subflowId;\n\n    // ─── Phase 0: CLASSIFY — subflow detection ───\n    if (node.isSubflowRoot && node.subflowId) {\n      const resolvedNode = this.nodeResolver.resolveSubflowReference(node);\n      const previousSubflowId = this.extractorRunner.currentSubflowId;\n      this.extractorRunner.currentSubflowId = node.subflowId;\n\n      let subflowOutput: any;\n      try {\n        subflowOutput = await this.subflowExecutor.executeSubflow(\n          resolvedNode,\n          context,\n          breakFlag,\n          branchPath,\n          this.subflowResults,\n        );\n      } finally {\n        this.extractorRunner.currentSubflowId = previousSubflowId;\n      }\n\n      const isReferenceBasedSubflow = resolvedNode !== node;\n      const hasChildren = Boolean(node.children && node.children.length > 0);\n      const shouldExecuteContinuation = isReferenceBasedSubflow || hasChildren;\n\n      if (node.next && shouldExecuteContinuation) {\n        const nextCtx = context.createNext(branchPath as string, node.next.name);\n        return await this.executeNode(node.next, nextCtx, breakFlag, branchPath);\n      }\n\n      return subflowOutput;\n    }\n\n    const stageFunc = this.getStageFn(node);\n    const hasStageFunction = Boolean(stageFunc);\n    const isScopeBasedDecider = Boolean(node.deciderFn);\n    const isScopeBasedSelector = Boolean(node.selectorFn);\n    const isDeciderNode = isScopeBasedDecider;\n    const hasChildren = Boolean(node.children?.length);\n    const hasNext = Boolean(node.next);\n    const originalNext = node.next;\n\n    // ─── Phase 1: VALIDATE — node invariants ───\n    if (!hasStageFunction && !isDeciderNode && !isScopeBasedSelector && !hasChildren) {\n      const errorMessage = `Node '${node.name}' must define: embedded fn OR a stageMap entry OR have children/decider`;\n      this.logger.error(`Error in pipeline (${branchPath}) stage [${node.name}]:`, { error: errorMessage });\n      throw new Error(errorMessage);\n    }\n    if (isDeciderNode && !hasChildren) {\n      const errorMessage = 'Decider node needs to have children to execute';\n      this.logger.error(`Error in pipeline (${branchPath}) stage [${node.name}]:`, { error: errorMessage });\n      throw new Error(errorMessage);\n    }\n    if (isScopeBasedSelector && !hasChildren) {\n      const errorMessage = 'Selector node needs to have children to execute';\n      this.logger.error(`Error in pipeline (${branchPath}) stage [${node.name}]:`, { error: errorMessage });\n      throw new Error(errorMessage);\n    }\n\n    // Role markers for debug panels\n    if (!hasStageFunction) {\n      if (isDeciderNode) context.setAsDecider();\n      else if (hasChildren) context.setAsFork();\n    }\n\n    const breakFn = () => (breakFlag.shouldBreak = true);\n\n    // ─── Phase 2a: SELECTOR — scope-based multi-choice ───\n    if (isScopeBasedSelector) {\n      const previousForkId = this.extractorRunner.currentForkId;\n      this.extractorRunner.currentForkId = node.id;\n\n      try {\n        const selectorResult = await this.selectorHandler.handleScopeBased(\n          node,\n          stageFunc!,\n          context,\n          breakFlag,\n          branchPath,\n          this.executeStage.bind(this),\n          this.executeNode.bind(this),\n          this.extractorRunner.callExtractor.bind(this.extractorRunner),\n          this.extractorRunner.getStagePath.bind(this.extractorRunner),\n        );\n\n        if (hasNext) {\n          const nextCtx = context.createNext(branchPath as string, node.next!.name);\n          return await this.executeNode(node.next!, nextCtx, breakFlag, branchPath);\n        }\n        return selectorResult;\n      } finally {\n        this.extractorRunner.currentForkId = previousForkId;\n      }\n    }\n\n    // ─── Phase 2b: DECIDER — scope-based single-choice conditional branch ───\n    if (isDeciderNode) {\n      const deciderResult = await this.deciderHandler.handleScopeBased(\n        node,\n        stageFunc!,\n        context,\n        breakFlag,\n        branchPath,\n        this.executeStage.bind(this),\n        this.executeNode.bind(this),\n        this.extractorRunner.callExtractor.bind(this.extractorRunner),\n        this.extractorRunner.getStagePath.bind(this.extractorRunner),\n      );\n\n      // After branch execution, follow decider's own next (e.g., loopTo target)\n      if (hasNext && !breakFlag.shouldBreak) {\n        const nextNode = originalNext!;\n        const isLoopRef =\n          !this.getStageFn(nextNode) &&\n          !nextNode.children?.length &&\n          !nextNode.deciderFn &&\n          !nextNode.selectorFn &&\n          !nextNode.isSubflowRoot;\n\n        if (isLoopRef) {\n          return this.continuationResolver.resolve(\n            nextNode,\n            node,\n            context,\n            breakFlag,\n            branchPath,\n            this.executeNode.bind(this),\n          );\n        }\n\n        this.narrativeGenerator.onNext(node.name, nextNode.name, nextNode.description);\n        const nextCtx = context.createNext(branchPath as string, nextNode.name);\n        return await this.executeNode(nextNode, nextCtx, breakFlag, branchPath);\n      }\n\n      return deciderResult;\n    }\n\n    // ─── Abort check — cooperative cancellation ───\n    if (this.signal?.aborted) {\n      const reason =\n        this.signal.reason instanceof Error ? this.signal.reason : new Error(this.signal.reason ?? 'Aborted');\n      throw reason;\n    }\n\n    // ─── Phase 3: EXECUTE — run stage function ───\n    let stageOutput: TOut | undefined;\n    let dynamicNext: StageNode<TOut, TScope> | undefined;\n\n    if (stageFunc) {\n      try {\n        stageOutput = await this.executeStage(node, stageFunc, context, breakFn);\n      } catch (error: any) {\n        context.commit();\n        this.extractorRunner.callExtractor(\n          node,\n          context,\n          this.extractorRunner.getStagePath(node, branchPath, context.stageName),\n          undefined,\n          { type: 'stageExecutionError', message: error.toString() },\n        );\n        this.narrativeGenerator.onError(node.name, error.toString(), error);\n        this.logger.error(`Error in pipeline (${branchPath}) stage [${node.name}]:`, { error });\n        context.addError('stageExecutionError', error.toString());\n        throw error;\n      }\n      context.commit();\n      this.extractorRunner.callExtractor(\n        node,\n        context,\n        this.extractorRunner.getStagePath(node, branchPath, context.stageName),\n        stageOutput,\n      );\n      this.narrativeGenerator.onStageExecuted(node.name, node.description);\n\n      if (breakFlag.shouldBreak) {\n        this.narrativeGenerator.onBreak(node.name);\n        this.logger.info(`Execution stopped in pipeline (${branchPath}) after ${node.name} due to break condition.`);\n        return stageOutput;\n      }\n\n      // ─── Phase 4: DYNAMIC — StageNode return detection ───\n      if (stageOutput && typeof stageOutput === 'object' && isStageNodeReturn(stageOutput)) {\n        const dynamicNode = stageOutput as StageNode<TOut, TScope>;\n        context.addLog('isDynamic', true);\n        context.addLog('dynamicPattern', 'StageNodeReturn');\n\n        // Dynamic subflow auto-registration\n        if (dynamicNode.isSubflowRoot && dynamicNode.subflowDef && dynamicNode.subflowId) {\n          context.addLog('dynamicPattern', 'dynamicSubflow');\n          context.addLog('dynamicSubflowId', dynamicNode.subflowId);\n          this.autoRegisterSubflowDef(dynamicNode.subflowId, dynamicNode.subflowDef, node.id);\n\n          node.isSubflowRoot = true;\n          node.subflowId = dynamicNode.subflowId;\n          node.subflowName = dynamicNode.subflowName;\n          node.subflowMountOptions = dynamicNode.subflowMountOptions;\n\n          this.structureManager.updateDynamicSubflow(\n            node.id,\n            dynamicNode.subflowId!,\n            dynamicNode.subflowName,\n            dynamicNode.subflowDef?.buildTimeStructure,\n          );\n\n          return await this.executeNode(node, context, breakFlag, branchPath);\n        }\n\n        // Check children for subflowDef\n        if (dynamicNode.children) {\n          for (const child of dynamicNode.children) {\n            if (child.isSubflowRoot && child.subflowDef && child.subflowId) {\n              this.autoRegisterSubflowDef(child.subflowId, child.subflowDef, child.id);\n              this.structureManager.updateDynamicSubflow(\n                child.id,\n                child.subflowId!,\n                child.subflowName,\n                child.subflowDef?.buildTimeStructure,\n              );\n            }\n          }\n        }\n\n        // Dynamic children (fork pattern)\n        if (dynamicNode.children && dynamicNode.children.length > 0) {\n          node.children = dynamicNode.children;\n          context.addLog('dynamicChildCount', dynamicNode.children.length);\n          context.addLog(\n            'dynamicChildIds',\n            dynamicNode.children.map((c) => c.id),\n          );\n\n          this.structureManager.updateDynamicChildren(\n            node.id,\n            dynamicNode.children,\n            Boolean(dynamicNode.nextNodeSelector),\n            Boolean(dynamicNode.deciderFn),\n          );\n\n          if (typeof dynamicNode.nextNodeSelector === 'function') {\n            node.nextNodeSelector = dynamicNode.nextNodeSelector;\n            context.addLog('hasSelector', true);\n          }\n        }\n\n        // Dynamic next (linear continuation)\n        if (dynamicNode.next) {\n          dynamicNext = dynamicNode.next;\n          this.structureManager.updateDynamicNext(node.id, dynamicNode.next);\n          node.next = dynamicNode.next;\n          context.addLog('hasDynamicNext', true);\n        }\n\n        stageOutput = undefined;\n      }\n\n      // Restore original next to avoid stale reference on loop revisit\n      if (dynamicNext) {\n        node.next = originalNext;\n      }\n    }\n\n    // ─── Phase 5: CHILDREN — fork dispatch ───\n    const hasChildrenAfterStage = Boolean(node.children?.length);\n\n    if (hasChildrenAfterStage) {\n      context.addLog('totalChildren', node.children?.length);\n      context.addLog('orderOfExecution', 'ChildrenAfterStage');\n\n      let nodeChildrenResults: Record<string, NodeResultType>;\n\n      if (node.nextNodeSelector) {\n        const previousForkId = this.extractorRunner.currentForkId;\n        this.extractorRunner.currentForkId = node.id;\n        try {\n          nodeChildrenResults = await this.childrenExecutor.executeSelectedChildren(\n            node.nextNodeSelector,\n            node.children!,\n            stageOutput,\n            context,\n            branchPath as string,\n          );\n        } finally {\n          this.extractorRunner.currentForkId = previousForkId;\n        }\n      } else {\n        const childCount = node.children?.length ?? 0;\n        const childNames = node.children?.map((c) => c.name).join(', ');\n        context.addFlowDebugMessage('children', `Executing all ${childCount} children in parallel: ${childNames}`, {\n          count: childCount,\n          targetStage: node.children?.map((c) => c.name),\n        });\n\n        const previousForkId = this.extractorRunner.currentForkId;\n        this.extractorRunner.currentForkId = node.id;\n        try {\n          nodeChildrenResults = await this.childrenExecutor.executeNodeChildren(node, context, undefined, branchPath);\n        } finally {\n          this.extractorRunner.currentForkId = previousForkId;\n        }\n      }\n\n      // Fork-only: return bundle\n      if (!hasNext && !dynamicNext) {\n        return nodeChildrenResults!;\n      }\n\n      // Capture dynamic children as synthetic subflow result for UI\n      const isDynamic = context.debug?.logContext?.isDynamic;\n      if (isDynamic && node.children && node.children.length > 0) {\n        this.captureDynamicChildrenResult(node, context);\n      }\n    }\n\n    // ─── Phase 6: CONTINUE — dynamic next / linear next ───\n    if (dynamicNext) {\n      return this.continuationResolver.resolve(\n        dynamicNext,\n        node,\n        context,\n        breakFlag,\n        branchPath,\n        this.executeNode.bind(this),\n      );\n    }\n\n    if (hasNext) {\n      const nextNode = originalNext!;\n\n      // Detect loop reference nodes created by loopTo() — marked with isLoopRef flag.\n      // Route through ContinuationResolver for proper ID resolution, iteration\n      // tracking, and narrative generation.\n      const isLoopReference = nextNode.isLoopRef;\n\n      if (isLoopReference) {\n        return this.continuationResolver.resolve(\n          nextNode,\n          node,\n          context,\n          breakFlag,\n          branchPath,\n          this.executeNode.bind(this),\n        );\n      }\n\n      this.narrativeGenerator.onNext(node.name, nextNode.name, nextNode.description);\n      context.addFlowDebugMessage('next', `Moving to ${nextNode.name} stage`, {\n        targetStage: nextNode.name,\n      });\n      const nextCtx = context.createNext(branchPath as string, nextNode.name);\n      return await this.executeNode(nextNode, nextCtx, breakFlag, branchPath);\n    }\n\n    // ─── Phase 7: LEAF — no continuation ───\n    return stageOutput;\n  }\n\n  // ─────────────────────── Private Helpers ───────────────────────\n\n  private captureDynamicChildrenResult(node: StageNode<TOut, TScope>, context: StageContext): void {\n    const parentStageId = context.getStageId();\n\n    const childStructure: any = {\n      id: `${node.id}-children`,\n      name: 'Dynamic Children',\n      type: 'fork',\n      children: node.children!.map((c) => ({\n        id: c.id,\n        name: c.name,\n        type: 'stage',\n      })),\n    };\n\n    const childStages: Record<string, unknown> = {};\n    if (context.children) {\n      for (const childCtx of context.children) {\n        const snapshot = childCtx.getSnapshot();\n        childStages[snapshot.name || snapshot.id] = {\n          name: snapshot.name,\n          output: snapshot.logs,\n          errors: snapshot.errors,\n          metrics: snapshot.metrics,\n          status: snapshot.errors && Object.keys(snapshot.errors).length > 0 ? 'error' : 'success',\n        };\n      }\n    }\n\n    this.subflowResults.set(node.id, {\n      subflowId: node.id,\n      subflowName: node.name,\n      treeContext: {\n        globalContext: {},\n        stageContexts: childStages as unknown as Record<string, unknown>,\n        history: [],\n      },\n      parentStageId,\n      pipelineStructure: childStructure,\n    });\n  }\n\n  private autoRegisterSubflowDef(\n    subflowId: string,\n    subflowDef: NonNullable<StageNode['subflowDef']>,\n    mountNodeId?: string,\n  ): void {\n    let subflowsDict = this.subflows;\n    if (!subflowsDict) {\n      subflowsDict = {};\n      this.subflows = subflowsDict;\n    }\n\n    // First-write-wins\n    const isNewRegistration = !subflowsDict[subflowId];\n    if (isNewRegistration) {\n      subflowsDict[subflowId] = {\n        root: subflowDef.root as StageNode<TOut, TScope>,\n        ...(subflowDef.buildTimeStructure ? { buildTimeStructure: subflowDef.buildTimeStructure } : {}),\n      } as any;\n    }\n\n    // Merge stageMap entries (parent entries preserved)\n    if (subflowDef.stageMap) {\n      for (const [key, fn] of Array.from(subflowDef.stageMap.entries())) {\n        if (!this.stageMap.has(key)) {\n          this.stageMap.set(key, fn as StageFunction<TOut, TScope>);\n        }\n      }\n    }\n\n    // Merge nested subflows\n    if (subflowDef.subflows) {\n      for (const [key, def] of Object.entries(subflowDef.subflows)) {\n        if (!subflowsDict[key]) {\n          subflowsDict[key] = def as { root: StageNode<TOut, TScope> };\n        }\n      }\n    }\n\n    if (mountNodeId) {\n      this.structureManager.updateDynamicSubflow(\n        mountNodeId,\n        subflowId,\n        subflowDef.root?.subflowName || subflowDef.root?.name,\n        subflowDef.buildTimeStructure,\n      );\n    }\n\n    // Notify FlowRecorders only on first registration (matches first-write-wins)\n    if (isNewRegistration) {\n      const subflowName = subflowDef.root?.subflowName || subflowDef.root?.name || subflowId;\n      this.narrativeGenerator.onSubflowRegistered(\n        subflowId,\n        subflowName,\n        subflowDef.root?.description,\n        subflowDef.buildTimeStructure,\n      );\n    }\n  }\n}\n"]}
@@ -13,4 +13,4 @@ export const defaultLogger = {
13
13
  error: (message, ...args) => console.error(message, ...args),
14
14
  warn: (message, ...args) => console.warn(message, ...args),
15
15
  };
16
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/lib/engine/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAuBH,oCAAoC;AACpC,wDAAwD;AACxD,MAAM,CAAC,MAAM,aAAa,GAAY;IACpC,IAAI,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;IACvE,GAAG,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;IACrE,KAAK,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;IACzE,KAAK,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;IACzE,IAAI,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;CACxE,CAAC","sourcesContent":["/**\n * types.ts — All type definitions for the engine library.\n *\n * Centralizes type definitions to avoid circular dependencies.\n * Every handler receives HandlerDeps (the DI bag) instead of importing the traverser.\n */\n\nimport type { StageContext } from '../memory/StageContext';\nimport type { ScopeProtectionMode } from '../scope/protection/types';\nimport type { Decider, Selector, StageNode } from './graph/StageNode';\nimport type { IControlFlowNarrative } from './narrative/types';\n\n// Re-export StageNode types for convenience\nexport type { Decider, Selector, StageNode } from './graph/StageNode';\n\n// ---------------------------------------------------------------------------\n// Logger\n// ---------------------------------------------------------------------------\n\n/** Minimal logging contract. Mirrors Console API subset. */\nexport interface ILogger {\n  info(message?: any, ...optionalParams: any[]): void;\n  log(message?: any, ...optionalParams: any[]): void;\n  debug(message?: any, ...optionalParams: any[]): void;\n  error(message?: any, ...optionalParams: any[]): void;\n  warn(message?: any, ...optionalParams: any[]): void;\n}\n\n/** Default console-based logger. */\n/* istanbul ignore next -- trivial console delegation */\nexport const defaultLogger: ILogger = {\n  info: (message?: any, ...args: any[]) => console.info(message, ...args),\n  log: (message?: any, ...args: any[]) => console.log(message, ...args),\n  debug: (message?: any, ...args: any[]) => console.debug(message, ...args),\n  error: (message?: any, ...args: any[]) => console.error(message, ...args),\n  warn: (message?: any, ...args: any[]) => console.warn(message, ...args),\n};\n\n// ---------------------------------------------------------------------------\n// Stage Function\n// ---------------------------------------------------------------------------\n\n/** Callback that receives tokens during streaming. */\nexport type StreamCallback = (token: string) => void;\n\n/**\n * The function signature for stage handlers.\n * - TOut: return type produced by the stage\n * - TScope: the scope object passed to the stage\n * - Optional 3rd parameter `streamCallback` injected for streaming stages.\n */\nexport type StageFunction<TOut = any, TScope = any> = (\n  scope: TScope,\n  breakPipeline: () => void,\n  streamCallback?: StreamCallback,\n) => Promise<TOut> | TOut;\n\n/** Factory that creates a scope instance for each stage. */\nexport type ScopeFactory<TScope = any> = (\n  context: StageContext,\n  stageName: string,\n  readOnlyContext?: unknown,\n) => TScope;\n\n// ---------------------------------------------------------------------------\n// Streaming\n// ---------------------------------------------------------------------------\n\nexport type StreamTokenHandler = (streamId: string, token: string) => void;\nexport type StreamLifecycleHandler = (streamId: string, fullText?: string) => void;\n\nexport interface StreamHandlers {\n  onToken?: StreamTokenHandler;\n  onStart?: StreamLifecycleHandler;\n  onEnd?: StreamLifecycleHandler;\n}\n\n// ---------------------------------------------------------------------------\n// Subflow\n// ---------------------------------------------------------------------------\n\nexport interface SubflowMountOptions<TParentScope = any, TSubflowInput = any, TSubflowOutput = any> {\n  inputMapper?: (parentScope: TParentScope) => TSubflowInput;\n  outputMapper?: (subflowOutput: TSubflowOutput, parentScope: TParentScope) => Record<string, unknown>;\n}\n\nexport interface SubflowResult {\n  subflowId: string;\n  subflowName: string;\n  treeContext: {\n    globalContext: Record<string, unknown>;\n    stageContexts: Record<string, unknown>;\n    history: unknown[];\n  };\n  parentStageId: string;\n  pipelineStructure?: unknown;\n}\n\n// ---------------------------------------------------------------------------\n// Execution Runtime Interface\n// ---------------------------------------------------------------------------\n\n/**\n * IExecutionRuntime — Interface for the runtime environment.\n *\n * Defines the contract that engine handlers need from the runner layer,\n * avoiding circular imports between engine/ and runner/.\n */\nexport interface IExecutionRuntime {\n  globalStore: { getState(): Record<string, unknown> };\n  rootStageContext: StageContext;\n  executionHistory: { list(): unknown[] };\n  getSnapshot(): {\n    sharedState: Record<string, unknown>;\n    executionTree: unknown;\n    commitLog: unknown[];\n    subflowResults?: Record<string, unknown>;\n  };\n  setRootObject(path: string[], key: string, value: unknown): void;\n  getPipelines(): string[];\n}\n\n// ---------------------------------------------------------------------------\n// Handler Dependencies (DI bag) — was PipelineContext\n// ---------------------------------------------------------------------------\n\n/**\n * HandlerDeps — Dependency injection bag passed to all handler modules.\n *\n * Provides shared state (stageMap, runtime, scopeFactory, etc.) without\n * handlers needing to import the traverser directly. Avoids circular deps.\n */\nexport interface HandlerDeps<TOut = any, TScope = any> {\n  stageMap: Map<string, StageFunction<TOut, TScope>>;\n  root: StageNode<TOut, TScope>;\n  executionRuntime: IExecutionRuntime;\n  ScopeFactory: ScopeFactory<TScope>;\n  subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  throttlingErrorChecker?: (error: unknown) => boolean;\n  streamHandlers?: StreamHandlers;\n  scopeProtectionMode: ScopeProtectionMode;\n  readOnlyContext?: unknown;\n  narrativeGenerator: IControlFlowNarrative;\n  logger: ILogger;\n  signal?: AbortSignal;\n}\n\n/** Options for FlowChartExecutor.run(). */\nexport interface RunOptions {\n  /** AbortSignal for cooperative cancellation. */\n  signal?: AbortSignal;\n  /** Timeout in milliseconds. Creates an internal AbortController. */\n  timeoutMs?: number;\n  /**\n   * Runtime input data for the pipeline.\n   * Becomes the readOnlyContext accessible via `scope.getArgs()`.\n   * Stages cannot overwrite these keys with `setValue()`.\n   */\n  input?: Record<string, unknown>;\n}\n\n// ---------------------------------------------------------------------------\n// Flow Control Narrative\n// ---------------------------------------------------------------------------\n\nexport type FlowControlType = 'next' | 'branch' | 'children' | 'selected' | 'subflow' | 'loop';\n\nexport interface FlowMessage {\n  type: FlowControlType;\n  description: string;\n  targetStage?: string | string[];\n  rationale?: string;\n  count?: number;\n  iteration?: number;\n  timestamp?: number;\n}\n\n// ---------------------------------------------------------------------------\n// Traversal Extractor\n// ---------------------------------------------------------------------------\n\nexport interface RuntimeStructureMetadata {\n  type: 'stage' | 'decider' | 'fork' | 'streaming';\n  subflowId?: string;\n  isSubflowRoot?: boolean;\n  subflowName?: string;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  loopTarget?: string;\n  isDynamic?: boolean;\n  isLoopReference?: boolean;\n  streamId?: string;\n}\n\nexport interface StageSnapshot<TOut = any, TScope = any> {\n  node: StageNode<TOut, TScope>;\n  context: StageContext;\n  stepNumber: number;\n  structureMetadata: RuntimeStructureMetadata;\n  scopeState?: Record<string, unknown>;\n  debugInfo?: {\n    logs: Record<string, unknown>;\n    errors: Record<string, unknown>;\n    metrics: Record<string, unknown>;\n    evals: Record<string, unknown>;\n    flowMessages?: FlowMessage[];\n  };\n  stageOutput?: unknown;\n  errorInfo?: { type: string; message: string };\n  historyIndex?: number;\n}\n\nexport type TraversalExtractor<TResult = unknown> = (snapshot: StageSnapshot) => TResult | undefined | null;\n\nexport interface ExtractorError {\n  stagePath: string;\n  message: string;\n  error: unknown;\n}\n\n// ---------------------------------------------------------------------------\n// Node Result\n// ---------------------------------------------------------------------------\n\nexport type NodeResultType = {\n  id: string;\n  result: unknown;\n  isError?: boolean;\n};\n\n// ---------------------------------------------------------------------------\n// Execution Response\n// ---------------------------------------------------------------------------\n\nexport type BranchResult = {\n  result: string | Error;\n  isError: boolean;\n};\n\nexport type BranchResults = { [branchId: string]: BranchResult };\nexport type TraversalResult = BranchResults | string | Error;\n\n// ---------------------------------------------------------------------------\n// Serialized Pipeline Structure (for visualization)\n// ---------------------------------------------------------------------------\n\nexport interface SerializedPipelineNode {\n  name: string;\n  id?: string;\n  type?: 'stage' | 'decider' | 'fork' | 'streaming' | 'loop' | 'user' | 'tool' | 'function' | 'sequence';\n  description?: string;\n  children?: SerializedPipelineNode[];\n  next?: SerializedPipelineNode;\n  branches?: Record<string, SerializedPipelineNode>;\n  hasDecider?: boolean;\n  hasSelector?: boolean;\n  hasSubtree?: boolean;\n  isStreaming?: boolean;\n  streamId?: string;\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n  loopTarget?: string;\n  isLoopReference?: boolean;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  isDynamic?: boolean;\n}\n\n// ---------------------------------------------------------------------------\n// FlowChart (compiled output of FlowChartBuilder)\n// ---------------------------------------------------------------------------\n\nexport type FlowChart<TOut = any, TScope = any> = {\n  root: StageNode<TOut, TScope>;\n  stageMap: Map<string, StageFunction<TOut, TScope>>;\n  extractor?: TraversalExtractor;\n  subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  enrichSnapshots?: boolean;\n  enableNarrative?: boolean;\n  logger?: ILogger;\n  buildTimeStructure?: SerializedPipelineStructure;\n  /** Input schema (Zod or JSON Schema) — used for runtime input validation. */\n  inputSchema?: unknown;\n};\n\n/** Alias for SerializedPipelineNode used as full structure */\nexport type SerializedPipelineStructure = SerializedPipelineNode & {\n  branchIds?: string[];\n  subflowStructure?: SerializedPipelineStructure;\n  iterationCount?: number;\n};\n"]}
16
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/lib/engine/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAuBH,oCAAoC;AACpC,wDAAwD;AACxD,MAAM,CAAC,MAAM,aAAa,GAAY;IACpC,IAAI,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;IACvE,GAAG,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;IACrE,KAAK,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;IACzE,KAAK,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;IACzE,IAAI,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;CACxE,CAAC","sourcesContent":["/**\n * types.ts — All type definitions for the engine library.\n *\n * Centralizes type definitions to avoid circular dependencies.\n * Every handler receives HandlerDeps (the DI bag) instead of importing the traverser.\n */\n\nimport type { StageContext } from '../memory/StageContext';\nimport type { ScopeProtectionMode } from '../scope/protection/types';\nimport type { Decider, Selector, StageNode } from './graph/StageNode';\nimport type { IControlFlowNarrative } from './narrative/types';\n\n// Re-export StageNode types for convenience\nexport type { Decider, Selector, StageNode } from './graph/StageNode';\n\n// ---------------------------------------------------------------------------\n// Logger\n// ---------------------------------------------------------------------------\n\n/** Minimal logging contract. Mirrors Console API subset. */\nexport interface ILogger {\n  info(message?: any, ...optionalParams: any[]): void;\n  log(message?: any, ...optionalParams: any[]): void;\n  debug(message?: any, ...optionalParams: any[]): void;\n  error(message?: any, ...optionalParams: any[]): void;\n  warn(message?: any, ...optionalParams: any[]): void;\n}\n\n/** Default console-based logger. */\n/* istanbul ignore next -- trivial console delegation */\nexport const defaultLogger: ILogger = {\n  info: (message?: any, ...args: any[]) => console.info(message, ...args),\n  log: (message?: any, ...args: any[]) => console.log(message, ...args),\n  debug: (message?: any, ...args: any[]) => console.debug(message, ...args),\n  error: (message?: any, ...args: any[]) => console.error(message, ...args),\n  warn: (message?: any, ...args: any[]) => console.warn(message, ...args),\n};\n\n// ---------------------------------------------------------------------------\n// Stage Function\n// ---------------------------------------------------------------------------\n\n/** Callback that receives tokens during streaming. */\nexport type StreamCallback = (token: string) => void;\n\n/**\n * The function signature for stage handlers.\n * - TOut: return type produced by the stage\n * - TScope: the scope object passed to the stage\n * - Optional 3rd parameter `streamCallback` injected for streaming stages.\n */\nexport type StageFunction<TOut = any, TScope = any> = (\n  scope: TScope,\n  breakPipeline: () => void,\n  streamCallback?: StreamCallback,\n) => Promise<TOut> | TOut;\n\n/** Factory that creates a scope instance for each stage. */\nexport type ScopeFactory<TScope = any> = (\n  context: StageContext,\n  stageName: string,\n  readOnlyContext?: unknown,\n  executionEnv?: ExecutionEnv,\n) => TScope;\n\n// ---------------------------------------------------------------------------\n// Streaming\n// ---------------------------------------------------------------------------\n\nexport type StreamTokenHandler = (streamId: string, token: string) => void;\nexport type StreamLifecycleHandler = (streamId: string, fullText?: string) => void;\n\nexport interface StreamHandlers {\n  onToken?: StreamTokenHandler;\n  onStart?: StreamLifecycleHandler;\n  onEnd?: StreamLifecycleHandler;\n}\n\n// ---------------------------------------------------------------------------\n// Subflow\n// ---------------------------------------------------------------------------\n\nexport interface SubflowMountOptions<TParentScope = any, TSubflowInput = any, TSubflowOutput = any> {\n  inputMapper?: (parentScope: TParentScope) => TSubflowInput;\n  outputMapper?: (subflowOutput: TSubflowOutput, parentScope: TParentScope) => Record<string, unknown>;\n}\n\nexport interface SubflowResult {\n  subflowId: string;\n  subflowName: string;\n  treeContext: {\n    globalContext: Record<string, unknown>;\n    stageContexts: Record<string, unknown>;\n    history: unknown[];\n  };\n  parentStageId: string;\n  pipelineStructure?: unknown;\n}\n\n// ---------------------------------------------------------------------------\n// Execution Runtime Interface\n// ---------------------------------------------------------------------------\n\n/**\n * IExecutionRuntime — Interface for the runtime environment.\n *\n * Defines the contract that engine handlers need from the runner layer,\n * avoiding circular imports between engine/ and runner/.\n */\nexport interface IExecutionRuntime {\n  globalStore: { getState(): Record<string, unknown> };\n  rootStageContext: StageContext;\n  executionHistory: { list(): unknown[] };\n  getSnapshot(): {\n    sharedState: Record<string, unknown>;\n    executionTree: unknown;\n    commitLog: unknown[];\n    subflowResults?: Record<string, unknown>;\n  };\n  setRootObject(path: string[], key: string, value: unknown): void;\n  getPipelines(): string[];\n}\n\n// ---------------------------------------------------------------------------\n// Execution Environment — read-only, propagates through nested executors\n// ---------------------------------------------------------------------------\n\n/**\n * ExecutionEnv — infrastructure values that propagate through nested executors.\n *\n * Like `process.env` for flowcharts: read-only, inherited by child executors,\n * infrastructure-only (not business logic).\n *\n * Litmus test: Created external to the flowchart + passed in for execution = env.\n * Business config for a specific flowchart = args (getArgs()).\n *\n * Intentionally a closed type — not extensible to prevent coupling between\n * parent and child flowcharts.\n */\nexport interface ExecutionEnv {\n  /** AbortSignal for cooperative cancellation across nested executors. */\n  readonly signal?: AbortSignal;\n  /** Timeout budget in milliseconds. */\n  readonly timeoutMs?: number;\n  /** Trace identifier for distributed tracing / observability. */\n  readonly traceId?: string;\n}\n\n// ---------------------------------------------------------------------------\n// Handler Dependencies (DI bag) — was PipelineContext\n// ---------------------------------------------------------------------------\n\n/**\n * HandlerDeps — Dependency injection bag passed to all handler modules.\n *\n * Provides shared state (stageMap, runtime, scopeFactory, etc.) without\n * handlers needing to import the traverser directly. Avoids circular deps.\n */\nexport interface HandlerDeps<TOut = any, TScope = any> {\n  stageMap: Map<string, StageFunction<TOut, TScope>>;\n  root: StageNode<TOut, TScope>;\n  executionRuntime: IExecutionRuntime;\n  ScopeFactory: ScopeFactory<TScope>;\n  subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  throttlingErrorChecker?: (error: unknown) => boolean;\n  streamHandlers?: StreamHandlers;\n  scopeProtectionMode: ScopeProtectionMode;\n  readOnlyContext?: unknown;\n  /** Execution environment — propagates to subflows automatically. */\n  executionEnv?: ExecutionEnv;\n  narrativeGenerator: IControlFlowNarrative;\n  logger: ILogger;\n  signal?: AbortSignal;\n}\n\n/** Options for FlowChartExecutor.run(). */\nexport interface RunOptions {\n  /** AbortSignal for cooperative cancellation. */\n  signal?: AbortSignal;\n  /** Timeout in milliseconds. Creates an internal AbortController. */\n  timeoutMs?: number;\n  /**\n   * Runtime input data for the pipeline.\n   * Becomes the readOnlyContext accessible via `scope.getArgs()`.\n   * Stages cannot overwrite these keys with `setValue()`.\n   */\n  input?: Record<string, unknown>;\n  /**\n   * Execution environment — read-only infrastructure values that propagate\n   * through nested executors (like `process.env` for flowcharts).\n   * Accessible via `scope.getEnv()`. Inherited by subflows automatically.\n   */\n  env?: ExecutionEnv;\n}\n\n// ---------------------------------------------------------------------------\n// Flow Control Narrative\n// ---------------------------------------------------------------------------\n\nexport type FlowControlType = 'next' | 'branch' | 'children' | 'selected' | 'subflow' | 'loop';\n\nexport interface FlowMessage {\n  type: FlowControlType;\n  description: string;\n  targetStage?: string | string[];\n  rationale?: string;\n  count?: number;\n  iteration?: number;\n  timestamp?: number;\n}\n\n// ---------------------------------------------------------------------------\n// Traversal Extractor\n// ---------------------------------------------------------------------------\n\nexport interface RuntimeStructureMetadata {\n  type: 'stage' | 'decider' | 'fork' | 'streaming';\n  subflowId?: string;\n  isSubflowRoot?: boolean;\n  subflowName?: string;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  loopTarget?: string;\n  isDynamic?: boolean;\n  isLoopReference?: boolean;\n  streamId?: string;\n}\n\nexport interface StageSnapshot<TOut = any, TScope = any> {\n  node: StageNode<TOut, TScope>;\n  context: StageContext;\n  stepNumber: number;\n  structureMetadata: RuntimeStructureMetadata;\n  scopeState?: Record<string, unknown>;\n  debugInfo?: {\n    logs: Record<string, unknown>;\n    errors: Record<string, unknown>;\n    metrics: Record<string, unknown>;\n    evals: Record<string, unknown>;\n    flowMessages?: FlowMessage[];\n  };\n  stageOutput?: unknown;\n  errorInfo?: { type: string; message: string };\n  historyIndex?: number;\n}\n\nexport type TraversalExtractor<TResult = unknown> = (snapshot: StageSnapshot) => TResult | undefined | null;\n\nexport interface ExtractorError {\n  stagePath: string;\n  message: string;\n  error: unknown;\n}\n\n// ---------------------------------------------------------------------------\n// Node Result\n// ---------------------------------------------------------------------------\n\nexport type NodeResultType = {\n  id: string;\n  result: unknown;\n  isError?: boolean;\n};\n\n// ---------------------------------------------------------------------------\n// Execution Response\n// ---------------------------------------------------------------------------\n\nexport type BranchResult = {\n  result: string | Error;\n  isError: boolean;\n};\n\nexport type BranchResults = { [branchId: string]: BranchResult };\nexport type TraversalResult = BranchResults | string | Error;\n\n// ---------------------------------------------------------------------------\n// Serialized Pipeline Structure (for visualization)\n// ---------------------------------------------------------------------------\n\nexport interface SerializedPipelineNode {\n  name: string;\n  id?: string;\n  type?: 'stage' | 'decider' | 'fork' | 'streaming' | 'loop' | 'user' | 'tool' | 'function' | 'sequence';\n  description?: string;\n  children?: SerializedPipelineNode[];\n  next?: SerializedPipelineNode;\n  branches?: Record<string, SerializedPipelineNode>;\n  hasDecider?: boolean;\n  hasSelector?: boolean;\n  hasSubtree?: boolean;\n  isStreaming?: boolean;\n  streamId?: string;\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n  loopTarget?: string;\n  isLoopReference?: boolean;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  isDynamic?: boolean;\n}\n\n// ---------------------------------------------------------------------------\n// FlowChart (compiled output of FlowChartBuilder)\n// ---------------------------------------------------------------------------\n\nexport type FlowChart<TOut = any, TScope = any> = {\n  root: StageNode<TOut, TScope>;\n  stageMap: Map<string, StageFunction<TOut, TScope>>;\n  extractor?: TraversalExtractor;\n  subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  enrichSnapshots?: boolean;\n  enableNarrative?: boolean;\n  logger?: ILogger;\n  buildTimeStructure?: SerializedPipelineStructure;\n  /** Input schema (Zod or JSON Schema) — used for runtime input validation. */\n  inputSchema?: unknown;\n};\n\n/** Alias for SerializedPipelineNode used as full structure */\nexport type SerializedPipelineStructure = SerializedPipelineNode & {\n  branchIds?: string[];\n  subflowStructure?: SerializedPipelineStructure;\n  iterationCount?: number;\n};\n"]}