footprintjs 0.2.1 → 0.2.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (44) hide show
  1. package/README.md +85 -32
  2. package/dist/esm/lib/builder/FlowChartBuilder.js +54 -91
  3. package/dist/esm/lib/builder/types.js +1 -1
  4. package/dist/esm/lib/engine/graph/StageNode.js +1 -1
  5. package/dist/esm/lib/engine/handlers/ChildrenExecutor.js +5 -5
  6. package/dist/esm/lib/engine/handlers/ContinuationResolver.js +6 -6
  7. package/dist/esm/lib/engine/handlers/DeciderHandler.js +4 -4
  8. package/dist/esm/lib/engine/handlers/NodeResolver.js +1 -2
  9. package/dist/esm/lib/engine/handlers/RuntimeStructureManager.js +1 -2
  10. package/dist/esm/lib/engine/handlers/SelectorHandler.js +6 -6
  11. package/dist/esm/lib/engine/narrative/ControlFlowNarrativeGenerator.js +13 -18
  12. package/dist/esm/lib/engine/narrative/types.js +1 -1
  13. package/dist/esm/lib/engine/traversal/FlowchartTraverser.js +10 -11
  14. package/dist/esm/lib/engine/types.js +1 -1
  15. package/dist/esm/lib/runner/ExecutionRuntime.js +1 -1
  16. package/dist/esm/types/lib/builder/FlowChartBuilder.d.ts +8 -10
  17. package/dist/esm/types/lib/builder/types.d.ts +0 -6
  18. package/dist/esm/types/lib/engine/graph/StageNode.d.ts +0 -2
  19. package/dist/esm/types/lib/engine/narrative/ControlFlowNarrativeGenerator.d.ts +6 -6
  20. package/dist/esm/types/lib/engine/narrative/types.d.ts +6 -6
  21. package/dist/esm/types/lib/engine/types.d.ts +0 -1
  22. package/dist/esm/types/lib/runner/ExecutionRuntime.d.ts +0 -1
  23. package/dist/lib/builder/FlowChartBuilder.js +54 -91
  24. package/dist/lib/builder/types.js +1 -1
  25. package/dist/lib/engine/graph/StageNode.js +1 -1
  26. package/dist/lib/engine/handlers/ChildrenExecutor.js +5 -5
  27. package/dist/lib/engine/handlers/ContinuationResolver.js +6 -6
  28. package/dist/lib/engine/handlers/DeciderHandler.js +4 -4
  29. package/dist/lib/engine/handlers/NodeResolver.js +1 -2
  30. package/dist/lib/engine/handlers/RuntimeStructureManager.js +1 -2
  31. package/dist/lib/engine/handlers/SelectorHandler.js +6 -6
  32. package/dist/lib/engine/narrative/ControlFlowNarrativeGenerator.js +13 -18
  33. package/dist/lib/engine/narrative/types.js +1 -1
  34. package/dist/lib/engine/traversal/FlowchartTraverser.js +10 -11
  35. package/dist/lib/engine/types.js +1 -1
  36. package/dist/lib/runner/ExecutionRuntime.js +1 -1
  37. package/dist/types/lib/builder/FlowChartBuilder.d.ts +8 -10
  38. package/dist/types/lib/builder/types.d.ts +0 -6
  39. package/dist/types/lib/engine/graph/StageNode.d.ts +0 -2
  40. package/dist/types/lib/engine/narrative/ControlFlowNarrativeGenerator.d.ts +6 -6
  41. package/dist/types/lib/engine/narrative/types.d.ts +6 -6
  42. package/dist/types/lib/engine/types.d.ts +0 -1
  43. package/dist/types/lib/runner/ExecutionRuntime.d.ts +0 -1
  44. package/package.json +1 -1
@@ -16,4 +16,4 @@ exports.defaultLogger = {
16
16
  error: (message, ...args) => console.error(message, ...args),
17
17
  warn: (message, ...args) => console.warn(message, ...args),
18
18
  };
