footprintjs 4.0.5 → 4.2.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.
Files changed (61) hide show
  1. package/CLAUDE.md +7 -0
  2. package/dist/esm/index.js +6 -1
  3. package/dist/esm/lib/builder/FlowChartBuilder.js +13 -8
  4. package/dist/esm/lib/engine/graph/StageNode.js +1 -1
  5. package/dist/esm/lib/engine/handlers/DeciderHandler.js +8 -7
  6. package/dist/esm/lib/engine/handlers/SelectorHandler.js +8 -5
  7. package/dist/esm/lib/engine/handlers/SubflowExecutor.js +28 -246
  8. package/dist/esm/lib/engine/narrative/CombinedNarrativeRecorder.js +232 -139
  9. package/dist/esm/lib/engine/narrative/index.js +1 -1
  10. package/dist/esm/lib/engine/narrative/narrativeTypes.js +1 -1
  11. package/dist/esm/lib/engine/traversal/FlowchartTraverser.js +64 -22
  12. package/dist/esm/lib/engine/types.js +1 -1
  13. package/dist/esm/lib/memory/StageContext.js +36 -9
  14. package/dist/esm/lib/reactive/createTypedScope.js +9 -6
  15. package/dist/esm/lib/reactive/types.js +1 -1
  16. package/dist/esm/lib/recorder/CompositeRecorder.js +172 -0
  17. package/dist/esm/lib/recorder/index.js +2 -0
  18. package/dist/esm/lib/runner/FlowChartExecutor.js +33 -3
  19. package/dist/esm/lib/scope/ScopeFacade.js +52 -4
  20. package/dist/esm/lib/scope/recorders/DebugRecorder.js +18 -2
  21. package/dist/esm/lib/scope/recorders/MetricRecorder.js +51 -4
  22. package/dist/esm/recorders.js +6 -5
  23. package/dist/index.js +21 -15
  24. package/dist/lib/builder/FlowChartBuilder.js +13 -8
  25. package/dist/lib/engine/graph/StageNode.js +1 -1
  26. package/dist/lib/engine/handlers/DeciderHandler.js +8 -7
  27. package/dist/lib/engine/handlers/SelectorHandler.js +8 -5
  28. package/dist/lib/engine/handlers/SubflowExecutor.js +27 -245
  29. package/dist/lib/engine/narrative/CombinedNarrativeRecorder.js +232 -139
  30. package/dist/lib/engine/narrative/index.js +1 -1
  31. package/dist/lib/engine/narrative/narrativeTypes.js +1 -1
  32. package/dist/lib/engine/traversal/FlowchartTraverser.js +64 -22
  33. package/dist/lib/engine/types.js +1 -1
  34. package/dist/lib/memory/StageContext.js +36 -9
  35. package/dist/lib/reactive/createTypedScope.js +9 -6
  36. package/dist/lib/reactive/types.js +1 -1
  37. package/dist/lib/recorder/CompositeRecorder.js +176 -0
  38. package/dist/lib/recorder/index.js +6 -0
  39. package/dist/lib/runner/FlowChartExecutor.js +33 -3
  40. package/dist/lib/scope/ScopeFacade.js +52 -4
  41. package/dist/lib/scope/recorders/DebugRecorder.js +18 -2
  42. package/dist/lib/scope/recorders/MetricRecorder.js +51 -4
  43. package/dist/recorders.js +8 -6
  44. package/dist/types/index.d.ts +4 -0
  45. package/dist/types/lib/engine/graph/StageNode.d.ts +4 -0
  46. package/dist/types/lib/engine/handlers/SubflowExecutor.d.ts +10 -29
  47. package/dist/types/lib/engine/narrative/CombinedNarrativeRecorder.d.ts +18 -1
  48. package/dist/types/lib/engine/narrative/index.d.ts +1 -1
  49. package/dist/types/lib/engine/narrative/narrativeTypes.d.ts +92 -0
  50. package/dist/types/lib/engine/traversal/FlowchartTraverser.d.ts +20 -8
  51. package/dist/types/lib/engine/types.d.ts +51 -0
  52. package/dist/types/lib/memory/StageContext.d.ts +14 -3
  53. package/dist/types/lib/reactive/types.d.ts +2 -0
  54. package/dist/types/lib/recorder/CompositeRecorder.d.ts +95 -0
  55. package/dist/types/lib/recorder/index.d.ts +2 -0
  56. package/dist/types/lib/runner/FlowChartExecutor.d.ts +27 -1
  57. package/dist/types/lib/scope/ScopeFacade.d.ts +11 -0
  58. package/dist/types/lib/scope/recorders/DebugRecorder.d.ts +16 -0
  59. package/dist/types/lib/scope/recorders/MetricRecorder.d.ts +47 -2
  60. package/dist/types/recorders.d.ts +9 -4
  61. package/package.json +1 -1
@@ -1,33 +1,29 @@
1
1
  /**
2
- * SubflowExecutor — Isolated recursive execution with I/O mapping.
2
+ * SubflowExecutor — Isolation boundary for subflow execution.
3
3
  *
4
4
  * Responsibilities:
5
- * - Execute subflows with isolated ExecutionRuntime contexts
5
+ * - Create isolated ExecutionRuntime for each subflow
6
6
  * - Apply input/output mapping via SubflowInputMapper
7
- * - Handle nested subflow detection and delegation
7
+ * - Delegate traversal to a factory-created FlowchartTraverser
8
8
  * - Track subflow results for debugging/visualization
9
9
  *
10
10
  * Each subflow gets its own GlobalStore for isolation.
11
- * The subflow's `next` chain after children is NOT executed inside —
12
- * the parent's executeNode continues with node.next after return.
11
+ * Traversal uses the SAME 7-phase algorithm as the top-level traverser
12
+ * (via SubflowTraverserFactory), so deciders, selectors, loops, lazy subflows,
13
+ * and abort signals all work inside subflows automatically.
13
14
  */
