footprintjs 0.14.3 → 0.14.4

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 (92) hide show
  1. package/dist/esm/lib/engine/handlers/RuntimeStructureManager.js +3 -2
  2. package/dist/lib/engine/handlers/RuntimeStructureManager.js +3 -2
  3. package/package.json +1 -1
  4. package/dist/esm/types/advanced.d.ts +0 -35
  5. package/dist/esm/types/index.d.ts +0 -46
  6. package/dist/esm/types/lib/builder/FlowChartBuilder.d.ts +0 -129
  7. package/dist/esm/types/lib/builder/index.d.ts +0 -9
  8. package/dist/esm/types/lib/builder/types.d.ts +0 -102
  9. package/dist/esm/types/lib/contract/defineContract.d.ts +0 -18
  10. package/dist/esm/types/lib/contract/index.d.ts +0 -14
  11. package/dist/esm/types/lib/contract/openapi.d.ts +0 -12
  12. package/dist/esm/types/lib/contract/schema.d.ts +0 -15
  13. package/dist/esm/types/lib/contract/types.d.ts +0 -94
  14. package/dist/esm/types/lib/engine/errors/errorInfo.d.ts +0 -45
  15. package/dist/esm/types/lib/engine/errors/index.d.ts +0 -2
  16. package/dist/esm/types/lib/engine/graph/StageNode.d.ts +0 -78
  17. package/dist/esm/types/lib/engine/graph/index.d.ts +0 -2
  18. package/dist/esm/types/lib/engine/handlers/ChildrenExecutor.d.ts +0 -33
  19. package/dist/esm/types/lib/engine/handlers/ContinuationResolver.d.ts +0 -57
  20. package/dist/esm/types/lib/engine/handlers/DeciderHandler.d.ts +0 -34
  21. package/dist/esm/types/lib/engine/handlers/ExtractorRunner.d.ts +0 -41
  22. package/dist/esm/types/lib/engine/handlers/NodeResolver.d.ts +0 -26
  23. package/dist/esm/types/lib/engine/handlers/RuntimeStructureManager.d.ts +0 -36
  24. package/dist/esm/types/lib/engine/handlers/SelectorHandler.d.ts +0 -26
  25. package/dist/esm/types/lib/engine/handlers/StageRunner.d.ts +0 -17
  26. package/dist/esm/types/lib/engine/handlers/SubflowExecutor.d.ts +0 -57
  27. package/dist/esm/types/lib/engine/handlers/SubflowInputMapper.d.ts +0 -40
  28. package/dist/esm/types/lib/engine/handlers/index.d.ts +0 -15
  29. package/dist/esm/types/lib/engine/index.d.ts +0 -30
  30. package/dist/esm/types/lib/engine/narrative/CombinedNarrativeBuilder.d.ts +0 -46
  31. package/dist/esm/types/lib/engine/narrative/CombinedNarrativeRecorder.d.ts +0 -63
  32. package/dist/esm/types/lib/engine/narrative/ControlFlowNarrativeGenerator.d.ts +0 -30
  33. package/dist/esm/types/lib/engine/narrative/FlowRecorderDispatcher.d.ts +0 -39
  34. package/dist/esm/types/lib/engine/narrative/NarrativeFlowRecorder.d.ts +0 -42
  35. package/dist/esm/types/lib/engine/narrative/NullControlFlowNarrativeGenerator.d.ts +0 -22
  36. package/dist/esm/types/lib/engine/narrative/index.d.ts +0 -17
  37. package/dist/esm/types/lib/engine/narrative/recorders/AdaptiveNarrativeFlowRecorder.d.ts +0 -25
  38. package/dist/esm/types/lib/engine/narrative/recorders/ManifestFlowRecorder.d.ts +0 -63
  39. package/dist/esm/types/lib/engine/narrative/recorders/MilestoneNarrativeFlowRecorder.d.ts +0 -24
  40. package/dist/esm/types/lib/engine/narrative/recorders/ProgressiveNarrativeFlowRecorder.d.ts +0 -30
  41. package/dist/esm/types/lib/engine/narrative/recorders/RLENarrativeFlowRecorder.d.ts +0 -25
  42. package/dist/esm/types/lib/engine/narrative/recorders/SeparateNarrativeFlowRecorder.d.ts +0 -32
  43. package/dist/esm/types/lib/engine/narrative/recorders/SilentNarrativeFlowRecorder.d.ts +0 -25
  44. package/dist/esm/types/lib/engine/narrative/recorders/WindowedNarrativeFlowRecorder.d.ts +0 -29
  45. package/dist/esm/types/lib/engine/narrative/recorders/index.d.ts +0 -9
  46. package/dist/esm/types/lib/engine/narrative/types.d.ts +0 -135
  47. package/dist/esm/types/lib/engine/traversal/FlowchartTraverser.d.ts +0 -97
  48. package/dist/esm/types/lib/engine/traversal/index.d.ts +0 -2
  49. package/dist/esm/types/lib/engine/types.d.ts +0 -244
  50. package/dist/esm/types/lib/memory/DiagnosticCollector.d.ts +0 -33
  51. package/dist/esm/types/lib/memory/EventLog.d.ts +0 -27
  52. package/dist/esm/types/lib/memory/SharedMemory.d.ts +0 -34
  53. package/dist/esm/types/lib/memory/StageContext.d.ts +0 -82
  54. package/dist/esm/types/lib/memory/TransactionBuffer.d.ts +0 -38
  55. package/dist/esm/types/lib/memory/index.d.ts +0 -13
  56. package/dist/esm/types/lib/memory/types.d.ts +0 -68
  57. package/dist/esm/types/lib/memory/utils.d.ts +0 -67
  58. package/dist/esm/types/lib/runner/ComposableRunner.d.ts +0 -32
  59. package/dist/esm/types/lib/runner/ExecutionRuntime.d.ts +0 -40
  60. package/dist/esm/types/lib/runner/FlowChartExecutor.d.ts +0 -100
  61. package/dist/esm/types/lib/runner/getSubtreeSnapshot.d.ts +0 -60
  62. package/dist/esm/types/lib/runner/index.d.ts +0 -6
  63. package/dist/esm/types/lib/runner/validateInput.d.ts +0 -11
  64. package/dist/esm/types/lib/schema/detect.d.ts +0 -32
  65. package/dist/esm/types/lib/schema/errors.d.ts +0 -36
  66. package/dist/esm/types/lib/schema/index.d.ts +0 -14
  67. package/dist/esm/types/lib/schema/validate.d.ts +0 -33
  68. package/dist/esm/types/lib/scope/ScopeFacade.d.ts +0 -110
  69. package/dist/esm/types/lib/scope/index.d.ts +0 -23
  70. package/dist/esm/types/lib/scope/protection/createProtectedScope.d.ts +0 -9
  71. package/dist/esm/types/lib/scope/protection/index.d.ts +0 -2
  72. package/dist/esm/types/lib/scope/protection/readonlyInput.d.ts +0 -26
  73. package/dist/esm/types/lib/scope/protection/types.d.ts +0 -13
  74. package/dist/esm/types/lib/scope/providers/baseStateCompatible.d.ts +0 -28
  75. package/dist/esm/types/lib/scope/providers/guards.d.ts +0 -14
  76. package/dist/esm/types/lib/scope/providers/index.d.ts +0 -6
  77. package/dist/esm/types/lib/scope/providers/providers.d.ts +0 -8
  78. package/dist/esm/types/lib/scope/providers/registry.d.ts +0 -11
  79. package/dist/esm/types/lib/scope/providers/resolve.d.ts +0 -8
  80. package/dist/esm/types/lib/scope/providers/types.d.ts +0 -40
  81. package/dist/esm/types/lib/scope/recorders/DebugRecorder.d.ts +0 -35
  82. package/dist/esm/types/lib/scope/recorders/MetricRecorder.d.ts +0 -36
  83. package/dist/esm/types/lib/scope/recorders/NarrativeRecorder.d.ts +0 -50
  84. package/dist/esm/types/lib/scope/recorders/index.d.ts +0 -7
  85. package/dist/esm/types/lib/scope/state/installResolvers.d.ts +0 -4
  86. package/dist/esm/types/lib/scope/state/zod/defineScopeFromZod.d.ts +0 -9
  87. package/dist/esm/types/lib/scope/state/zod/index.d.ts +0 -5
  88. package/dist/esm/types/lib/scope/state/zod/resolver.d.ts +0 -5
  89. package/dist/esm/types/lib/scope/state/zod/schema/builder.d.ts +0 -12
  90. package/dist/esm/types/lib/scope/state/zod/scopeFactory.d.ts +0 -9
  91. package/dist/esm/types/lib/scope/state/zod/utils/validateHelper.d.ts +0 -13
  92. package/dist/esm/types/lib/scope/types.d.ts +0 -83