19
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/lib/engine/types.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;;AAuBH,oCAAoC;AACpC,wDAAwD;AAC3C,QAAA,aAAa,GAAY;IACpC,IAAI,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;IACvE,GAAG,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;IACrE,KAAK,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;IACzE,KAAK,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;IACzE,IAAI,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;CACxE,CAAC","sourcesContent":["/**\n * types.ts — All type definitions for the engine library.\n *\n * Centralizes type definitions to avoid circular dependencies.\n * Every handler receives HandlerDeps (the DI bag) instead of importing the traverser.\n */\n\nimport type { StageContext } from '../memory/StageContext';\nimport type { ScopeProtectionMode } from '../scope/protection/types';\nimport type { Decider, Selector, StageNode } from './graph/StageNode';\nimport type { IControlFlowNarrative } from './narrative/types';\n\n// Re-export StageNode types for convenience\nexport type { Decider, Selector, StageNode } from './graph/StageNode';\n\n// ---------------------------------------------------------------------------\n// Logger\n// ---------------------------------------------------------------------------\n\n/** Minimal logging contract. Mirrors Console API subset. */\nexport interface ILogger {\n  info(message?: any, ...optionalParams: any[]): void;\n  log(message?: any, ...optionalParams: any[]): void;\n  debug(message?: any, ...optionalParams: any[]): void;\n  error(message?: any, ...optionalParams: any[]): void;\n  warn(message?: any, ...optionalParams: any[]): void;\n}\n\n/** Default console-based logger. */\n/* istanbul ignore next -- trivial console delegation */\nexport const defaultLogger: ILogger = {\n  info: (message?: any, ...args: any[]) => console.info(message, ...args),\n  log: (message?: any, ...args: any[]) => console.log(message, ...args),\n  debug: (message?: any, ...args: any[]) => console.debug(message, ...args),\n  error: (message?: any, ...args: any[]) => console.error(message, ...args),\n  warn: (message?: any, ...args: any[]) => console.warn(message, ...args),\n};\n\n// ---------------------------------------------------------------------------\n// Stage Function\n// ---------------------------------------------------------------------------\n\n/** Callback that receives tokens during streaming. */\nexport type StreamCallback = (token: string) => void;\n\n/**\n * The function signature for stage handlers.\n * - TOut: return type produced by the stage\n * - TScope: the scope object passed to the stage\n * - Optional 3rd parameter `streamCallback` injected for streaming stages.\n */\nexport type StageFunction<TOut = any, TScope = any> = (\n  scope: TScope,\n  breakPipeline: () => void,\n  streamCallback?: StreamCallback,\n) => Promise<TOut> | TOut;\n\n/** Factory that creates a scope instance for each stage. */\nexport type ScopeFactory<TScope = any> = (\n  context: StageContext,\n  stageName: string,\n  readOnlyContext?: unknown,\n) => TScope;\n\n// ---------------------------------------------------------------------------\n// Streaming\n// ---------------------------------------------------------------------------\n\nexport type StreamTokenHandler = (streamId: string, token: string) => void;\nexport type StreamLifecycleHandler = (streamId: string, fullText?: string) => void;\n\nexport interface StreamHandlers {\n  onToken?: StreamTokenHandler;\n  onStart?: StreamLifecycleHandler;\n  onEnd?: StreamLifecycleHandler;\n}\n\n// ---------------------------------------------------------------------------\n// Subflow\n// ---------------------------------------------------------------------------\n\nexport interface SubflowMountOptions<TParentScope = any, TSubflowInput = any, TSubflowOutput = any> {\n  inputMapper?: (parentScope: TParentScope) => TSubflowInput;\n  outputMapper?: (subflowOutput: TSubflowOutput, parentScope: TParentScope) => Record<string, unknown>;\n}\n\nexport interface SubflowResult {\n  subflowId: string;\n  subflowName: string;\n  treeContext: {\n    globalContext: Record<string, unknown>;\n    stageContexts: Record<string, unknown>;\n    history: unknown[];\n  };\n  parentStageId: string;\n  pipelineStructure?: unknown;\n}\n\n// ---------------------------------------------------------------------------\n// Execution Runtime Interface\n// ---------------------------------------------------------------------------\n\n/**\n * IExecutionRuntime — Interface for the runtime environment.\n *\n * Defines the contract that engine handlers need from the runner layer,\n * avoiding circular imports between engine/ and runner/.\n */\nexport interface IExecutionRuntime {\n  globalStore: { getState(): Record<string, unknown> };\n  rootStageContext: StageContext;\n  executionHistory: { list(): unknown[] };\n  getSnapshot(): { sharedState: Record<string, unknown>; executionTree: unknown; commitLog: unknown[] };\n  setRootObject(path: string[], key: string, value: unknown): void;\n  getPipelines(): string[];\n}\n\n// ---------------------------------------------------------------------------\n// Handler Dependencies (DI bag) — was PipelineContext\n// ---------------------------------------------------------------------------\n\n/**\n * HandlerDeps — Dependency injection bag passed to all handler modules.\n *\n * Provides shared state (stageMap, runtime, scopeFactory, etc.) without\n * handlers needing to import the traverser directly. Avoids circular deps.\n */\nexport interface HandlerDeps<TOut = any, TScope = any> {\n  stageMap: Map<string, StageFunction<TOut, TScope>>;\n  root: StageNode<TOut, TScope>;\n  executionRuntime: IExecutionRuntime;\n  ScopeFactory: ScopeFactory<TScope>;\n  subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  throttlingErrorChecker?: (error: unknown) => boolean;\n  streamHandlers?: StreamHandlers;\n  scopeProtectionMode: ScopeProtectionMode;\n  readOnlyContext?: unknown;\n  narrativeGenerator: IControlFlowNarrative;\n  logger: ILogger;\n  signal?: AbortSignal;\n}\n\n/** Options for FlowChartExecutor.run(). */\nexport interface RunOptions {\n  /** AbortSignal for cooperative cancellation. */\n  signal?: AbortSignal;\n  /** Timeout in milliseconds. Creates an internal AbortController. */\n  timeoutMs?: number;\n}\n\n// ---------------------------------------------------------------------------\n// Flow Control Narrative\n// ---------------------------------------------------------------------------\n\nexport type FlowControlType = 'next' | 'branch' | 'children' | 'selected' | 'subflow' | 'loop';\n\nexport interface FlowMessage {\n  type: FlowControlType;\n  description: string;\n  targetStage?: string | string[];\n  rationale?: string;\n  count?: number;\n  iteration?: number;\n  timestamp?: number;\n}\n\n// ---------------------------------------------------------------------------\n// Traversal Extractor\n// ---------------------------------------------------------------------------\n\nexport interface RuntimeStructureMetadata {\n  type: 'stage' | 'decider' | 'fork' | 'streaming';\n  subflowId?: string;\n  isSubflowRoot?: boolean;\n  subflowName?: string;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  loopTarget?: string;\n  isDynamic?: boolean;\n  isLoopReference?: boolean;\n  streamId?: string;\n}\n\nexport interface StageSnapshot<TOut = any, TScope = any> {\n  node: StageNode<TOut, TScope>;\n  context: StageContext;\n  stepNumber: number;\n  structureMetadata: RuntimeStructureMetadata;\n  scopeState?: Record<string, unknown>;\n  debugInfo?: {\n    logs: Record<string, unknown>;\n    errors: Record<string, unknown>;\n    metrics: Record<string, unknown>;\n    evals: Record<string, unknown>;\n    flowMessages?: FlowMessage[];\n  };\n  stageOutput?: unknown;\n  errorInfo?: { type: string; message: string };\n  historyIndex?: number;\n}\n\nexport type TraversalExtractor<TResult = unknown> = (snapshot: StageSnapshot) => TResult | undefined | null;\n\nexport interface ExtractorError {\n  stagePath: string;\n  message: string;\n  error: unknown;\n}\n\n// ---------------------------------------------------------------------------\n// Node Result\n// ---------------------------------------------------------------------------\n\nexport type NodeResultType = {\n  id: string;\n  result: unknown;\n  isError?: boolean;\n};\n\n// ---------------------------------------------------------------------------\n// Execution Response\n// ---------------------------------------------------------------------------\n\nexport type BranchResult = {\n  result: string | Error;\n  isError: boolean;\n};\n\nexport type BranchResults = { [branchId: string]: BranchResult };\nexport type TraversalResult = BranchResults | string | Error;\n\n// ---------------------------------------------------------------------------\n// Serialized Pipeline Structure (for visualization)\n// ---------------------------------------------------------------------------\n\nexport interface SerializedPipelineNode {\n  name: string;\n  id?: string;\n  type?: 'stage' | 'decider' | 'fork' | 'streaming' | 'loop' | 'user' | 'tool' | 'function' | 'sequence';\n  displayName?: string;\n  description?: string;\n  children?: SerializedPipelineNode[];\n  next?: SerializedPipelineNode;\n  branches?: Record<string, SerializedPipelineNode>;\n  hasDecider?: boolean;\n  hasSelector?: boolean;\n  hasSubtree?: boolean;\n  isStreaming?: boolean;\n  streamId?: string;\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n  loopTarget?: string;\n  isLoopReference?: boolean;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  isDynamic?: boolean;\n}\n\n// ---------------------------------------------------------------------------\n// FlowChart (compiled output of FlowChartBuilder)\n// ---------------------------------------------------------------------------\n\nexport type FlowChart<TOut = any, TScope = any> = {\n  root: StageNode<TOut, TScope>;\n  stageMap: Map<string, StageFunction<TOut, TScope>>;\n  extractor?: TraversalExtractor;\n  subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  enrichSnapshots?: boolean;\n  enableNarrative?: boolean;\n  logger?: ILogger;\n  buildTimeStructure?: SerializedPipelineStructure;\n};\n\n/** Alias for SerializedPipelineNode used as full structure */\nexport type SerializedPipelineStructure = SerializedPipelineNode & {\n  branchIds?: string[];\n  subflowStructure?: SerializedPipelineStructure;\n  iterationCount?: number;\n};\n"]}
19
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/lib/engine/types.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;;AAuBH,oCAAoC;AACpC,wDAAwD;AAC3C,QAAA,aAAa,GAAY;IACpC,IAAI,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;IACvE,GAAG,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;IACrE,KAAK,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;IACzE,KAAK,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;IACzE,IAAI,EAAE,CAAC,OAAa,EAAE,GAAG,IAAW,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;CACxE,CAAC","sourcesContent":["/**\n * types.ts — All type definitions for the engine library.\n *\n * Centralizes type definitions to avoid circular dependencies.\n * Every handler receives HandlerDeps (the DI bag) instead of importing the traverser.\n */\n\nimport type { StageContext } from '../memory/StageContext';\nimport type { ScopeProtectionMode } from '../scope/protection/types';\nimport type { Decider, Selector, StageNode } from './graph/StageNode';\nimport type { IControlFlowNarrative } from './narrative/types';\n\n// Re-export StageNode types for convenience\nexport type { Decider, Selector, StageNode } from './graph/StageNode';\n\n// ---------------------------------------------------------------------------\n// Logger\n// ---------------------------------------------------------------------------\n\n/** Minimal logging contract. Mirrors Console API subset. */\nexport interface ILogger {\n  info(message?: any, ...optionalParams: any[]): void;\n  log(message?: any, ...optionalParams: any[]): void;\n  debug(message?: any, ...optionalParams: any[]): void;\n  error(message?: any, ...optionalParams: any[]): void;\n  warn(message?: any, ...optionalParams: any[]): void;\n}\n\n/** Default console-based logger. */\n/* istanbul ignore next -- trivial console delegation */\nexport const defaultLogger: ILogger = {\n  info: (message?: any, ...args: any[]) => console.info(message, ...args),\n  log: (message?: any, ...args: any[]) => console.log(message, ...args),\n  debug: (message?: any, ...args: any[]) => console.debug(message, ...args),\n  error: (message?: any, ...args: any[]) => console.error(message, ...args),\n  warn: (message?: any, ...args: any[]) => console.warn(message, ...args),\n};\n\n// ---------------------------------------------------------------------------\n// Stage Function\n// ---------------------------------------------------------------------------\n\n/** Callback that receives tokens during streaming. */\nexport type StreamCallback = (token: string) => void;\n\n/**\n * The function signature for stage handlers.\n * - TOut: return type produced by the stage\n * - TScope: the scope object passed to the stage\n * - Optional 3rd parameter `streamCallback` injected for streaming stages.\n */\nexport type StageFunction<TOut = any, TScope = any> = (\n  scope: TScope,\n  breakPipeline: () => void,\n  streamCallback?: StreamCallback,\n) => Promise<TOut> | TOut;\n\n/** Factory that creates a scope instance for each stage. */\nexport type ScopeFactory<TScope = any> = (\n  context: StageContext,\n  stageName: string,\n  readOnlyContext?: unknown,\n) => TScope;\n\n// ---------------------------------------------------------------------------\n// Streaming\n// ---------------------------------------------------------------------------\n\nexport type StreamTokenHandler = (streamId: string, token: string) => void;\nexport type StreamLifecycleHandler = (streamId: string, fullText?: string) => void;\n\nexport interface StreamHandlers {\n  onToken?: StreamTokenHandler;\n  onStart?: StreamLifecycleHandler;\n  onEnd?: StreamLifecycleHandler;\n}\n\n// ---------------------------------------------------------------------------\n// Subflow\n// ---------------------------------------------------------------------------\n\nexport interface SubflowMountOptions<TParentScope = any, TSubflowInput = any, TSubflowOutput = any> {\n  inputMapper?: (parentScope: TParentScope) => TSubflowInput;\n  outputMapper?: (subflowOutput: TSubflowOutput, parentScope: TParentScope) => Record<string, unknown>;\n}\n\nexport interface SubflowResult {\n  subflowId: string;\n  subflowName: string;\n  treeContext: {\n    globalContext: Record<string, unknown>;\n    stageContexts: Record<string, unknown>;\n    history: unknown[];\n  };\n  parentStageId: string;\n  pipelineStructure?: unknown;\n}\n\n// ---------------------------------------------------------------------------\n// Execution Runtime Interface\n// ---------------------------------------------------------------------------\n\n/**\n * IExecutionRuntime — Interface for the runtime environment.\n *\n * Defines the contract that engine handlers need from the runner layer,\n * avoiding circular imports between engine/ and runner/.\n */\nexport interface IExecutionRuntime {\n  globalStore: { getState(): Record<string, unknown> };\n  rootStageContext: StageContext;\n  executionHistory: { list(): unknown[] };\n  getSnapshot(): { sharedState: Record<string, unknown>; executionTree: unknown; commitLog: unknown[] };\n  setRootObject(path: string[], key: string, value: unknown): void;\n  getPipelines(): string[];\n}\n\n// ---------------------------------------------------------------------------\n// Handler Dependencies (DI bag) — was PipelineContext\n// ---------------------------------------------------------------------------\n\n/**\n * HandlerDeps — Dependency injection bag passed to all handler modules.\n *\n * Provides shared state (stageMap, runtime, scopeFactory, etc.) without\n * handlers needing to import the traverser directly. Avoids circular deps.\n */\nexport interface HandlerDeps<TOut = any, TScope = any> {\n  stageMap: Map<string, StageFunction<TOut, TScope>>;\n  root: StageNode<TOut, TScope>;\n  executionRuntime: IExecutionRuntime;\n  ScopeFactory: ScopeFactory<TScope>;\n  subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  throttlingErrorChecker?: (error: unknown) => boolean;\n  streamHandlers?: StreamHandlers;\n  scopeProtectionMode: ScopeProtectionMode;\n  readOnlyContext?: unknown;\n  narrativeGenerator: IControlFlowNarrative;\n  logger: ILogger;\n  signal?: AbortSignal;\n}\n\n/** Options for FlowChartExecutor.run(). */\nexport interface RunOptions {\n  /** AbortSignal for cooperative cancellation. */\n  signal?: AbortSignal;\n  /** Timeout in milliseconds. Creates an internal AbortController. */\n  timeoutMs?: number;\n}\n\n// ---------------------------------------------------------------------------\n// Flow Control Narrative\n// ---------------------------------------------------------------------------\n\nexport type FlowControlType = 'next' | 'branch' | 'children' | 'selected' | 'subflow' | 'loop';\n\nexport interface FlowMessage {\n  type: FlowControlType;\n  description: string;\n  targetStage?: string | string[];\n  rationale?: string;\n  count?: number;\n  iteration?: number;\n  timestamp?: number;\n}\n\n// ---------------------------------------------------------------------------\n// Traversal Extractor\n// ---------------------------------------------------------------------------\n\nexport interface RuntimeStructureMetadata {\n  type: 'stage' | 'decider' | 'fork' | 'streaming';\n  subflowId?: string;\n  isSubflowRoot?: boolean;\n  subflowName?: string;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  loopTarget?: string;\n  isDynamic?: boolean;\n  isLoopReference?: boolean;\n  streamId?: string;\n}\n\nexport interface StageSnapshot<TOut = any, TScope = any> {\n  node: StageNode<TOut, TScope>;\n  context: StageContext;\n  stepNumber: number;\n  structureMetadata: RuntimeStructureMetadata;\n  scopeState?: Record<string, unknown>;\n  debugInfo?: {\n    logs: Record<string, unknown>;\n    errors: Record<string, unknown>;\n    metrics: Record<string, unknown>;\n    evals: Record<string, unknown>;\n    flowMessages?: FlowMessage[];\n  };\n  stageOutput?: unknown;\n  errorInfo?: { type: string; message: string };\n  historyIndex?: number;\n}\n\nexport type TraversalExtractor<TResult = unknown> = (snapshot: StageSnapshot) => TResult | undefined | null;\n\nexport interface ExtractorError {\n  stagePath: string;\n  message: string;\n  error: unknown;\n}\n\n// ---------------------------------------------------------------------------\n// Node Result\n// ---------------------------------------------------------------------------\n\nexport type NodeResultType = {\n  id: string;\n  result: unknown;\n  isError?: boolean;\n};\n\n// ---------------------------------------------------------------------------\n// Execution Response\n// ---------------------------------------------------------------------------\n\nexport type BranchResult = {\n  result: string | Error;\n  isError: boolean;\n};\n\nexport type BranchResults = { [branchId: string]: BranchResult };\nexport type TraversalResult = BranchResults | string | Error;\n\n// ---------------------------------------------------------------------------\n// Serialized Pipeline Structure (for visualization)\n// ---------------------------------------------------------------------------\n\nexport interface SerializedPipelineNode {\n  name: string;\n  id?: string;\n  type?: 'stage' | 'decider' | 'fork' | 'streaming' | 'loop' | 'user' | 'tool' | 'function' | 'sequence';\n  description?: string;\n  children?: SerializedPipelineNode[];\n  next?: SerializedPipelineNode;\n  branches?: Record<string, SerializedPipelineNode>;\n  hasDecider?: boolean;\n  hasSelector?: boolean;\n  hasSubtree?: boolean;\n  isStreaming?: boolean;\n  streamId?: string;\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n  loopTarget?: string;\n  isLoopReference?: boolean;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  isDynamic?: boolean;\n}\n\n// ---------------------------------------------------------------------------\n// FlowChart (compiled output of FlowChartBuilder)\n// ---------------------------------------------------------------------------\n\nexport type FlowChart<TOut = any, TScope = any> = {\n  root: StageNode<TOut, TScope>;\n  stageMap: Map<string, StageFunction<TOut, TScope>>;\n  extractor?: TraversalExtractor;\n  subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  enrichSnapshots?: boolean;\n  enableNarrative?: boolean;\n  logger?: ILogger;\n  buildTimeStructure?: SerializedPipelineStructure;\n};\n\n/** Alias for SerializedPipelineNode used as full structure */\nexport type SerializedPipelineStructure = SerializedPipelineNode & {\n  branchIds?: string[];\n  subflowStructure?: SerializedPipelineStructure;\n  iterationCount?: number;\n};\n"]}
@@ -65,4 +65,4 @@ class ExecutionRuntime {
65
65
  }