14
- import { isStageNodeReturn } from '../graph/StageNode.js';
15
- import { StageRunner } from './StageRunner.js';
16
- import { applyOutputMapping, createSubflowHandlerDeps, getInitialScopeValues, seedSubflowGlobalStore, } from './SubflowInputMapper.js';
15
+ import { applyOutputMapping, getInitialScopeValues, seedSubflowGlobalStore } from './SubflowInputMapper.js';
17
16
  export class SubflowExecutor {
18
- constructor(deps, nodeResolver, executeStage, callExtractor, getStageFn) {
17
+ constructor(deps, traverserFactory) {
19
18
  this.deps = deps;
20
- this.nodeResolver = nodeResolver;
21
- this.executeStage = executeStage;
22
- this.callExtractor = callExtractor;
23
- this.getStageFn = getStageFn;
19
+ this.traverserFactory = traverserFactory;
24
20
  }
25
21
  /**
26
22
  * Execute a subflow with isolated context.
27
23
  *
28
24
  * 1. Creates a fresh ExecutionRuntime for the subflow
29
25
  * 2. Applies input mapping to seed the subflow's GlobalStore
30
- * 3. Executes the subflow's internal structure
26
+ * 3. Delegates traversal to a factory-created FlowchartTraverser
31
27
  * 4. Applies output mapping to write results back to parent scope
32
28
  * 5. Stores execution data for debugging/visualization
33
29
  */
@@ -68,38 +64,38 @@ export class SubflowExecutor {
68
64
  nestedRootContext = new StageContextClass('', nestedRootContext.stageName, nestedRootContext.stageId, nestedRuntime.globalStore, '', nestedRuntime.executionHistory);
69
65
  nestedRuntime.rootStageContext = nestedRootContext;
70
66
  }
71
- // Create subflow HandlerDeps
72
- const subflowDeps = createSubflowHandlerDeps(this.deps, nestedRuntime, mappedInput);
73
- const subflowBreakFlag = { shouldBreak: false };
67
+ // Prepare subflow root node — strip isSubflowRoot to prevent re-delegation
74
68
  const hasChildren = Boolean(node.children && node.children.length > 0);
75
69
  const subflowNode = {
76
70
  ...node,
77
71
  isSubflowRoot: false,
78
72
  next: hasChildren ? undefined : node.next,
79
73
  };
74
+ // ─── Execute via factory traverser ───
75
+ // The factory creates a full FlowchartTraverser with the same 7-phase algorithm,
76
+ // sharing the parent's stageMap, subflows dict, and narrative generator.
80
77
  let subflowOutput;
81
78
  let subflowError;
82
- // Save parent subflow state — nested executeSubflow() calls (from executeSubflowInternal's
83
- // nested subflow detection) would otherwise clobber these instance variables.
84
- const savedSubflowRoot = this.currentSubflowRoot;
85
- const savedSubflowDeps = this.currentSubflowDeps;
86
- const savedSubflowResultsMap = this.subflowResultsMap;
79
+ let traverserHandle;
87
80
  try {
88
- this.subflowResultsMap = subflowResultsMap;
89
- this.currentSubflowRoot = subflowNode;
90
- this.currentSubflowDeps = subflowDeps;
91
- subflowOutput = await this.executeSubflowInternal(subflowNode, nestedRootContext, subflowBreakFlag, subflowId);
81
+ traverserHandle = this.traverserFactory({
82
+ root: subflowNode,
83
+ executionRuntime: nestedRuntime,
84
+ readOnlyContext: mappedInput,
85
+ subflowId,
86
+ });
87
+ subflowOutput = await traverserHandle.execute();
92
88
  }
93
89
  catch (error) {
94
90
  subflowError = error;
95
91
  parentContext.addError('subflowError', error.toString());
96
92
  this.deps.logger.error(`Error in subflow (${subflowId}):`, { error });
97
93
  }
98
- finally {
99
- // Restore parent subflow state so continuation stages execute in the right context.
100
- this.currentSubflowRoot = savedSubflowRoot;
101
- this.currentSubflowDeps = savedSubflowDeps;
102
- this.subflowResultsMap = savedSubflowResultsMap;
94
+ // Always merge nested subflow results (even on error — partial results aid debugging)
95
+ if (traverserHandle) {
96
+ for (const [key, value] of traverserHandle.getSubflowResults()) {
97
+ subflowResultsMap.set(key, value);
98
+ }
103
99
  }
104
100
  const subflowTreeContext = nestedRuntime.getSnapshot();
105
101
  // ─── Output Mapping ───
@@ -153,219 +149,5 @@ export class SubflowExecutor {
153
149
  }
154
150
  return subflowOutput;
155
151
  }
156
- /**
157
- * Internal execution within subflow context.
158
- * Mirrors the traverser's executeNode but within the subflow's isolated runtime.
159
- */
160
- async executeSubflowInternal(node, context, breakFlag, branchPath) {
161
- var _a, _b, _c, _d, _e;
162
- // Detect nested subflows
163
- if (node.isSubflowRoot && node.subflowId) {
164
- const resolvedNode = this.nodeResolver.resolveSubflowReference(node);
165
- const nestedOutput = await this.executeSubflow(resolvedNode, context, breakFlag, branchPath, this.subflowResultsMap);
166
- // Continue with node.next after nested subflow completes.
167
- // Without this, stages chained after an inner subflow mount are silently skipped.
168
- // Mirrors FlowchartTraverser.executeNode() which checks node.next after subflow return.
169
- if (node.next) {
170
- const nestedTraversalCtx = {
171
- stageId: (_a = node.id) !== null && _a !== void 0 ? _a : context.stageId,
172
- stageName: node.name,
173
- parentStageId: (_b = context.parent) === null || _b === void 0 ? void 0 : _b.stageId,
174
- subflowId: branchPath || undefined,
175
- subflowPath: branchPath || undefined,
176
- depth: this.computeContextDepth(context),
177
- };
178
- this.deps.narrativeGenerator.onNext(node.name, node.next.name, node.next.description, nestedTraversalCtx);
179
- const nextCtx = context.createNext('', node.next.name, node.next.id);
180
- return await this.executeSubflowInternal(node.next, nextCtx, breakFlag, branchPath);
181
- }
182
- return nestedOutput;
183
- }
184
- // Build traversal context for subflow stage events
185
- const traversalContext = {
186
- stageId: (_c = node.id) !== null && _c !== void 0 ? _c : context.stageId,
187
- stageName: node.name,
188
- parentStageId: (_d = context.parent) === null || _d === void 0 ? void 0 : _d.stageId,
189
- subflowId: branchPath || undefined,
190
- subflowPath: branchPath || undefined,
191
- depth: this.computeContextDepth(context),
192
- };
193
- const stageFunc = this.getStageFn(node);
194
- const breakFn = () => (breakFlag.shouldBreak = true);
195
- let stageOutput;
196
- if (stageFunc) {
197
- try {
198
- if (this.currentSubflowDeps) {
199
- const subflowStageRunner = new StageRunner(this.currentSubflowDeps);
200
- stageOutput = await subflowStageRunner.run(node, stageFunc, context, breakFn);
201
- }
202
- else {
203
- stageOutput = await this.executeStage(node, stageFunc, context, breakFn);
204
- }
205
- }
206
- catch (error) {
207
- context.commit();
208
- this.callExtractor(node, context, this.getStagePath(node, branchPath, context.stageName), undefined, {
209
- type: 'stageExecutionError',
210
- message: error.toString(),
211
- });
212
- context.addError('stageExecutionError', error.toString());
213
- this.deps.narrativeGenerator.onError(node.name, error.toString(), error, traversalContext);
214
- throw error;
215
- }
216
- context.commit();
217
- this.callExtractor(node, context, this.getStagePath(node, branchPath, context.stageName), stageOutput);
218
- this.deps.narrativeGenerator.onStageExecuted(node.name, node.description, traversalContext);
219
- if (breakFlag.shouldBreak) {
220
- this.deps.narrativeGenerator.onBreak(node.name, traversalContext);
221
- return stageOutput;
222
- }
223
- // Handle dynamic StageNode return
224
- if (stageOutput && typeof stageOutput === 'object' && isStageNodeReturn(stageOutput)) {
225
- const dynamicNode = stageOutput;
226
- context.addLog('isDynamic', true);
227
- context.addLog('dynamicPattern', 'StageNodeReturn');
228
- if (dynamicNode.children && dynamicNode.children.length > 0) {
229
- node.children = dynamicNode.children;
230
- context.addLog('dynamicChildCount', dynamicNode.children.length);
231
- context.addLog('dynamicChildIds', dynamicNode.children.map((c) => c.id));
232
- if (typeof dynamicNode.nextNodeSelector === 'function') {
233
- node.nextNodeSelector = dynamicNode.nextNodeSelector;
234
- context.addLog('hasSelector', true);
235
- }
236
- }
237
- if (dynamicNode.next) {
238
- node.next = dynamicNode.next;
239
- context.addLog('hasDynamicNext', true);
240
- const loopTargetId = dynamicNode.next.id;
241
- if (loopTargetId) {
242
- context.addLog('loopTarget', loopTargetId);
243
- }
244
- }
245
- stageOutput = undefined;
246
- }
247
- }
248
- // ─── Children dispatch ───
249
- const hasChildrenAfterStage = Boolean((_e = node.children) === null || _e === void 0 ? void 0 : _e.length);
250
- const hasNextAfterStage = Boolean(node.next);
251
- if (hasChildrenAfterStage) {
252
- if (node.nextNodeSelector) {
253
- const results = await this.executeSelectedChildrenInternal(node.nextNodeSelector, node.children, stageOutput, context, branchPath, breakFlag);
254
- if (!hasNextAfterStage)
255
- return results;
256
- }
257
- else {
258
- const results = await this.executeNodeChildrenInternal(node, context, branchPath, breakFlag);
259
- if (!hasNextAfterStage)
260
- return results;
261
- }
262
- }
263
- // ─── Linear next ───
264
- if (hasNextAfterStage) {
265
- let nextNode = node.next;
266
- // Resolve reference nodes (has id but no fn)
267
- if (nextNode.id && !nextNode.fn) {
268
- let resolvedNode;
269
- if (this.currentSubflowRoot) {
270
- resolvedNode = this.nodeResolver.findNodeById(nextNode.id, this.currentSubflowRoot);
271
- if (resolvedNode)
272
- context.addLog('dynamicNextResolvedFrom', 'subflow');
273
- }
274
- if (!resolvedNode) {
275
- resolvedNode = this.nodeResolver.findNodeById(nextNode.id);
276
- if (resolvedNode)
277
- context.addLog('dynamicNextResolvedFrom', 'mainPipeline');
278
- }
279
- if (resolvedNode) {
280
- nextNode = resolvedNode;
281
- context.addLog('dynamicNextResolved', true);
282
- context.addLog('dynamicNextTarget', nextNode.id);
283
- }
284
- else {
285
- this.deps.logger.info(`Dynamic next node '${nextNode.id}' not found in subflow or main pipeline`);
286
- context.addLog('dynamicNextResolved', false);
287
- context.addLog('dynamicNextNotFound', nextNode.id);
288
- }
289
- }
290
- this.deps.narrativeGenerator.onNext(node.name, nextNode.name, nextNode.description, traversalContext);
291
- const nextCtx = context.createNext('', nextNode.name, nextNode.id);
292
- return await this.executeSubflowInternal(nextNode, nextCtx, breakFlag, branchPath);
293
- }
294
- return stageOutput;
295
- }
296
- computeContextDepth(context) {
297
- let depth = 0;
298
- let current = context.parent;
299
- while (current) {
300
- depth++;
301
- current = current.parent;
302
- }
303
- return depth;
304
- }
305
- getStagePath(node, branchPath, contextStageName) {
306
- const baseName = node.id;
307
- const nodeId = contextStageName && contextStageName !== node.name ? contextStageName : baseName;
308
- if (!branchPath)
309
- return nodeId;
310
- return `${branchPath}.${nodeId}`;
311
- }
312
- async executeNodeChildrenInternal(node, context, branchPath, breakFlag) {
313
- var _a;
314
- const childPromises = ((_a = node.children) !== null && _a !== void 0 ? _a : []).map((child) => {
315
- const childContext = context.createChild('', child.id, child.name, child.id);
316
- const childBreakFlag = { shouldBreak: false };
317
- return this.executeSubflowInternal(child, childContext, childBreakFlag, branchPath)
318
- .then((result) => {
319
- childContext.commit();
320
- return { id: child.id, result, isError: false };
321
- })
322
- .catch((error) => {
323
- childContext.commit();
324
- this.deps.logger.info(`TREE PIPELINE: executeNodeChildrenInternal - Error for id: ${child === null || child === void 0 ? void 0 : child.id}`, { error });
325
- return { id: child.id, result: error, isError: true };
326
- });
327
- });
328
- const settled = await Promise.allSettled(childPromises);
329
- const childrenResults = {};
330
- settled.forEach((s) => {
331
- if (s.status === 'fulfilled') {
332
- const { id, result, isError } = s.value;
333
- childrenResults[id] = { id, result, isError };
334
- }
335
- else {
336
- this.deps.logger.error(`Execution failed: ${s.reason}`);
337
- }
338
- });
339
- return childrenResults;
340
- }
341
- async executeSelectedChildrenInternal(selector, children, input, context, branchPath, breakFlag) {
342
- const selectorResult = await selector(input);
343
- const selectedIds = Array.isArray(selectorResult) ? selectorResult : [selectorResult];
344
- context.addLog('selectedChildIds', selectedIds);
345
- context.addLog('selectorPattern', 'multi-choice');
346
- if (selectedIds.length === 0) {
347
- context.addLog('skippedAllChildren', true);
348
- return {};
349
- }
350
- const selectedChildren = children.filter((c) => selectedIds.includes(c.id));
351
- if (selectedChildren.length !== selectedIds.length) {
352
- const childIds = children.map((c) => c.id);
353
- const missing = selectedIds.filter((id) => !childIds.includes(id));
354
- const errorMessage = `Selector returned unknown child IDs: ${missing.join(', ')}. Available: ${childIds.join(', ')}`;
355
- this.deps.logger.error(`Error in subflow (${branchPath}):`, { error: errorMessage });
356
- context.addError('selectorError', errorMessage);
357
- throw new Error(errorMessage);
358
- }
359
- const skippedIds = children.filter((c) => !selectedIds.includes(c.id)).map((c) => c.id);
360
- if (skippedIds.length > 0) {
361
- context.addLog('skippedChildIds', skippedIds);
362
- }
363
- const tempNode = {
364
- name: 'selector-temp',
365
- id: 'selector-temp',
366
- children: selectedChildren,
367
- };
368
- return await this.executeNodeChildrenInternal(tempNode, context, branchPath, breakFlag);
369
- }
370
152
  }
371
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SubflowExecutor.js","sourceRoot":"","sources":["../../../../../src/lib/engine/handlers/SubflowExecutor.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * SubflowExecutor — Isolated recursive execution with I/O mapping.\n *\n * Responsibilities:\n * - Execute subflows with isolated ExecutionRuntime contexts\n * - Apply input/output mapping via SubflowInputMapper\n * - Handle nested subflow detection and delegation\n * - Track subflow results for debugging/visualization\n *\n * Each subflow gets its own GlobalStore for isolation.\n * The subflow's `next` chain after children is NOT executed inside —\n * the parent's executeNode continues with node.next after return.\n */\n\nimport type { StageContext } from '../../memory/StageContext.js';\nimport type { Selector, StageNode } from '../graph/StageNode.js';\nimport { isStageNodeReturn } from '../graph/StageNode.js';\nimport type { TraversalContext } from '../narrative/types.js';\nimport type { HandlerDeps, IExecutionRuntime, NodeResultType, StageFunction, SubflowResult } from '../types.js';\nimport type { NodeResolver } from './NodeResolver.js';\nimport { StageRunner } from './StageRunner.js';\nimport {\n  applyOutputMapping,\n  createSubflowHandlerDeps,\n  getInitialScopeValues,\n  seedSubflowGlobalStore,\n} from './SubflowInputMapper.js';\nimport type { CallExtractorFn, RunStageFn } from './types.js';\n\nexport type { CallExtractorFn, RunStageFn } from './types.js';\n\n/** Callback for getting a stage function from the stage map. */\nexport type GetStageFnFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n) => StageFunction<TOut, TScope> | undefined;\n\nexport class SubflowExecutor<TOut = any, TScope = any> {\n  private currentSubflowDeps?: HandlerDeps<TOut, TScope>;\n  private currentSubflowRoot?: StageNode<TOut, TScope>;\n  private subflowResultsMap?: Map<string, SubflowResult>;\n\n  constructor(\n    private deps: HandlerDeps<TOut, TScope>,\n    private nodeResolver: NodeResolver<TOut, TScope>,\n    private executeStage: RunStageFn<TOut, TScope>,\n    private callExtractor: CallExtractorFn<TOut, TScope>,\n    private getStageFn: GetStageFnFn<TOut, TScope>,\n  ) {}\n\n  /**\n   * Execute a subflow with isolated context.\n   *\n   * 1. Creates a fresh ExecutionRuntime for the subflow\n   * 2. Applies input mapping to seed the subflow's GlobalStore\n   * 3. Executes the subflow's internal structure\n   * 4. Applies output mapping to write results back to parent scope\n   * 5. Stores execution data for debugging/visualization\n   */\n  async executeSubflow(\n    node: StageNode<TOut, TScope>,\n    parentContext: StageContext,\n    breakFlag: { shouldBreak: boolean },\n    branchPath: string | undefined,\n    subflowResultsMap: Map<string, SubflowResult>,\n    parentTraversalContext?: TraversalContext,\n  ): Promise<any> {\n    const subflowId = node.subflowId!;\n    const subflowName = node.subflowName ?? node.name;\n\n    parentContext.addFlowDebugMessage('subflow', `Entering ${subflowName} subflow`, {\n      targetStage: subflowId,\n    });\n    this.deps.narrativeGenerator.onSubflowEntry(subflowName, subflowId, node.description, parentTraversalContext);\n\n    // ─── Input Mapping ───\n    const mountOptions = node.subflowMountOptions;\n    let mappedInput: Record<string, unknown> = {};\n\n    if (mountOptions) {\n      try {\n        const parentScope = parentContext.getScope();\n        mappedInput = getInitialScopeValues(parentScope, mountOptions);\n        if (Object.keys(mappedInput).length > 0) {\n          // mappedInput is captured in SubflowResult.treeContext for debugging\n        }\n      } catch (error: any) {\n        parentContext.addError('inputMapperError', error.toString());\n        this.deps.logger.error(`Error in inputMapper for subflow (${subflowId}):`, { error });\n        throw error;\n      }\n    }\n\n    // Create isolated runtime via dynamic construction (avoids circular import)\n    const ExecutionRuntimeClass = this.deps.executionRuntime.constructor as new (\n      name: string,\n      id: string,\n    ) => IExecutionRuntime;\n    const nestedRuntime = new ExecutionRuntimeClass(node.name, node.id);\n    let nestedRootContext = nestedRuntime.rootStageContext;\n\n    // Seed GlobalStore with input\n    if (Object.keys(mappedInput).length > 0) {\n      seedSubflowGlobalStore(nestedRuntime, mappedInput);\n      // Refresh rootStageContext so WriteBuffer sees committed data\n      const StageContextClass = nestedRootContext.constructor as new (...args: any[]) => StageContext;\n      nestedRootContext = new StageContextClass(\n        '',\n        nestedRootContext.stageName,\n        nestedRootContext.stageId,\n        nestedRuntime.globalStore,\n        '',\n        nestedRuntime.executionHistory,\n      );\n      nestedRuntime.rootStageContext = nestedRootContext;\n    }\n\n    // Create subflow HandlerDeps\n    const subflowDeps = createSubflowHandlerDeps(this.deps, nestedRuntime, mappedInput);\n\n    const subflowBreakFlag = { shouldBreak: false };\n\n    const hasChildren = Boolean(node.children && node.children.length > 0);\n    const subflowNode: StageNode<TOut, TScope> = {\n      ...node,\n      isSubflowRoot: false,\n      next: hasChildren ? undefined : node.next,\n    };\n\n    let subflowOutput: any;\n    let subflowError: Error | undefined;\n\n    // Save parent subflow state — nested executeSubflow() calls (from executeSubflowInternal's\n    // nested subflow detection) would otherwise clobber these instance variables.\n    const savedSubflowRoot = this.currentSubflowRoot;\n    const savedSubflowDeps = this.currentSubflowDeps;\n    const savedSubflowResultsMap = this.subflowResultsMap;\n\n    try {\n      this.subflowResultsMap = subflowResultsMap;\n      this.currentSubflowRoot = subflowNode;\n      this.currentSubflowDeps = subflowDeps;\n\n      subflowOutput = await this.executeSubflowInternal(subflowNode, nestedRootContext, subflowBreakFlag, subflowId);\n    } catch (error: any) {\n      subflowError = error;\n      parentContext.addError('subflowError', error.toString());\n      this.deps.logger.error(`Error in subflow (${subflowId}):`, { error });\n    } finally {\n      // Restore parent subflow state so continuation stages execute in the right context.\n      this.currentSubflowRoot = savedSubflowRoot;\n      this.currentSubflowDeps = savedSubflowDeps;\n      this.subflowResultsMap = savedSubflowResultsMap;\n    }\n\n    const subflowTreeContext = nestedRuntime.getSnapshot();\n\n    // ─── Output Mapping ───\n    if (!subflowError && mountOptions?.outputMapper) {\n      try {\n        let outputContext = parentContext;\n        if (parentContext.branchId && parentContext.branchId !== '' && parentContext.parent) {\n          outputContext = parentContext.parent;\n        }\n\n        const parentScope = outputContext.getScope();\n        // For TypedScope subflows, stage functions return void — fall back to a shallow clone\n        // of the subflow's shared state so outputMapper can access all scope values written\n        // during the subflow. We shallow-clone to avoid aliasing the live SharedMemory context.\n        // NOTE: the full scope is passed (not just declared outputs) — outputMapper must\n        // explicitly select what to propagate to the parent.\n        // Redaction: the subflow shares the parent's _redactedKeys Set (via the same ScopeFactory),\n        // so any key marked redacted in the subflow is already visible in the parent's scope.\n        // ScopeFacade.setValue checks _redactedKeys.has(key), so writes via outputMapper\n        // automatically inherit the subflow's dynamic redaction state.\n        const effectiveOutput = subflowOutput ?? { ...subflowTreeContext.sharedState };\n        const mappedOutput = applyOutputMapping(effectiveOutput, parentScope, outputContext, mountOptions);\n\n        outputContext.commit();\n      } catch (error: any) {\n        parentContext.addError('outputMapperError', error.toString());\n        this.deps.logger.error(`Error in outputMapper for subflow (${subflowId}):`, { error });\n      }\n    }\n\n    const subflowResult: SubflowResult = {\n      subflowId,\n      subflowName,\n      treeContext: {\n        globalContext: subflowTreeContext.sharedState,\n        stageContexts: subflowTreeContext.executionTree as unknown as Record<string, unknown>,\n        history: subflowTreeContext.commitLog,\n      },\n      parentStageId: parentContext.getStageId(),\n    };\n\n    const subflowDef = this.deps.subflows?.[subflowId];\n    if (subflowDef && (subflowDef as any).buildTimeStructure) {\n      subflowResult.pipelineStructure = (subflowDef as any).buildTimeStructure;\n    }\n\n    subflowResultsMap.set(subflowId, subflowResult);\n\n    parentContext.addFlowDebugMessage('subflow', `Exiting ${subflowName} subflow`, {\n      targetStage: subflowId,\n    });\n    this.deps.narrativeGenerator.onSubflowExit(subflowName, subflowId, parentTraversalContext);\n\n    parentContext.commit();\n\n    if (subflowError) {\n      throw subflowError;\n    }\n\n    return subflowOutput;\n  }\n\n  /**\n   * Internal execution within subflow context.\n   * Mirrors the traverser's executeNode but within the subflow's isolated runtime.\n   */\n  private async executeSubflowInternal(\n    node: StageNode<TOut, TScope>,\n    context: StageContext,\n    breakFlag: { shouldBreak: boolean },\n    branchPath: string,\n  ): Promise<any> {\n    // Detect nested subflows\n    if (node.isSubflowRoot && node.subflowId) {\n      const resolvedNode = this.nodeResolver.resolveSubflowReference(node);\n      const nestedOutput = await this.executeSubflow(\n        resolvedNode,\n        context,\n        breakFlag,\n        branchPath,\n        this.subflowResultsMap!,\n      );\n\n      // Continue with node.next after nested subflow completes.\n      // Without this, stages chained after an inner subflow mount are silently skipped.\n      // Mirrors FlowchartTraverser.executeNode() which checks node.next after subflow return.\n      if (node.next) {\n        const nestedTraversalCtx: TraversalContext = {\n          stageId: node.id ?? context.stageId,\n          stageName: node.name,\n          parentStageId: context.parent?.stageId,\n          subflowId: branchPath || undefined,\n          subflowPath: branchPath || undefined,\n          depth: this.computeContextDepth(context),\n        };\n        this.deps.narrativeGenerator.onNext(node.name, node.next.name, node.next.description, nestedTraversalCtx);\n        const nextCtx = context.createNext('', node.next.name, node.next.id);\n        return await this.executeSubflowInternal(node.next, nextCtx, breakFlag, branchPath);\n      }\n      return nestedOutput;\n    }\n\n    // Build traversal context for subflow stage events\n    const traversalContext: TraversalContext = {\n      stageId: node.id ?? context.stageId,\n      stageName: node.name,\n      parentStageId: context.parent?.stageId,\n      subflowId: branchPath || undefined,\n      subflowPath: branchPath || undefined,\n      depth: this.computeContextDepth(context),\n    };\n\n    const stageFunc = this.getStageFn(node);\n    const breakFn = () => (breakFlag.shouldBreak = true);\n\n    let stageOutput: TOut | undefined;\n    if (stageFunc) {\n      try {\n        if (this.currentSubflowDeps) {\n          const subflowStageRunner = new StageRunner<TOut, TScope>(this.currentSubflowDeps);\n          stageOutput = await subflowStageRunner.run(node, stageFunc, context, breakFn);\n        } else {\n          stageOutput = await this.executeStage(node, stageFunc, context, breakFn);\n        }\n      } catch (error: any) {\n        context.commit();\n        this.callExtractor(node, context, this.getStagePath(node, branchPath, context.stageName), undefined, {\n          type: 'stageExecutionError',\n          message: error.toString(),\n        });\n        context.addError('stageExecutionError', error.toString());\n        this.deps.narrativeGenerator.onError(node.name, error.toString(), error, traversalContext);\n        throw error;\n      }\n      context.commit();\n      this.callExtractor(node, context, this.getStagePath(node, branchPath, context.stageName), stageOutput);\n      this.deps.narrativeGenerator.onStageExecuted(node.name, node.description, traversalContext);\n\n      if (breakFlag.shouldBreak) {\n        this.deps.narrativeGenerator.onBreak(node.name, traversalContext);\n        return stageOutput;\n      }\n\n      // Handle dynamic StageNode return\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        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          if (typeof dynamicNode.nextNodeSelector === 'function') {\n            node.nextNodeSelector = dynamicNode.nextNodeSelector;\n            context.addLog('hasSelector', true);\n          }\n        }\n\n        if (dynamicNode.next) {\n          node.next = dynamicNode.next;\n          context.addLog('hasDynamicNext', true);\n          const loopTargetId = dynamicNode.next.id;\n          if (loopTargetId) {\n            context.addLog('loopTarget', loopTargetId);\n          }\n        }\n\n        stageOutput = undefined;\n      }\n    }\n\n    // ─── Children dispatch ───\n    const hasChildrenAfterStage = Boolean(node.children?.length);\n    const hasNextAfterStage = Boolean(node.next);\n\n    if (hasChildrenAfterStage) {\n      if (node.nextNodeSelector) {\n        const results = await this.executeSelectedChildrenInternal(\n          node.nextNodeSelector,\n          node.children!,\n          stageOutput,\n          context,\n          branchPath,\n          breakFlag,\n        );\n        if (!hasNextAfterStage) return results;\n      } else {\n        const results = await this.executeNodeChildrenInternal(node, context, branchPath, breakFlag);\n        if (!hasNextAfterStage) return results;\n      }\n    }\n\n    // ─── Linear next ───\n    if (hasNextAfterStage) {\n      let nextNode = node.next!;\n\n      // Resolve reference nodes (has id but no fn)\n      if (nextNode.id && !nextNode.fn) {\n        let resolvedNode: StageNode<TOut, TScope> | undefined;\n        if (this.currentSubflowRoot) {\n          resolvedNode = this.nodeResolver.findNodeById(nextNode.id, this.currentSubflowRoot);\n          if (resolvedNode) context.addLog('dynamicNextResolvedFrom', 'subflow');\n        }\n        if (!resolvedNode) {\n          resolvedNode = this.nodeResolver.findNodeById(nextNode.id);\n          if (resolvedNode) context.addLog('dynamicNextResolvedFrom', 'mainPipeline');\n        }\n        if (resolvedNode) {\n          nextNode = resolvedNode;\n          context.addLog('dynamicNextResolved', true);\n          context.addLog('dynamicNextTarget', nextNode.id);\n        } else {\n          this.deps.logger.info(`Dynamic next node '${nextNode.id}' not found in subflow or main pipeline`);\n          context.addLog('dynamicNextResolved', false);\n          context.addLog('dynamicNextNotFound', nextNode.id);\n        }\n      }\n\n      this.deps.narrativeGenerator.onNext(node.name, nextNode.name, nextNode.description, traversalContext);\n      const nextCtx = context.createNext('', nextNode.name, nextNode.id);\n      return await this.executeSubflowInternal(nextNode, nextCtx, breakFlag, branchPath);\n    }\n\n    return stageOutput;\n  }\n\n  private computeContextDepth(context: StageContext): number {\n    let depth = 0;\n    let current = context.parent;\n    while (current) {\n      depth++;\n      current = current.parent;\n    }\n    return depth;\n  }\n\n  private getStagePath(node: StageNode<TOut, TScope>, branchPath?: string, contextStageName?: string): string {\n    const baseName = node.id;\n    const nodeId = contextStageName && contextStageName !== node.name ? contextStageName : baseName;\n    if (!branchPath) return nodeId;\n    return `${branchPath}.${nodeId}`;\n  }\n\n  private async executeNodeChildrenInternal(\n    node: StageNode<TOut, TScope>,\n    context: StageContext,\n    branchPath: string,\n    breakFlag: { shouldBreak: boolean },\n  ): Promise<Record<string, NodeResultType>> {\n    const childPromises: Promise<NodeResultType>[] = (node.children ?? []).map((child) => {\n      const childContext = context.createChild('', child.id as string, child.name, child.id);\n      const childBreakFlag = { shouldBreak: false };\n\n      return this.executeSubflowInternal(child, childContext, childBreakFlag, branchPath)\n        .then((result) => {\n          childContext.commit();\n          return { id: child.id!, result, isError: false };\n        })\n        .catch((error) => {\n          childContext.commit();\n          this.deps.logger.info(`TREE PIPELINE: executeNodeChildrenInternal - Error for id: ${child?.id}`, { error });\n          return { id: child.id!, result: error, isError: true };\n        });\n    });\n\n    const settled = await Promise.allSettled(childPromises);\n    const childrenResults: Record<string, NodeResultType> = {};\n    settled.forEach((s) => {\n      if (s.status === 'fulfilled') {\n        const { id, result, isError } = s.value;\n        childrenResults[id] = { id, result, isError };\n      } else {\n        this.deps.logger.error(`Execution failed: ${s.reason}`);\n      }\n    });\n    return childrenResults;\n  }\n\n  private async executeSelectedChildrenInternal(\n    selector: Selector,\n    children: StageNode<TOut, TScope>[],\n    input: any,\n    context: StageContext,\n    branchPath: string,\n    breakFlag: { shouldBreak: boolean },\n  ): Promise<Record<string, NodeResultType>> {\n    const selectorResult = await selector(input);\n    const selectedIds = Array.isArray(selectorResult) ? selectorResult : [selectorResult];\n\n    context.addLog('selectedChildIds', selectedIds);\n    context.addLog('selectorPattern', 'multi-choice');\n\n    if (selectedIds.length === 0) {\n      context.addLog('skippedAllChildren', true);\n      return {};\n    }\n\n    const selectedChildren = children.filter((c) => selectedIds.includes(c.id!));\n    if (selectedChildren.length !== selectedIds.length) {\n      const childIds = children.map((c) => c.id);\n      const missing = selectedIds.filter((id) => !childIds.includes(id));\n      const errorMessage = `Selector returned unknown child IDs: ${missing.join(', ')}. Available: ${childIds.join(\n        ', ',\n      )}`;\n      this.deps.logger.error(`Error in subflow (${branchPath}):`, { error: errorMessage });\n      context.addError('selectorError', errorMessage);\n      throw new Error(errorMessage);\n    }\n\n    const skippedIds = children.filter((c) => !selectedIds.includes(c.id!)).map((c) => c.id);\n    if (skippedIds.length > 0) {\n      context.addLog('skippedChildIds', skippedIds);\n    }\n\n    const tempNode: StageNode<TOut, TScope> = {\n      name: 'selector-temp',\n      id: 'selector-temp',\n      children: selectedChildren,\n    };\n    return await this.executeNodeChildrenInternal(tempNode, context, branchPath, breakFlag);\n  }\n}\n"]}
153
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SubflowExecutor.js","sourceRoot":"","sources":["../../../../../src/lib/engine/handlers/SubflowExecutor.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * SubflowExecutor — Isolation boundary for subflow execution.\n *\n * Responsibilities:\n * - Create isolated ExecutionRuntime for each subflow\n * - Apply input/output mapping via SubflowInputMapper\n * - Delegate traversal to a factory-created FlowchartTraverser\n * - Track subflow results for debugging/visualization\n *\n * Each subflow gets its own GlobalStore for isolation.\n * Traversal uses the SAME 7-phase algorithm as the top-level traverser\n * (via SubflowTraverserFactory), so deciders, selectors, loops, lazy subflows,\n * and abort signals all work inside subflows automatically.\n */\n\nimport type { StageContext } from '../../memory/StageContext.js';\nimport type { StageNode } from '../graph/StageNode.js';\nimport type { TraversalContext } from '../narrative/types.js';\nimport type {\n  HandlerDeps,\n  IExecutionRuntime,\n  SubflowResult,\n  SubflowTraverserFactory,\n  SubflowTraverserHandle,\n} from '../types.js';\nimport { applyOutputMapping, getInitialScopeValues, seedSubflowGlobalStore } from './SubflowInputMapper.js';\n\nexport class SubflowExecutor<TOut = any, TScope = any> {\n  constructor(\n    private deps: HandlerDeps<TOut, TScope>,\n    private traverserFactory: SubflowTraverserFactory<TOut, TScope>,\n  ) {}\n\n  /**\n   * Execute a subflow with isolated context.\n   *\n   * 1. Creates a fresh ExecutionRuntime for the subflow\n   * 2. Applies input mapping to seed the subflow's GlobalStore\n   * 3. Delegates traversal to a factory-created FlowchartTraverser\n   * 4. Applies output mapping to write results back to parent scope\n   * 5. Stores execution data for debugging/visualization\n   */\n  async executeSubflow(\n    node: StageNode<TOut, TScope>,\n    parentContext: StageContext,\n    breakFlag: { shouldBreak: boolean },\n    branchPath: string | undefined,\n    subflowResultsMap: Map<string, SubflowResult>,\n    parentTraversalContext?: TraversalContext,\n  ): Promise<any> {\n    const subflowId = node.subflowId!;\n    const subflowName = node.subflowName ?? node.name;\n\n    parentContext.addFlowDebugMessage('subflow', `Entering ${subflowName} subflow`, {\n      targetStage: subflowId,\n    });\n    this.deps.narrativeGenerator.onSubflowEntry(subflowName, subflowId, node.description, parentTraversalContext);\n\n    // ─── Input Mapping ───\n    const mountOptions = node.subflowMountOptions;\n    let mappedInput: Record<string, unknown> = {};\n\n    if (mountOptions) {\n      try {\n        const parentScope = parentContext.getScope();\n        mappedInput = getInitialScopeValues(parentScope, mountOptions);\n        if (Object.keys(mappedInput).length > 0) {\n          // mappedInput is captured in SubflowResult.treeContext for debugging\n        }\n      } catch (error: any) {\n        parentContext.addError('inputMapperError', error.toString());\n        this.deps.logger.error(`Error in inputMapper for subflow (${subflowId}):`, { error });\n        throw error;\n      }\n    }\n\n    // Create isolated runtime via dynamic construction (avoids circular import)\n    const ExecutionRuntimeClass = this.deps.executionRuntime.constructor as new (\n      name: string,\n      id: string,\n    ) => IExecutionRuntime;\n    const nestedRuntime = new ExecutionRuntimeClass(node.name, node.id);\n    let nestedRootContext = nestedRuntime.rootStageContext;\n\n    // Seed GlobalStore with input\n    if (Object.keys(mappedInput).length > 0) {\n      seedSubflowGlobalStore(nestedRuntime, mappedInput);\n      // Refresh rootStageContext so WriteBuffer sees committed data\n      const StageContextClass = nestedRootContext.constructor as new (...args: any[]) => StageContext;\n      nestedRootContext = new StageContextClass(\n        '',\n        nestedRootContext.stageName,\n        nestedRootContext.stageId,\n        nestedRuntime.globalStore,\n        '',\n        nestedRuntime.executionHistory,\n      );\n      nestedRuntime.rootStageContext = nestedRootContext;\n    }\n\n    // Prepare subflow root node — strip isSubflowRoot to prevent re-delegation\n    const hasChildren = Boolean(node.children && node.children.length > 0);\n    const subflowNode: StageNode<TOut, TScope> = {\n      ...node,\n      isSubflowRoot: false,\n      next: hasChildren ? undefined : node.next,\n    };\n\n    // ─── Execute via factory traverser ───\n    // The factory creates a full FlowchartTraverser with the same 7-phase algorithm,\n    // sharing the parent's stageMap, subflows dict, and narrative generator.\n    let subflowOutput: any;\n    let subflowError: Error | undefined;\n    let traverserHandle: SubflowTraverserHandle<TOut, TScope> | undefined;\n\n    try {\n      traverserHandle = this.traverserFactory({\n        root: subflowNode,\n        executionRuntime: nestedRuntime,\n        readOnlyContext: mappedInput,\n        subflowId,\n      });\n\n      subflowOutput = await traverserHandle.execute();\n    } catch (error: any) {\n      subflowError = error;\n      parentContext.addError('subflowError', error.toString());\n      this.deps.logger.error(`Error in subflow (${subflowId}):`, { error });\n    }\n\n    // Always merge nested subflow results (even on error — partial results aid debugging)\n    if (traverserHandle) {\n      for (const [key, value] of traverserHandle.getSubflowResults()) {\n        subflowResultsMap.set(key, value);\n      }\n    }\n\n    const subflowTreeContext = nestedRuntime.getSnapshot();\n\n    // ─── Output Mapping ───\n    if (!subflowError && mountOptions?.outputMapper) {\n      try {\n        let outputContext = parentContext;\n        if (parentContext.branchId && parentContext.branchId !== '' && parentContext.parent) {\n          outputContext = parentContext.parent;\n        }\n\n        const parentScope = outputContext.getScope();\n        // For TypedScope subflows, stage functions return void — fall back to a shallow clone\n        // of the subflow's shared state so outputMapper can access all scope values written\n        // during the subflow. We shallow-clone to avoid aliasing the live SharedMemory context.\n        // NOTE: the full scope is passed (not just declared outputs) — outputMapper must\n        // explicitly select what to propagate to the parent.\n        // Redaction: the subflow shares the parent's _redactedKeys Set (via the same ScopeFactory),\n        // so any key marked redacted in the subflow is already visible in the parent's scope.\n        // ScopeFacade.setValue checks _redactedKeys.has(key), so writes via outputMapper\n        // automatically inherit the subflow's dynamic redaction state.\n        const effectiveOutput = subflowOutput ?? { ...subflowTreeContext.sharedState };\n        const mappedOutput = applyOutputMapping(effectiveOutput, parentScope, outputContext, mountOptions);\n\n        outputContext.commit();\n      } catch (error: any) {\n        parentContext.addError('outputMapperError', error.toString());\n        this.deps.logger.error(`Error in outputMapper for subflow (${subflowId}):`, { error });\n      }\n    }\n\n    const subflowResult: SubflowResult = {\n      subflowId,\n      subflowName,\n      treeContext: {\n        globalContext: subflowTreeContext.sharedState,\n        stageContexts: subflowTreeContext.executionTree as unknown as Record<string, unknown>,\n        history: subflowTreeContext.commitLog,\n      },\n      parentStageId: parentContext.getStageId(),\n    };\n\n    const subflowDef = this.deps.subflows?.[subflowId];\n    if (subflowDef && (subflowDef as any).buildTimeStructure) {\n      subflowResult.pipelineStructure = (subflowDef as any).buildTimeStructure;\n    }\n\n    subflowResultsMap.set(subflowId, subflowResult);\n\n    parentContext.addFlowDebugMessage('subflow', `Exiting ${subflowName} subflow`, {\n      targetStage: subflowId,\n    });\n    this.deps.narrativeGenerator.onSubflowExit(subflowName, subflowId, parentTraversalContext);\n\n    parentContext.commit();\n\n    if (subflowError) {\n      throw subflowError;\n    }\n\n    return subflowOutput;\n  }\n}\n"]}