@@ -125,7 +125,8 @@ export class RuntimeStructureManager {
125
125
  mountStructure.subflowName = subflowName;
126
126
  }
127
127
  if (subflowBuildTimeStructure) {
128
- mountStructure.subflowStructure = subflowBuildTimeStructure;
128
+ // Deep-copy to prevent external mutation of the stored structure
129
+ mountStructure.subflowStructure = JSON.parse(JSON.stringify(subflowBuildTimeStructure));
129
130
  this.buildNodeMap(mountStructure.subflowStructure);
130
131
  }
131
132
  }
@@ -150,4 +151,4 @@ export class RuntimeStructureManager {
150
151
  nodeStructure.iterationCount = count;
151
152
  }
152
153
  }
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RuntimeStructureManager.js","sourceRoot":"","sources":["../../../../../src/lib/engine/handlers/RuntimeStructureManager.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * RuntimeStructureManager — Mutable structure tracking for visualization.\n *\n * During execution, dynamic events (new children, subflows, next chains,\n * loop iterations) modify the pipeline. This manager keeps a serialized\n * structure in sync so consumers get the complete picture.\n *\n * Deep-clones build-time structure at init, then maintains O(1) lookup map.\n */\n\nimport type { StageNode } from '../graph/StageNode.js';\nimport type { SerializedPipelineStructure } from '../types.js';\n\n/**\n * Compute the node type from node properties.\n * Shared by RuntimeStructureManager (serialization) and ExtractorRunner (metadata).\n */\nexport function computeNodeType(node: StageNode): 'stage' | 'decider' | 'fork' | 'streaming' {\n  if (node.nextNodeSelector || node.deciderFn || node.selectorFn) return 'decider';\n  if (node.isStreaming) return 'streaming';\n\n  const hasDynamicChildren = Boolean(node.children?.length && !node.nextNodeSelector && node.fn);\n  if (node.children && node.children.length > 0 && !hasDynamicChildren) return 'fork';\n\n  return 'stage';\n}\n\nexport class RuntimeStructureManager {\n  private runtimePipelineStructure?: SerializedPipelineStructure;\n  private structureNodeMap: Map<string, SerializedPipelineStructure> = new Map();\n\n  /** Initialize from build-time structure. Deep-clones via JSON round-trip. */\n  init(buildTimeStructure?: SerializedPipelineStructure): void {\n    if (!buildTimeStructure) return;\n    this.runtimePipelineStructure = JSON.parse(JSON.stringify(buildTimeStructure));\n    this.buildNodeMap(this.runtimePipelineStructure!);\n  }\n\n  /** Returns the current runtime structure (mutated during execution). */\n  getStructure(): SerializedPipelineStructure | undefined {\n    return this.runtimePipelineStructure;\n  }\n\n  /** Recursively registers all nodes in the O(1) lookup map. */\n  private buildNodeMap(node: SerializedPipelineStructure): void {\n    const key = node.id ?? node.name;\n    this.structureNodeMap.set(key, node);\n\n    if (node.children) {\n      for (const child of node.children) {\n        this.buildNodeMap(child);\n      }\n    }\n    if (node.next) {\n      this.buildNodeMap(node.next);\n    }\n    if (node.subflowStructure) {\n      this.buildNodeMap(node.subflowStructure);\n    }\n  }\n\n  /** Convert a runtime StageNode into a SerializedPipelineStructure node. */\n  stageNodeToStructure(node: StageNode): SerializedPipelineStructure {\n    const structure: SerializedPipelineStructure = {\n      name: node.name,\n      id: node.id,\n      type: computeNodeType(node),\n      description: node.description,\n    };\n\n    if (node.isStreaming) {\n      structure.isStreaming = true;\n      structure.streamId = node.streamId;\n    }\n\n    if (node.isSubflowRoot) {\n      structure.isSubflowRoot = true;\n      structure.subflowId = node.subflowId;\n      structure.subflowName = node.subflowName;\n    }\n\n    if (node.deciderFn) {\n      structure.hasDecider = true;\n      structure.branchIds = node.children?.map((c) => c.id);\n    }\n\n    if (node.nextNodeSelector) {\n      structure.hasSelector = true;\n      structure.branchIds = node.children?.map((c) => c.id);\n    }\n\n    if (node.children?.length) {\n      structure.children = node.children.map((c) => this.stageNodeToStructure(c));\n    }\n\n    if (node.next) {\n      structure.next = this.stageNodeToStructure(node.next);\n    }\n\n    if (node.subflowDef?.buildTimeStructure) {\n      structure.subflowStructure = node.subflowDef.buildTimeStructure as SerializedPipelineStructure;\n    }\n\n    return structure;\n  }\n\n  /** Update structure when dynamic children are discovered at runtime. */\n  updateDynamicChildren(\n    parentNodeId: string,\n    dynamicChildren: StageNode[],\n    hasSelector?: boolean,\n    hasDecider?: boolean,\n  ): void {\n    if (!this.runtimePipelineStructure) return;\n\n    const parentStructure = this.structureNodeMap.get(parentNodeId);\n    if (!parentStructure) return;\n\n    const childStructures = dynamicChildren.map((child) => this.stageNodeToStructure(child));\n    parentStructure.children = childStructures;\n\n    for (const childStructure of childStructures) {\n      this.buildNodeMap(childStructure);\n    }\n\n    if (hasSelector) {\n      parentStructure.hasSelector = true;\n      parentStructure.branchIds = childStructures.map((c) => c.id ?? c.name);\n    }\n\n    if (hasDecider) {\n      parentStructure.hasDecider = true;\n      parentStructure.branchIds = childStructures.map((c) => c.id ?? c.name);\n    }\n  }\n\n  /** Update structure when a dynamic subflow is registered at runtime. */\n  updateDynamicSubflow(\n    mountNodeId: string,\n    subflowId: string,\n    subflowName?: string,\n    subflowBuildTimeStructure?: unknown,\n  ): void {\n    if (!this.runtimePipelineStructure) return;\n\n    const mountStructure = this.structureNodeMap.get(mountNodeId);\n    if (!mountStructure) return;\n\n    mountStructure.isSubflowRoot = true;\n    mountStructure.subflowId = subflowId;\n\n    if (subflowName !== undefined) {\n      mountStructure.subflowName = subflowName;\n    }\n\n    if (subflowBuildTimeStructure) {\n      mountStructure.subflowStructure = subflowBuildTimeStructure as SerializedPipelineStructure;\n      this.buildNodeMap(mountStructure.subflowStructure);\n    }\n  }\n\n  /** Update structure when a dynamic next chain is discovered at runtime. */\n  updateDynamicNext(currentNodeId: string, dynamicNext: StageNode): void {\n    if (!this.runtimePipelineStructure) return;\n\n    const currentStructure = this.structureNodeMap.get(currentNodeId);\n    if (!currentStructure) return;\n\n    const nextStructure = this.stageNodeToStructure(dynamicNext);\n    currentStructure.next = nextStructure;\n    this.buildNodeMap(nextStructure);\n  }\n\n  /** Update the iteration count for a node (loop support). */\n  updateIterationCount(nodeId: string, count: number): void {\n    if (!this.runtimePipelineStructure) return;\n    const nodeStructure = this.structureNodeMap.get(nodeId);\n    if (!nodeStructure) return;\n    nodeStructure.iterationCount = count;\n  }\n}\n"]}
154
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RuntimeStructureManager.js","sourceRoot":"","sources":["../../../../../src/lib/engine/handlers/RuntimeStructureManager.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * RuntimeStructureManager — Mutable structure tracking for visualization.\n *\n * During execution, dynamic events (new children, subflows, next chains,\n * loop iterations) modify the pipeline. This manager keeps a serialized\n * structure in sync so consumers get the complete picture.\n *\n * Deep-clones build-time structure at init, then maintains O(1) lookup map.\n */\n\nimport type { StageNode } from '../graph/StageNode.js';\nimport type { SerializedPipelineStructure } from '../types.js';\n\n/**\n * Compute the node type from node properties.\n * Shared by RuntimeStructureManager (serialization) and ExtractorRunner (metadata).\n */\nexport function computeNodeType(node: StageNode): 'stage' | 'decider' | 'fork' | 'streaming' {\n  if (node.nextNodeSelector || node.deciderFn || node.selectorFn) return 'decider';\n  if (node.isStreaming) return 'streaming';\n\n  const hasDynamicChildren = Boolean(node.children?.length && !node.nextNodeSelector && node.fn);\n  if (node.children && node.children.length > 0 && !hasDynamicChildren) return 'fork';\n\n  return 'stage';\n}\n\nexport class RuntimeStructureManager {\n  private runtimePipelineStructure?: SerializedPipelineStructure;\n  private structureNodeMap: Map<string, SerializedPipelineStructure> = new Map();\n\n  /** Initialize from build-time structure. Deep-clones via JSON round-trip. */\n  init(buildTimeStructure?: SerializedPipelineStructure): void {\n    if (!buildTimeStructure) return;\n    this.runtimePipelineStructure = JSON.parse(JSON.stringify(buildTimeStructure));\n    this.buildNodeMap(this.runtimePipelineStructure!);\n  }\n\n  /** Returns the current runtime structure (mutated during execution). */\n  getStructure(): SerializedPipelineStructure | undefined {\n    return this.runtimePipelineStructure;\n  }\n\n  /** Recursively registers all nodes in the O(1) lookup map. */\n  private buildNodeMap(node: SerializedPipelineStructure): void {\n    const key = node.id ?? node.name;\n    this.structureNodeMap.set(key, node);\n\n    if (node.children) {\n      for (const child of node.children) {\n        this.buildNodeMap(child);\n      }\n    }\n    if (node.next) {\n      this.buildNodeMap(node.next);\n    }\n    if (node.subflowStructure) {\n      this.buildNodeMap(node.subflowStructure);\n    }\n  }\n\n  /** Convert a runtime StageNode into a SerializedPipelineStructure node. */\n  stageNodeToStructure(node: StageNode): SerializedPipelineStructure {\n    const structure: SerializedPipelineStructure = {\n      name: node.name,\n      id: node.id,\n      type: computeNodeType(node),\n      description: node.description,\n    };\n\n    if (node.isStreaming) {\n      structure.isStreaming = true;\n      structure.streamId = node.streamId;\n    }\n\n    if (node.isSubflowRoot) {\n      structure.isSubflowRoot = true;\n      structure.subflowId = node.subflowId;\n      structure.subflowName = node.subflowName;\n    }\n\n    if (node.deciderFn) {\n      structure.hasDecider = true;\n      structure.branchIds = node.children?.map((c) => c.id);\n    }\n\n    if (node.nextNodeSelector) {\n      structure.hasSelector = true;\n      structure.branchIds = node.children?.map((c) => c.id);\n    }\n\n    if (node.children?.length) {\n      structure.children = node.children.map((c) => this.stageNodeToStructure(c));\n    }\n\n    if (node.next) {\n      structure.next = this.stageNodeToStructure(node.next);\n    }\n\n    if (node.subflowDef?.buildTimeStructure) {\n      structure.subflowStructure = node.subflowDef.buildTimeStructure as SerializedPipelineStructure;\n    }\n\n    return structure;\n  }\n\n  /** Update structure when dynamic children are discovered at runtime. */\n  updateDynamicChildren(\n    parentNodeId: string,\n    dynamicChildren: StageNode[],\n    hasSelector?: boolean,\n    hasDecider?: boolean,\n  ): void {\n    if (!this.runtimePipelineStructure) return;\n\n    const parentStructure = this.structureNodeMap.get(parentNodeId);\n    if (!parentStructure) return;\n\n    const childStructures = dynamicChildren.map((child) => this.stageNodeToStructure(child));\n    parentStructure.children = childStructures;\n\n    for (const childStructure of childStructures) {\n      this.buildNodeMap(childStructure);\n    }\n\n    if (hasSelector) {\n      parentStructure.hasSelector = true;\n      parentStructure.branchIds = childStructures.map((c) => c.id ?? c.name);\n    }\n\n    if (hasDecider) {\n      parentStructure.hasDecider = true;\n      parentStructure.branchIds = childStructures.map((c) => c.id ?? c.name);\n    }\n  }\n\n  /** Update structure when a dynamic subflow is registered at runtime. */\n  updateDynamicSubflow(\n    mountNodeId: string,\n    subflowId: string,\n    subflowName?: string,\n    subflowBuildTimeStructure?: unknown,\n  ): void {\n    if (!this.runtimePipelineStructure) return;\n\n    const mountStructure = this.structureNodeMap.get(mountNodeId);\n    if (!mountStructure) return;\n\n    mountStructure.isSubflowRoot = true;\n    mountStructure.subflowId = subflowId;\n\n    if (subflowName !== undefined) {\n      mountStructure.subflowName = subflowName;\n    }\n\n    if (subflowBuildTimeStructure) {\n      // Deep-copy to prevent external mutation of the stored structure\n      mountStructure.subflowStructure = JSON.parse(\n        JSON.stringify(subflowBuildTimeStructure),\n      ) as SerializedPipelineStructure;\n      this.buildNodeMap(mountStructure.subflowStructure);\n    }\n  }\n\n  /** Update structure when a dynamic next chain is discovered at runtime. */\n  updateDynamicNext(currentNodeId: string, dynamicNext: StageNode): void {\n    if (!this.runtimePipelineStructure) return;\n\n    const currentStructure = this.structureNodeMap.get(currentNodeId);\n    if (!currentStructure) return;\n\n    const nextStructure = this.stageNodeToStructure(dynamicNext);\n    currentStructure.next = nextStructure;\n    this.buildNodeMap(nextStructure);\n  }\n\n  /** Update the iteration count for a node (loop support). */\n  updateIterationCount(nodeId: string, count: number): void {\n    if (!this.runtimePipelineStructure) return;\n    const nodeStructure = this.structureNodeMap.get(nodeId);\n    if (!nodeStructure) return;\n    nodeStructure.iterationCount = count;\n  }\n}\n"]}
@@ -129,7 +129,8 @@ class RuntimeStructureManager {
129
129
  mountStructure.subflowName = subflowName;
130
130
  }
131
131
  if (subflowBuildTimeStructure) {
132
- mountStructure.subflowStructure = subflowBuildTimeStructure;
132
+ // Deep-copy to prevent external mutation of the stored structure
133
+ mountStructure.subflowStructure = JSON.parse(JSON.stringify(subflowBuildTimeStructure));
133
134
  this.buildNodeMap(mountStructure.subflowStructure);
134
135
  }
135
136
  }
@@ -155,4 +156,4 @@ class RuntimeStructureManager {
155
156
  }
156
157
  }
157
158
  exports.RuntimeStructureManager = RuntimeStructureManager;
158
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RuntimeStructureManager.js","sourceRoot":"","sources":["../../../../src/lib/engine/handlers/RuntimeStructureManager.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * RuntimeStructureManager — Mutable structure tracking for visualization.\n *\n * During execution, dynamic events (new children, subflows, next chains,\n * loop iterations) modify the pipeline. This manager keeps a serialized\n * structure in sync so consumers get the complete picture.\n *\n * Deep-clones build-time structure at init, then maintains O(1) lookup map.\n */\n\nimport type { StageNode } from '../graph/StageNode.js';\nimport type { SerializedPipelineStructure } from '../types.js';\n\n/**\n * Compute the node type from node properties.\n * Shared by RuntimeStructureManager (serialization) and ExtractorRunner (metadata).\n */\nexport function computeNodeType(node: StageNode): 'stage' | 'decider' | 'fork' | 'streaming' {\n  if (node.nextNodeSelector || node.deciderFn || node.selectorFn) return 'decider';\n  if (node.isStreaming) return 'streaming';\n\n  const hasDynamicChildren = Boolean(node.children?.length && !node.nextNodeSelector && node.fn);\n  if (node.children && node.children.length > 0 && !hasDynamicChildren) return 'fork';\n\n  return 'stage';\n}\n\nexport class RuntimeStructureManager {\n  private runtimePipelineStructure?: SerializedPipelineStructure;\n  private structureNodeMap: Map<string, SerializedPipelineStructure> = new Map();\n\n  /** Initialize from build-time structure. Deep-clones via JSON round-trip. */\n  init(buildTimeStructure?: SerializedPipelineStructure): void {\n    if (!buildTimeStructure) return;\n    this.runtimePipelineStructure = JSON.parse(JSON.stringify(buildTimeStructure));\n    this.buildNodeMap(this.runtimePipelineStructure!);\n  }\n\n  /** Returns the current runtime structure (mutated during execution). */\n  getStructure(): SerializedPipelineStructure | undefined {\n    return this.runtimePipelineStructure;\n  }\n\n  /** Recursively registers all nodes in the O(1) lookup map. */\n  private buildNodeMap(node: SerializedPipelineStructure): void {\n    const key = node.id ?? node.name;\n    this.structureNodeMap.set(key, node);\n\n    if (node.children) {\n      for (const child of node.children) {\n        this.buildNodeMap(child);\n      }\n    }\n    if (node.next) {\n      this.buildNodeMap(node.next);\n    }\n    if (node.subflowStructure) {\n      this.buildNodeMap(node.subflowStructure);\n    }\n  }\n\n  /** Convert a runtime StageNode into a SerializedPipelineStructure node. */\n  stageNodeToStructure(node: StageNode): SerializedPipelineStructure {\n    const structure: SerializedPipelineStructure = {\n      name: node.name,\n      id: node.id,\n      type: computeNodeType(node),\n      description: node.description,\n    };\n\n    if (node.isStreaming) {\n      structure.isStreaming = true;\n      structure.streamId = node.streamId;\n    }\n\n    if (node.isSubflowRoot) {\n      structure.isSubflowRoot = true;\n      structure.subflowId = node.subflowId;\n      structure.subflowName = node.subflowName;\n    }\n\n    if (node.deciderFn) {\n      structure.hasDecider = true;\n      structure.branchIds = node.children?.map((c) => c.id);\n    }\n\n    if (node.nextNodeSelector) {\n      structure.hasSelector = true;\n      structure.branchIds = node.children?.map((c) => c.id);\n    }\n\n    if (node.children?.length) {\n      structure.children = node.children.map((c) => this.stageNodeToStructure(c));\n    }\n\n    if (node.next) {\n      structure.next = this.stageNodeToStructure(node.next);\n    }\n\n    if (node.subflowDef?.buildTimeStructure) {\n      structure.subflowStructure = node.subflowDef.buildTimeStructure as SerializedPipelineStructure;\n    }\n\n    return structure;\n  }\n\n  /** Update structure when dynamic children are discovered at runtime. */\n  updateDynamicChildren(\n    parentNodeId: string,\n    dynamicChildren: StageNode[],\n    hasSelector?: boolean,\n    hasDecider?: boolean,\n  ): void {\n    if (!this.runtimePipelineStructure) return;\n\n    const parentStructure = this.structureNodeMap.get(parentNodeId);\n    if (!parentStructure) return;\n\n    const childStructures = dynamicChildren.map((child) => this.stageNodeToStructure(child));\n    parentStructure.children = childStructures;\n\n    for (const childStructure of childStructures) {\n      this.buildNodeMap(childStructure);\n    }\n\n    if (hasSelector) {\n      parentStructure.hasSelector = true;\n      parentStructure.branchIds = childStructures.map((c) => c.id ?? c.name);\n    }\n\n    if (hasDecider) {\n      parentStructure.hasDecider = true;\n      parentStructure.branchIds = childStructures.map((c) => c.id ?? c.name);\n    }\n  }\n\n  /** Update structure when a dynamic subflow is registered at runtime. */\n  updateDynamicSubflow(\n    mountNodeId: string,\n    subflowId: string,\n    subflowName?: string,\n    subflowBuildTimeStructure?: unknown,\n  ): void {\n    if (!this.runtimePipelineStructure) return;\n\n    const mountStructure = this.structureNodeMap.get(mountNodeId);\n    if (!mountStructure) return;\n\n    mountStructure.isSubflowRoot = true;\n    mountStructure.subflowId = subflowId;\n\n    if (subflowName !== undefined) {\n      mountStructure.subflowName = subflowName;\n    }\n\n    if (subflowBuildTimeStructure) {\n      mountStructure.subflowStructure = subflowBuildTimeStructure as SerializedPipelineStructure;\n      this.buildNodeMap(mountStructure.subflowStructure);\n    }\n  }\n\n  /** Update structure when a dynamic next chain is discovered at runtime. */\n  updateDynamicNext(currentNodeId: string, dynamicNext: StageNode): void {\n    if (!this.runtimePipelineStructure) return;\n\n    const currentStructure = this.structureNodeMap.get(currentNodeId);\n    if (!currentStructure) return;\n\n    const nextStructure = this.stageNodeToStructure(dynamicNext);\n    currentStructure.next = nextStructure;\n    this.buildNodeMap(nextStructure);\n  }\n\n  /** Update the iteration count for a node (loop support). */\n  updateIterationCount(nodeId: string, count: number): void {\n    if (!this.runtimePipelineStructure) return;\n    const nodeStructure = this.structureNodeMap.get(nodeId);\n    if (!nodeStructure) return;\n    nodeStructure.iterationCount = count;\n  }\n}\n"]}
159
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RuntimeStructureManager.js","sourceRoot":"","sources":["../../../../src/lib/engine/handlers/RuntimeStructureManager.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * RuntimeStructureManager — Mutable structure tracking for visualization.\n *\n * During execution, dynamic events (new children, subflows, next chains,\n * loop iterations) modify the pipeline. This manager keeps a serialized\n * structure in sync so consumers get the complete picture.\n *\n * Deep-clones build-time structure at init, then maintains O(1) lookup map.\n */\n\nimport type { StageNode } from '../graph/StageNode.js';\nimport type { SerializedPipelineStructure } from '../types.js';\n\n/**\n * Compute the node type from node properties.\n * Shared by RuntimeStructureManager (serialization) and ExtractorRunner (metadata).\n */\nexport function computeNodeType(node: StageNode): 'stage' | 'decider' | 'fork' | 'streaming' {\n  if (node.nextNodeSelector || node.deciderFn || node.selectorFn) return 'decider';\n  if (node.isStreaming) return 'streaming';\n\n  const hasDynamicChildren = Boolean(node.children?.length && !node.nextNodeSelector && node.fn);\n  if (node.children && node.children.length > 0 && !hasDynamicChildren) return 'fork';\n\n  return 'stage';\n}\n\nexport class RuntimeStructureManager {\n  private runtimePipelineStructure?: SerializedPipelineStructure;\n  private structureNodeMap: Map<string, SerializedPipelineStructure> = new Map();\n\n  /** Initialize from build-time structure. Deep-clones via JSON round-trip. */\n  init(buildTimeStructure?: SerializedPipelineStructure): void {\n    if (!buildTimeStructure) return;\n    this.runtimePipelineStructure = JSON.parse(JSON.stringify(buildTimeStructure));\n    this.buildNodeMap(this.runtimePipelineStructure!);\n  }\n\n  /** Returns the current runtime structure (mutated during execution). */\n  getStructure(): SerializedPipelineStructure | undefined {\n    return this.runtimePipelineStructure;\n  }\n\n  /** Recursively registers all nodes in the O(1) lookup map. */\n  private buildNodeMap(node: SerializedPipelineStructure): void {\n    const key = node.id ?? node.name;\n    this.structureNodeMap.set(key, node);\n\n    if (node.children) {\n      for (const child of node.children) {\n        this.buildNodeMap(child);\n      }\n    }\n    if (node.next) {\n      this.buildNodeMap(node.next);\n    }\n    if (node.subflowStructure) {\n      this.buildNodeMap(node.subflowStructure);\n    }\n  }\n\n  /** Convert a runtime StageNode into a SerializedPipelineStructure node. */\n  stageNodeToStructure(node: StageNode): SerializedPipelineStructure {\n    const structure: SerializedPipelineStructure = {\n      name: node.name,\n      id: node.id,\n      type: computeNodeType(node),\n      description: node.description,\n    };\n\n    if (node.isStreaming) {\n      structure.isStreaming = true;\n      structure.streamId = node.streamId;\n    }\n\n    if (node.isSubflowRoot) {\n      structure.isSubflowRoot = true;\n      structure.subflowId = node.subflowId;\n      structure.subflowName = node.subflowName;\n    }\n\n    if (node.deciderFn) {\n      structure.hasDecider = true;\n      structure.branchIds = node.children?.map((c) => c.id);\n    }\n\n    if (node.nextNodeSelector) {\n      structure.hasSelector = true;\n      structure.branchIds = node.children?.map((c) => c.id);\n    }\n\n    if (node.children?.length) {\n      structure.children = node.children.map((c) => this.stageNodeToStructure(c));\n    }\n\n    if (node.next) {\n      structure.next = this.stageNodeToStructure(node.next);\n    }\n\n    if (node.subflowDef?.buildTimeStructure) {\n      structure.subflowStructure = node.subflowDef.buildTimeStructure as SerializedPipelineStructure;\n    }\n\n    return structure;\n  }\n\n  /** Update structure when dynamic children are discovered at runtime. */\n  updateDynamicChildren(\n    parentNodeId: string,\n    dynamicChildren: StageNode[],\n    hasSelector?: boolean,\n    hasDecider?: boolean,\n  ): void {\n    if (!this.runtimePipelineStructure) return;\n\n    const parentStructure = this.structureNodeMap.get(parentNodeId);\n    if (!parentStructure) return;\n\n    const childStructures = dynamicChildren.map((child) => this.stageNodeToStructure(child));\n    parentStructure.children = childStructures;\n\n    for (const childStructure of childStructures) {\n      this.buildNodeMap(childStructure);\n    }\n\n    if (hasSelector) {\n      parentStructure.hasSelector = true;\n      parentStructure.branchIds = childStructures.map((c) => c.id ?? c.name);\n    }\n\n    if (hasDecider) {\n      parentStructure.hasDecider = true;\n      parentStructure.branchIds = childStructures.map((c) => c.id ?? c.name);\n    }\n  }\n\n  /** Update structure when a dynamic subflow is registered at runtime. */\n  updateDynamicSubflow(\n    mountNodeId: string,\n    subflowId: string,\n    subflowName?: string,\n    subflowBuildTimeStructure?: unknown,\n  ): void {\n    if (!this.runtimePipelineStructure) return;\n\n    const mountStructure = this.structureNodeMap.get(mountNodeId);\n    if (!mountStructure) return;\n\n    mountStructure.isSubflowRoot = true;\n    mountStructure.subflowId = subflowId;\n\n    if (subflowName !== undefined) {\n      mountStructure.subflowName = subflowName;\n    }\n\n    if (subflowBuildTimeStructure) {\n      // Deep-copy to prevent external mutation of the stored structure\n      mountStructure.subflowStructure = JSON.parse(\n        JSON.stringify(subflowBuildTimeStructure),\n      ) as SerializedPipelineStructure;\n      this.buildNodeMap(mountStructure.subflowStructure);\n    }\n  }\n\n  /** Update structure when a dynamic next chain is discovered at runtime. */\n  updateDynamicNext(currentNodeId: string, dynamicNext: StageNode): void {\n    if (!this.runtimePipelineStructure) return;\n\n    const currentStructure = this.structureNodeMap.get(currentNodeId);\n    if (!currentStructure) return;\n\n    const nextStructure = this.stageNodeToStructure(dynamicNext);\n    currentStructure.next = nextStructure;\n    this.buildNodeMap(nextStructure);\n  }\n\n  /** Update the iteration count for a node (loop support). */\n  updateIterationCount(nodeId: string, count: number): void {\n    if (!this.runtimePipelineStructure) return;\n    const nodeStructure = this.structureNodeMap.get(nodeId);\n    if (!nodeStructure) return;\n    nodeStructure.iterationCount = count;\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "footprintjs",
3
- "version": "0.14.3",
3
+ "version": "0.14.4",
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",
@@ -1,35 +0,0 @@
1
- /**
2
- * FootPrint — Advanced / Internal API
3
- *
4
- * These exports are for advanced use cases, testing, and building
5
- * custom execution engines. Most users should use the main 'footprint' entry point.
6
- *
7
- * Import via: import { ... } from 'footprint/advanced'
8
- */
9
- export type { CommitBundle, FlowControlType, FlowMessage, MemoryPatch, ScopeFactory, StageSnapshot, TraceEntry, } from './lib/memory';
10
- export { SharedMemory } from './lib/memory';
11
- export { StageContext } from './lib/memory';
12
- export { EventLog } from './lib/memory';
13
- export { TransactionBuffer } from './lib/memory';
14
- export { DiagnosticCollector } from './lib/memory';
15
- export { applySmartMerge, deepSmartMerge, getNestedValue, getRunAndGlobalPaths, normalisePath, redactPatch, setNestedValue, updateNestedValue, updateValue, } from './lib/memory';
16
- export type { BuildTimeExtractor, BuildTimeNodeMetadata, ExecOptions, FlowChartSpec, ILogger, PipelineStageFunction, ScopeProtectionMode, SerializedPipelineStructure, SimplifiedParallelSpec, StageFn, StageNode, StreamCallback, StreamLifecycleHandler, StreamTokenHandler, SubflowMountOptions, SubflowRef, } from './lib/builder';
17
- export { DeciderList, SelectorFnList, specToStageNode } from './lib/builder';
18
- export type { ProviderResolver, ResolveOptions, ScopeProvider, StageContextLike, StrictMode } from './lib/scope';
19
- export { createErrorMessage, createProtectedScope } from './lib/scope';
20
- export { attachBaseStateCompat, attachScopeMethods, isSubclassOfScopeFacade, looksLikeClassCtor, looksLikeFactory, makeClassProvider, makeFactoryProvider, registerScopeResolver, resolveScopeProvider, toScopeFactory, } from './lib/scope';
21
- export type { AggregatedMetrics, DebugEntry, DebugRecorderOptions, DebugVerbosity, DefineScopeOptions, NarrativeDetail, NarrativeOperation, NarrativeRecorderOptions, RecorderContext, StageEvent, StageMetrics, StageNarrativeData, } from './lib/scope';
22
- export { createScopeProxyFromZod, defineScopeSchema, isScopeSchema, ZodScopeResolver } from './lib/scope';
23
- export type { NarrativeEntry, RuntimeSnapshot } from './lib/runner';
24
- export { ExecutionRuntime } from './lib/runner';
25
- export type { TraverserOptions } from './lib/engine';
26
- export type { Decider } from './lib/engine';
27
- export { FlowchartTraverser } from './lib/engine';
28
- export { isStageNodeReturn } from './lib/engine';
29
- export type { IControlFlowNarrative } from './lib/engine';
30
- export type { CombinedNarrativeEntry, CombinedNarrativeOptions } from './lib/engine';
31
- export type { BranchResult, BranchResults, SerializedPipelineStructure as EngineSerializedPipelineStructure, StageSnapshot as EngineStageSnapshot, ExtractorError, HandlerDeps, IExecutionRuntime, NodeResultType, RuntimeStructureMetadata, SerializedPipelineNode, StageFunction, SubflowResult, TraversalExtractor, TraversalResult, } from './lib/engine';
32
- export { ControlFlowNarrativeGenerator } from './lib/engine';
33
- export { NullControlFlowNarrativeGenerator } from './lib/engine';
34
- export type { CallExtractorFn, ExecuteNodeFn, GetStagePathFn, RunStageFn } from './lib/engine';
35
- export { applyOutputMapping, ChildrenExecutor, computeNodeType, ContinuationResolver, createSubflowHandlerDeps, DeciderHandler, DEFAULT_MAX_ITERATIONS, ExtractorRunner, extractParentScopeValues, getInitialScopeValues, NodeResolver, RuntimeStructureManager, seedSubflowGlobalStore, SelectorHandler, StageRunner, SubflowExecutor, } from './lib/engine';
@@ -1,46 +0,0 @@
1
- /**
2
- * FootPrint — Public API
3
- *
4
- * Connected causal trace library for LLM pipelines.
5
- * Builds flowcharts, executes them via DFS traversal, and captures
6
- * every stage's context (state, decisions, errors) in an auditable trace.
7
- *
8
- * For advanced/internal APIs (memory primitives, engine handlers, providers),
9
- * import from 'footprint/advanced'.
10
- */
11
- export type { FlowChart, PipelineStageFunction as StageHandler, StreamHandlers } from './lib/builder';
12
- export { flowChart, FlowChartBuilder } from './lib/builder';
13
- export { FlowChartExecutor } from './lib/runner';
14
- export type { ComposableRunner } from './lib/runner';
15
- export type { SubtreeSnapshot } from './lib/runner';
16
- export { getSubtreeSnapshot, listSubflowPaths } from './lib/runner';
17
- export { ScopeFacade } from './lib/scope';
18
- export { MetricRecorder } from './lib/scope';
19
- export { DebugRecorder } from './lib/scope';
20
- export { NarrativeRecorder } from './lib/scope';
21
- export type { CommitEvent, ErrorEvent, ReadEvent, Recorder, RedactionPolicy, RedactionReport, WriteEvent, } from './lib/scope';
22
- export { defineScopeFromZod } from './lib/scope';
23
- export type { CombinedNarrativeEntry } from './lib/engine';
24
- export { CombinedNarrativeBuilder } from './lib/engine';
25
- export type { FlowErrorEvent, FlowLoopEvent, FlowRecorder, FlowSubflowEvent, FlowSubflowRegisteredEvent, } from './lib/engine';
26
- export { NarrativeFlowRecorder } from './lib/engine';
27
- export type { StructuredErrorInfo } from './lib/engine';
28
- export { extractErrorInfo, formatErrorInfo } from './lib/engine';
29
- export type { ManifestEntry } from './lib/engine';
30
- export { ManifestFlowRecorder } from './lib/engine';
31
- export { AdaptiveNarrativeFlowRecorder } from './lib/engine';
32
- export { MilestoneNarrativeFlowRecorder } from './lib/engine';
33
- export { ProgressiveNarrativeFlowRecorder } from './lib/engine';
34
- export { RLENarrativeFlowRecorder } from './lib/engine';
35
- export { SeparateNarrativeFlowRecorder } from './lib/engine';
36
- export { SilentNarrativeFlowRecorder } from './lib/engine';
37
- export { WindowedNarrativeFlowRecorder } from './lib/engine';
38
- export type { ExecutionEnv, RunOptions } from './lib/engine';
39
- export type { ScopeFactory } from './lib/memory';
40
- export type { FlowChartContract, FlowChartContractOptions, JsonSchema, OpenAPIOptions, OpenAPISpec, } from './lib/contract';
41
- export { defineContract } from './lib/contract';
42
- export { normalizeSchema, zodToJsonSchema } from './lib/contract';
43
- export { generateOpenAPI } from './lib/contract';
44
- export type { SchemaKind, ValidationIssue, ValidationResult } from './lib/schema';
45
- export { detectSchema, isValidatable, isZod } from './lib/schema';
46
- export { InputValidationError, validateAgainstSchema, validateOrThrow } from './lib/schema';
@@ -1,129 +0,0 @@
1
- /**
2
- * FlowChartBuilder — Fluent API for constructing flowchart execution graphs.
3
- *
4
- * Builds StageNode trees and SerializedPipelineStructure (JSON) in tandem.
5
- * Zero dependencies on old code — only imports from local types.
6
- *
7
- * The builder creates two parallel structures:
8
- * 1. StageNode tree — runtime graph with embedded functions
9
- * 2. SerializedPipelineStructure — JSON-safe structure for visualization
10
- *
11
- * The execute() convenience method is intentionally omitted —
12
- * it belongs in the runner layer (Phase 5).
13
- */
14
- import type { BuildTimeExtractor, FlowChart, FlowChartSpec, ILogger, PipelineStageFunction, SerializedPipelineStructure, SimplifiedParallelSpec, StageNode, StreamLifecycleHandler, StreamTokenHandler, SubflowMountOptions, TraversalExtractor } from './types';
15
- /**
16
- * Fluent helper returned by addDeciderFunction to add branches.
17
- * `end()` sets `deciderFn = true` — the fn IS the decider.
18
- */
19
- export declare class DeciderList<TOut = any, TScope = any> {
20
- private readonly b;
21
- private readonly curNode;
22
- private readonly curSpec;
23
- private readonly branchIds;
24
- private defaultId?;
25
- private readonly parentDescriptionParts;
26
- private readonly parentStageDescriptions;
27
- private readonly reservedStepNumber;
28
- private readonly deciderDescription?;
29
- private readonly branchDescInfo;
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>, description?: string): DeciderList<TOut, TScope>;
32
- addSubFlowChartBranch(id: string, subflow: FlowChart<TOut, TScope>, mountName?: string, options?: SubflowMountOptions): DeciderList<TOut, TScope>;
33
- addBranchList(branches: Array<{
34
- id: string;
35
- name: string;
36
- fn?: PipelineStageFunction<TOut, TScope>;
37
- }>): DeciderList<TOut, TScope>;
38
- setDefault(id: string): DeciderList<TOut, TScope>;
39
- end(): FlowChartBuilder<TOut, TScope>;
40
- }
41
- export declare class SelectorFnList<TOut = any, TScope = any> {
42
- private readonly b;
43
- private readonly curNode;
44
- private readonly curSpec;
45
- private readonly branchIds;
46
- private readonly parentDescriptionParts;
47
- private readonly parentStageDescriptions;
48
- private readonly reservedStepNumber;
49
- private readonly selectorDescription?;
50
- private readonly branchDescInfo;
51
- constructor(builder: FlowChartBuilder<TOut, TScope>, curNode: StageNode<TOut, TScope>, curSpec: SerializedPipelineStructure, parentDescriptionParts?: string[], parentStageDescriptions?: Map<string, string>, reservedStepNumber?: number, selectorDescription?: string);
52
- addFunctionBranch(id: string, name: string, fn?: PipelineStageFunction<TOut, TScope>, description?: string): SelectorFnList<TOut, TScope>;
53
- addSubFlowChartBranch(id: string, subflow: FlowChart<TOut, TScope>, mountName?: string, options?: SubflowMountOptions): SelectorFnList<TOut, TScope>;
54
- addBranchList(branches: Array<{
55
- id: string;
56
- name: string;
57
- fn?: PipelineStageFunction<TOut, TScope>;
58
- }>): SelectorFnList<TOut, TScope>;
59
- end(): FlowChartBuilder<TOut, TScope>;
60
- }
61
- export declare class FlowChartBuilder<TOut = any, TScope = any> {
62
- private _root?;
63
- private _rootSpec?;
64
- private _cursor?;
65
- private _cursorSpec?;
66
- private _stageMap;
67
- _subflowDefs: Map<string, {
68
- root: StageNode<TOut, TScope>;
69
- }>;
70
- private _streamHandlers;
71
- private _extractor?;
72
- private _buildTimeExtractor?;
73
- private _buildTimeExtractorErrors;
74
- private _enableNarrative;
75
- private _logger?;
76
- private _descriptionParts;
77
- private _stepCounter;
78
- private _stageDescriptions;
79
- private _stageStepMap;
80
- private _knownStageIds;
81
- private _inputSchema?;
82
- private _outputSchema?;
83
- private _outputMapper?;
84
- constructor(buildTimeExtractor?: BuildTimeExtractor<any>);
85
- private _appendDescriptionLine;
86
- private _appendSubflowDescription;
87
- setEnableNarrative(): this;
88
- setLogger(logger: ILogger): this;
89
- /** Declare the input schema (readOnlyContext shape). Accepts Zod schema or JSON Schema. */
90
- setInputSchema(schema: unknown): this;
91
- /** Declare the output schema (response shape). Accepts Zod schema or JSON Schema. */
92
- setOutputSchema(schema: unknown): this;
93
- /** Set the output mapper that extracts the response from final scope. */
94
- setOutputMapper(mapper: (finalScope: Record<string, unknown>) => unknown): this;
95
- start(name: string, fn: PipelineStageFunction<TOut, TScope>, id: string, description?: string): this;
96
- addFunction(name: string, fn: PipelineStageFunction<TOut, TScope>, id: string, description?: string): this;
97
- addStreamingFunction(name: string, fn: PipelineStageFunction<TOut, TScope>, id: string, streamId?: string, description?: string): this;
98
- addDeciderFunction(name: string, fn: PipelineStageFunction<TOut, TScope>, id: string, description?: string): DeciderList<TOut, TScope>;
99
- addSelectorFunction(name: string, fn: PipelineStageFunction<TOut, TScope>, id: string, description?: string): SelectorFnList<TOut, TScope>;
100
- addListOfFunction(children: SimplifiedParallelSpec<TOut, TScope>[], options?: {
101
- failFast?: boolean;
102
- }): this;
103
- addSubFlowChart(id: string, subflow: FlowChart<TOut, TScope>, mountName?: string, options?: SubflowMountOptions): this;
104
- addSubFlowChartNext(id: string, subflow: FlowChart<TOut, TScope>, mountName?: string, options?: SubflowMountOptions): this;
105
- loopTo(stageId: string): this;
106
- onStream(handler: StreamTokenHandler): this;
107
- onStreamStart(handler: StreamLifecycleHandler): this;
108
- onStreamEnd(handler: StreamLifecycleHandler): this;
109
- addTraversalExtractor<TResult = unknown>(extractor: TraversalExtractor<TResult>): this;
110
- addBuildTimeExtractor<TResult = FlowChartSpec>(extractor: BuildTimeExtractor<TResult>): this;
111
- getBuildTimeExtractorErrors(): Array<{
112
- message: string;
113
- error: unknown;
114
- }>;
115
- build(): FlowChart<TOut, TScope>;
116
- toSpec<TResult = SerializedPipelineStructure>(): TResult;
117
- toMermaid(): string;
118
- private _needCursor;
119
- private _needCursorSpec;
120
- _applyExtractorToNode(spec: SerializedPipelineStructure): SerializedPipelineStructure;
121
- _addToMap(name: string, fn: PipelineStageFunction<TOut, TScope>): void;
122
- _mergeStageMap(other: Map<string, PipelineStageFunction<TOut, TScope>>, prefix?: string): void;
123
- _prefixNodeTree(node: StageNode<TOut, TScope>, prefix: string): StageNode<TOut, TScope>;
124
- _mergeSubflows(subflows: Record<string, {
125
- root: StageNode<TOut, TScope>;
126
- }> | undefined, prefix: string): void;
127
- }
128
- export declare function flowChart<TOut = any, TScope = any>(name: string, fn: PipelineStageFunction<TOut, TScope>, id: string, buildTimeExtractor?: BuildTimeExtractor<any>, description?: string): FlowChartBuilder<TOut, TScope>;
129
- export declare function specToStageNode(spec: FlowChartSpec): StageNode<any, any>;
@@ -1,9 +0,0 @@
1
- /**
2
- * builder/ — Flowchart construction library (zero deps on old code)
3
- *
4
- * Fluent API for building StageNode trees and SerializedPipelineStructure.
5
- * Can be used standalone for building flowchart specs without execution.
6
- */
7
- export { DeciderList, FlowChartBuilder, SelectorFnList } from './FlowChartBuilder';
8
- export { flowChart, specToStageNode } from './FlowChartBuilder';
9
- export type { BuildTimeExtractor, BuildTimeNodeMetadata, ExecOptions, FlowChart, FlowChartSpec, ILogger, PipelineStageFunction, ScopeProtectionMode, SerializedPipelineStructure, SimplifiedParallelSpec, StageFn, StageFunction, StageNode, StreamCallback, StreamHandlers, StreamLifecycleHandler, StreamTokenHandler, SubflowMountOptions, SubflowRef, TraversalExtractor, } from './types';
@@ -1,102 +0,0 @@
1
- /**
2
- * builder/types.ts — All types used by the builder library.
3
- *
4
- * Shared types (StageNode, StageFunction, etc.) are imported from the engine.
5
- * Builder-specific types (FlowChartSpec, FlowChart, SerializedPipelineStructure)
6
- * are defined locally — they carry builder-only fields (description, outputMapper, etc.).
7
- *
8
- * NOTE: All engine imports are `import type` — zero runtime dependency.
9
- * The builder remains standalone at runtime.
10
- */
11
- import type { StageNode } from '../engine/graph/StageNode';
12
- import type { ILogger, StageFunction } from '../engine/types';
13
- export type { StageNode } from '../engine/graph/StageNode';
14
- export type { ILogger, StageFunction, StreamCallback, StreamHandlers, StreamLifecycleHandler, StreamTokenHandler, SubflowMountOptions, } from '../engine/types';
15
- /** @deprecated Use StageFunction instead. */
16
- export type PipelineStageFunction<TOut = any, TScope = any> = StageFunction<TOut, TScope>;
17
- /** Relaxed-generic alias for builder ergonomics. */
18
- export type StageFn = StageFunction<any, any>;
19
- export type ScopeProtectionMode = 'error' | 'warn' | 'off';
20
- export interface SerializedPipelineStructure {
21
- name: string;
22
- id?: string;
23
- type: 'stage' | 'decider' | 'fork' | 'streaming';
24
- /** Semantic icon hint for visualization (e.g., "llm", "tool", "rag", "agent", "start") */
25
- icon?: string;
26
- description?: string;
27
- children?: SerializedPipelineStructure[];
28
- next?: SerializedPipelineStructure;
29
- hasDecider?: boolean;
30
- hasSelector?: boolean;
31
- branchIds?: string[];
32
- loopTarget?: string;
33
- isStreaming?: boolean;
34
- streamId?: string;
35
- isParallelChild?: boolean;
36
- parallelGroupId?: string;
37
- isSubflowRoot?: boolean;
38
- subflowId?: string;
39
- subflowName?: string;
40
- subflowStructure?: SerializedPipelineStructure;
41
- iterationCount?: number;
42
- }
43
- export interface FlowChartSpec {
44
- name: string;
45
- id?: string;
46
- /** Semantic icon hint for visualization (e.g., "llm", "tool", "rag", "agent", "start") */
47
- icon?: string;
48
- description?: string;
49
- children?: FlowChartSpec[];
50
- next?: FlowChartSpec;
51
- hasDecider?: boolean;
52
- hasSelector?: boolean;
53
- branchIds?: string[];
54
- loopTarget?: string;
55
- isStreaming?: boolean;
56
- streamId?: string;
57
- isParallelChild?: boolean;
58
- parallelGroupId?: string;
59
- isSubflowRoot?: boolean;
60
- subflowId?: string;
61
- subflowName?: string;
62
- }
63
- /** Metadata provided to the build-time extractor for each node. */
64
- export type BuildTimeNodeMetadata = FlowChartSpec;
65
- export type BuildTimeExtractor<TResult = FlowChartSpec> = (metadata: BuildTimeNodeMetadata) => TResult;
66
- export type TraversalExtractor<TResult = unknown> = (snapshot: unknown) => TResult | undefined | null;
67
- export type FlowChart<TOut = any, TScope = any> = {
68
- root: StageNode<TOut, TScope>;
69
- stageMap: Map<string, StageFunction<TOut, TScope>>;
70
- extractor?: TraversalExtractor;
71
- subflows?: Record<string, {
72
- root: StageNode<TOut, TScope>;
73
- }>;
74
- buildTimeStructure: SerializedPipelineStructure;
75
- enableNarrative?: boolean;
76
- logger?: ILogger;
77
- description: string;
78
- stageDescriptions: Map<string, string>;
79
- /** Input schema (Zod or JSON Schema) — declared via setInputSchema(). */
80
- inputSchema?: unknown;
81
- /** Output schema (Zod or JSON Schema) — declared via setOutputSchema(). */
82
- outputSchema?: unknown;
83
- /** Output mapper — extracts response from final scope. */
84
- outputMapper?: (finalScope: Record<string, unknown>) => unknown;
85
- };
86
- export type SimplifiedParallelSpec<TOut = any, TScope = any> = {
87
- id: string;
88
- name: string;
89
- fn?: StageFunction<TOut, TScope>;
90
- };
91
- export type ExecOptions = {
92
- defaults?: unknown;
93
- initial?: unknown;
94
- readOnly?: unknown;
95
- throttlingErrorChecker?: (e: unknown) => boolean;
96
- scopeProtectionMode?: ScopeProtectionMode;
97
- enableNarrative?: boolean;
98
- };
99
- export interface SubflowRef {
100
- $ref: string;
101
- mountId: string;
102
- }
@@ -1,18 +0,0 @@
1
- /**
2
- * contract/defineContract.ts — Factory for creating a FlowChartContract.
3
- *
4
- * Wraps a compiled FlowChart with I/O schemas and an output mapper,
5
- * using the same pattern as SubflowMountOptions (inputMapper/outputMapper).
6
- *
7
- * Usage:
8
- * const contract = defineContract(chart, {
9
- * inputSchema: z.object({ name: z.string() }),
10
- * outputSchema: z.object({ greeting: z.string() }),
11
- * outputMapper: (scope) => ({ greeting: scope.message as string }),
12
- * });
13
- *
14
- * const openapi = contract.toOpenAPI();
15
- */
16
- import type { FlowChart } from '../builder/types';
17
- import type { FlowChartContract, FlowChartContractOptions } from './types';
18
- export declare function defineContract<TInput = unknown, TOutput = unknown>(chart: FlowChart, options: FlowChartContractOptions<TInput, TOutput>): FlowChartContract<TInput, TOutput>;
@@ -1,14 +0,0 @@
1
- /**
2
- * contract/ — FlowChart I/O contract and OpenAPI generation layer.
3
- *
4
- * Standalone library: wraps a compiled FlowChart with input/output schemas
5
- * and generates OpenAPI 3.1 specs. Uses the same inputMapper/outputMapper
6
- * pattern as subflow mounting.
7
- *
8
- * Zero runtime deps on Zod — Zod schemas detected via duck-typing and
9
- * converted to JSON Schema at contract creation time.
10
- */
11
- export { defineContract } from './defineContract';
12
- export { isZodSchema, normalizeSchema, zodToJsonSchema } from './schema';
13
- export { generateOpenAPI } from './openapi';
14
- export type { FlowChartContract, FlowChartContractOptions, JsonSchema, OpenAPIOptions, OpenAPISpec, SchemaInput, } from './types';
@@ -1,12 +0,0 @@
1
- /**
2
- * contract/openapi.ts — OpenAPI 3.1 spec generator.
3
- *
4
- * Generates an OpenAPI spec from a FlowChartContract by combining:
5
- * - chart.description → operation description
6
- * - chart.stageDescriptions → step-by-step detail
7
- * - inputSchema → requestBody
8
- * - outputSchema → response
9
- * - chart.buildTimeStructure → operation metadata (branches, forks, etc.)
10
- */
11
- import type { FlowChartContract, OpenAPIOptions, OpenAPISpec } from './types';
12
- export declare function generateOpenAPI(contract: FlowChartContract, options?: OpenAPIOptions): OpenAPISpec;
@@ -1,15 +0,0 @@
1
- /**
2
- * contract/schema.ts — Schema normalization utilities.
3
- *
4
- * Converts Zod schemas or raw JSON Schema objects into a normalized
5
- * JsonSchema format. Detection delegated to schema/detect.ts (single source of truth).
6
- *
7
- * Standalone: no dependency on Zod at import time.
8
- * Compatible with Zod v4 internals.
9
- */
10
- import type { JsonSchema, SchemaInput } from './types';
11
- /** @deprecated Use `isZod()` from `schema/detect` instead. Kept for backward compatibility. */
12
- export declare function isZodSchema(input: unknown): boolean;
13
- /** Convert a Zod schema object to JSON Schema. */
14
- export declare function zodToJsonSchema(zodSchema: Record<string, unknown>): JsonSchema;
15
- export declare function normalizeSchema(input: SchemaInput): JsonSchema;