66
66
  }
67
67
  exports.ExecutionRuntime = ExecutionRuntime;
68
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRXhlY3V0aW9uUnVudGltZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvcnVubmVyL0V4ZWN1dGlvblJ1bnRpbWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7O0dBVUc7OztBQUVILGlEQUE4QztBQUM5Qyx5REFBc0Q7QUFDdEQseURBQXNEO0FBa0J0RCxNQUFhLGdCQUFnQjtJQUszQixZQUFZLFFBQWdCLEVBQUUsYUFBdUIsRUFBRSxZQUFzQjtRQUMzRSxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxtQkFBUSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ25ELElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSwyQkFBWSxDQUFDLGFBQWEsRUFBRSxZQUFZLENBQUMsQ0FBQztRQUNqRSxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSwyQkFBWSxDQUFDLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRSxFQUFFLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDdEcsQ0FBQztJQUVELFlBQVk7UUFDVixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQzFDLE9BQU8sS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBb0MsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDeEYsQ0FBQztJQUVELGFBQWEsQ0FBQyxJQUFjLEVBQUUsR0FBVyxFQUFFLEtBQWM7UUFDdkQsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFNBQVMsQ0FBQyxJQUFJLEVBQUUsR0FBRyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFRCxXQUFXO1FBQ1QsT0FBTztZQUNMLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsRUFBRTtZQUN4QyxhQUFhLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFdBQVcsRUFBRTtZQUNsRCxTQUFTLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksRUFBRTtTQUN4QyxDQUFDO0lBQ0osQ0FBQztJQUVELGdCQUFnQjtRQUNkLE1BQU0sU0FBUyxHQUFxQixFQUFFLENBQUM7UUFDdkMsSUFBSSxTQUFTLEdBQUcsQ0FBQyxDQUFDO1FBRWxCLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUMsT0FBTyxFQUFFLEVBQUU7WUFDdEQsTUFBTSxhQUFhLEdBQUksT0FBTyxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsT0FBb0IsSUFBSSxFQUFFLENBQUM7WUFDM0UsTUFBTSxZQUFZLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxZQUFZLENBQUM7WUFDaEQsTUFBTSxXQUFXLEdBQUcsWUFBWSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO1lBRTFFLFNBQVMsQ0FBQyxJQUFJLENBQUM7Z0JBQ2IsT0FBTyxFQUFFLE9BQU8sQ0FBQyxVQUFVLEVBQUU7Z0JBQzdCLFNBQVMsRUFBRSxPQUFPLENBQUMsU0FBUztnQkFDNUIsYUFBYTtnQkFDYixXQUFXO2dCQUNYLFNBQVMsRUFBRSxTQUFTLEVBQUU7YUFDdkIsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFFSCxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0lBRU8sZUFBZSxDQUFDLE9BQXFCLEVBQUUsT0FBb0M7UUFDakYsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2pCLElBQUksT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ3JCLEtBQUssTUFBTSxLQUFLLElBQUksT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDO2dCQUNyQyxJQUFJLENBQUMsZUFBZSxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQztZQUN2QyxDQUFDO1FBQ0gsQ0FBQztRQUNELElBQUksT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ2pCLElBQUksQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxPQUFPLENBQUMsQ0FBQztRQUM5QyxDQUFDO0lBQ0gsQ0FBQztDQUNGO0FBNURELDRDQTREQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXhlY3V0aW9uUnVudGltZSDigJQgVGhlIHJ1bnRpbWUgZW52aXJvbm1lbnQgZm9yIG9uZSBmbG93Y2hhcnQgZXhlY3V0aW9uLlxuICpcbiAqIFdpcmVzIHVwIHRoZSB0aHJlZSBtZW1vcnkgcHJpbWl0aXZlcyBpbnRvIGEgc2luZ2xlIGNvbnRhaW5lcjpcbiAqICAgLSBTaGFyZWRNZW1vcnkgKHRoZSBoZWFwIOKAlCBzaGFyZWQgc3RhdGUgYWNyb3NzIGFsbCBzdGFnZXMpXG4gKiAgIC0gU3RhZ2VDb250ZXh0ICAodGhlIGNhbGwgc3RhY2sg4oCUIHBlci1zdGFnZSBleGVjdXRpb24gdHJlZSlcbiAqICAgLSBFdmVudExvZyAgICAgICh0aGUgdHJhbnNhY3Rpb24gbG9nIOKAlCBjb21taXQgaGlzdG9yeSBmb3IgcmVwbGF5KVxuICpcbiAqIFRoZSBlbmdpbmUgKEZsb3djaGFydFRyYXZlcnNlcikgcmVjZWl2ZXMgdGhpcyBhcyBpdHMgcnVudGltZSBwYXJhbWV0ZXIuXG4gKiBBZnRlciBleGVjdXRpb24sIGNvbnN1bWVycyBxdWVyeSBpdCBmb3IgdGhlIGZ1bGwgZXhlY3V0aW9uIHN0YXRlLlxuICovXG5cbmltcG9ydCB7IEV2ZW50TG9nIH0gZnJvbSAnLi4vbWVtb3J5L0V2ZW50TG9nJztcbmltcG9ydCB7IFNoYXJlZE1lbW9yeSB9IGZyb20gJy4uL21lbW9yeS9TaGFyZWRNZW1vcnknO1xuaW1wb3J0IHsgU3RhZ2VDb250ZXh0IH0gZnJvbSAnLi4vbWVtb3J5L1N0YWdlQ29udGV4dCc7XG5pbXBvcnQgdHlwZSB7IENvbW1pdEJ1bmRsZSwgRmxvd01lc3NhZ2UsIFN0YWdlU25hcHNob3QgfSBmcm9tICcuLi9tZW1vcnkvdHlwZXMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIE5hcnJhdGl2ZUVudHJ5IHtcbiAgc3RhZ2VJZDogc3RyaW5nO1xuICBzdGFnZU5hbWU6IHN0cmluZztcbiAgZGlzcGxheU5hbWU/OiBzdHJpbmc7XG4gIHN0YWdlTWVzc2FnZXM6IHN0cmluZ1tdO1xuICBmbG93TWVzc2FnZT86IEZsb3dNZXNzYWdlO1xuICB0aW1lSW5kZXg6IG51bWJlcjtcbn1cblxuZXhwb3J0IHR5cGUgUnVudGltZVNuYXBzaG90ID0ge1xuICBzaGFyZWRTdGF0ZTogUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG4gIGV4ZWN1dGlvblRyZWU6IFN0YWdlU25hcHNob3Q7XG4gIGNvbW1pdExvZzogQ29tbWl0QnVuZGxlW107XG59O1xuXG5leHBvcnQgY2xhc3MgRXhlY3V0aW9uUnVudGltZSB7XG4gIHB1YmxpYyBnbG9iYWxTdG9yZTogU2hhcmVkTWVtb3J5O1xuICBwdWJsaWMgcm9vdFN0YWdlQ29udGV4dDogU3RhZ2VDb250ZXh0O1xuICBwdWJsaWMgZXhlY3V0aW9uSGlzdG9yeTogRXZlbnRMb2c7XG5cbiAgY29uc3RydWN0b3Iocm9vdE5hbWU6IHN0cmluZywgZGVmYXVsdFZhbHVlcz86IHVua25vd24sIGluaXRpYWxTdGF0ZT86IHVua25vd24pIHtcbiAgICB0aGlzLmV4ZWN1dGlvbkhpc3RvcnkgPSBuZXcgRXZlbnRMb2coaW5pdGlhbFN0YXRlKTtcbiAgICB0aGlzLmdsb2JhbFN0b3JlID0gbmV3IFNoYXJlZE1lbW9yeShkZWZhdWx0VmFsdWVzLCBpbml0aWFsU3RhdGUpO1xuICAgIHRoaXMucm9vdFN0YWdlQ29udGV4dCA9IG5ldyBTdGFnZUNvbnRleHQoJycsIHJvb3ROYW1lLCB0aGlzLmdsb2JhbFN0b3JlLCAnJywgdGhpcy5leGVjdXRpb25IaXN0b3J5KTtcbiAgfVxuXG4gIGdldFBpcGVsaW5lcygpOiBzdHJpbmdbXSB7XG4gICAgY29uc3Qgc3RhdGUgPSB0aGlzLmdsb2JhbFN0b3JlLmdldFN0YXRlKCk7XG4gICAgcmV0dXJuIHN0YXRlLnBpcGVsaW5lcyA/IE9iamVjdC5rZXlzKHN0YXRlLnBpcGVsaW5lcyBhcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPikgOiBbXTtcbiAgfVxuXG4gIHNldFJvb3RPYmplY3QocGF0aDogc3RyaW5nW10sIGtleTogc3RyaW5nLCB2YWx1ZTogdW5rbm93bikge1xuICAgIHRoaXMucm9vdFN0YWdlQ29udGV4dC5zZXRPYmplY3QocGF0aCwga2V5LCB2YWx1ZSk7XG4gIH1cblxuICBnZXRTbmFwc2hvdCgpOiBSdW50aW1lU25hcHNob3Qge1xuICAgIHJldHVybiB7XG4gICAgICBzaGFyZWRTdGF0ZTogdGhpcy5nbG9iYWxTdG9yZS5nZXRTdGF0ZSgpLFxuICAgICAgZXhlY3V0aW9uVHJlZTogdGhpcy5yb290U3RhZ2VDb250ZXh0LmdldFNuYXBzaG90KCksXG4gICAgICBjb21taXRMb2c6IHRoaXMuZXhlY3V0aW9uSGlzdG9yeS5saXN0KCksXG4gICAgfTtcbiAgfVxuXG4gIGdldEZ1bGxOYXJyYXRpdmUoKTogTmFycmF0aXZlRW50cnlbXSB7XG4gICAgY29uc3QgbmFycmF0aXZlOiBOYXJyYXRpdmVFbnRyeVtdID0gW107XG4gICAgbGV0IHRpbWVJbmRleCA9IDA7XG5cbiAgICB0aGlzLndhbGtDb250ZXh0VHJlZSh0aGlzLnJvb3RTdGFnZUNvbnRleHQsIChjb250ZXh0KSA9PiB7XG4gICAgICBjb25zdCBzdGFnZU1lc3NhZ2VzID0gKGNvbnRleHQuZGVidWcubG9nQ29udGV4dC5tZXNzYWdlIGFzIHN0cmluZ1tdKSB8fCBbXTtcbiAgICAgIGNvbnN0IGZsb3dNZXNzYWdlcyA9IGNvbnRleHQuZGVidWcuZmxvd01lc3NhZ2VzO1xuICAgICAgY29uc3QgZmxvd01lc3NhZ2UgPSBmbG93TWVzc2FnZXMubGVuZ3RoID4gMCA/IGZsb3dNZXNzYWdlc1swXSA6IHVuZGVmaW5lZDtcblxuICAgICAgbmFycmF0aXZlLnB1c2goe1xuICAgICAgICBzdGFnZUlkOiBjb250ZXh0LmdldFN0YWdlSWQoKSxcbiAgICAgICAgc3RhZ2VOYW1lOiBjb250ZXh0LnN0YWdlTmFtZSxcbiAgICAgICAgc3RhZ2VNZXNzYWdlcyxcbiAgICAgICAgZmxvd01lc3NhZ2UsXG4gICAgICAgIHRpbWVJbmRleDogdGltZUluZGV4KyssXG4gICAgICB9KTtcbiAgICB9KTtcblxuICAgIHJldHVybiBuYXJyYXRpdmU7XG4gIH1cblxuICBwcml2YXRlIHdhbGtDb250ZXh0VHJlZShjb250ZXh0OiBTdGFnZUNvbnRleHQsIHZpc2l0b3I6IChjdHg6IFN0YWdlQ29udGV4dCkgPT4gdm9pZCk6IHZvaWQge1xuICAgIHZpc2l0b3IoY29udGV4dCk7XG4gICAgaWYgKGNvbnRleHQuY2hpbGRyZW4pIHtcbiAgICAgIGZvciAoY29uc3QgY2hpbGQgb2YgY29udGV4dC5jaGlsZHJlbikge1xuICAgICAgICB0aGlzLndhbGtDb250ZXh0VHJlZShjaGlsZCwgdmlzaXRvcik7XG4gICAgICB9XG4gICAgfVxuICAgIGlmIChjb250ZXh0Lm5leHQpIHtcbiAgICAgIHRoaXMud2Fsa0NvbnRleHRUcmVlKGNvbnRleHQubmV4dCwgdmlzaXRvcik7XG4gICAgfVxuICB9XG59XG4iXX0=
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRXhlY3V0aW9uUnVudGltZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvcnVubmVyL0V4ZWN1dGlvblJ1bnRpbWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7O0dBVUc7OztBQUVILGlEQUE4QztBQUM5Qyx5REFBc0Q7QUFDdEQseURBQXNEO0FBaUJ0RCxNQUFhLGdCQUFnQjtJQUszQixZQUFZLFFBQWdCLEVBQUUsYUFBdUIsRUFBRSxZQUFzQjtRQUMzRSxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxtQkFBUSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ25ELElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSwyQkFBWSxDQUFDLGFBQWEsRUFBRSxZQUFZLENBQUMsQ0FBQztRQUNqRSxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSwyQkFBWSxDQUFDLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRSxFQUFFLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDdEcsQ0FBQztJQUVELFlBQVk7UUFDVixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQzFDLE9BQU8sS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBb0MsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDeEYsQ0FBQztJQUVELGFBQWEsQ0FBQyxJQUFjLEVBQUUsR0FBVyxFQUFFLEtBQWM7UUFDdkQsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFNBQVMsQ0FBQyxJQUFJLEVBQUUsR0FBRyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFRCxXQUFXO1FBQ1QsT0FBTztZQUNMLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsRUFBRTtZQUN4QyxhQUFhLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFdBQVcsRUFBRTtZQUNsRCxTQUFTLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksRUFBRTtTQUN4QyxDQUFDO0lBQ0osQ0FBQztJQUVELGdCQUFnQjtRQUNkLE1BQU0sU0FBUyxHQUFxQixFQUFFLENBQUM7UUFDdkMsSUFBSSxTQUFTLEdBQUcsQ0FBQyxDQUFDO1FBRWxCLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUMsT0FBTyxFQUFFLEVBQUU7WUFDdEQsTUFBTSxhQUFhLEdBQUksT0FBTyxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsT0FBb0IsSUFBSSxFQUFFLENBQUM7WUFDM0UsTUFBTSxZQUFZLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxZQUFZLENBQUM7WUFDaEQsTUFBTSxXQUFXLEdBQUcsWUFBWSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO1lBRTFFLFNBQVMsQ0FBQyxJQUFJLENBQUM7Z0JBQ2IsT0FBTyxFQUFFLE9BQU8sQ0FBQyxVQUFVLEVBQUU7Z0JBQzdCLFNBQVMsRUFBRSxPQUFPLENBQUMsU0FBUztnQkFDNUIsYUFBYTtnQkFDYixXQUFXO2dCQUNYLFNBQVMsRUFBRSxTQUFTLEVBQUU7YUFDdkIsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFFSCxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0lBRU8sZUFBZSxDQUFDLE9BQXFCLEVBQUUsT0FBb0M7UUFDakYsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2pCLElBQUksT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ3JCLEtBQUssTUFBTSxLQUFLLElBQUksT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDO2dCQUNyQyxJQUFJLENBQUMsZUFBZSxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQztZQUN2QyxDQUFDO1FBQ0gsQ0FBQztRQUNELElBQUksT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ2pCLElBQUksQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxPQUFPLENBQUMsQ0FBQztRQUM5QyxDQUFDO0lBQ0gsQ0FBQztDQUNGO0FBNURELDRDQTREQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXhlY3V0aW9uUnVudGltZSDigJQgVGhlIHJ1bnRpbWUgZW52aXJvbm1lbnQgZm9yIG9uZSBmbG93Y2hhcnQgZXhlY3V0aW9uLlxuICpcbiAqIFdpcmVzIHVwIHRoZSB0aHJlZSBtZW1vcnkgcHJpbWl0aXZlcyBpbnRvIGEgc2luZ2xlIGNvbnRhaW5lcjpcbiAqICAgLSBTaGFyZWRNZW1vcnkgKHRoZSBoZWFwIOKAlCBzaGFyZWQgc3RhdGUgYWNyb3NzIGFsbCBzdGFnZXMpXG4gKiAgIC0gU3RhZ2VDb250ZXh0ICAodGhlIGNhbGwgc3RhY2sg4oCUIHBlci1zdGFnZSBleGVjdXRpb24gdHJlZSlcbiAqICAgLSBFdmVudExvZyAgICAgICh0aGUgdHJhbnNhY3Rpb24gbG9nIOKAlCBjb21taXQgaGlzdG9yeSBmb3IgcmVwbGF5KVxuICpcbiAqIFRoZSBlbmdpbmUgKEZsb3djaGFydFRyYXZlcnNlcikgcmVjZWl2ZXMgdGhpcyBhcyBpdHMgcnVudGltZSBwYXJhbWV0ZXIuXG4gKiBBZnRlciBleGVjdXRpb24sIGNvbnN1bWVycyBxdWVyeSBpdCBmb3IgdGhlIGZ1bGwgZXhlY3V0aW9uIHN0YXRlLlxuICovXG5cbmltcG9ydCB7IEV2ZW50TG9nIH0gZnJvbSAnLi4vbWVtb3J5L0V2ZW50TG9nJztcbmltcG9ydCB7IFNoYXJlZE1lbW9yeSB9IGZyb20gJy4uL21lbW9yeS9TaGFyZWRNZW1vcnknO1xuaW1wb3J0IHsgU3RhZ2VDb250ZXh0IH0gZnJvbSAnLi4vbWVtb3J5L1N0YWdlQ29udGV4dCc7XG5pbXBvcnQgdHlwZSB7IENvbW1pdEJ1bmRsZSwgRmxvd01lc3NhZ2UsIFN0YWdlU25hcHNob3QgfSBmcm9tICcuLi9tZW1vcnkvdHlwZXMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIE5hcnJhdGl2ZUVudHJ5IHtcbiAgc3RhZ2VJZDogc3RyaW5nO1xuICBzdGFnZU5hbWU6IHN0cmluZztcbiAgc3RhZ2VNZXNzYWdlczogc3RyaW5nW107XG4gIGZsb3dNZXNzYWdlPzogRmxvd01lc3NhZ2U7XG4gIHRpbWVJbmRleDogbnVtYmVyO1xufVxuXG5leHBvcnQgdHlwZSBSdW50aW1lU25hcHNob3QgPSB7XG4gIHNoYXJlZFN0YXRlOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbiAgZXhlY3V0aW9uVHJlZTogU3RhZ2VTbmFwc2hvdDtcbiAgY29tbWl0TG9nOiBDb21taXRCdW5kbGVbXTtcbn07XG5cbmV4cG9ydCBjbGFzcyBFeGVjdXRpb25SdW50aW1lIHtcbiAgcHVibGljIGdsb2JhbFN0b3JlOiBTaGFyZWRNZW1vcnk7XG4gIHB1YmxpYyByb290U3RhZ2VDb250ZXh0OiBTdGFnZUNvbnRleHQ7XG4gIHB1YmxpYyBleGVjdXRpb25IaXN0b3J5OiBFdmVudExvZztcblxuICBjb25zdHJ1Y3Rvcihyb290TmFtZTogc3RyaW5nLCBkZWZhdWx0VmFsdWVzPzogdW5rbm93biwgaW5pdGlhbFN0YXRlPzogdW5rbm93bikge1xuICAgIHRoaXMuZXhlY3V0aW9uSGlzdG9yeSA9IG5ldyBFdmVudExvZyhpbml0aWFsU3RhdGUpO1xuICAgIHRoaXMuZ2xvYmFsU3RvcmUgPSBuZXcgU2hhcmVkTWVtb3J5KGRlZmF1bHRWYWx1ZXMsIGluaXRpYWxTdGF0ZSk7XG4gICAgdGhpcy5yb290U3RhZ2VDb250ZXh0ID0gbmV3IFN0YWdlQ29udGV4dCgnJywgcm9vdE5hbWUsIHRoaXMuZ2xvYmFsU3RvcmUsICcnLCB0aGlzLmV4ZWN1dGlvbkhpc3RvcnkpO1xuICB9XG5cbiAgZ2V0UGlwZWxpbmVzKCk6IHN0cmluZ1tdIHtcbiAgICBjb25zdCBzdGF0ZSA9IHRoaXMuZ2xvYmFsU3RvcmUuZ2V0U3RhdGUoKTtcbiAgICByZXR1cm4gc3RhdGUucGlwZWxpbmVzID8gT2JqZWN0LmtleXMoc3RhdGUucGlwZWxpbmVzIGFzIFJlY29yZDxzdHJpbmcsIHVua25vd24+KSA6IFtdO1xuICB9XG5cbiAgc2V0Um9vdE9iamVjdChwYXRoOiBzdHJpbmdbXSwga2V5OiBzdHJpbmcsIHZhbHVlOiB1bmtub3duKSB7XG4gICAgdGhpcy5yb290U3RhZ2VDb250ZXh0LnNldE9iamVjdChwYXRoLCBrZXksIHZhbHVlKTtcbiAgfVxuXG4gIGdldFNuYXBzaG90KCk6IFJ1bnRpbWVTbmFwc2hvdCB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHNoYXJlZFN0YXRlOiB0aGlzLmdsb2JhbFN0b3JlLmdldFN0YXRlKCksXG4gICAgICBleGVjdXRpb25UcmVlOiB0aGlzLnJvb3RTdGFnZUNvbnRleHQuZ2V0U25hcHNob3QoKSxcbiAgICAgIGNvbW1pdExvZzogdGhpcy5leGVjdXRpb25IaXN0b3J5Lmxpc3QoKSxcbiAgICB9O1xuICB9XG5cbiAgZ2V0RnVsbE5hcnJhdGl2ZSgpOiBOYXJyYXRpdmVFbnRyeVtdIHtcbiAgICBjb25zdCBuYXJyYXRpdmU6IE5hcnJhdGl2ZUVudHJ5W10gPSBbXTtcbiAgICBsZXQgdGltZUluZGV4ID0gMDtcblxuICAgIHRoaXMud2Fsa0NvbnRleHRUcmVlKHRoaXMucm9vdFN0YWdlQ29udGV4dCwgKGNvbnRleHQpID0+IHtcbiAgICAgIGNvbnN0IHN0YWdlTWVzc2FnZXMgPSAoY29udGV4dC5kZWJ1Zy5sb2dDb250ZXh0Lm1lc3NhZ2UgYXMgc3RyaW5nW10pIHx8IFtdO1xuICAgICAgY29uc3QgZmxvd01lc3NhZ2VzID0gY29udGV4dC5kZWJ1Zy5mbG93TWVzc2FnZXM7XG4gICAgICBjb25zdCBmbG93TWVzc2FnZSA9IGZsb3dNZXNzYWdlcy5sZW5ndGggPiAwID8gZmxvd01lc3NhZ2VzWzBdIDogdW5kZWZpbmVkO1xuXG4gICAgICBuYXJyYXRpdmUucHVzaCh7XG4gICAgICAgIHN0YWdlSWQ6IGNvbnRleHQuZ2V0U3RhZ2VJZCgpLFxuICAgICAgICBzdGFnZU5hbWU6IGNvbnRleHQuc3RhZ2VOYW1lLFxuICAgICAgICBzdGFnZU1lc3NhZ2VzLFxuICAgICAgICBmbG93TWVzc2FnZSxcbiAgICAgICAgdGltZUluZGV4OiB0aW1lSW5kZXgrKyxcbiAgICAgIH0pO1xuICAgIH0pO1xuXG4gICAgcmV0dXJuIG5hcnJhdGl2ZTtcbiAgfVxuXG4gIHByaXZhdGUgd2Fsa0NvbnRleHRUcmVlKGNvbnRleHQ6IFN0YWdlQ29udGV4dCwgdmlzaXRvcjogKGN0eDogU3RhZ2VDb250ZXh0KSA9PiB2b2lkKTogdm9pZCB7XG4gICAgdmlzaXRvcihjb250ZXh0KTtcbiAgICBpZiAoY29udGV4dC5jaGlsZHJlbikge1xuICAgICAgZm9yIChjb25zdCBjaGlsZCBvZiBjb250ZXh0LmNoaWxkcmVuKSB7XG4gICAgICAgIHRoaXMud2Fsa0NvbnRleHRUcmVlKGNoaWxkLCB2aXNpdG9yKTtcbiAgICAgIH1cbiAgICB9XG4gICAgaWYgKGNvbnRleHQubmV4dCkge1xuICAgICAgdGhpcy53YWxrQ29udGV4dFRyZWUoY29udGV4dC5uZXh0LCB2aXNpdG9yKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
@@ -28,13 +28,12 @@ export declare class DeciderList<TOut = any, TScope = any> {
28
28
  private readonly deciderDescription?;
29
29
  private readonly branchDescInfo;
30
30
  constructor(builder: FlowChartBuilder<TOut, TScope>, curNode: StageNode<TOut, TScope>, curSpec: SerializedPipelineStructure, parentDescriptionParts?: string[], parentStageDescriptions?: Map<string, string>, reservedStepNumber?: number, deciderDescription?: string);
31
- addFunctionBranch(id: string, name: string, fn?: PipelineStageFunction<TOut, TScope>, displayName?: string, description?: string): DeciderList<TOut, TScope>;
31
+ addFunctionBranch(id: string, name: string, fn?: PipelineStageFunction<TOut, TScope>, description?: string): DeciderList<TOut, TScope>;
32
32
  addSubFlowChartBranch(id: string, subflow: FlowChart<TOut, TScope>, mountName?: string, options?: SubflowMountOptions): DeciderList<TOut, TScope>;
33
33
  addBranchList(branches: Array<{
34
34
  id: string;
35
35
  name: string;
36
36
  fn?: PipelineStageFunction<TOut, TScope>;
37
- displayName?: string;
38
37
  }>): DeciderList<TOut, TScope>;
39
38
  setDefault(id: string): DeciderList<TOut, TScope>;
40
39
  end(): FlowChartBuilder<TOut, TScope>;
@@ -50,13 +49,12 @@ export declare class SelectorFnList<TOut = any, TScope = any> {
50
49
  private readonly selectorDescription?;
51
50
  private readonly branchDescInfo;
52
51
  constructor(builder: FlowChartBuilder<TOut, TScope>, curNode: StageNode<TOut, TScope>, curSpec: SerializedPipelineStructure, parentDescriptionParts?: string[], parentStageDescriptions?: Map<string, string>, reservedStepNumber?: number, selectorDescription?: string);
53
- addFunctionBranch(id: string, name: string, fn?: PipelineStageFunction<TOut, TScope>, displayName?: string, description?: string): SelectorFnList<TOut, TScope>;
52
+ addFunctionBranch(id: string, name: string, fn?: PipelineStageFunction<TOut, TScope>, description?: string): SelectorFnList<TOut, TScope>;
54
53
  addSubFlowChartBranch(id: string, subflow: FlowChart<TOut, TScope>, mountName?: string, options?: SubflowMountOptions): SelectorFnList<TOut, TScope>;
55
54
  addBranchList(branches: Array<{
56
55
  id: string;
57
56
  name: string;
58
57
  fn?: PipelineStageFunction<TOut, TScope>;
59
- displayName?: string;
60
58
  }>): SelectorFnList<TOut, TScope>;
61
59
  end(): FlowChartBuilder<TOut, TScope>;
62
60
  }
@@ -84,11 +82,11 @@ export declare class FlowChartBuilder<TOut = any, TScope = any> {
84
82
  private _appendSubflowDescription;
85
83
  setEnableNarrative(): this;
86
84
  setLogger(logger: ILogger): this;
87
- start(name: string, fn?: PipelineStageFunction<TOut, TScope>, id?: string, displayName?: string, description?: string): this;
88
- addFunction(name: string, fn?: PipelineStageFunction<TOut, TScope>, id?: string, displayName?: string, description?: string): this;
89
- addStreamingFunction(name: string, streamId?: string, fn?: PipelineStageFunction<TOut, TScope>, id?: string, displayName?: string, description?: string): this;
90
- addDeciderFunction(name: string, fn: PipelineStageFunction<TOut, TScope>, id?: string, displayName?: string, description?: string): DeciderList<TOut, TScope>;
91
- addSelectorFunction(name: string, fn: PipelineStageFunction<TOut, TScope>, id?: string, displayName?: string, description?: string): SelectorFnList<TOut, TScope>;
85
+ start(name: string, fn?: PipelineStageFunction<TOut, TScope>, id?: string, description?: string): this;
86
+ addFunction(name: string, fn?: PipelineStageFunction<TOut, TScope>, id?: string, description?: string): this;
87
+ addStreamingFunction(name: string, streamId?: string, fn?: PipelineStageFunction<TOut, TScope>, id?: string, description?: string): this;
88
+ addDeciderFunction(name: string, fn: PipelineStageFunction<TOut, TScope>, id?: string, description?: string): DeciderList<TOut, TScope>;
89
+ addSelectorFunction(name: string, fn: PipelineStageFunction<TOut, TScope>, id?: string, description?: string): SelectorFnList<TOut, TScope>;
92
90
  addListOfFunction(children: SimplifiedParallelSpec<TOut, TScope>[], options?: {
93
91
  failFast?: boolean;
94
92
  }): this;
@@ -117,5 +115,5 @@ export declare class FlowChartBuilder<TOut = any, TScope = any> {
117
115
  root: StageNode<TOut, TScope>;
118
116
  }> | undefined, prefix: string): void;
119
117
  }
