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.
- package/README.md +85 -32
- package/dist/esm/lib/builder/FlowChartBuilder.js +54 -91
- package/dist/esm/lib/builder/types.js +1 -1
- package/dist/esm/lib/engine/graph/StageNode.js +1 -1
- package/dist/esm/lib/engine/handlers/ChildrenExecutor.js +5 -5
- package/dist/esm/lib/engine/handlers/ContinuationResolver.js +6 -6
- package/dist/esm/lib/engine/handlers/DeciderHandler.js +4 -4
- package/dist/esm/lib/engine/handlers/NodeResolver.js +1 -2
- package/dist/esm/lib/engine/handlers/RuntimeStructureManager.js +1 -2
- package/dist/esm/lib/engine/handlers/SelectorHandler.js +6 -6
- package/dist/esm/lib/engine/narrative/ControlFlowNarrativeGenerator.js +13 -18
- package/dist/esm/lib/engine/narrative/types.js +1 -1
- package/dist/esm/lib/engine/traversal/FlowchartTraverser.js +10 -11
- package/dist/esm/lib/engine/types.js +1 -1
- package/dist/esm/lib/runner/ExecutionRuntime.js +1 -1
- package/dist/esm/types/lib/builder/FlowChartBuilder.d.ts +8 -10
- package/dist/esm/types/lib/builder/types.d.ts +0 -6
- package/dist/esm/types/lib/engine/graph/StageNode.d.ts +0 -2
- package/dist/esm/types/lib/engine/narrative/ControlFlowNarrativeGenerator.d.ts +6 -6
- package/dist/esm/types/lib/engine/narrative/types.d.ts +6 -6
- package/dist/esm/types/lib/engine/types.d.ts +0 -1
- package/dist/esm/types/lib/runner/ExecutionRuntime.d.ts +0 -1
- package/dist/lib/builder/FlowChartBuilder.js +54 -91
- package/dist/lib/builder/types.js +1 -1
- package/dist/lib/engine/graph/StageNode.js +1 -1
- package/dist/lib/engine/handlers/ChildrenExecutor.js +5 -5
- package/dist/lib/engine/handlers/ContinuationResolver.js +6 -6
- package/dist/lib/engine/handlers/DeciderHandler.js +4 -4
- package/dist/lib/engine/handlers/NodeResolver.js +1 -2
- package/dist/lib/engine/handlers/RuntimeStructureManager.js +1 -2
- package/dist/lib/engine/handlers/SelectorHandler.js +6 -6
- package/dist/lib/engine/narrative/ControlFlowNarrativeGenerator.js +13 -18
- package/dist/lib/engine/narrative/types.js +1 -1
- package/dist/lib/engine/traversal/FlowchartTraverser.js +10 -11
- package/dist/lib/engine/types.js +1 -1
- package/dist/lib/runner/ExecutionRuntime.js +1 -1
- package/dist/types/lib/builder/FlowChartBuilder.d.ts +8 -10
- package/dist/types/lib/builder/types.d.ts +0 -6
- package/dist/types/lib/engine/graph/StageNode.d.ts +0 -2
- package/dist/types/lib/engine/narrative/ControlFlowNarrativeGenerator.d.ts +6 -6
- package/dist/types/lib/engine/narrative/types.d.ts +6 -6
- package/dist/types/lib/engine/types.d.ts +0 -1
- package/dist/types/lib/runner/ExecutionRuntime.d.ts +0 -1
- package/package.json +1 -1
package/dist/lib/engine/types.js
CHANGED
|
@@ -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,
|
|
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>,
|
|
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>,
|
|
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,
|
|
88
|
-
addFunction(name: string, fn?: PipelineStageFunction<TOut, TScope>, id?: string,
|
|
89
|
-
addStreamingFunction(name: string, streamId?: string, fn?: PipelineStageFunction<TOut, TScope>, id?: string,
|
|
90
|
-
addDeciderFunction(name: string, fn: PipelineStageFunction<TOut, TScope>, id?: string,
|
|
91
|
-
addSelectorFunction(name: string, fn: PipelineStageFunction<TOut, TScope>, id?: string,
|
|
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,
|
|
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,
|
|
18
|
-
onNext(fromStage: string, toStage: string,
|
|
19
|
-
onDecision(deciderName: string, chosenBranch: string,
|
|
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,
|
|
25
|
-
onBreak(stageName: string
|
|
26
|
-
onError(stageName: string, errorMessage: string
|
|
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,
|
|
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,
|
|
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,
|
|
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,
|
|
26
|
+
onLoop(targetStage: string, iteration: number, description?: string): void;
|
|
27
27
|
/** Called when a stage triggers break (early termination). */
|
|
28
|
-
onBreak(stageName: string
|
|
28
|
+
onBreak(stageName: string): void;
|
|
29
29
|
/** Called when a stage throws an error. */
|
|
30
|
-
onError(stageName: string, errorMessage: string
|
|
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