footprintjs 4.13.0 → 4.14.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.
@@ -193,8 +193,8 @@ export class FlowchartTraverser {
193
193
  getRuntimeStructure() {
194
194
  return this.structureManager.getStructure();
195
195
  }
196
- getSnapshot() {
197
- return this.executionRuntime.getSnapshot();
196
+ getSnapshot(options) {
197
+ return this.executionRuntime.getSnapshot(options);
198
198
  }
199
199
  getRuntime() {
200
200
  return this.executionRuntime;
@@ -721,4 +721,4 @@ export class FlowchartTraverser {
721
721
  * execution. `FlowChartExecutor.run()` always creates a fresh traverser per call.
722
722
  */
723
723
  FlowchartTraverser.MAX_EXECUTE_DEPTH = 500;
724
- //# 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.js';\nimport { isPauseSignal } from '../../pause/types.js';\nimport type { ScopeProtectionMode } from '../../scope/protection/types.js';\nimport { isStageNodeReturn } from '../graph/StageNode.js';\nimport { ChildrenExecutor } from '../handlers/ChildrenExecutor.js';\nimport { ContinuationResolver } from '../handlers/ContinuationResolver.js';\nimport { DeciderHandler } from '../handlers/DeciderHandler.js';\nimport { ExtractorRunner } from '../handlers/ExtractorRunner.js';\nimport { NodeResolver } from '../handlers/NodeResolver.js';\nimport { RuntimeStructureManager } from '../handlers/RuntimeStructureManager.js';\nimport { SelectorHandler } from '../handlers/SelectorHandler.js';\nimport { StageRunner } from '../handlers/StageRunner.js';\nimport { SubflowExecutor } from '../handlers/SubflowExecutor.js';\nimport type { BreakFlag } from '../handlers/types.js';\nimport { FlowRecorderDispatcher } from '../narrative/FlowRecorderDispatcher.js';\nimport { NarrativeFlowRecorder } from '../narrative/NarrativeFlowRecorder.js';\nimport { NullControlFlowNarrativeGenerator } from '../narrative/NullControlFlowNarrativeGenerator.js';\nimport type { FlowRecorder, IControlFlowNarrative, TraversalContext } from '../narrative/types.js';\nimport { buildRuntimeStageId } from '../runtimeStageId.js';\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  SubflowTraverserFactory,\n  TraversalExtractor,\n  TraversalResult,\n} from '../types.js';\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   * Pre-configured narrative generator. If provided, takes precedence over\n   * flowRecorders and narrativeEnabled. Used by the subflow traverser factory\n   * to share the parent's narrative generator with subflow traversers.\n   */\n  narrativeGenerator?: IControlFlowNarrative;\n  /**\n   * Maximum recursive executeNode depth. Defaults to FlowchartTraverser.MAX_EXECUTE_DEPTH (500).\n   * Override in tests or unusually deep pipelines.\n   */\n  maxDepth?: number;\n  /**\n   * When this traverser runs inside a subflow, set this to the subflow's ID.\n   * Propagated to TraversalContext so narrative entries carry the correct subflowId.\n   */\n  parentSubflowId?: string;\n  /** Shared execution counter from parent traverser. Subflows continue the parent's numbering. */\n  executionCounter?: { value: number };\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  private readonly parentSubflowId?: string;\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  /**\n   * Per-traverser set of lazy subflow IDs that have been resolved by THIS run.\n   * Used instead of writing `node.subflowResolver = undefined` back to the shared\n   * StageNode graph — avoids a race where a concurrent traverser clears the shared\n   * resolver before another traverser has finished using it.\n   */\n  private readonly resolvedLazySubflows = new Set<string>();\n\n  /**\n   * Recursion depth counter for executeNode.\n   * Each recursive executeNode call increments this; decrements on exit (try/finally).\n   * Prevents call-stack overflow on infinite loops or excessively deep stage chains.\n   */\n  private _executeDepth = 0;\n\n  /**\n   * Shared mutable execution counter — monotonic, incremented per stage execution.\n   * Shared with child traversers (subflows) so indices are globally unique within a run.\n   */\n  private readonly _executionCounter: { value: number };\n\n  /**\n   * Per-instance maximum depth (set from TraverserOptions.maxDepth or the class default).\n   */\n  private readonly _maxDepth: number;\n\n  /**\n   * Default maximum recursive executeNode depth before an error is thrown.\n   * 500 comfortably covers any realistic pipeline depth (including deeply nested\n   * subflows) while preventing call-stack overflow (~10 000 frames in V8).\n   *\n   * **Note on counting:** the counter increments once per `executeNode` call, not once per\n   * logical user stage. Subflow root entry and subflow continuation after return each cost\n   * one tick. For pipelines with many nested subflows, budget roughly 2 × (avg stages per\n   * subflow) of headroom when computing a custom `maxDepth` via `RunOptions.maxDepth`.\n   *\n   * **Note on loops:** for `loopTo()` pipelines, this depth guard and `ContinuationResolver`'s\n   * iteration limit are independent — the lower one fires first. The default depth guard (500)\n   * fires before the default iteration limit (1000) for loop-heavy pipelines.\n   *\n   * @remarks Not safe for concurrent `.execute()` calls on the same instance — concurrent\n   * executions race on `_executeDepth`. Use a separate `FlowchartTraverser` per concurrent\n   * execution. `FlowChartExecutor.run()` always creates a fresh traverser per call.\n   */\n  static readonly MAX_EXECUTE_DEPTH = 500;\n\n  constructor(opts: TraverserOptions<TOut, TScope>) {\n    const maxDepth = opts.maxDepth ?? FlowchartTraverser.MAX_EXECUTE_DEPTH;\n    if (maxDepth < 1) throw new Error('FlowchartTraverser: maxDepth must be >= 1');\n    this._maxDepth = maxDepth;\n    this._executionCounter = opts.executionCounter ?? { value: 0 };\n    this.root = opts.root;\n    // Shallow-copy stageMap and subflows so that lazy-resolution mutations\n    // (prefixed entries added during execution) stay scoped to THIS traverser\n    // and do not escape to the shared FlowChart object. Without the copy,\n    // concurrent FlowChartExecutor runs sharing the same FlowChart would race\n    // on these two mutable dictionaries.\n    this.stageMap = new Map(opts.stageMap);\n    this.executionRuntime = opts.executionRuntime;\n    this.subflows = opts.subflows ? { ...opts.subflows } : {};\n    this.logger = opts.logger;\n    this.signal = opts.signal;\n    this.parentSubflowId = opts.parentSubflowId;\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    // Priority: explicit narrativeGenerator > flowRecorders > default NarrativeFlowRecorder > null.\n    // Subflow traversers receive the parent's narrativeGenerator so all events flow to one place.\n    if (opts.narrativeGenerator) {\n      this.narrativeGenerator = opts.narrativeGenerator;\n    } else 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    // Build O(1) node ID map from the root graph (avoids repeated DFS on every loopTo())\n    const nodeIdMap = this.buildNodeIdMap(opts.root);\n\n    // Initialize handler modules\n    this.nodeResolver = new NodeResolver(deps, nodeIdMap);\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(deps, this.createSubflowTraverserFactory(opts));\n  }\n\n  /**\n   * Create a factory that produces FlowchartTraverser instances for subflow execution.\n   * Captures parent config in closure — SubflowExecutor provides subflow-specific overrides.\n   * Each subflow gets a full traverser with all 7 phases (deciders, selectors, loops, etc.).\n   */\n  private createSubflowTraverserFactory(\n    parentOpts: TraverserOptions<TOut, TScope>,\n  ): SubflowTraverserFactory<TOut, TScope> {\n    // Capture references to mutable state — factory reads the CURRENT state when called,\n    // not the state at factory creation time. This is correct because lazy subflow resolution\n    // may add entries to stageMap/subflows before a nested subflow is encountered.\n    const parentStageMap = this.stageMap;\n    const parentSubflows = this.subflows;\n    const narrativeGenerator = this.narrativeGenerator;\n\n    return (subflowOpts) => {\n      const traverser = new FlowchartTraverser<TOut, TScope>({\n        root: subflowOpts.root,\n        stageMap: parentStageMap, // Constructor shallow-copies this\n        scopeFactory: parentOpts.scopeFactory,\n        executionRuntime: subflowOpts.executionRuntime,\n        readOnlyContext: subflowOpts.readOnlyContext,\n        executionEnv: parentOpts.executionEnv,\n        throttlingErrorChecker: parentOpts.throttlingErrorChecker,\n        streamHandlers: parentOpts.streamHandlers,\n        extractor: parentOpts.extractor,\n        scopeProtectionMode: parentOpts.scopeProtectionMode,\n        subflows: parentSubflows, // Constructor shallow-copies this\n        enrichSnapshots: parentOpts.enrichSnapshots,\n        narrativeGenerator, // Share parent's — all events flow to one place\n        logger: parentOpts.logger,\n        signal: parentOpts.signal,\n        maxDepth: this._maxDepth,\n        parentSubflowId: subflowOpts.subflowId,\n        executionCounter: this._executionCounter, // Share counter — subflow continues global numbering\n      });\n\n      return {\n        execute: () => traverser.execute(),\n        getSubflowResults: () => traverser.getSubflowResults(),\n        getBreakState: () => traverser.getBreakState(),\n      };\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  /**\n   * Holds the top-level break flag for the duration of `execute()`. Kept as\n   * a field (not a local) so `getBreakState()` can surface the final state\n   * for callers like `SubflowExecutor` that implement `propagateBreak`.\n   */\n  private _topBreakFlag: { shouldBreak: boolean; reason?: string } = { shouldBreak: false };\n\n  async execute(branchPath?: string): Promise<TraversalResult> {\n    const context = this.executionRuntime.rootStageContext;\n    this._topBreakFlag = { shouldBreak: false };\n    return await this.executeNode(this.root, context, this._topBreakFlag, branchPath ?? '');\n  }\n\n  /**\n   * Break state captured at the top-level of the most recent `execute()`.\n   * `shouldBreak` is true when a stage called `scope.$break(reason)`; the\n   * optional `reason` carries the string passed to `$break`.\n   *\n   * Used by `SubflowExecutor` to propagate an inner subflow's break up to\n   * the parent traverser when the mount sets `propagateBreak: true`.\n   */\n  getBreakState(): { shouldBreak: boolean; reason?: string } {\n    return { ...this._topBreakFlag };\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  /**\n   * Build an O(1) ID→node map from the root graph.\n   * Used by NodeResolver to avoid repeated DFS on every loopTo() call.\n   * Depth-guarded at MAX_EXECUTE_DEPTH to prevent infinite recursion on cyclic graphs.\n   * Dynamic subflows and lazy-resolved nodes are added to stageMap at runtime but not to this map —\n   * those use the DFS fallback in NodeResolver.\n   */\n  private buildNodeIdMap(root: StageNode<TOut, TScope>): Map<string, StageNode<TOut, TScope>> {\n    const map = new Map<string, StageNode<TOut, TScope>>();\n    const visit = (node: StageNode<TOut, TScope>, depth: number): void => {\n      if (depth > FlowchartTraverser.MAX_EXECUTE_DEPTH) return;\n      if (map.has(node.id)) return; // already visited (avoids infinite loops on cyclic refs)\n      map.set(node.id, node);\n      if (node.children) {\n        for (const child of node.children) visit(child, depth + 1);\n      }\n      if (node.next) visit(node.next, depth + 1);\n    };\n    visit(root, 0);\n    return map;\n  }\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    // Primary: look up by id (stable identifier, keyed by FlowChartBuilder)\n    const byId = this.stageMap.get(node.id);\n    if (byId !== undefined) return byId;\n    // Fallback: look up by name (supports hand-crafted stageMaps in tests and advanced use)\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    // runtimeStageId is assigned in executeNode() before traversalContext creation,\n    // ensuring scope events and flow events use the same value.\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: BreakFlag,\n    branchPath?: string,\n  ): Promise<any> {\n    // ─── Recursion depth guard ───\n    // Each `await executeNode(...)` keeps the calling frame on the stack.\n    // Without a cap, an infinite loop or an excessively deep stage chain will\n    // eventually overflow the V8 call stack (~10 000 frames) with a cryptic\n    // \"Maximum call stack size exceeded\" error.  We fail early with a clear\n    // message so users can diagnose the cause (infinite loop, missing break, etc.).\n    // The increment is inside `try` so `finally` always decrements — no fragile\n    // gap between check and try entry.\n    try {\n      if (++this._executeDepth > this._maxDepth) {\n        throw new Error(\n          `FlowchartTraverser: maximum traversal depth exceeded (${this._maxDepth}). ` +\n            'Check for infinite loops or missing break conditions in your flowchart. ' +\n            `Last stage: '${node.name}'. ` +\n            'For loopTo() pipelines, consider adding a break condition or using RunOptions.maxDepth to raise the limit.',\n        );\n      }\n\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      // Assign runtimeStageId BEFORE traversalContext creation — ensures scope events\n      // (buffered by runtimeStageId) and flow events (flushed by traversalContext.runtimeStageId)\n      // use the same value. Must happen before executeStage AND before traversalContext.\n      const idx = this._executionCounter.value++;\n      context.runtimeStageId = buildRuntimeStageId(node.id, idx);\n\n      // Build traversal context for recorder events — created once per stage, shared by all events\n      const traversalContext: TraversalContext = {\n        stageId: node.id ?? context.stageId,\n        runtimeStageId: context.runtimeStageId,\n        stageName: node.name,\n        parentStageId: context.parent?.stageId,\n        subflowId: context.subflowId ?? this.parentSubflowId,\n        subflowPath: branchPath || undefined,\n        depth: this.computeContextDepth(context),\n      };\n\n      // ─── Phase 0a: LAZY RESOLVE — deferred subflow resolution ───\n      // Guard uses the per-traverser resolvedLazySubflows set (not the shared node) so\n      // concurrent traversers do not race on node.subflowResolver or clear it for each other.\n      if (node.isSubflowRoot && node.subflowResolver && !this.resolvedLazySubflows.has(node.subflowId!)) {\n        const resolved = node.subflowResolver();\n        const prefixedRoot = this.prefixNodeTree(resolved.root as StageNode<TOut, TScope>, node.subflowId!);\n\n        // Register the resolved subflow (same path as eager registration)\n        this.subflows[node.subflowId!] = { root: prefixedRoot };\n\n        // Merge stageMap entries\n        for (const [key, fn] of resolved.stageMap) {\n          const prefixedKey = `${node.subflowId}/${key}`;\n          if (!this.stageMap.has(prefixedKey)) {\n            this.stageMap.set(prefixedKey, fn as StageFunction<TOut, TScope>);\n          }\n        }\n\n        // Merge nested subflows\n        if (resolved.subflows) {\n          for (const [key, def] of Object.entries(resolved.subflows)) {\n            const prefixedKey = `${node.subflowId}/${key}`;\n            if (!this.subflows[prefixedKey]) {\n              this.subflows[prefixedKey] = def as { root: StageNode<TOut, TScope> };\n            }\n          }\n        }\n\n        // Update runtime structure with the now-resolved spec\n        this.structureManager.updateDynamicSubflow(\n          node.id,\n          node.subflowId!,\n          node.subflowName,\n          resolved.buildTimeStructure,\n        );\n\n        // Mark as resolved for THIS traverser — per-traverser set prevents re-entry\n        // without mutating the shared StageNode graph (which would race concurrent traversers).\n        this.resolvedLazySubflows.add(node.subflowId!);\n      }\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            traversalContext,\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        // ─── Break-flag check AFTER subflow returns ───\n        // If the subflow was mounted with `propagateBreak: true` and broke\n        // internally, `SubflowExecutor` has already flipped our breakFlag.\n        // Stop the outer traversal here — do not run the next linear stage.\n        if (breakFlag.shouldBreak) {\n          return subflowOutput;\n        }\n\n        if (node.next && shouldExecuteContinuation) {\n          const nextCtx = context.createNext(branchPath as string, node.next.name, node.next.id);\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      // Break handler wired to the scope. Captures the optional reason\n      // passed via `scope.$break(reason)` and parks it on the breakFlag so\n      // downstream code (FlowRecorder.onBreak, subflow propagation) can\n      // surface it. A second $break call in the same stage keeps the FIRST\n      // reason — first-break-wins — matching the \"execution stopped\" story.\n      const breakFn = (reason?: string) => {\n        breakFlag.shouldBreak = true;\n        if (reason !== undefined && breakFlag.reason === undefined) {\n          breakFlag.reason = reason;\n        }\n      };\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            traversalContext,\n          );\n\n          if (hasNext) {\n            const nextCtx = context.createNext(branchPath as string, node.next!.name, node.next!.id);\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          traversalContext,\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          // Use the isLoopRef flag set by loopTo() — do not rely on stageMap absence,\n          // since id-keyed stageMaps would otherwise cause loop targets to be executed directly.\n          const isLoopRef =\n            nextNode.isLoopRef === true ||\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, traversalContext);\n          const nextCtx = context.createNext(branchPath as string, nextNode.name, nextNode.id);\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          // PauseSignal is expected control flow, not an error — fire narrative, commit, re-throw.\n          if (isPauseSignal(error)) {\n            context.commit();\n            this.narrativeGenerator.onPause(node.name, node.id, error.pauseData, error.subflowPath, traversalContext);\n            throw error;\n          }\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, traversalContext);\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, traversalContext);\n\n        if (breakFlag.shouldBreak) {\n          // Forward the optional reason captured on breakFlag — set by the\n          // stage's $break(reason) call OR by a subflow's propagateBreak.\n          this.narrativeGenerator.onBreak(node.name, traversalContext, breakFlag.reason);\n          const reasonSuffix = breakFlag.reason ? ` (reason: ${breakFlag.reason})` : '';\n          this.logger.info(\n            `Execution stopped in pipeline (${branchPath}) after ${node.name} due to break condition${reasonSuffix}.`,\n          );\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\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              traversalContext,\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(\n              node,\n              context,\n              undefined,\n              branchPath,\n              traversalContext,\n            );\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            traversalContext,\n          );\n        }\n\n        this.narrativeGenerator.onNext(node.name, nextNode.name, nextNode.description, traversalContext);\n        context.addFlowDebugMessage('next', `Moving to ${nextNode.name} stage`, {\n          targetStage: nextNode.name,\n        });\n        const nextCtx = context.createNext(branchPath as string, nextNode.name, nextNode.id);\n        return await this.executeNode(nextNode, nextCtx, breakFlag, branchPath);\n      }\n\n      // ─── Phase 7: LEAF — no continuation ───\n      return stageOutput;\n    } finally {\n      this._executeDepth--;\n    }\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 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 prefixNodeTree(node: StageNode<TOut, TScope>, prefix: string): StageNode<TOut, TScope> {\n    if (!node) return node;\n    const clone: StageNode<TOut, TScope> = { ...node };\n    clone.name = `${prefix}/${node.name}`;\n    clone.id = `${prefix}/${clone.id}`;\n    if (clone.subflowId) clone.subflowId = `${prefix}/${clone.subflowId}`;\n    if (clone.next) clone.next = this.prefixNodeTree(clone.next, prefix);\n    if (clone.children) {\n      clone.children = clone.children.map((c) => this.prefixNodeTree(c, prefix));\n    }\n    return clone;\n  }\n\n  private autoRegisterSubflowDef(\n    subflowId: string,\n    subflowDef: NonNullable<StageNode['subflowDef']>,\n    mountNodeId?: string,\n  ): void {\n    // this.subflows is always initialized in the constructor; the null guard below is unreachable.\n    const subflowsDict = this.subflows;\n\n    // First-write-wins\n    const isNewRegistration = !subflowsDict[subflowId];\n    if (isNewRegistration && subflowDef.root) {\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"]}
724
+ //# 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.js';\nimport { isPauseSignal } from '../../pause/types.js';\nimport type { ScopeProtectionMode } from '../../scope/protection/types.js';\nimport { isStageNodeReturn } from '../graph/StageNode.js';\nimport { ChildrenExecutor } from '../handlers/ChildrenExecutor.js';\nimport { ContinuationResolver } from '../handlers/ContinuationResolver.js';\nimport { DeciderHandler } from '../handlers/DeciderHandler.js';\nimport { ExtractorRunner } from '../handlers/ExtractorRunner.js';\nimport { NodeResolver } from '../handlers/NodeResolver.js';\nimport { RuntimeStructureManager } from '../handlers/RuntimeStructureManager.js';\nimport { SelectorHandler } from '../handlers/SelectorHandler.js';\nimport { StageRunner } from '../handlers/StageRunner.js';\nimport { SubflowExecutor } from '../handlers/SubflowExecutor.js';\nimport type { BreakFlag } from '../handlers/types.js';\nimport { FlowRecorderDispatcher } from '../narrative/FlowRecorderDispatcher.js';\nimport { NarrativeFlowRecorder } from '../narrative/NarrativeFlowRecorder.js';\nimport { NullControlFlowNarrativeGenerator } from '../narrative/NullControlFlowNarrativeGenerator.js';\nimport type { FlowRecorder, IControlFlowNarrative, TraversalContext } from '../narrative/types.js';\nimport { buildRuntimeStageId } from '../runtimeStageId.js';\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  SubflowTraverserFactory,\n  TraversalExtractor,\n  TraversalResult,\n} from '../types.js';\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   * Pre-configured narrative generator. If provided, takes precedence over\n   * flowRecorders and narrativeEnabled. Used by the subflow traverser factory\n   * to share the parent's narrative generator with subflow traversers.\n   */\n  narrativeGenerator?: IControlFlowNarrative;\n  /**\n   * Maximum recursive executeNode depth. Defaults to FlowchartTraverser.MAX_EXECUTE_DEPTH (500).\n   * Override in tests or unusually deep pipelines.\n   */\n  maxDepth?: number;\n  /**\n   * When this traverser runs inside a subflow, set this to the subflow's ID.\n   * Propagated to TraversalContext so narrative entries carry the correct subflowId.\n   */\n  parentSubflowId?: string;\n  /** Shared execution counter from parent traverser. Subflows continue the parent's numbering. */\n  executionCounter?: { value: number };\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  private readonly parentSubflowId?: string;\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  /**\n   * Per-traverser set of lazy subflow IDs that have been resolved by THIS run.\n   * Used instead of writing `node.subflowResolver = undefined` back to the shared\n   * StageNode graph — avoids a race where a concurrent traverser clears the shared\n   * resolver before another traverser has finished using it.\n   */\n  private readonly resolvedLazySubflows = new Set<string>();\n\n  /**\n   * Recursion depth counter for executeNode.\n   * Each recursive executeNode call increments this; decrements on exit (try/finally).\n   * Prevents call-stack overflow on infinite loops or excessively deep stage chains.\n   */\n  private _executeDepth = 0;\n\n  /**\n   * Shared mutable execution counter — monotonic, incremented per stage execution.\n   * Shared with child traversers (subflows) so indices are globally unique within a run.\n   */\n  private readonly _executionCounter: { value: number };\n\n  /**\n   * Per-instance maximum depth (set from TraverserOptions.maxDepth or the class default).\n   */\n  private readonly _maxDepth: number;\n\n  /**\n   * Default maximum recursive executeNode depth before an error is thrown.\n   * 500 comfortably covers any realistic pipeline depth (including deeply nested\n   * subflows) while preventing call-stack overflow (~10 000 frames in V8).\n   *\n   * **Note on counting:** the counter increments once per `executeNode` call, not once per\n   * logical user stage. Subflow root entry and subflow continuation after return each cost\n   * one tick. For pipelines with many nested subflows, budget roughly 2 × (avg stages per\n   * subflow) of headroom when computing a custom `maxDepth` via `RunOptions.maxDepth`.\n   *\n   * **Note on loops:** for `loopTo()` pipelines, this depth guard and `ContinuationResolver`'s\n   * iteration limit are independent — the lower one fires first. The default depth guard (500)\n   * fires before the default iteration limit (1000) for loop-heavy pipelines.\n   *\n   * @remarks Not safe for concurrent `.execute()` calls on the same instance — concurrent\n   * executions race on `_executeDepth`. Use a separate `FlowchartTraverser` per concurrent\n   * execution. `FlowChartExecutor.run()` always creates a fresh traverser per call.\n   */\n  static readonly MAX_EXECUTE_DEPTH = 500;\n\n  constructor(opts: TraverserOptions<TOut, TScope>) {\n    const maxDepth = opts.maxDepth ?? FlowchartTraverser.MAX_EXECUTE_DEPTH;\n    if (maxDepth < 1) throw new Error('FlowchartTraverser: maxDepth must be >= 1');\n    this._maxDepth = maxDepth;\n    this._executionCounter = opts.executionCounter ?? { value: 0 };\n    this.root = opts.root;\n    // Shallow-copy stageMap and subflows so that lazy-resolution mutations\n    // (prefixed entries added during execution) stay scoped to THIS traverser\n    // and do not escape to the shared FlowChart object. Without the copy,\n    // concurrent FlowChartExecutor runs sharing the same FlowChart would race\n    // on these two mutable dictionaries.\n    this.stageMap = new Map(opts.stageMap);\n    this.executionRuntime = opts.executionRuntime;\n    this.subflows = opts.subflows ? { ...opts.subflows } : {};\n    this.logger = opts.logger;\n    this.signal = opts.signal;\n    this.parentSubflowId = opts.parentSubflowId;\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    // Priority: explicit narrativeGenerator > flowRecorders > default NarrativeFlowRecorder > null.\n    // Subflow traversers receive the parent's narrativeGenerator so all events flow to one place.\n    if (opts.narrativeGenerator) {\n      this.narrativeGenerator = opts.narrativeGenerator;\n    } else 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    // Build O(1) node ID map from the root graph (avoids repeated DFS on every loopTo())\n    const nodeIdMap = this.buildNodeIdMap(opts.root);\n\n    // Initialize handler modules\n    this.nodeResolver = new NodeResolver(deps, nodeIdMap);\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(deps, this.createSubflowTraverserFactory(opts));\n  }\n\n  /**\n   * Create a factory that produces FlowchartTraverser instances for subflow execution.\n   * Captures parent config in closure — SubflowExecutor provides subflow-specific overrides.\n   * Each subflow gets a full traverser with all 7 phases (deciders, selectors, loops, etc.).\n   */\n  private createSubflowTraverserFactory(\n    parentOpts: TraverserOptions<TOut, TScope>,\n  ): SubflowTraverserFactory<TOut, TScope> {\n    // Capture references to mutable state — factory reads the CURRENT state when called,\n    // not the state at factory creation time. This is correct because lazy subflow resolution\n    // may add entries to stageMap/subflows before a nested subflow is encountered.\n    const parentStageMap = this.stageMap;\n    const parentSubflows = this.subflows;\n    const narrativeGenerator = this.narrativeGenerator;\n\n    return (subflowOpts) => {\n      const traverser = new FlowchartTraverser<TOut, TScope>({\n        root: subflowOpts.root,\n        stageMap: parentStageMap, // Constructor shallow-copies this\n        scopeFactory: parentOpts.scopeFactory,\n        executionRuntime: subflowOpts.executionRuntime,\n        readOnlyContext: subflowOpts.readOnlyContext,\n        executionEnv: parentOpts.executionEnv,\n        throttlingErrorChecker: parentOpts.throttlingErrorChecker,\n        streamHandlers: parentOpts.streamHandlers,\n        extractor: parentOpts.extractor,\n        scopeProtectionMode: parentOpts.scopeProtectionMode,\n        subflows: parentSubflows, // Constructor shallow-copies this\n        enrichSnapshots: parentOpts.enrichSnapshots,\n        narrativeGenerator, // Share parent's — all events flow to one place\n        logger: parentOpts.logger,\n        signal: parentOpts.signal,\n        maxDepth: this._maxDepth,\n        parentSubflowId: subflowOpts.subflowId,\n        executionCounter: this._executionCounter, // Share counter — subflow continues global numbering\n      });\n\n      return {\n        execute: () => traverser.execute(),\n        getSubflowResults: () => traverser.getSubflowResults(),\n        getBreakState: () => traverser.getBreakState(),\n      };\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  /**\n   * Holds the top-level break flag for the duration of `execute()`. Kept as\n   * a field (not a local) so `getBreakState()` can surface the final state\n   * for callers like `SubflowExecutor` that implement `propagateBreak`.\n   */\n  private _topBreakFlag: { shouldBreak: boolean; reason?: string } = { shouldBreak: false };\n\n  async execute(branchPath?: string): Promise<TraversalResult> {\n    const context = this.executionRuntime.rootStageContext;\n    this._topBreakFlag = { shouldBreak: false };\n    return await this.executeNode(this.root, context, this._topBreakFlag, branchPath ?? '');\n  }\n\n  /**\n   * Break state captured at the top-level of the most recent `execute()`.\n   * `shouldBreak` is true when a stage called `scope.$break(reason)`; the\n   * optional `reason` carries the string passed to `$break`.\n   *\n   * Used by `SubflowExecutor` to propagate an inner subflow's break up to\n   * the parent traverser when the mount sets `propagateBreak: true`.\n   */\n  getBreakState(): { shouldBreak: boolean; reason?: string } {\n    return { ...this._topBreakFlag };\n  }\n\n  getRuntimeStructure(): SerializedPipelineStructure | undefined {\n    return this.structureManager.getStructure();\n  }\n\n  getSnapshot(options?: { redact?: boolean }) {\n    return this.executionRuntime.getSnapshot(options);\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  /**\n   * Build an O(1) ID→node map from the root graph.\n   * Used by NodeResolver to avoid repeated DFS on every loopTo() call.\n   * Depth-guarded at MAX_EXECUTE_DEPTH to prevent infinite recursion on cyclic graphs.\n   * Dynamic subflows and lazy-resolved nodes are added to stageMap at runtime but not to this map —\n   * those use the DFS fallback in NodeResolver.\n   */\n  private buildNodeIdMap(root: StageNode<TOut, TScope>): Map<string, StageNode<TOut, TScope>> {\n    const map = new Map<string, StageNode<TOut, TScope>>();\n    const visit = (node: StageNode<TOut, TScope>, depth: number): void => {\n      if (depth > FlowchartTraverser.MAX_EXECUTE_DEPTH) return;\n      if (map.has(node.id)) return; // already visited (avoids infinite loops on cyclic refs)\n      map.set(node.id, node);\n      if (node.children) {\n        for (const child of node.children) visit(child, depth + 1);\n      }\n      if (node.next) visit(node.next, depth + 1);\n    };\n    visit(root, 0);\n    return map;\n  }\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    // Primary: look up by id (stable identifier, keyed by FlowChartBuilder)\n    const byId = this.stageMap.get(node.id);\n    if (byId !== undefined) return byId;\n    // Fallback: look up by name (supports hand-crafted stageMaps in tests and advanced use)\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    // runtimeStageId is assigned in executeNode() before traversalContext creation,\n    // ensuring scope events and flow events use the same value.\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: BreakFlag,\n    branchPath?: string,\n  ): Promise<any> {\n    // ─── Recursion depth guard ───\n    // Each `await executeNode(...)` keeps the calling frame on the stack.\n    // Without a cap, an infinite loop or an excessively deep stage chain will\n    // eventually overflow the V8 call stack (~10 000 frames) with a cryptic\n    // \"Maximum call stack size exceeded\" error.  We fail early with a clear\n    // message so users can diagnose the cause (infinite loop, missing break, etc.).\n    // The increment is inside `try` so `finally` always decrements — no fragile\n    // gap between check and try entry.\n    try {\n      if (++this._executeDepth > this._maxDepth) {\n        throw new Error(\n          `FlowchartTraverser: maximum traversal depth exceeded (${this._maxDepth}). ` +\n            'Check for infinite loops or missing break conditions in your flowchart. ' +\n            `Last stage: '${node.name}'. ` +\n            'For loopTo() pipelines, consider adding a break condition or using RunOptions.maxDepth to raise the limit.',\n        );\n      }\n\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      // Assign runtimeStageId BEFORE traversalContext creation — ensures scope events\n      // (buffered by runtimeStageId) and flow events (flushed by traversalContext.runtimeStageId)\n      // use the same value. Must happen before executeStage AND before traversalContext.\n      const idx = this._executionCounter.value++;\n      context.runtimeStageId = buildRuntimeStageId(node.id, idx);\n\n      // Build traversal context for recorder events — created once per stage, shared by all events\n      const traversalContext: TraversalContext = {\n        stageId: node.id ?? context.stageId,\n        runtimeStageId: context.runtimeStageId,\n        stageName: node.name,\n        parentStageId: context.parent?.stageId,\n        subflowId: context.subflowId ?? this.parentSubflowId,\n        subflowPath: branchPath || undefined,\n        depth: this.computeContextDepth(context),\n      };\n\n      // ─── Phase 0a: LAZY RESOLVE — deferred subflow resolution ───\n      // Guard uses the per-traverser resolvedLazySubflows set (not the shared node) so\n      // concurrent traversers do not race on node.subflowResolver or clear it for each other.\n      if (node.isSubflowRoot && node.subflowResolver && !this.resolvedLazySubflows.has(node.subflowId!)) {\n        const resolved = node.subflowResolver();\n        const prefixedRoot = this.prefixNodeTree(resolved.root as StageNode<TOut, TScope>, node.subflowId!);\n\n        // Register the resolved subflow (same path as eager registration)\n        this.subflows[node.subflowId!] = { root: prefixedRoot };\n\n        // Merge stageMap entries\n        for (const [key, fn] of resolved.stageMap) {\n          const prefixedKey = `${node.subflowId}/${key}`;\n          if (!this.stageMap.has(prefixedKey)) {\n            this.stageMap.set(prefixedKey, fn as StageFunction<TOut, TScope>);\n          }\n        }\n\n        // Merge nested subflows\n        if (resolved.subflows) {\n          for (const [key, def] of Object.entries(resolved.subflows)) {\n            const prefixedKey = `${node.subflowId}/${key}`;\n            if (!this.subflows[prefixedKey]) {\n              this.subflows[prefixedKey] = def as { root: StageNode<TOut, TScope> };\n            }\n          }\n        }\n\n        // Update runtime structure with the now-resolved spec\n        this.structureManager.updateDynamicSubflow(\n          node.id,\n          node.subflowId!,\n          node.subflowName,\n          resolved.buildTimeStructure,\n        );\n\n        // Mark as resolved for THIS traverser — per-traverser set prevents re-entry\n        // without mutating the shared StageNode graph (which would race concurrent traversers).\n        this.resolvedLazySubflows.add(node.subflowId!);\n      }\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            traversalContext,\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        // ─── Break-flag check AFTER subflow returns ───\n        // If the subflow was mounted with `propagateBreak: true` and broke\n        // internally, `SubflowExecutor` has already flipped our breakFlag.\n        // Stop the outer traversal here — do not run the next linear stage.\n        if (breakFlag.shouldBreak) {\n          return subflowOutput;\n        }\n\n        if (node.next && shouldExecuteContinuation) {\n          const nextCtx = context.createNext(branchPath as string, node.next.name, node.next.id);\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      // Break handler wired to the scope. Captures the optional reason\n      // passed via `scope.$break(reason)` and parks it on the breakFlag so\n      // downstream code (FlowRecorder.onBreak, subflow propagation) can\n      // surface it. A second $break call in the same stage keeps the FIRST\n      // reason — first-break-wins — matching the \"execution stopped\" story.\n      const breakFn = (reason?: string) => {\n        breakFlag.shouldBreak = true;\n        if (reason !== undefined && breakFlag.reason === undefined) {\n          breakFlag.reason = reason;\n        }\n      };\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            traversalContext,\n          );\n\n          if (hasNext) {\n            const nextCtx = context.createNext(branchPath as string, node.next!.name, node.next!.id);\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          traversalContext,\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          // Use the isLoopRef flag set by loopTo() — do not rely on stageMap absence,\n          // since id-keyed stageMaps would otherwise cause loop targets to be executed directly.\n          const isLoopRef =\n            nextNode.isLoopRef === true ||\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, traversalContext);\n          const nextCtx = context.createNext(branchPath as string, nextNode.name, nextNode.id);\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          // PauseSignal is expected control flow, not an error — fire narrative, commit, re-throw.\n          if (isPauseSignal(error)) {\n            context.commit();\n            this.narrativeGenerator.onPause(node.name, node.id, error.pauseData, error.subflowPath, traversalContext);\n            throw error;\n          }\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, traversalContext);\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, traversalContext);\n\n        if (breakFlag.shouldBreak) {\n          // Forward the optional reason captured on breakFlag — set by the\n          // stage's $break(reason) call OR by a subflow's propagateBreak.\n          this.narrativeGenerator.onBreak(node.name, traversalContext, breakFlag.reason);\n          const reasonSuffix = breakFlag.reason ? ` (reason: ${breakFlag.reason})` : '';\n          this.logger.info(\n            `Execution stopped in pipeline (${branchPath}) after ${node.name} due to break condition${reasonSuffix}.`,\n          );\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\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              traversalContext,\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(\n              node,\n              context,\n              undefined,\n              branchPath,\n              traversalContext,\n            );\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            traversalContext,\n          );\n        }\n\n        this.narrativeGenerator.onNext(node.name, nextNode.name, nextNode.description, traversalContext);\n        context.addFlowDebugMessage('next', `Moving to ${nextNode.name} stage`, {\n          targetStage: nextNode.name,\n        });\n        const nextCtx = context.createNext(branchPath as string, nextNode.name, nextNode.id);\n        return await this.executeNode(nextNode, nextCtx, breakFlag, branchPath);\n      }\n\n      // ─── Phase 7: LEAF — no continuation ───\n      return stageOutput;\n    } finally {\n      this._executeDepth--;\n    }\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 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 prefixNodeTree(node: StageNode<TOut, TScope>, prefix: string): StageNode<TOut, TScope> {\n    if (!node) return node;\n    const clone: StageNode<TOut, TScope> = { ...node };\n    clone.name = `${prefix}/${node.name}`;\n    clone.id = `${prefix}/${clone.id}`;\n    if (clone.subflowId) clone.subflowId = `${prefix}/${clone.subflowId}`;\n    if (clone.next) clone.next = this.prefixNodeTree(clone.next, prefix);\n    if (clone.children) {\n      clone.children = clone.children.map((c) => this.prefixNodeTree(c, prefix));\n    }\n    return clone;\n  }\n\n  private autoRegisterSubflowDef(\n    subflowId: string,\n    subflowDef: NonNullable<StageNode['subflowDef']>,\n    mountNodeId?: string,\n  ): void {\n    // this.subflows is always initialized in the constructor; the null guard below is unreachable.\n    const subflowsDict = this.subflows;\n\n    // First-write-wins\n    const isNewRegistration = !subflowsDict[subflowId];\n    if (isNewRegistration && subflowDef.root) {\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"]}
@@ -27,4 +27,4 @@ export var ArrayMergeMode;
27
27
  /** Overwrite parent array with subflow output. Use for Dynamic loops. */
28
28
  ArrayMergeMode["Replace"] = "replace";
29
29
  })(ArrayMergeMode || (ArrayMergeMode = {}));
30
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/lib/engine/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAaH,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAe9E,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;AAmDF,8EAA8E;AAC9E,UAAU;AACV,8EAA8E;AAE9E;;GAEG;AACH,MAAM,CAAN,IAAY,cAKX;AALD,WAAY,cAAc;IACxB,wFAAwF;IACxF,mCAAiB,CAAA;IACjB,yEAAyE;IACzE,qCAAmB,CAAA;AACrB,CAAC,EALW,cAAc,KAAd,cAAc,QAKzB","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.js';\nimport type { FlowControlType, FlowMessage } from '../memory/types.js';\nimport type { ScopeProtectionMode } from '../scope/protection/types.js';\nimport type { Decider, Selector, StageNode } from './graph/StageNode.js';\nimport type { IControlFlowNarrative } from './narrative/types.js';\n\n// Re-export StageNode types for convenience\nexport type { Decider, Selector, StageNode } from './graph/StageNode.js';\n\n// Re-export pause types from pause/ library\nexport type { FlowchartCheckpoint, PausableHandler, PauseResult } from '../pause/index.js';\nexport { isPauseResult, isPauseSignal, PauseSignal } from '../pause/index.js';\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 | void> | TOut | void;\n\n/**\n * Stage function for pausable stages — return value is the pause data (any type).\n * Return non-void to pause, return void to continue normally.\n */\nexport type PausableStageFunction<TScope = any> = (\n  scope: TScope,\n  breakPipeline: () => void,\n) => Promise<unknown> | unknown;\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\n/**\n * Controls how array values from outputMapper are merged into parent scope.\n */\nexport enum ArrayMergeMode {\n  /** Append subflow output to existing parent array: [...existing, ...value]. Default. */\n  Concat = 'concat',\n  /** Overwrite parent array with subflow output. Use for Dynamic loops. */\n  Replace = 'replace',\n}\n\nexport interface SubflowMountOptions<TParentScope = any, TSubflowInput = any, TSubflowOutput = any> {\n  inputMapper?: (parentScope: TParentScope) => TSubflowInput;\n  /**\n   * Maps subflow output back into parent scope.\n   *\n   * **Array merge behavior** is controlled by `arrayMerge`:\n   * - `'concat'` (default): `[...existing, ...value]` — return only **delta** items\n   * - `'replace'`: overwrites the parent value — return the full array\n   *\n   * Scalar values are always replaced regardless of `arrayMerge`.\n   *\n   * @example\n   * ```typescript\n   * // Delta mode (default) — return only new items, concat appends\n   * outputMapper: (sf) => ({ messages: sf.newMessages })\n   *\n   * // Replace mode — return full array, parent value is overwritten\n   * // Useful in Dynamic loops where the subflow recomputes the full value each iteration\n   * outputMapper: (sf) => ({ toolDescriptions: sf.toolDescriptions }),\n   * arrayMerge: ArrayMergeMode.Replace,\n   *\n   * // Scalars are fine in both modes — always replaced\n   * outputMapper: (sf) => ({ status: sf.result, count: sf.total })\n   * ```\n   */\n  outputMapper?: (subflowOutput: TSubflowOutput, parentScope: TParentScope) => Record<string, unknown>;\n  /**\n   * Controls how array values from outputMapper are merged into parent scope.\n   * Applies only to top-level array keys. Nested arrays inside objects\n   * always use append (appendToArray) regardless of this setting.\n   *\n   * @default ArrayMergeMode.Concat\n   */\n  arrayMerge?: ArrayMergeMode;\n\n  /**\n   * When `true`, an inner `scope.$break(reason)` call inside this subflow\n   * propagates up to the parent — i.e., the parent's `breakFlag` is set\n   * after the subflow exits, terminating the parent's outer loop too.\n   *\n   * **Default: `false`** (current behaviour — inner break stops only the\n   * subflow; parent continues).\n   *\n   * ## When to use\n   *\n   * Set `propagateBreak: true` on subflow mounts that represent\n   * **terminal** branches — \"if this subflow fires, the outer loop is\n   * done\". Examples:\n   *\n   * - A human-review runner that takes over from an agent's tool-calling\n   *   loop and produces the final response.\n   * - A safety-gate subflow that halts the outer workflow when a policy\n   *   violation is detected.\n   * - An error-recovery subflow that restores state and then terminates.\n   *\n   * ## Semantics\n   *\n   * 1. Inside the subflow, a stage calls `scope.$break(reason)`.\n   * 2. The subflow's own execution stops (normal `$break` behaviour).\n   * 3. `SubflowExecutor` inspects the subflow's exit state. If\n   *    `propagateBreak === true` AND the inner break fired, it forwards\n   *    the break (and its reason) to the parent's `breakFlag`.\n   * 4. The parent traverser sees `shouldBreak` on its next step and exits.\n   * 5. A `FlowRecorder.onBreak` event fires at the parent-mount level with\n   *    `propagatedFromSubflow` = the subflow's id and the inner reason.\n   *\n   * ## Parallel/fan-out\n   *\n   * Follows the existing library rule in `ChildrenExecutor`: the parent\n   * breaks only when **every** child of a fork broke. A single\n   * `propagateBreak: true` subflow contributing its break to the count\n   * does not on its own terminate the parent fan-out.\n   *\n   * ## outputMapper still runs\n   *\n   * The subflow's `outputMapper` (if supplied) ALWAYS runs before the\n   * break propagates, so the subflow's partial state is still written to\n   * the parent scope. This is intentional — the typical use case is an\n   * \"escalation\" subflow whose output IS the final answer that needs to\n   * land in the parent scope before the outer loop terminates. If you\n   * want to suppress output mapping on break, check the break state\n   * inside your `outputMapper` and return `{}` early.\n   *\n   * @default false\n   */\n  propagateBreak?: boolean;\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// Subflow Traverser Factory\n// ---------------------------------------------------------------------------\n\n/**\n * SubflowTraverserFactory — Creates a FlowchartTraverser for subflow execution.\n *\n * Injected into SubflowExecutor to break the circular dependency:\n * FlowchartTraverser → SubflowExecutor → FlowchartTraverser.\n *\n * The factory captures parent traverser config (stageMap, scopeFactory, narrative, etc.)\n * in a closure. SubflowExecutor calls it with subflow-specific overrides (root, runtime, input).\n * The returned traverser uses the SAME 7-phase algorithm as the top-level traverser,\n * so deciders, selectors, loops, lazy subflows, and abort signals all work inside subflows.\n */\nexport type SubflowTraverserFactory<TOut = any, TScope = any> = (options: {\n  /** Root node of the subflow (with isSubflowRoot stripped). */\n  root: StageNode<TOut, TScope>;\n  /** Isolated execution runtime for the subflow. */\n  executionRuntime: IExecutionRuntime;\n  /** Mapped input from parent scope (becomes readOnlyContext for stages). */\n  readOnlyContext?: unknown;\n  /** Subflow identifier — used as branchPath for narrative context. */\n  subflowId?: string;\n}) => SubflowTraverserHandle<TOut, TScope>;\n\n/**\n * Handle returned by SubflowTraverserFactory.\n * Provides execute() + access to nested subflow results.\n */\nexport interface SubflowTraverserHandle<TOut = any, TScope = any> {\n  /** Execute the subflow's graph using the full 7-phase traversal algorithm. */\n  execute(): Promise<TraversalResult>;\n  /** Collect nested subflow results (from subflows mounted inside this subflow). */\n  getSubflowResults(): Map<string, SubflowResult>;\n  /**\n   * Final break state of the subflow after `execute()` returns.\n   *\n   *   - `shouldBreak: true`  → a stage inside the subflow called\n   *     `scope.$break(reason)`, stopping the subflow's own traversal.\n   *   - `reason`             → the optional string passed to `$break`.\n   *\n   * Used by `SubflowExecutor` to implement `SubflowMountOptions.propagateBreak`:\n   * if the mount opts in AND the subflow broke, the parent's break flag is\n   * forwarded.\n   */\n  getBreakState(): { shouldBreak: boolean; reason?: string };\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    recorders?: Array<{ id: string; name: string; data: 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?: 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   * Override the maximum recursive `executeNode` depth for this run.\n   * Defaults to `FlowchartTraverser.MAX_EXECUTE_DEPTH` (500).\n   * Useful when deeply nested subflows or long chains need more headroom.\n   * Must be >= 1.\n   */\n  maxDepth?: number;\n}\n\n// ---------------------------------------------------------------------------\n// Flow Control Narrative — canonical definitions live in memory/types.ts\n// ---------------------------------------------------------------------------\n\nexport type { FlowControlType, FlowMessage };\n\n// ---------------------------------------------------------------------------\n// Traversal Extractor\n// ---------------------------------------------------------------------------\n\nexport interface RuntimeStructureMetadata {\n  type: 'stage' | 'decider' | 'selector' | 'fork' | 'streaming' | 'subflow' | 'loop';\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/** Returned by run()/resume() when execution pauses. */\nexport type PausedResult = {\n  readonly paused: true;\n  readonly checkpoint: import('../pause/types.js').FlowchartCheckpoint;\n};\n\n/** Full return type of FlowChartExecutor.run() and resume(). */\nexport type ExecutorResult = TraversalResult | PausedResult;\n\n// ---------------------------------------------------------------------------\n// Serialized Pipeline Structure (for visualization)\n// ---------------------------------------------------------------------------\n\nexport interface SerializedPipelineNode {\n  name: string;\n  id: string;\n  type?:\n    | 'stage'\n    | 'decider'\n    | 'selector'\n    | 'fork'\n    | 'streaming'\n    | 'subflow'\n    | 'loop'\n    | 'user'\n    | 'tool'\n    | 'function'\n    | '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  /** When true, this stage can pause execution (PausableHandler pattern). */\n  isPausable?: 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  /** Scope factory — auto-embedded by flowChart<T>(). Executor reads this if no factory param. */\n  scopeFactory?: ScopeFactory<TScope>;\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"]}
30
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/lib/engine/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAaH,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAe9E,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;AAmDF,8EAA8E;AAC9E,UAAU;AACV,8EAA8E;AAE9E;;GAEG;AACH,MAAM,CAAN,IAAY,cAKX;AALD,WAAY,cAAc;IACxB,wFAAwF;IACxF,mCAAiB,CAAA;IACjB,yEAAyE;IACzE,qCAAmB,CAAA;AACrB,CAAC,EALW,cAAc,KAAd,cAAc,QAKzB","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.js';\nimport type { FlowControlType, FlowMessage } from '../memory/types.js';\nimport type { ScopeProtectionMode } from '../scope/protection/types.js';\nimport type { Decider, Selector, StageNode } from './graph/StageNode.js';\nimport type { IControlFlowNarrative } from './narrative/types.js';\n\n// Re-export StageNode types for convenience\nexport type { Decider, Selector, StageNode } from './graph/StageNode.js';\n\n// Re-export pause types from pause/ library\nexport type { FlowchartCheckpoint, PausableHandler, PauseResult } from '../pause/index.js';\nexport { isPauseResult, isPauseSignal, PauseSignal } from '../pause/index.js';\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 | void> | TOut | void;\n\n/**\n * Stage function for pausable stages — return value is the pause data (any type).\n * Return non-void to pause, return void to continue normally.\n */\nexport type PausableStageFunction<TScope = any> = (\n  scope: TScope,\n  breakPipeline: () => void,\n) => Promise<unknown> | unknown;\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\n/**\n * Controls how array values from outputMapper are merged into parent scope.\n */\nexport enum ArrayMergeMode {\n  /** Append subflow output to existing parent array: [...existing, ...value]. Default. */\n  Concat = 'concat',\n  /** Overwrite parent array with subflow output. Use for Dynamic loops. */\n  Replace = 'replace',\n}\n\nexport interface SubflowMountOptions<TParentScope = any, TSubflowInput = any, TSubflowOutput = any> {\n  inputMapper?: (parentScope: TParentScope) => TSubflowInput;\n  /**\n   * Maps subflow output back into parent scope.\n   *\n   * **Array merge behavior** is controlled by `arrayMerge`:\n   * - `'concat'` (default): `[...existing, ...value]` — return only **delta** items\n   * - `'replace'`: overwrites the parent value — return the full array\n   *\n   * Scalar values are always replaced regardless of `arrayMerge`.\n   *\n   * @example\n   * ```typescript\n   * // Delta mode (default) — return only new items, concat appends\n   * outputMapper: (sf) => ({ messages: sf.newMessages })\n   *\n   * // Replace mode — return full array, parent value is overwritten\n   * // Useful in Dynamic loops where the subflow recomputes the full value each iteration\n   * outputMapper: (sf) => ({ toolDescriptions: sf.toolDescriptions }),\n   * arrayMerge: ArrayMergeMode.Replace,\n   *\n   * // Scalars are fine in both modes — always replaced\n   * outputMapper: (sf) => ({ status: sf.result, count: sf.total })\n   * ```\n   */\n  outputMapper?: (subflowOutput: TSubflowOutput, parentScope: TParentScope) => Record<string, unknown>;\n  /**\n   * Controls how array values from outputMapper are merged into parent scope.\n   * Applies only to top-level array keys. Nested arrays inside objects\n   * always use append (appendToArray) regardless of this setting.\n   *\n   * @default ArrayMergeMode.Concat\n   */\n  arrayMerge?: ArrayMergeMode;\n\n  /**\n   * When `true`, an inner `scope.$break(reason)` call inside this subflow\n   * propagates up to the parent — i.e., the parent's `breakFlag` is set\n   * after the subflow exits, terminating the parent's outer loop too.\n   *\n   * **Default: `false`** (current behaviour — inner break stops only the\n   * subflow; parent continues).\n   *\n   * ## When to use\n   *\n   * Set `propagateBreak: true` on subflow mounts that represent\n   * **terminal** branches — \"if this subflow fires, the outer loop is\n   * done\". Examples:\n   *\n   * - A human-review runner that takes over from an agent's tool-calling\n   *   loop and produces the final response.\n   * - A safety-gate subflow that halts the outer workflow when a policy\n   *   violation is detected.\n   * - An error-recovery subflow that restores state and then terminates.\n   *\n   * ## Semantics\n   *\n   * 1. Inside the subflow, a stage calls `scope.$break(reason)`.\n   * 2. The subflow's own execution stops (normal `$break` behaviour).\n   * 3. `SubflowExecutor` inspects the subflow's exit state. If\n   *    `propagateBreak === true` AND the inner break fired, it forwards\n   *    the break (and its reason) to the parent's `breakFlag`.\n   * 4. The parent traverser sees `shouldBreak` on its next step and exits.\n   * 5. A `FlowRecorder.onBreak` event fires at the parent-mount level with\n   *    `propagatedFromSubflow` = the subflow's id and the inner reason.\n   *\n   * ## Parallel/fan-out\n   *\n   * Follows the existing library rule in `ChildrenExecutor`: the parent\n   * breaks only when **every** child of a fork broke. A single\n   * `propagateBreak: true` subflow contributing its break to the count\n   * does not on its own terminate the parent fan-out.\n   *\n   * ## outputMapper still runs\n   *\n   * The subflow's `outputMapper` (if supplied) ALWAYS runs before the\n   * break propagates, so the subflow's partial state is still written to\n   * the parent scope. This is intentional — the typical use case is an\n   * \"escalation\" subflow whose output IS the final answer that needs to\n   * land in the parent scope before the outer loop terminates. If you\n   * want to suppress output mapping on break, check the break state\n   * inside your `outputMapper` and return `{}` early.\n   *\n   * @default false\n   */\n  propagateBreak?: boolean;\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// Subflow Traverser Factory\n// ---------------------------------------------------------------------------\n\n/**\n * SubflowTraverserFactory — Creates a FlowchartTraverser for subflow execution.\n *\n * Injected into SubflowExecutor to break the circular dependency:\n * FlowchartTraverser → SubflowExecutor → FlowchartTraverser.\n *\n * The factory captures parent traverser config (stageMap, scopeFactory, narrative, etc.)\n * in a closure. SubflowExecutor calls it with subflow-specific overrides (root, runtime, input).\n * The returned traverser uses the SAME 7-phase algorithm as the top-level traverser,\n * so deciders, selectors, loops, lazy subflows, and abort signals all work inside subflows.\n */\nexport type SubflowTraverserFactory<TOut = any, TScope = any> = (options: {\n  /** Root node of the subflow (with isSubflowRoot stripped). */\n  root: StageNode<TOut, TScope>;\n  /** Isolated execution runtime for the subflow. */\n  executionRuntime: IExecutionRuntime;\n  /** Mapped input from parent scope (becomes readOnlyContext for stages). */\n  readOnlyContext?: unknown;\n  /** Subflow identifier — used as branchPath for narrative context. */\n  subflowId?: string;\n}) => SubflowTraverserHandle<TOut, TScope>;\n\n/**\n * Handle returned by SubflowTraverserFactory.\n * Provides execute() + access to nested subflow results.\n */\nexport interface SubflowTraverserHandle<TOut = any, TScope = any> {\n  /** Execute the subflow's graph using the full 7-phase traversal algorithm. */\n  execute(): Promise<TraversalResult>;\n  /** Collect nested subflow results (from subflows mounted inside this subflow). */\n  getSubflowResults(): Map<string, SubflowResult>;\n  /**\n   * Final break state of the subflow after `execute()` returns.\n   *\n   *   - `shouldBreak: true`  → a stage inside the subflow called\n   *     `scope.$break(reason)`, stopping the subflow's own traversal.\n   *   - `reason`             → the optional string passed to `$break`.\n   *\n   * Used by `SubflowExecutor` to implement `SubflowMountOptions.propagateBreak`:\n   * if the mount opts in AND the subflow broke, the parent's break flag is\n   * forwarded.\n   */\n  getBreakState(): { shouldBreak: boolean; reason?: string };\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(options?: { redact?: boolean }): {\n    sharedState: Record<string, unknown>;\n    executionTree: unknown;\n    commitLog: unknown[];\n    subflowResults?: Record<string, unknown>;\n    recorders?: Array<{ id: string; name: string; data: 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?: 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   * Override the maximum recursive `executeNode` depth for this run.\n   * Defaults to `FlowchartTraverser.MAX_EXECUTE_DEPTH` (500).\n   * Useful when deeply nested subflows or long chains need more headroom.\n   * Must be >= 1.\n   */\n  maxDepth?: number;\n}\n\n// ---------------------------------------------------------------------------\n// Flow Control Narrative — canonical definitions live in memory/types.ts\n// ---------------------------------------------------------------------------\n\nexport type { FlowControlType, FlowMessage };\n\n// ---------------------------------------------------------------------------\n// Traversal Extractor\n// ---------------------------------------------------------------------------\n\nexport interface RuntimeStructureMetadata {\n  type: 'stage' | 'decider' | 'selector' | 'fork' | 'streaming' | 'subflow' | 'loop';\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/** Returned by run()/resume() when execution pauses. */\nexport type PausedResult = {\n  readonly paused: true;\n  readonly checkpoint: import('../pause/types.js').FlowchartCheckpoint;\n};\n\n/** Full return type of FlowChartExecutor.run() and resume(). */\nexport type ExecutorResult = TraversalResult | PausedResult;\n\n// ---------------------------------------------------------------------------\n// Serialized Pipeline Structure (for visualization)\n// ---------------------------------------------------------------------------\n\nexport interface SerializedPipelineNode {\n  name: string;\n  id: string;\n  type?:\n    | 'stage'\n    | 'decider'\n    | 'selector'\n    | 'fork'\n    | 'streaming'\n    | 'subflow'\n    | 'loop'\n    | 'user'\n    | 'tool'\n    | 'function'\n    | '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  /** When true, this stage can pause execution (PausableHandler pattern). */\n  isPausable?: 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  /** Scope factory — auto-embedded by flowChart<T>(). Executor reads this if no factory param. */\n  scopeFactory?: ScopeFactory<TScope>;\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"]}