120
- export declare function flowChart<TOut = any, TScope = any>(name: string, fn?: PipelineStageFunction<TOut, TScope>, id?: string, displayName?: string, buildTimeExtractor?: BuildTimeExtractor<any>, description?: string): FlowChartBuilder<TOut, TScope>;
118
+ export declare function flowChart<TOut = any, TScope = any>(name: string, fn?: PipelineStageFunction<TOut, TScope>, id?: string, buildTimeExtractor?: BuildTimeExtractor<any>, description?: string): FlowChartBuilder<TOut, TScope>;
121
119
  export declare function specToStageNode(spec: FlowChartSpec): StageNode<any, any>;
@@ -40,8 +40,6 @@ export type StageNode<TOut = any, TScope = any> = {
40
40
  name: string;
41
41
  /** Optional stable id (required by decider/fork aggregation). */
42
42
  id?: string;
43
- /** Human-readable display name for UI. */
44
- displayName?: string;
45
43
  /** Human-readable description of what this stage does. */
46
44
  description?: string;
47
45
  /** Linear continuation. */
@@ -77,7 +75,6 @@ export interface SerializedPipelineStructure {
77
75
  name: string;
78
76
  id?: string;
79
77
  type: 'stage' | 'decider' | 'fork' | 'streaming';
80
- displayName?: string;
81
78
  description?: string;
82
79
  children?: SerializedPipelineStructure[];
83
80
  next?: SerializedPipelineStructure;
@@ -98,7 +95,6 @@ export interface SerializedPipelineStructure {
98
95
  export interface FlowChartSpec {
99
96
  name: string;
100
97
  id?: string;
101
- displayName?: string;
102
98
  description?: string;
103
99
  children?: FlowChartSpec[];
104
100
  next?: FlowChartSpec;
@@ -134,7 +130,6 @@ export type FlowChart<TOut = any, TScope = any> = {
134
130
  export type SimplifiedParallelSpec<TOut = any, TScope = any> = {
135
131
  id: string;
136
132
  name: string;
137
- displayName?: string;
138
133
  fn?: PipelineStageFunction<TOut, TScope>;
139
134
  };
140
135
  export type ExecOptions = {
@@ -148,5 +143,4 @@ export type ExecOptions = {
148
143
  export interface SubflowRef {
149
144
  $ref: string;
150
145
  mountId: string;
151
- displayName?: string;
152
146
  }
@@ -23,8 +23,6 @@ export type StageNode<TOut = any, TScope = any> = {
23
23
  name: string;
24
24
  /** Optional stable id (required by decider/fork aggregation) */
25
25
  id?: string;
26
- /** Human-readable display name for UI */
27
- displayName?: string;
28
26
  /** Description of what this stage does. Used for narrative and tool descriptions. */
29
27
  description?: string;
30
28
  /** Linear continuation (linked list next pointer) */
@@ -14,16 +14,16 @@ import type { IControlFlowNarrative } from './types';
14
14
  export declare class ControlFlowNarrativeGenerator implements IControlFlowNarrative {
15
15
  private sentences;
16
16
  private isFirstStage;
17
- onStageExecuted(stageName: string, displayName?: string, description?: string): void;
18
- onNext(fromStage: string, toStage: string, toDisplayName?: string, description?: string): void;
19
- onDecision(deciderName: string, chosenBranch: string, chosenDisplayName?: string, rationale?: string, deciderDescription?: string): void;
17
+ onStageExecuted(stageName: string, description?: string): void;
18
+ onNext(fromStage: string, toStage: string, description?: string): void;
19
+ onDecision(deciderName: string, chosenBranch: string, rationale?: string, deciderDescription?: string): void;
20
20
  onFork(parentStage: string, childNames: string[]): void;
21
21
  onSelected(parentStage: string, selectedNames: string[], totalCount: number): void;
22
22
  onSubflowEntry(subflowName: string): void;
23
23
  onSubflowExit(subflowName: string): void;
24
- onLoop(targetStage: string, targetDisplayName: string | undefined, iteration: number, description?: string): void;
25
- onBreak(stageName: string, displayName?: string): void;
26
- onError(stageName: string, errorMessage: string, displayName?: string): void;
24
+ onLoop(targetStage: string, iteration: number, description?: string): void;
25
+ onBreak(stageName: string): void;
26
+ onError(stageName: string, errorMessage: string): void;
27
27
  /** Returns a defensive copy of accumulated sentences. */
28
28
  getSentences(): string[];
29
29
  }
@@ -9,11 +9,11 @@
9
9
  */
10
10
  export interface IControlFlowNarrative {
11
11
  /** Called when a stage executes. First stage uses distinct opening pattern. */
12
- onStageExecuted(stageName: string, displayName?: string, description?: string): void;
12
+ onStageExecuted(stageName: string, description?: string): void;
13
13
  /** Called on linear continuation from one stage to the next. */
14
- onNext(fromStage: string, toStage: string, toDisplayName?: string, description?: string): void;
14
+ onNext(fromStage: string, toStage: string, description?: string): void;
15
15
  /** Called when a decider selects a branch. Most valuable for LLM context. */
16
- onDecision(deciderName: string, chosenBranch: string, chosenDisplayName?: string, rationale?: string, deciderDescription?: string): void;
16
+ onDecision(deciderName: string, chosenBranch: string, rationale?: string, deciderDescription?: string): void;
17
17
  /** Called when a fork executes all children in parallel. */
18
18
  onFork(parentStage: string, childNames: string[]): void;
19
19
  /** Called when a selector picks a subset of children. */
@@ -23,11 +23,11 @@ export interface IControlFlowNarrative {
23
23
  /** Called when exiting a subflow. */
24
24
  onSubflowExit(subflowName: string): void;
25
25
  /** Called on loop iteration (back-edge traversal). */
26
- onLoop(targetStage: string, targetDisplayName: string | undefined, iteration: number, description?: string): void;
26
+ onLoop(targetStage: string, iteration: number, description?: string): void;
27
27
  /** Called when a stage triggers break (early termination). */
28
- onBreak(stageName: string, displayName?: string): void;
28
+ onBreak(stageName: string): void;
29
29
  /** Called when a stage throws an error. */
30
- onError(stageName: string, errorMessage: string, displayName?: string): void;
30
+ onError(stageName: string, errorMessage: string): void;
31
31
  /** Returns accumulated narrative sentences in execution order. */
32
32
  getSentences(): string[];
33
33
  }
@@ -169,7 +169,6 @@ export interface SerializedPipelineNode {
169
169
  name: string;
170
170
  id?: string;
171
171
  type?: 'stage' | 'decider' | 'fork' | 'streaming' | 'loop' | 'user' | 'tool' | 'function' | 'sequence';
172
- displayName?: string;
173
172
  description?: string;
174
173
  children?: SerializedPipelineNode[];
175
174
  next?: SerializedPipelineNode;
@@ -16,7 +16,6 @@ import type { CommitBundle, FlowMessage, StageSnapshot } from '../memory/types';
16
16
  export interface NarrativeEntry {
17
17
  stageId: string;
18
18
  stageName: string;
19
- displayName?: string;
20
19
  stageMessages: string[];
21
20
  flowMessage?: FlowMessage;
22
21
  timeIndex: number;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "footprintjs",
3
- "version": "0.2.1",
3
+ "version": "0.2.3",
4
4
  "description": "Turn your whiteboard flowchart into running code — with automatic causal traces for LLM reasoning",
5
5
  "license": "MIT",
6
6
  "author": "Sanjay Krishna Anbalagan",