footprintjs 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (251) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +658 -0
  3. package/dist/advanced.js +84 -0
  4. package/dist/esm/advanced.js +26 -0
  5. package/dist/esm/index.js +30 -0
  6. package/dist/esm/lib/builder/FlowChartBuilder.js +809 -0
  7. package/dist/esm/lib/builder/index.js +12 -0
  8. package/dist/esm/lib/builder/types.js +9 -0
  9. package/dist/esm/lib/engine/graph/StageNode.js +38 -0
  10. package/dist/esm/lib/engine/graph/index.js +2 -0
  11. package/dist/esm/lib/engine/handlers/ChildrenExecutor.js +116 -0
  12. package/dist/esm/lib/engine/handlers/ContinuationResolver.js +121 -0
  13. package/dist/esm/lib/engine/handlers/DeciderHandler.js +78 -0
  14. package/dist/esm/lib/engine/handlers/ExtractorRunner.js +117 -0
  15. package/dist/esm/lib/engine/handlers/NodeResolver.js +72 -0
  16. package/dist/esm/lib/engine/handlers/RuntimeStructureManager.js +154 -0
  17. package/dist/esm/lib/engine/handlers/SelectorHandler.js +79 -0
  18. package/dist/esm/lib/engine/handlers/StageRunner.js +86 -0
  19. package/dist/esm/lib/engine/handlers/SubflowExecutor.js +322 -0
  20. package/dist/esm/lib/engine/handlers/SubflowInputMapper.js +113 -0
  21. package/dist/esm/lib/engine/handlers/index.js +23 -0
  22. package/dist/esm/lib/engine/index.js +18 -0
  23. package/dist/esm/lib/engine/narrative/CombinedNarrativeBuilder.js +158 -0
  24. package/dist/esm/lib/engine/narrative/ControlFlowNarrativeGenerator.js +90 -0
  25. package/dist/esm/lib/engine/narrative/NullControlFlowNarrativeGenerator.js +24 -0
  26. package/dist/esm/lib/engine/narrative/index.js +4 -0
  27. package/dist/esm/lib/engine/narrative/types.js +11 -0
  28. package/dist/esm/lib/engine/traversal/FlowchartTraverser.js +419 -0
  29. package/dist/esm/lib/engine/traversal/index.js +2 -0
  30. package/dist/esm/lib/engine/types.js +16 -0
  31. package/dist/esm/lib/memory/DiagnosticCollector.js +44 -0
  32. package/dist/esm/lib/memory/EventLog.js +44 -0
  33. package/dist/esm/lib/memory/SharedMemory.js +53 -0
  34. package/dist/esm/lib/memory/StageContext.js +221 -0
  35. package/dist/esm/lib/memory/TransactionBuffer.js +66 -0
  36. package/dist/esm/lib/memory/index.js +16 -0
  37. package/dist/esm/lib/memory/types.js +7 -0
  38. package/dist/esm/lib/memory/utils.js +155 -0
  39. package/dist/esm/lib/runner/ExecutionRuntime.js +64 -0
  40. package/dist/esm/lib/runner/FlowChartExecutor.js +108 -0
  41. package/dist/esm/lib/runner/index.js +3 -0
  42. package/dist/esm/lib/scope/ScopeFacade.js +175 -0
  43. package/dist/esm/lib/scope/index.js +19 -0
  44. package/dist/esm/lib/scope/protection/createProtectedScope.js +59 -0
  45. package/dist/esm/lib/scope/protection/index.js +3 -0
  46. package/dist/esm/lib/scope/protection/types.js +8 -0
  47. package/dist/esm/lib/scope/providers/baseStateCompatible.js +29 -0
  48. package/dist/esm/lib/scope/providers/guards.js +43 -0
  49. package/dist/esm/lib/scope/providers/index.js +7 -0
  50. package/dist/esm/lib/scope/providers/providers.js +18 -0
  51. package/dist/esm/lib/scope/providers/registry.js +36 -0
  52. package/dist/esm/lib/scope/providers/resolve.js +11 -0
  53. package/dist/esm/lib/scope/providers/types.js +8 -0
  54. package/dist/esm/lib/scope/recorders/DebugRecorder.js +81 -0
  55. package/dist/esm/lib/scope/recorders/MetricRecorder.js +81 -0
  56. package/dist/esm/lib/scope/recorders/NarrativeRecorder.js +167 -0
  57. package/dist/esm/lib/scope/recorders/index.js +4 -0
  58. package/dist/esm/lib/scope/state/installResolvers.js +15 -0
  59. package/dist/esm/lib/scope/state/zod/defineScopeFromZod.js +14 -0
  60. package/dist/esm/lib/scope/state/zod/index.js +5 -0
  61. package/dist/esm/lib/scope/state/zod/resolver.js +28 -0
  62. package/dist/esm/lib/scope/state/zod/schema/builder.js +16 -0
  63. package/dist/esm/lib/scope/state/zod/scopeFactory.js +156 -0
  64. package/dist/esm/lib/scope/state/zod/utils/validateHelper.js +97 -0
  65. package/dist/esm/lib/scope/types.js +9 -0
  66. package/dist/esm/types/advanced.d.ts +35 -0
  67. package/dist/esm/types/index.d.ts +22 -0
  68. package/dist/esm/types/lib/builder/FlowChartBuilder.d.ts +121 -0
  69. package/dist/esm/types/lib/builder/index.d.ts +9 -0
  70. package/dist/esm/types/lib/builder/types.d.ts +152 -0
  71. package/dist/esm/types/lib/engine/graph/StageNode.d.ts +78 -0
  72. package/dist/esm/types/lib/engine/graph/index.d.ts +2 -0
  73. package/dist/esm/types/lib/engine/handlers/ChildrenExecutor.d.ts +33 -0
  74. package/dist/esm/types/lib/engine/handlers/ContinuationResolver.d.ts +57 -0
  75. package/dist/esm/types/lib/engine/handlers/DeciderHandler.d.ts +34 -0
  76. package/dist/esm/types/lib/engine/handlers/ExtractorRunner.d.ts +41 -0
  77. package/dist/esm/types/lib/engine/handlers/NodeResolver.d.ts +26 -0
  78. package/dist/esm/types/lib/engine/handlers/RuntimeStructureManager.d.ts +36 -0
  79. package/dist/esm/types/lib/engine/handlers/SelectorHandler.d.ts +26 -0
  80. package/dist/esm/types/lib/engine/handlers/StageRunner.d.ts +17 -0
  81. package/dist/esm/types/lib/engine/handlers/SubflowExecutor.d.ts +57 -0
  82. package/dist/esm/types/lib/engine/handlers/SubflowInputMapper.d.ts +40 -0
  83. package/dist/esm/types/lib/engine/handlers/index.d.ts +15 -0
  84. package/dist/esm/types/lib/engine/index.d.ts +16 -0
  85. package/dist/esm/types/lib/engine/narrative/CombinedNarrativeBuilder.d.ts +33 -0
  86. package/dist/esm/types/lib/engine/narrative/ControlFlowNarrativeGenerator.d.ts +29 -0
  87. package/dist/esm/types/lib/engine/narrative/NullControlFlowNarrativeGenerator.d.ts +21 -0
  88. package/dist/esm/types/lib/engine/narrative/index.d.ts +5 -0
  89. package/dist/esm/types/lib/engine/narrative/types.d.ts +33 -0
  90. package/dist/esm/types/lib/engine/traversal/FlowchartTraverser.d.ts +87 -0
  91. package/dist/esm/types/lib/engine/traversal/index.d.ts +2 -0
  92. package/dist/esm/types/lib/engine/types.d.ts +208 -0
  93. package/dist/esm/types/lib/memory/DiagnosticCollector.d.ts +33 -0
  94. package/dist/esm/types/lib/memory/EventLog.d.ts +27 -0
  95. package/dist/esm/types/lib/memory/SharedMemory.d.ts +34 -0
  96. package/dist/esm/types/lib/memory/StageContext.d.ts +74 -0
  97. package/dist/esm/types/lib/memory/TransactionBuffer.d.ts +38 -0
  98. package/dist/esm/types/lib/memory/index.d.ts +13 -0
  99. package/dist/esm/types/lib/memory/types.d.ts +60 -0
  100. package/dist/esm/types/lib/memory/utils.d.ts +67 -0
  101. package/dist/esm/types/lib/runner/ExecutionRuntime.d.ts +39 -0
  102. package/dist/esm/types/lib/runner/FlowChartExecutor.d.ts +34 -0
  103. package/dist/esm/types/lib/runner/index.d.ts +3 -0
  104. package/dist/esm/types/lib/scope/ScopeFacade.d.ts +47 -0
  105. package/dist/esm/types/lib/scope/index.d.ts +23 -0
  106. package/dist/esm/types/lib/scope/protection/createProtectedScope.d.ts +9 -0
  107. package/dist/esm/types/lib/scope/protection/index.d.ts +2 -0
  108. package/dist/esm/types/lib/scope/protection/types.d.ts +13 -0
  109. package/dist/esm/types/lib/scope/providers/baseStateCompatible.d.ts +26 -0
  110. package/dist/esm/types/lib/scope/providers/guards.d.ts +14 -0
  111. package/dist/esm/types/lib/scope/providers/index.d.ts +6 -0
  112. package/dist/esm/types/lib/scope/providers/providers.d.ts +8 -0
  113. package/dist/esm/types/lib/scope/providers/registry.d.ts +11 -0
  114. package/dist/esm/types/lib/scope/providers/resolve.d.ts +8 -0
  115. package/dist/esm/types/lib/scope/providers/types.d.ts +40 -0
  116. package/dist/esm/types/lib/scope/recorders/DebugRecorder.d.ts +35 -0
  117. package/dist/esm/types/lib/scope/recorders/MetricRecorder.d.ts +36 -0
  118. package/dist/esm/types/lib/scope/recorders/NarrativeRecorder.d.ts +45 -0
  119. package/dist/esm/types/lib/scope/recorders/index.d.ts +7 -0
  120. package/dist/esm/types/lib/scope/state/installResolvers.d.ts +4 -0
  121. package/dist/esm/types/lib/scope/state/zod/defineScopeFromZod.d.ts +9 -0
  122. package/dist/esm/types/lib/scope/state/zod/index.d.ts +5 -0
  123. package/dist/esm/types/lib/scope/state/zod/resolver.d.ts +5 -0
  124. package/dist/esm/types/lib/scope/state/zod/schema/builder.d.ts +12 -0
  125. package/dist/esm/types/lib/scope/state/zod/scopeFactory.d.ts +9 -0
  126. package/dist/esm/types/lib/scope/state/zod/utils/validateHelper.d.ts +10 -0
  127. package/dist/esm/types/lib/scope/types.d.ts +53 -0
  128. package/dist/index.js +42 -0
  129. package/dist/lib/builder/FlowChartBuilder.js +817 -0
  130. package/dist/lib/builder/index.js +20 -0
  131. package/dist/lib/builder/types.js +10 -0
  132. package/dist/lib/engine/graph/StageNode.js +42 -0
  133. package/dist/lib/engine/graph/index.js +6 -0
  134. package/dist/lib/engine/handlers/ChildrenExecutor.js +120 -0
  135. package/dist/lib/engine/handlers/ContinuationResolver.js +125 -0
  136. package/dist/lib/engine/handlers/DeciderHandler.js +82 -0
  137. package/dist/lib/engine/handlers/ExtractorRunner.js +121 -0
  138. package/dist/lib/engine/handlers/NodeResolver.js +76 -0
  139. package/dist/lib/engine/handlers/RuntimeStructureManager.js +159 -0
  140. package/dist/lib/engine/handlers/SelectorHandler.js +83 -0
  141. package/dist/lib/engine/handlers/StageRunner.js +90 -0
  142. package/dist/lib/engine/handlers/SubflowExecutor.js +326 -0
  143. package/dist/lib/engine/handlers/SubflowInputMapper.js +121 -0
  144. package/dist/lib/engine/handlers/index.js +42 -0
  145. package/dist/lib/engine/index.js +40 -0
  146. package/dist/lib/engine/narrative/CombinedNarrativeBuilder.js +162 -0
  147. package/dist/lib/engine/narrative/ControlFlowNarrativeGenerator.js +94 -0
  148. package/dist/lib/engine/narrative/NullControlFlowNarrativeGenerator.js +28 -0
  149. package/dist/lib/engine/narrative/index.js +10 -0
  150. package/dist/lib/engine/narrative/types.js +12 -0
  151. package/dist/lib/engine/traversal/FlowchartTraverser.js +423 -0
  152. package/dist/lib/engine/traversal/index.js +6 -0
  153. package/dist/lib/engine/types.js +19 -0
  154. package/dist/lib/memory/DiagnosticCollector.js +48 -0
  155. package/dist/lib/memory/EventLog.js +48 -0
  156. package/dist/lib/memory/SharedMemory.js +60 -0
  157. package/dist/lib/memory/StageContext.js +225 -0
  158. package/dist/lib/memory/TransactionBuffer.js +73 -0
  159. package/dist/lib/memory/index.js +34 -0
  160. package/dist/lib/memory/types.js +8 -0
  161. package/dist/lib/memory/utils.js +170 -0
  162. package/dist/lib/runner/ExecutionRuntime.js +68 -0
  163. package/dist/lib/runner/FlowChartExecutor.js +112 -0
  164. package/dist/lib/runner/index.js +8 -0
  165. package/dist/lib/scope/ScopeFacade.js +179 -0
  166. package/dist/lib/scope/index.js +44 -0
  167. package/dist/lib/scope/protection/createProtectedScope.js +64 -0
  168. package/dist/lib/scope/protection/index.js +8 -0
  169. package/dist/lib/scope/protection/types.js +9 -0
  170. package/dist/lib/scope/providers/baseStateCompatible.js +33 -0
  171. package/dist/lib/scope/providers/guards.js +49 -0
  172. package/dist/lib/scope/providers/index.js +21 -0
  173. package/dist/lib/scope/providers/providers.js +23 -0
  174. package/dist/lib/scope/providers/registry.js +42 -0
  175. package/dist/lib/scope/providers/resolve.js +16 -0
  176. package/dist/lib/scope/providers/types.js +9 -0
  177. package/dist/lib/scope/recorders/DebugRecorder.js +85 -0
  178. package/dist/lib/scope/recorders/MetricRecorder.js +85 -0
  179. package/dist/lib/scope/recorders/NarrativeRecorder.js +171 -0
  180. package/dist/lib/scope/recorders/index.js +10 -0
  181. package/dist/lib/scope/state/installResolvers.js +19 -0
  182. package/dist/lib/scope/state/zod/defineScopeFromZod.js +18 -0
  183. package/dist/lib/scope/state/zod/index.js +13 -0
  184. package/dist/lib/scope/state/zod/resolver.js +31 -0
  185. package/dist/lib/scope/state/zod/schema/builder.js +21 -0
  186. package/dist/lib/scope/state/zod/scopeFactory.js +160 -0
  187. package/dist/lib/scope/state/zod/utils/validateHelper.js +104 -0
  188. package/dist/lib/scope/types.js +10 -0
  189. package/dist/types/advanced.d.ts +35 -0
  190. package/dist/types/index.d.ts +22 -0
  191. package/dist/types/lib/builder/FlowChartBuilder.d.ts +121 -0
  192. package/dist/types/lib/builder/index.d.ts +9 -0
  193. package/dist/types/lib/builder/types.d.ts +152 -0
  194. package/dist/types/lib/engine/graph/StageNode.d.ts +78 -0
  195. package/dist/types/lib/engine/graph/index.d.ts +2 -0
  196. package/dist/types/lib/engine/handlers/ChildrenExecutor.d.ts +33 -0
  197. package/dist/types/lib/engine/handlers/ContinuationResolver.d.ts +57 -0
  198. package/dist/types/lib/engine/handlers/DeciderHandler.d.ts +34 -0
  199. package/dist/types/lib/engine/handlers/ExtractorRunner.d.ts +41 -0
  200. package/dist/types/lib/engine/handlers/NodeResolver.d.ts +26 -0
  201. package/dist/types/lib/engine/handlers/RuntimeStructureManager.d.ts +36 -0
  202. package/dist/types/lib/engine/handlers/SelectorHandler.d.ts +26 -0
  203. package/dist/types/lib/engine/handlers/StageRunner.d.ts +17 -0
  204. package/dist/types/lib/engine/handlers/SubflowExecutor.d.ts +57 -0
  205. package/dist/types/lib/engine/handlers/SubflowInputMapper.d.ts +40 -0
  206. package/dist/types/lib/engine/handlers/index.d.ts +15 -0
  207. package/dist/types/lib/engine/index.d.ts +16 -0
  208. package/dist/types/lib/engine/narrative/CombinedNarrativeBuilder.d.ts +33 -0
  209. package/dist/types/lib/engine/narrative/ControlFlowNarrativeGenerator.d.ts +29 -0
  210. package/dist/types/lib/engine/narrative/NullControlFlowNarrativeGenerator.d.ts +21 -0
  211. package/dist/types/lib/engine/narrative/index.d.ts +5 -0
  212. package/dist/types/lib/engine/narrative/types.d.ts +33 -0
  213. package/dist/types/lib/engine/traversal/FlowchartTraverser.d.ts +87 -0
  214. package/dist/types/lib/engine/traversal/index.d.ts +2 -0
  215. package/dist/types/lib/engine/types.d.ts +208 -0
  216. package/dist/types/lib/memory/DiagnosticCollector.d.ts +33 -0
  217. package/dist/types/lib/memory/EventLog.d.ts +27 -0
  218. package/dist/types/lib/memory/SharedMemory.d.ts +34 -0
  219. package/dist/types/lib/memory/StageContext.d.ts +74 -0
  220. package/dist/types/lib/memory/TransactionBuffer.d.ts +38 -0
  221. package/dist/types/lib/memory/index.d.ts +13 -0
  222. package/dist/types/lib/memory/types.d.ts +60 -0
  223. package/dist/types/lib/memory/utils.d.ts +67 -0
  224. package/dist/types/lib/runner/ExecutionRuntime.d.ts +39 -0
  225. package/dist/types/lib/runner/FlowChartExecutor.d.ts +34 -0
  226. package/dist/types/lib/runner/index.d.ts +3 -0
  227. package/dist/types/lib/scope/ScopeFacade.d.ts +47 -0
  228. package/dist/types/lib/scope/index.d.ts +23 -0
  229. package/dist/types/lib/scope/protection/createProtectedScope.d.ts +9 -0
  230. package/dist/types/lib/scope/protection/index.d.ts +2 -0
  231. package/dist/types/lib/scope/protection/types.d.ts +13 -0
  232. package/dist/types/lib/scope/providers/baseStateCompatible.d.ts +26 -0
  233. package/dist/types/lib/scope/providers/guards.d.ts +14 -0
  234. package/dist/types/lib/scope/providers/index.d.ts +6 -0
  235. package/dist/types/lib/scope/providers/providers.d.ts +8 -0
  236. package/dist/types/lib/scope/providers/registry.d.ts +11 -0
  237. package/dist/types/lib/scope/providers/resolve.d.ts +8 -0
  238. package/dist/types/lib/scope/providers/types.d.ts +40 -0
  239. package/dist/types/lib/scope/recorders/DebugRecorder.d.ts +35 -0
  240. package/dist/types/lib/scope/recorders/MetricRecorder.d.ts +36 -0
  241. package/dist/types/lib/scope/recorders/NarrativeRecorder.d.ts +45 -0
  242. package/dist/types/lib/scope/recorders/index.d.ts +7 -0
  243. package/dist/types/lib/scope/state/installResolvers.d.ts +4 -0
  244. package/dist/types/lib/scope/state/zod/defineScopeFromZod.d.ts +9 -0
  245. package/dist/types/lib/scope/state/zod/index.d.ts +5 -0
  246. package/dist/types/lib/scope/state/zod/resolver.d.ts +5 -0
  247. package/dist/types/lib/scope/state/zod/schema/builder.d.ts +12 -0
  248. package/dist/types/lib/scope/state/zod/scopeFactory.d.ts +9 -0
  249. package/dist/types/lib/scope/state/zod/utils/validateHelper.d.ts +10 -0
  250. package/dist/types/lib/scope/types.d.ts +53 -0
  251. package/package.json +148 -0
@@ -0,0 +1,809 @@
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
+ // ─────────────────────────────────────────────────────────────────────────────
15
+ // Internal helpers
16
+ // ─────────────────────────────────────────────────────────────────────────────
17
+ const fail = (msg) => {
18
+ throw new Error(`[FlowChartBuilder] ${msg}`);
19
+ };
20
+ // ─────────────────────────────────────────────────────────────────────────────
21
+ // DeciderList
22
+ // ─────────────────────────────────────────────────────────────────────────────
23
+ /**
24
+ * Fluent helper returned by addDeciderFunction to add branches.
25
+ * `end()` sets `deciderFn = true` — the fn IS the decider.
26
+ */
27
+ export class DeciderList {
28
+ constructor(builder, curNode, curSpec, parentDescriptionParts = [], parentStageDescriptions = new Map(), reservedStepNumber = 0, deciderDescription) {
29
+ this.branchIds = new Set();
30
+ this.branchDescInfo = [];
31
+ this.b = builder;
32
+ this.curNode = curNode;
33
+ this.curSpec = curSpec;
34
+ this.parentDescriptionParts = parentDescriptionParts;
35
+ this.parentStageDescriptions = parentStageDescriptions;
36
+ this.reservedStepNumber = reservedStepNumber;
37
+ this.deciderDescription = deciderDescription;
38
+ }
39
+ addFunctionBranch(id, name, fn, displayName, description) {
40
+ if (this.branchIds.has(id))
41
+ fail(`duplicate decider branch id '${id}' under '${this.curNode.name}'`);
42
+ this.branchIds.add(id);
43
+ const node = { name: name !== null && name !== void 0 ? name : id };
44
+ if (id)
45
+ node.id = id;
46
+ if (displayName)
47
+ node.displayName = displayName;
48
+ if (description)
49
+ node.description = description;
50
+ if (fn) {
51
+ node.fn = fn;
52
+ this.b._addToMap(name, fn);
53
+ }
54
+ let spec = { name: name !== null && name !== void 0 ? name : id, type: 'stage' };
55
+ if (id)
56
+ spec.id = id;
57
+ if (displayName)
58
+ spec.displayName = displayName;
59
+ if (description)
60
+ spec.description = description;
61
+ spec = this.b._applyExtractorToNode(spec);
62
+ this.curNode.children = this.curNode.children || [];
63
+ this.curNode.children.push(node);
64
+ this.curSpec.children = this.curSpec.children || [];
65
+ this.curSpec.children.push(spec);
66
+ this.branchDescInfo.push({ id, displayName, description });
67
+ return this;
68
+ }
69
+ addSubFlowChartBranch(id, subflow, mountName, options) {
70
+ if (this.branchIds.has(id))
71
+ fail(`duplicate decider branch id '${id}' under '${this.curNode.name}'`);
72
+ this.branchIds.add(id);
73
+ const displayName = mountName || id;
74
+ const prefixedRoot = this.b._prefixNodeTree(subflow.root, id);
75
+ if (!this.b._subflowDefs.has(id)) {
76
+ this.b._subflowDefs.set(id, { root: prefixedRoot });
77
+ }
78
+ const node = {
79
+ name: displayName,
80
+ id,
81
+ isSubflowRoot: true,
82
+ subflowId: id,
83
+ subflowName: displayName,
84
+ };
85
+ if (options)
86
+ node.subflowMountOptions = options;
87
+ const spec = {
88
+ name: displayName,
89
+ type: 'stage',
90
+ id,
91
+ displayName,
92
+ isSubflowRoot: true,
93
+ subflowId: id,
94
+ subflowName: displayName,
95
+ subflowStructure: subflow.buildTimeStructure,
96
+ };
97
+ this.curNode.children = this.curNode.children || [];
98
+ this.curNode.children.push(node);
99
+ this.curSpec.children = this.curSpec.children || [];
100
+ this.curSpec.children.push(spec);
101
+ this.b._mergeStageMap(subflow.stageMap, id);
102
+ this.b._mergeSubflows(subflow.subflows, id);
103
+ return this;
104
+ }
105
+ addBranchList(branches) {
106
+ for (const { id, name, fn, displayName } of branches) {
107
+ this.addFunctionBranch(id, name, fn, displayName);
108
+ }
109
+ return this;
110
+ }
111
+ setDefault(id) {
112
+ this.defaultId = id;
113
+ return this;
114
+ }
115
+ end() {
116
+ const children = this.curNode.children;
117
+ if (!children || children.length === 0) {
118
+ throw new Error(`[FlowChartBuilder] decider at '${this.curNode.name}' requires at least one branch`);
119
+ }
120
+ this.curNode.deciderFn = true;
121
+ if (this.defaultId) {
122
+ const defaultChild = children.find((c) => c.id === this.defaultId);
123
+ if (defaultChild) {
124
+ children.push({ ...defaultChild, id: 'default' });
125
+ }
126
+ }
127
+ this.curSpec.branchIds = children
128
+ .map((c) => c.id)
129
+ .filter((id) => typeof id === 'string' && id.length > 0);
130
+ this.curSpec.type = 'decider';
131
+ if (this.reservedStepNumber > 0) {
132
+ const deciderLabel = this.curNode.displayName || this.curNode.name;
133
+ const branchIdList = this.branchDescInfo.map((b) => b.id).join(', ');
134
+ const mainLine = this.deciderDescription
135
+ ? `${this.reservedStepNumber}. ${deciderLabel} — ${this.deciderDescription}`
136
+ : `${this.reservedStepNumber}. ${deciderLabel} — Decides between: ${branchIdList}`;
137
+ this.parentDescriptionParts.push(mainLine);
138
+ if (this.deciderDescription) {
139
+ this.parentStageDescriptions.set(this.curNode.name, this.deciderDescription);
140
+ }
141
+ for (const branch of this.branchDescInfo) {
142
+ const branchText = branch.description || branch.displayName;
143
+ if (branchText) {
144
+ this.parentDescriptionParts.push(` → ${branch.id}: ${branchText}`);
145
+ }
146
+ if (branch.description) {
147
+ this.parentStageDescriptions.set(branch.id, branch.description);
148
+ }
149
+ }
150
+ }
151
+ return this.b;
152
+ }
153
+ }
154
+ // ─────────────────────────────────────────────────────────────────────────────
155
+ // SelectorFnList (scope-based selector — mirrors DeciderList)
156
+ // ─────────────────────────────────────────────────────────────────────────────
157
+ export class SelectorFnList {
158
+ constructor(builder, curNode, curSpec, parentDescriptionParts = [], parentStageDescriptions = new Map(), reservedStepNumber = 0, selectorDescription) {
159
+ this.branchIds = new Set();
160
+ this.branchDescInfo = [];
161
+ this.b = builder;
162
+ this.curNode = curNode;
163
+ this.curSpec = curSpec;
164
+ this.parentDescriptionParts = parentDescriptionParts;
165
+ this.parentStageDescriptions = parentStageDescriptions;
166
+ this.reservedStepNumber = reservedStepNumber;
167
+ this.selectorDescription = selectorDescription;
168
+ }
169
+ addFunctionBranch(id, name, fn, displayName, description) {
170
+ if (this.branchIds.has(id))
171
+ fail(`duplicate selector branch id '${id}' under '${this.curNode.name}'`);
172
+ this.branchIds.add(id);
173
+ const node = { name: name !== null && name !== void 0 ? name : id };
174
+ if (id)
175
+ node.id = id;
176
+ if (displayName)
177
+ node.displayName = displayName;
178
+ if (description)
179
+ node.description = description;
180
+ if (fn) {
181
+ node.fn = fn;
182
+ this.b._addToMap(name, fn);
183
+ }
184
+ let spec = { name: name !== null && name !== void 0 ? name : id, type: 'stage' };
185
+ if (id)
186
+ spec.id = id;
187
+ if (displayName)
188
+ spec.displayName = displayName;
189
+ if (description)
190
+ spec.description = description;
191
+ spec = this.b._applyExtractorToNode(spec);
192
+ this.curNode.children = this.curNode.children || [];
193
+ this.curNode.children.push(node);
194
+ this.curSpec.children = this.curSpec.children || [];
195
+ this.curSpec.children.push(spec);
196
+ this.branchDescInfo.push({ id, displayName, description });
197
+ return this;
198
+ }
199
+ addSubFlowChartBranch(id, subflow, mountName, options) {
200
+ if (this.branchIds.has(id))
201
+ fail(`duplicate selector branch id '${id}' under '${this.curNode.name}'`);
202
+ this.branchIds.add(id);
203
+ const displayName = mountName || id;
204
+ const prefixedRoot = this.b._prefixNodeTree(subflow.root, id);
205
+ if (!this.b._subflowDefs.has(id)) {
206
+ this.b._subflowDefs.set(id, { root: prefixedRoot });
207
+ }
208
+ const node = {
209
+ name: displayName,
210
+ id,
211
+ isSubflowRoot: true,
212
+ subflowId: id,
213
+ subflowName: displayName,
214
+ };
215
+ if (options)
216
+ node.subflowMountOptions = options;
217
+ const spec = {
218
+ name: displayName,
219
+ type: 'stage',
220
+ id,
221
+ displayName,
222
+ isSubflowRoot: true,
223
+ subflowId: id,
224
+ subflowName: displayName,
225
+ subflowStructure: subflow.buildTimeStructure,
226
+ };
227
+ this.curNode.children = this.curNode.children || [];
228
+ this.curNode.children.push(node);
229
+ this.curSpec.children = this.curSpec.children || [];
230
+ this.curSpec.children.push(spec);
231
+ this.b._mergeStageMap(subflow.stageMap, id);
232
+ this.b._mergeSubflows(subflow.subflows, id);
233
+ return this;
234
+ }
235
+ addBranchList(branches) {
236
+ for (const { id, name, fn, displayName } of branches) {
237
+ this.addFunctionBranch(id, name, fn, displayName);
238
+ }
239
+ return this;
240
+ }
241
+ end() {
242
+ const children = this.curNode.children;
243
+ if (!children || children.length === 0) {
244
+ throw new Error(`[FlowChartBuilder] selector at '${this.curNode.name}' requires at least one branch`);
245
+ }
246
+ this.curNode.selectorFn = true;
247
+ this.curSpec.branchIds = children
248
+ .map((c) => c.id)
249
+ .filter((id) => typeof id === 'string' && id.length > 0);
250
+ this.curSpec.type = 'decider';
251
+ this.curSpec.hasSelector = true;
252
+ if (this.reservedStepNumber > 0) {
253
+ const selectorLabel = this.curNode.displayName || this.curNode.name;
254
+ const branchIdList = this.branchDescInfo.map((b) => b.id).join(', ');
255
+ const mainLine = this.selectorDescription
256
+ ? `${this.reservedStepNumber}. ${selectorLabel} — ${this.selectorDescription}`
257
+ : `${this.reservedStepNumber}. ${selectorLabel} — Selects from: ${branchIdList}`;
258
+ this.parentDescriptionParts.push(mainLine);
259
+ if (this.selectorDescription) {
260
+ this.parentStageDescriptions.set(this.curNode.name, this.selectorDescription);
261
+ }
262
+ for (const branch of this.branchDescInfo) {
263
+ const branchText = branch.description || branch.displayName;
264
+ if (branchText)
265
+ this.parentDescriptionParts.push(` → ${branch.id}: ${branchText}`);
266
+ if (branch.description)
267
+ this.parentStageDescriptions.set(branch.id, branch.description);
268
+ }
269
+ }
270
+ return this.b;
271
+ }
272
+ }
273
+ // ─────────────────────────────────────────────────────────────────────────────
274
+ // FlowChartBuilder
275
+ // ─────────────────────────────────────────────────────────────────────────────
276
+ export class FlowChartBuilder {
277
+ constructor(buildTimeExtractor) {
278
+ this._stageMap = new Map();
279
+ this._subflowDefs = new Map();
280
+ this._streamHandlers = {};
281
+ this._buildTimeExtractorErrors = [];
282
+ this._enableNarrative = false;
283
+ this._descriptionParts = [];
284
+ this._stepCounter = 0;
285
+ this._stageDescriptions = new Map();
286
+ this._stageStepMap = new Map();
287
+ if (buildTimeExtractor) {
288
+ this._buildTimeExtractor = buildTimeExtractor;
289
+ }
290
+ }
291
+ // ── Description helpers ──
292
+ _appendDescriptionLine(displayName, name, description) {
293
+ this._stepCounter++;
294
+ this._stageStepMap.set(name, this._stepCounter);
295
+ const label = displayName || name;
296
+ const line = description ? `${this._stepCounter}. ${label} — ${description}` : `${this._stepCounter}. ${label}`;
297
+ this._descriptionParts.push(line);
298
+ if (description) {
299
+ this._stageDescriptions.set(name, description);
300
+ }
301
+ }
302
+ _appendSubflowDescription(id, displayName, subflow) {
303
+ this._stepCounter++;
304
+ this._stageStepMap.set(id, this._stepCounter);
305
+ if (subflow.description) {
306
+ this._descriptionParts.push(`${this._stepCounter}. [Sub-Execution: ${displayName}] — ${subflow.description}`);
307
+ const lines = subflow.description.split('\n');
308
+ const stepsIdx = lines.findIndex((l) => l.startsWith('Steps:'));
309
+ if (stepsIdx >= 0) {
310
+ for (let i = stepsIdx + 1; i < lines.length; i++) {
311
+ if (lines[i].trim())
312
+ this._descriptionParts.push(` ${lines[i]}`);
313
+ }
314
+ }
315
+ }
316
+ else {
317
+ this._descriptionParts.push(`${this._stepCounter}. [Sub-Execution: ${displayName}]`);
318
+ }
319
+ }
320
+ // ── Configuration ──
321
+ setEnableNarrative() {
322
+ this._enableNarrative = true;
323
+ return this;
324
+ }
325
+ setLogger(logger) {
326
+ this._logger = logger;
327
+ return this;
328
+ }
329
+ // ── Linear Chaining ──
330
+ start(name, fn, id, displayName, description) {
331
+ if (this._root)
332
+ fail('root already defined; create a new builder');
333
+ const node = { name };
334
+ if (id)
335
+ node.id = id;
336
+ if (displayName)
337
+ node.displayName = displayName;
338
+ if (description)
339
+ node.description = description;
340
+ if (fn) {
341
+ node.fn = fn;
342
+ this._addToMap(name, fn);
343
+ }
344
+ let spec = { name, type: 'stage' };
345
+ if (id)
346
+ spec.id = id;
347
+ if (displayName)
348
+ spec.displayName = displayName;
349
+ if (description)
350
+ spec.description = description;
351
+ spec = this._applyExtractorToNode(spec);
352
+ this._root = node;
353
+ this._rootSpec = spec;
354
+ this._cursor = node;
355
+ this._cursorSpec = spec;
356
+ this._appendDescriptionLine(displayName || name, name, description);
357
+ return this;
358
+ }
359
+ addFunction(name, fn, id, displayName, description) {
360
+ const cur = this._needCursor();
361
+ const curSpec = this._needCursorSpec();
362
+ const node = { name };
363
+ if (id)
364
+ node.id = id;
365
+ if (displayName)
366
+ node.displayName = displayName;
367
+ if (description)
368
+ node.description = description;
369
+ if (fn) {
370
+ node.fn = fn;
371
+ this._addToMap(name, fn);
372
+ }
373
+ let spec = { name, type: 'stage' };
374
+ if (id)
375
+ spec.id = id;
376
+ if (displayName)
377
+ spec.displayName = displayName;
378
+ if (description)
379
+ spec.description = description;
380
+ spec = this._applyExtractorToNode(spec);
381
+ cur.next = node;
382
+ curSpec.next = spec;
383
+ this._cursor = node;
384
+ this._cursorSpec = spec;
385
+ this._appendDescriptionLine(displayName || name, name, description);
386
+ return this;
387
+ }
388
+ addStreamingFunction(name, streamId, fn, id, displayName, description) {
389
+ const cur = this._needCursor();
390
+ const curSpec = this._needCursorSpec();
391
+ const node = {
392
+ name,
393
+ isStreaming: true,
394
+ streamId: streamId !== null && streamId !== void 0 ? streamId : name,
395
+ };
396
+ if (id)
397
+ node.id = id;
398
+ if (displayName)
399
+ node.displayName = displayName;
400
+ if (description)
401
+ node.description = description;
402
+ if (fn) {
403
+ node.fn = fn;
404
+ this._addToMap(name, fn);
405
+ }
406
+ let spec = {
407
+ name,
408
+ type: 'streaming',
409
+ isStreaming: true,
410
+ streamId: streamId !== null && streamId !== void 0 ? streamId : name,
411
+ };
412
+ if (id)
413
+ spec.id = id;
414
+ if (displayName)
415
+ spec.displayName = displayName;
416
+ if (description)
417
+ spec.description = description;
418
+ spec = this._applyExtractorToNode(spec);
419
+ cur.next = node;
420
+ curSpec.next = spec;
421
+ this._cursor = node;
422
+ this._cursorSpec = spec;
423
+ this._appendDescriptionLine(displayName || name, name, description);
424
+ return this;
425
+ }
426
+ // ── Branching ──
427
+ addDeciderFunction(name, fn, id, displayName, description) {
428
+ const cur = this._needCursor();
429
+ const curSpec = this._needCursorSpec();
430
+ if (cur.deciderFn)
431
+ fail(`decider already defined at '${cur.name}'`);
432
+ const node = { name };
433
+ if (id)
434
+ node.id = id;
435
+ if (displayName)
436
+ node.displayName = displayName;
437
+ if (description)
438
+ node.description = description;
439
+ node.fn = fn;
440
+ this._addToMap(name, fn);
441
+ let spec = { name, type: 'stage', hasDecider: true };
442
+ if (id)
443
+ spec.id = id;
444
+ if (displayName)
445
+ spec.displayName = displayName;
446
+ if (description)
447
+ spec.description = description;
448
+ spec = this._applyExtractorToNode(spec);
449
+ cur.next = node;
450
+ curSpec.next = spec;
451
+ this._cursor = node;
452
+ this._cursorSpec = spec;
453
+ this._stepCounter++;
454
+ this._stageStepMap.set(name, this._stepCounter);
455
+ return new DeciderList(this, node, spec, this._descriptionParts, this._stageDescriptions, this._stepCounter, description);
456
+ }
457
+ addSelectorFunction(name, fn, id, displayName, description) {
458
+ const cur = this._needCursor();
459
+ const curSpec = this._needCursorSpec();
460
+ if (cur.selectorFn)
461
+ fail(`selector already defined at '${cur.name}'`);
462
+ if (cur.deciderFn)
463
+ fail(`decider and selector are mutually exclusive at '${cur.name}'`);
464
+ const node = { name };
465
+ if (id)
466
+ node.id = id;
467
+ if (displayName)
468
+ node.displayName = displayName;
469
+ if (description)
470
+ node.description = description;
471
+ node.fn = fn;
472
+ this._addToMap(name, fn);
473
+ let spec = { name, type: 'stage', hasSelector: true };
474
+ if (id)
475
+ spec.id = id;
476
+ if (displayName)
477
+ spec.displayName = displayName;
478
+ if (description)
479
+ spec.description = description;
480
+ spec = this._applyExtractorToNode(spec);
481
+ cur.next = node;
482
+ curSpec.next = spec;
483
+ this._cursor = node;
484
+ this._cursorSpec = spec;
485
+ this._stepCounter++;
486
+ this._stageStepMap.set(name, this._stepCounter);
487
+ return new SelectorFnList(this, node, spec, this._descriptionParts, this._stageDescriptions, this._stepCounter, description);
488
+ }
489
+ // ── Parallel (Fork) ──
490
+ addListOfFunction(children, options) {
491
+ var _a, _b;
492
+ const cur = this._needCursor();
493
+ const curSpec = this._needCursorSpec();
494
+ const forkId = (_a = cur.id) !== null && _a !== void 0 ? _a : cur.name;
495
+ curSpec.type = 'fork';
496
+ if (options === null || options === void 0 ? void 0 : options.failFast)
497
+ cur.failFast = true;
498
+ for (const { id, name, displayName, fn } of children) {
499
+ if (!id)
500
+ fail(`child id required under '${cur.name}'`);
501
+ if ((_b = cur.children) === null || _b === void 0 ? void 0 : _b.some((c) => c.id === id)) {
502
+ fail(`duplicate child id '${id}' under '${cur.name}'`);
503
+ }
504
+ const node = { name: name !== null && name !== void 0 ? name : id };
505
+ if (id)
506
+ node.id = id;
507
+ if (displayName)
508
+ node.displayName = displayName;
509
+ if (fn) {
510
+ node.fn = fn;
511
+ this._addToMap(name, fn);
512
+ }
513
+ let spec = {
514
+ name: name !== null && name !== void 0 ? name : id,
515
+ type: 'stage',
516
+ isParallelChild: true,
517
+ parallelGroupId: forkId,
518
+ };
519
+ if (id)
520
+ spec.id = id;
521
+ if (displayName)
522
+ spec.displayName = displayName;
523
+ spec = this._applyExtractorToNode(spec);
524
+ cur.children = cur.children || [];
525
+ cur.children.push(node);
526
+ curSpec.children = curSpec.children || [];
527
+ curSpec.children.push(spec);
528
+ }
529
+ const childNames = children.map((c) => c.displayName || c.name || c.id).join(', ');
530
+ this._stepCounter++;
531
+ this._descriptionParts.push(`${this._stepCounter}. Runs in parallel: ${childNames}`);
532
+ return this;
533
+ }
534
+ // ── Subflow Mounting ──
535
+ addSubFlowChart(id, subflow, mountName, options) {
536
+ var _a, _b;
537
+ const cur = this._needCursor();
538
+ const curSpec = this._needCursorSpec();
539
+ if ((_a = cur.children) === null || _a === void 0 ? void 0 : _a.some((c) => c.id === id)) {
540
+ fail(`duplicate child id '${id}' under '${cur.name}'`);
541
+ }
542
+ const displayName = mountName || id;
543
+ const forkId = (_b = cur.id) !== null && _b !== void 0 ? _b : cur.name;
544
+ const prefixedRoot = this._prefixNodeTree(subflow.root, id);
545
+ if (!this._subflowDefs.has(id)) {
546
+ this._subflowDefs.set(id, { root: prefixedRoot });
547
+ }
548
+ const node = {
549
+ name: displayName,
550
+ id,
551
+ isSubflowRoot: true,
552
+ subflowId: id,
553
+ subflowName: displayName,
554
+ };
555
+ if (options)
556
+ node.subflowMountOptions = options;
557
+ let spec = {
558
+ name: displayName,
559
+ type: 'stage',
560
+ id,
561
+ displayName,
562
+ isSubflowRoot: true,
563
+ subflowId: id,
564
+ subflowName: displayName,
565
+ isParallelChild: true,
566
+ parallelGroupId: forkId,
567
+ subflowStructure: subflow.buildTimeStructure,
568
+ };
569
+ spec = this._applyExtractorToNode(spec);
570
+ curSpec.type = 'fork';
571
+ cur.children = cur.children || [];
572
+ cur.children.push(node);
573
+ curSpec.children = curSpec.children || [];
574
+ curSpec.children.push(spec);
575
+ this._mergeStageMap(subflow.stageMap, id);
576
+ this._mergeSubflows(subflow.subflows, id);
577
+ this._appendSubflowDescription(id, displayName, subflow);
578
+ return this;
579
+ }
580
+ addSubFlowChartNext(id, subflow, mountName, options) {
581
+ const cur = this._needCursor();
582
+ const curSpec = this._needCursorSpec();
583
+ if (cur.next) {
584
+ fail(`cannot add subflow as next when next is already defined at '${cur.name}'`);
585
+ }
586
+ const displayName = mountName || id;
587
+ const prefixedRoot = this._prefixNodeTree(subflow.root, id);
588
+ if (!this._subflowDefs.has(id)) {
589
+ this._subflowDefs.set(id, { root: prefixedRoot });
590
+ }
591
+ const node = {
592
+ name: displayName,
593
+ id,
594
+ isSubflowRoot: true,
595
+ subflowId: id,
596
+ subflowName: displayName,
597
+ };
598
+ if (options)
599
+ node.subflowMountOptions = options;
600
+ let attachedSpec = {
601
+ name: displayName,
602
+ type: 'stage',
603
+ id,
604
+ displayName,
605
+ isSubflowRoot: true,
606
+ subflowId: id,
607
+ subflowName: displayName,
608
+ subflowStructure: subflow.buildTimeStructure,
609
+ };
610
+ attachedSpec = this._applyExtractorToNode(attachedSpec);
611
+ cur.next = node;
612
+ curSpec.next = attachedSpec;
613
+ this._cursor = node;
614
+ this._cursorSpec = attachedSpec;
615
+ this._mergeStageMap(subflow.stageMap, id);
616
+ this._mergeSubflows(subflow.subflows, id);
617
+ this._appendSubflowDescription(id, displayName, subflow);
618
+ return this;
619
+ }
620
+ // ── Loop ──
621
+ loopTo(stageId) {
622
+ const cur = this._needCursor();
623
+ const curSpec = this._needCursorSpec();
624
+ if (curSpec.loopTarget)
625
+ fail(`loopTo already defined at '${cur.name}'`);
626
+ if (cur.next)
627
+ fail(`cannot set loopTo when next is already defined at '${cur.name}'`);
628
+ cur.next = { name: stageId, id: stageId };
629
+ curSpec.loopTarget = stageId;
630
+ curSpec.next = { name: stageId, id: stageId, type: 'stage' };
631
+ const targetStep = this._stageStepMap.get(stageId);
632
+ if (targetStep !== undefined) {
633
+ this._descriptionParts.push(`→ loops back to step ${targetStep}`);
634
+ }
635
+ else {
636
+ this._descriptionParts.push(`→ loops back to ${stageId}`);
637
+ }
638
+ return this;
639
+ }
640
+ // ── Streaming ──
641
+ onStream(handler) {
642
+ this._streamHandlers.onToken = handler;
643
+ return this;
644
+ }
645
+ onStreamStart(handler) {
646
+ this._streamHandlers.onStart = handler;
647
+ return this;
648
+ }
649
+ onStreamEnd(handler) {
650
+ this._streamHandlers.onEnd = handler;
651
+ return this;
652
+ }
653
+ // ── Extractors ──
654
+ addTraversalExtractor(extractor) {
655
+ this._extractor = extractor;
656
+ return this;
657
+ }
658
+ addBuildTimeExtractor(extractor) {
659
+ this._buildTimeExtractor = extractor;
660
+ return this;
661
+ }
662
+ getBuildTimeExtractorErrors() {
663
+ return this._buildTimeExtractorErrors;
664
+ }
665
+ // ── Output ──
666
+ build() {
667
+ var _a, _b, _c, _d, _e, _f;
668
+ const root = (_a = this._root) !== null && _a !== void 0 ? _a : fail('empty tree; call start() first');
669
+ const rootSpec = (_b = this._rootSpec) !== null && _b !== void 0 ? _b : fail('empty spec; call start() first');
670
+ const subflows = {};
671
+ for (const [key, def] of this._subflowDefs) {
672
+ subflows[key] = def;
673
+ }
674
+ const rootName = (_f = (_d = (_c = this._root) === null || _c === void 0 ? void 0 : _c.displayName) !== null && _d !== void 0 ? _d : (_e = this._root) === null || _e === void 0 ? void 0 : _e.name) !== null && _f !== void 0 ? _f : 'FlowChart';
675
+ const description = this._descriptionParts.length > 0 ? `FlowChart: ${rootName}\nSteps:\n${this._descriptionParts.join('\n')}` : '';
676
+ return {
677
+ root,
678
+ stageMap: this._stageMap,
679
+ extractor: this._extractor,
680
+ buildTimeStructure: rootSpec,
681
+ ...(Object.keys(subflows).length > 0 ? { subflows } : {}),
682
+ ...(this._enableNarrative ? { enableNarrative: true } : {}),
683
+ ...(this._logger ? { logger: this._logger } : {}),
684
+ description,
685
+ stageDescriptions: new Map(this._stageDescriptions),
686
+ };
687
+ }
688
+ toSpec() {
689
+ var _a;
690
+ const rootSpec = (_a = this._rootSpec) !== null && _a !== void 0 ? _a : fail('empty tree; call start() first');
691
+ return rootSpec;
692
+ }
693
+ toMermaid() {
694
+ var _a;
695
+ const lines = ['flowchart TD'];
696
+ const idOf = (k) => (k || '').replace(/[^a-zA-Z0-9_]/g, '_') || '_';
697
+ const root = (_a = this._root) !== null && _a !== void 0 ? _a : fail('empty tree; call start() first');
698
+ const walk = (n) => {
699
+ var _a, _b, _c;
700
+ const nid = idOf((_a = n.id) !== null && _a !== void 0 ? _a : n.name);
701
+ lines.push(`${nid}["${n.name}"]`);
702
+ for (const c of n.children || []) {
703
+ const cid = idOf((_b = c.id) !== null && _b !== void 0 ? _b : c.name);
704
+ lines.push(`${nid} --> ${cid}`);
705
+ walk(c);
706
+ }
707
+ if (n.next) {
708
+ const mid = idOf((_c = n.next.id) !== null && _c !== void 0 ? _c : n.next.name);
709
+ lines.push(`${nid} --> ${mid}`);
710
+ walk(n.next);
711
+ }
712
+ };
713
+ walk(root);
714
+ return lines.join('\n');
715
+ }
716
+ // ── Internals (exposed for helper classes) ──
717
+ _needCursor() {
718
+ var _a;
719
+ return (_a = this._cursor) !== null && _a !== void 0 ? _a : fail('cursor undefined; call start() first');
720
+ }
721
+ _needCursorSpec() {
722
+ var _a;
723
+ return (_a = this._cursorSpec) !== null && _a !== void 0 ? _a : fail('cursor undefined; call start() first');
724
+ }
725
+ _applyExtractorToNode(spec) {
726
+ var _a;
727
+ if (!this._buildTimeExtractor)
728
+ return spec;
729
+ try {
730
+ return this._buildTimeExtractor(spec);
731
+ }
732
+ catch (error) {
733
+ this._buildTimeExtractorErrors.push({
734
+ message: (_a = error === null || error === void 0 ? void 0 : error.message) !== null && _a !== void 0 ? _a : String(error),
735
+ error,
736
+ });
737
+ return spec;
738
+ }
739
+ }
740
+ _addToMap(name, fn) {
741
+ if (this._stageMap.has(name)) {
742
+ const existing = this._stageMap.get(name);
743
+ if (existing !== fn)
744
+ fail(`stageMap collision for '${name}'`);
745
+ }
746
+ this._stageMap.set(name, fn);
747
+ }
748
+ _mergeStageMap(other, prefix) {
749
+ for (const [k, v] of other) {
750
+ const key = prefix ? `${prefix}/${k}` : k;
751
+ if (this._stageMap.has(key)) {
752
+ const existing = this._stageMap.get(key);
753
+ if (existing !== v)
754
+ fail(`stageMap collision while mounting flowchart at '${key}'`);
755
+ }
756
+ else {
757
+ this._stageMap.set(key, v);
758
+ }
759
+ }
760
+ }
761
+ _prefixNodeTree(node, prefix) {
762
+ if (!node)
763
+ return node;
764
+ const clone = { ...node };
765
+ clone.name = `${prefix}/${node.name}`;
766
+ if (clone.subflowId)
767
+ clone.subflowId = `${prefix}/${clone.subflowId}`;
768
+ if (clone.next)
769
+ clone.next = this._prefixNodeTree(clone.next, prefix);
770
+ if (clone.children) {
771
+ clone.children = clone.children.map((c) => this._prefixNodeTree(c, prefix));
772
+ }
773
+ return clone;
774
+ }
775
+ _mergeSubflows(subflows, prefix) {
776
+ if (!subflows)
777
+ return;
778
+ for (const [key, def] of Object.entries(subflows)) {
779
+ const prefixedKey = `${prefix}/${key}`;
780
+ if (!this._subflowDefs.has(prefixedKey)) {
781
+ this._subflowDefs.set(prefixedKey, {
782
+ root: this._prefixNodeTree(def.root, prefix),
783
+ });
784
+ }
785
+ }
786
+ }
787
+ }
788
+ // ─────────────────────────────────────────────────────────────────────────────
789
+ // Factory Function
790
+ // ─────────────────────────────────────────────────────────────────────────────
791
+ export function flowChart(name, fn, id, displayName, buildTimeExtractor, description) {
792
+ return new FlowChartBuilder(buildTimeExtractor).start(name, fn, id, displayName, description);
793
+ }
794
+ // ─────────────────────────────────────────────────────────────────────────────
795
+ // Spec to StageNode Converter
796
+ // ─────────────────────────────────────────────────────────────────────────────
797
+ export function specToStageNode(spec) {
798
+ const inflate = (s) => {
799
+ var _a;
800
+ return ({
801
+ name: s.name,
802
+ id: s.id,
803
+ children: ((_a = s.children) === null || _a === void 0 ? void 0 : _a.length) ? s.children.map(inflate) : undefined,
804
+ next: s.next ? inflate(s.next) : undefined,
805
+ });
806
+ };
807
+ return inflate(spec);
808
+ }
809
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FlowChartBuilder.js","sourceRoot":"","sources":["../../../../src/lib/builder/FlowChartBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * FlowChartBuilder — Fluent API for constructing flowchart execution graphs.\n *\n * Builds StageNode trees and SerializedPipelineStructure (JSON) in tandem.\n * Zero dependencies on old code — only imports from local types.\n *\n * The builder creates two parallel structures:\n * 1. StageNode tree — runtime graph with embedded functions\n * 2. SerializedPipelineStructure — JSON-safe structure for visualization\n *\n * The execute() convenience method is intentionally omitted —\n * it belongs in the runner layer (Phase 5).\n */\n\nimport type {\n  BuildTimeExtractor,\n  FlowChart,\n  FlowChartSpec,\n  ILogger,\n  PipelineStageFunction,\n  SerializedPipelineStructure,\n  SimplifiedParallelSpec,\n  StageNode,\n  StreamHandlers,\n  StreamLifecycleHandler,\n  StreamTokenHandler,\n  SubflowMountOptions,\n  TraversalExtractor,\n} from './types';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Internal helpers\n// ─────────────────────────────────────────────────────────────────────────────\n\nconst fail = (msg: string): never => {\n  throw new Error(`[FlowChartBuilder] ${msg}`);\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// DeciderList\n// ─────────────────────────────────────────────────────────────────────────────\n\n/**\n * Fluent helper returned by addDeciderFunction to add branches.\n * `end()` sets `deciderFn = true` — the fn IS the decider.\n */\nexport class DeciderList<TOut = any, TScope = any> {\n  private readonly b: FlowChartBuilder<TOut, TScope>;\n  private readonly curNode: StageNode<TOut, TScope>;\n  private readonly curSpec: SerializedPipelineStructure;\n  private readonly branchIds = new Set<string>();\n  private defaultId?: string;\n\n  private readonly parentDescriptionParts: string[];\n  private readonly parentStageDescriptions: Map<string, string>;\n  private readonly reservedStepNumber: number;\n  private readonly deciderDescription?: string;\n  private readonly branchDescInfo: Array<{ id: string; displayName?: string; description?: string }> = [];\n\n  constructor(\n    builder: FlowChartBuilder<TOut, TScope>,\n    curNode: StageNode<TOut, TScope>,\n    curSpec: SerializedPipelineStructure,\n    parentDescriptionParts: string[] = [],\n    parentStageDescriptions: Map<string, string> = new Map(),\n    reservedStepNumber = 0,\n    deciderDescription?: string,\n  ) {\n    this.b = builder;\n    this.curNode = curNode;\n    this.curSpec = curSpec;\n    this.parentDescriptionParts = parentDescriptionParts;\n    this.parentStageDescriptions = parentStageDescriptions;\n    this.reservedStepNumber = reservedStepNumber;\n    this.deciderDescription = deciderDescription;\n  }\n\n  addFunctionBranch(\n    id: string,\n    name: string,\n    fn?: PipelineStageFunction<TOut, TScope>,\n    displayName?: string,\n    description?: string,\n  ): DeciderList<TOut, TScope> {\n    if (this.branchIds.has(id)) fail(`duplicate decider branch id '${id}' under '${this.curNode.name}'`);\n    this.branchIds.add(id);\n\n    const node: StageNode<TOut, TScope> = { name: name ?? id };\n    if (id) node.id = id;\n    if (displayName) node.displayName = displayName;\n    if (description) node.description = description;\n    if (fn) {\n      node.fn = fn;\n      this.b._addToMap(name, fn);\n    }\n\n    let spec: SerializedPipelineStructure = { name: name ?? id, type: 'stage' };\n    if (id) spec.id = id;\n    if (displayName) spec.displayName = displayName;\n    if (description) spec.description = description;\n    spec = this.b._applyExtractorToNode(spec);\n\n    this.curNode.children = this.curNode.children || [];\n    this.curNode.children.push(node);\n    this.curSpec.children = this.curSpec.children || [];\n    this.curSpec.children.push(spec);\n\n    this.branchDescInfo.push({ id, displayName, description });\n    return this;\n  }\n\n  addSubFlowChartBranch(\n    id: string,\n    subflow: FlowChart<TOut, TScope>,\n    mountName?: string,\n    options?: SubflowMountOptions,\n  ): DeciderList<TOut, TScope> {\n    if (this.branchIds.has(id)) fail(`duplicate decider branch id '${id}' under '${this.curNode.name}'`);\n    this.branchIds.add(id);\n\n    const displayName = mountName || id;\n    const prefixedRoot = this.b._prefixNodeTree(subflow.root, id);\n\n    if (!this.b._subflowDefs.has(id)) {\n      this.b._subflowDefs.set(id, { root: prefixedRoot });\n    }\n\n    const node: StageNode<TOut, TScope> = {\n      name: displayName,\n      id,\n      isSubflowRoot: true,\n      subflowId: id,\n      subflowName: displayName,\n    };\n    if (options) node.subflowMountOptions = options;\n\n    const spec: SerializedPipelineStructure = {\n      name: displayName,\n      type: 'stage',\n      id,\n      displayName,\n      isSubflowRoot: true,\n      subflowId: id,\n      subflowName: displayName,\n      subflowStructure: subflow.buildTimeStructure,\n    };\n\n    this.curNode.children = this.curNode.children || [];\n    this.curNode.children.push(node);\n    this.curSpec.children = this.curSpec.children || [];\n    this.curSpec.children.push(spec);\n\n    this.b._mergeStageMap(subflow.stageMap, id);\n    this.b._mergeSubflows(subflow.subflows, id);\n\n    return this;\n  }\n\n  addBranchList(\n    branches: Array<{\n      id: string;\n      name: string;\n      fn?: PipelineStageFunction<TOut, TScope>;\n      displayName?: string;\n    }>,\n  ): DeciderList<TOut, TScope> {\n    for (const { id, name, fn, displayName } of branches) {\n      this.addFunctionBranch(id, name, fn, displayName);\n    }\n    return this;\n  }\n\n  setDefault(id: string): DeciderList<TOut, TScope> {\n    this.defaultId = id;\n    return this;\n  }\n\n  end(): FlowChartBuilder<TOut, TScope> {\n    const children = this.curNode.children;\n    if (!children || children.length === 0) {\n      throw new Error(`[FlowChartBuilder] decider at '${this.curNode.name}' requires at least one branch`);\n    }\n\n    this.curNode.deciderFn = true;\n\n    if (this.defaultId) {\n      const defaultChild = children.find((c) => c.id === this.defaultId);\n      if (defaultChild) {\n        children.push({ ...defaultChild, id: 'default' });\n      }\n    }\n\n    this.curSpec.branchIds = children\n      .map((c) => c.id)\n      .filter((id): id is string => typeof id === 'string' && id.length > 0);\n    this.curSpec.type = 'decider';\n\n    if (this.reservedStepNumber > 0) {\n      const deciderLabel = this.curNode.displayName || this.curNode.name;\n      const branchIdList = this.branchDescInfo.map((b) => b.id).join(', ');\n      const mainLine = this.deciderDescription\n        ? `${this.reservedStepNumber}. ${deciderLabel} — ${this.deciderDescription}`\n        : `${this.reservedStepNumber}. ${deciderLabel} — Decides between: ${branchIdList}`;\n      this.parentDescriptionParts.push(mainLine);\n\n      if (this.deciderDescription) {\n        this.parentStageDescriptions.set(this.curNode.name, this.deciderDescription);\n      }\n\n      for (const branch of this.branchDescInfo) {\n        const branchText = branch.description || branch.displayName;\n        if (branchText) {\n          this.parentDescriptionParts.push(`   → ${branch.id}: ${branchText}`);\n        }\n        if (branch.description) {\n          this.parentStageDescriptions.set(branch.id, branch.description);\n        }\n      }\n    }\n\n    return this.b;\n  }\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// SelectorFnList (scope-based selector — mirrors DeciderList)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport class SelectorFnList<TOut = any, TScope = any> {\n  private readonly b: FlowChartBuilder<TOut, TScope>;\n  private readonly curNode: StageNode<TOut, TScope>;\n  private readonly curSpec: SerializedPipelineStructure;\n  private readonly branchIds = new Set<string>();\n\n  private readonly parentDescriptionParts: string[];\n  private readonly parentStageDescriptions: Map<string, string>;\n  private readonly reservedStepNumber: number;\n  private readonly selectorDescription?: string;\n  private readonly branchDescInfo: Array<{ id: string; displayName?: string; description?: string }> = [];\n\n  constructor(\n    builder: FlowChartBuilder<TOut, TScope>,\n    curNode: StageNode<TOut, TScope>,\n    curSpec: SerializedPipelineStructure,\n    parentDescriptionParts: string[] = [],\n    parentStageDescriptions: Map<string, string> = new Map(),\n    reservedStepNumber = 0,\n    selectorDescription?: string,\n  ) {\n    this.b = builder;\n    this.curNode = curNode;\n    this.curSpec = curSpec;\n    this.parentDescriptionParts = parentDescriptionParts;\n    this.parentStageDescriptions = parentStageDescriptions;\n    this.reservedStepNumber = reservedStepNumber;\n    this.selectorDescription = selectorDescription;\n  }\n\n  addFunctionBranch(\n    id: string,\n    name: string,\n    fn?: PipelineStageFunction<TOut, TScope>,\n    displayName?: string,\n    description?: string,\n  ): SelectorFnList<TOut, TScope> {\n    if (this.branchIds.has(id)) fail(`duplicate selector branch id '${id}' under '${this.curNode.name}'`);\n    this.branchIds.add(id);\n\n    const node: StageNode<TOut, TScope> = { name: name ?? id };\n    if (id) node.id = id;\n    if (displayName) node.displayName = displayName;\n    if (description) node.description = description;\n    if (fn) {\n      node.fn = fn;\n      this.b._addToMap(name, fn);\n    }\n\n    let spec: SerializedPipelineStructure = { name: name ?? id, type: 'stage' };\n    if (id) spec.id = id;\n    if (displayName) spec.displayName = displayName;\n    if (description) spec.description = description;\n    spec = this.b._applyExtractorToNode(spec);\n\n    this.curNode.children = this.curNode.children || [];\n    this.curNode.children.push(node);\n    this.curSpec.children = this.curSpec.children || [];\n    this.curSpec.children.push(spec);\n\n    this.branchDescInfo.push({ id, displayName, description });\n    return this;\n  }\n\n  addSubFlowChartBranch(\n    id: string,\n    subflow: FlowChart<TOut, TScope>,\n    mountName?: string,\n    options?: SubflowMountOptions,\n  ): SelectorFnList<TOut, TScope> {\n    if (this.branchIds.has(id)) fail(`duplicate selector branch id '${id}' under '${this.curNode.name}'`);\n    this.branchIds.add(id);\n\n    const displayName = mountName || id;\n    const prefixedRoot = this.b._prefixNodeTree(subflow.root, id);\n\n    if (!this.b._subflowDefs.has(id)) {\n      this.b._subflowDefs.set(id, { root: prefixedRoot });\n    }\n\n    const node: StageNode<TOut, TScope> = {\n      name: displayName,\n      id,\n      isSubflowRoot: true,\n      subflowId: id,\n      subflowName: displayName,\n    };\n    if (options) node.subflowMountOptions = options;\n\n    const spec: SerializedPipelineStructure = {\n      name: displayName,\n      type: 'stage',\n      id,\n      displayName,\n      isSubflowRoot: true,\n      subflowId: id,\n      subflowName: displayName,\n      subflowStructure: subflow.buildTimeStructure,\n    };\n\n    this.curNode.children = this.curNode.children || [];\n    this.curNode.children.push(node);\n    this.curSpec.children = this.curSpec.children || [];\n    this.curSpec.children.push(spec);\n\n    this.b._mergeStageMap(subflow.stageMap, id);\n    this.b._mergeSubflows(subflow.subflows, id);\n\n    return this;\n  }\n\n  addBranchList(\n    branches: Array<{\n      id: string;\n      name: string;\n      fn?: PipelineStageFunction<TOut, TScope>;\n      displayName?: string;\n    }>,\n  ): SelectorFnList<TOut, TScope> {\n    for (const { id, name, fn, displayName } of branches) {\n      this.addFunctionBranch(id, name, fn, displayName);\n    }\n    return this;\n  }\n\n  end(): FlowChartBuilder<TOut, TScope> {\n    const children = this.curNode.children;\n    if (!children || children.length === 0) {\n      throw new Error(`[FlowChartBuilder] selector at '${this.curNode.name}' requires at least one branch`);\n    }\n\n    this.curNode.selectorFn = true;\n\n    this.curSpec.branchIds = children\n      .map((c) => c.id)\n      .filter((id): id is string => typeof id === 'string' && id.length > 0);\n    this.curSpec.type = 'decider';\n    this.curSpec.hasSelector = true;\n\n    if (this.reservedStepNumber > 0) {\n      const selectorLabel = this.curNode.displayName || this.curNode.name;\n      const branchIdList = this.branchDescInfo.map((b) => b.id).join(', ');\n      const mainLine = this.selectorDescription\n        ? `${this.reservedStepNumber}. ${selectorLabel} — ${this.selectorDescription}`\n        : `${this.reservedStepNumber}. ${selectorLabel} — Selects from: ${branchIdList}`;\n      this.parentDescriptionParts.push(mainLine);\n\n      if (this.selectorDescription) {\n        this.parentStageDescriptions.set(this.curNode.name, this.selectorDescription);\n      }\n\n      for (const branch of this.branchDescInfo) {\n        const branchText = branch.description || branch.displayName;\n        if (branchText) this.parentDescriptionParts.push(`   → ${branch.id}: ${branchText}`);\n        if (branch.description) this.parentStageDescriptions.set(branch.id, branch.description);\n      }\n    }\n\n    return this.b;\n  }\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// FlowChartBuilder\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport class FlowChartBuilder<TOut = any, TScope = any> {\n  private _root?: StageNode<TOut, TScope>;\n  private _rootSpec?: SerializedPipelineStructure;\n  private _cursor?: StageNode<TOut, TScope>;\n  private _cursorSpec?: SerializedPipelineStructure;\n  private _stageMap = new Map<string, PipelineStageFunction<TOut, TScope>>();\n  _subflowDefs = new Map<string, { root: StageNode<TOut, TScope> }>();\n  private _streamHandlers: StreamHandlers = {};\n  private _extractor?: TraversalExtractor;\n  private _buildTimeExtractor?: BuildTimeExtractor<any>;\n  private _buildTimeExtractorErrors: Array<{ message: string; error: unknown }> = [];\n  private _enableNarrative = false;\n  private _logger?: ILogger;\n  private _descriptionParts: string[] = [];\n  private _stepCounter = 0;\n  private _stageDescriptions = new Map<string, string>();\n  private _stageStepMap = new Map<string, number>();\n\n  constructor(buildTimeExtractor?: BuildTimeExtractor<any>) {\n    if (buildTimeExtractor) {\n      this._buildTimeExtractor = buildTimeExtractor;\n    }\n  }\n\n  // ── Description helpers ──\n\n  private _appendDescriptionLine(displayName: string, name: string, description?: string): void {\n    this._stepCounter++;\n    this._stageStepMap.set(name, this._stepCounter);\n    const label = displayName || name;\n    const line = description ? `${this._stepCounter}. ${label} — ${description}` : `${this._stepCounter}. ${label}`;\n    this._descriptionParts.push(line);\n    if (description) {\n      this._stageDescriptions.set(name, description);\n    }\n  }\n\n  private _appendSubflowDescription(id: string, displayName: string, subflow: FlowChart<TOut, TScope>): void {\n    this._stepCounter++;\n    this._stageStepMap.set(id, this._stepCounter);\n    if (subflow.description) {\n      this._descriptionParts.push(`${this._stepCounter}. [Sub-Execution: ${displayName}] — ${subflow.description}`);\n      const lines = subflow.description.split('\\n');\n      const stepsIdx = lines.findIndex((l) => l.startsWith('Steps:'));\n      if (stepsIdx >= 0) {\n        for (let i = stepsIdx + 1; i < lines.length; i++) {\n          if (lines[i].trim()) this._descriptionParts.push(`   ${lines[i]}`);\n        }\n      }\n    } else {\n      this._descriptionParts.push(`${this._stepCounter}. [Sub-Execution: ${displayName}]`);\n    }\n  }\n\n  // ── Configuration ──\n\n  setEnableNarrative(): this {\n    this._enableNarrative = true;\n    return this;\n  }\n\n  setLogger(logger: ILogger): this {\n    this._logger = logger;\n    return this;\n  }\n\n  // ── Linear Chaining ──\n\n  start(\n    name: string,\n    fn?: PipelineStageFunction<TOut, TScope>,\n    id?: string,\n    displayName?: string,\n    description?: string,\n  ): this {\n    if (this._root) fail('root already defined; create a new builder');\n\n    const node: StageNode<TOut, TScope> = { name };\n    if (id) node.id = id;\n    if (displayName) node.displayName = displayName;\n    if (description) node.description = description;\n    if (fn) {\n      node.fn = fn;\n      this._addToMap(name, fn);\n    }\n\n    let spec: SerializedPipelineStructure = { name, type: 'stage' };\n    if (id) spec.id = id;\n    if (displayName) spec.displayName = displayName;\n    if (description) spec.description = description;\n    spec = this._applyExtractorToNode(spec);\n\n    this._root = node;\n    this._rootSpec = spec;\n    this._cursor = node;\n    this._cursorSpec = spec;\n\n    this._appendDescriptionLine(displayName || name, name, description);\n    return this;\n  }\n\n  addFunction(\n    name: string,\n    fn?: PipelineStageFunction<TOut, TScope>,\n    id?: string,\n    displayName?: string,\n    description?: string,\n  ): this {\n    const cur = this._needCursor();\n    const curSpec = this._needCursorSpec();\n\n    const node: StageNode<TOut, TScope> = { name };\n    if (id) node.id = id;\n    if (displayName) node.displayName = displayName;\n    if (description) node.description = description;\n    if (fn) {\n      node.fn = fn;\n      this._addToMap(name, fn);\n    }\n\n    let spec: SerializedPipelineStructure = { name, type: 'stage' };\n    if (id) spec.id = id;\n    if (displayName) spec.displayName = displayName;\n    if (description) spec.description = description;\n    spec = this._applyExtractorToNode(spec);\n\n    cur.next = node;\n    curSpec.next = spec;\n    this._cursor = node;\n    this._cursorSpec = spec;\n\n    this._appendDescriptionLine(displayName || name, name, description);\n    return this;\n  }\n\n  addStreamingFunction(\n    name: string,\n    streamId?: string,\n    fn?: PipelineStageFunction<TOut, TScope>,\n    id?: string,\n    displayName?: string,\n    description?: string,\n  ): this {\n    const cur = this._needCursor();\n    const curSpec = this._needCursorSpec();\n\n    const node: StageNode<TOut, TScope> = {\n      name,\n      isStreaming: true,\n      streamId: streamId ?? name,\n    };\n    if (id) node.id = id;\n    if (displayName) node.displayName = displayName;\n    if (description) node.description = description;\n    if (fn) {\n      node.fn = fn;\n      this._addToMap(name, fn);\n    }\n\n    let spec: SerializedPipelineStructure = {\n      name,\n      type: 'streaming',\n      isStreaming: true,\n      streamId: streamId ?? name,\n    };\n    if (id) spec.id = id;\n    if (displayName) spec.displayName = displayName;\n    if (description) spec.description = description;\n    spec = this._applyExtractorToNode(spec);\n\n    cur.next = node;\n    curSpec.next = spec;\n    this._cursor = node;\n    this._cursorSpec = spec;\n\n    this._appendDescriptionLine(displayName || name, name, description);\n    return this;\n  }\n\n  // ── Branching ──\n\n  addDeciderFunction(\n    name: string,\n    fn: PipelineStageFunction<TOut, TScope>,\n    id?: string,\n    displayName?: string,\n    description?: string,\n  ): DeciderList<TOut, TScope> {\n    const cur = this._needCursor();\n    const curSpec = this._needCursorSpec();\n\n    if (cur.deciderFn) fail(`decider already defined at '${cur.name}'`);\n\n    const node: StageNode<TOut, TScope> = { name };\n    if (id) node.id = id;\n    if (displayName) node.displayName = displayName;\n    if (description) node.description = description;\n    node.fn = fn;\n    this._addToMap(name, fn);\n\n    let spec: SerializedPipelineStructure = { name, type: 'stage', hasDecider: true };\n    if (id) spec.id = id;\n    if (displayName) spec.displayName = displayName;\n    if (description) spec.description = description;\n    spec = this._applyExtractorToNode(spec);\n\n    cur.next = node;\n    curSpec.next = spec;\n    this._cursor = node;\n    this._cursorSpec = spec;\n\n    this._stepCounter++;\n    this._stageStepMap.set(name, this._stepCounter);\n\n    return new DeciderList<TOut, TScope>(\n      this,\n      node,\n      spec,\n      this._descriptionParts,\n      this._stageDescriptions,\n      this._stepCounter,\n      description,\n    );\n  }\n\n  addSelectorFunction(\n    name: string,\n    fn: PipelineStageFunction<TOut, TScope>,\n    id?: string,\n    displayName?: string,\n    description?: string,\n  ): SelectorFnList<TOut, TScope> {\n    const cur = this._needCursor();\n    const curSpec = this._needCursorSpec();\n\n    if (cur.selectorFn) fail(`selector already defined at '${cur.name}'`);\n    if (cur.deciderFn) fail(`decider and selector are mutually exclusive at '${cur.name}'`);\n\n    const node: StageNode<TOut, TScope> = { name };\n    if (id) node.id = id;\n    if (displayName) node.displayName = displayName;\n    if (description) node.description = description;\n    node.fn = fn;\n    this._addToMap(name, fn);\n\n    let spec: SerializedPipelineStructure = { name, type: 'stage', hasSelector: true };\n    if (id) spec.id = id;\n    if (displayName) spec.displayName = displayName;\n    if (description) spec.description = description;\n    spec = this._applyExtractorToNode(spec);\n\n    cur.next = node;\n    curSpec.next = spec;\n    this._cursor = node;\n    this._cursorSpec = spec;\n\n    this._stepCounter++;\n    this._stageStepMap.set(name, this._stepCounter);\n\n    return new SelectorFnList<TOut, TScope>(\n      this,\n      node,\n      spec,\n      this._descriptionParts,\n      this._stageDescriptions,\n      this._stepCounter,\n      description,\n    );\n  }\n\n  // ── Parallel (Fork) ──\n\n  addListOfFunction(children: SimplifiedParallelSpec<TOut, TScope>[], options?: { failFast?: boolean }): this {\n    const cur = this._needCursor();\n    const curSpec = this._needCursorSpec();\n    const forkId = cur.id ?? cur.name;\n\n    curSpec.type = 'fork';\n    if (options?.failFast) cur.failFast = true;\n\n    for (const { id, name, displayName, fn } of children) {\n      if (!id) fail(`child id required under '${cur.name}'`);\n      if (cur.children?.some((c) => c.id === id)) {\n        fail(`duplicate child id '${id}' under '${cur.name}'`);\n      }\n\n      const node: StageNode<TOut, TScope> = { name: name ?? id };\n      if (id) node.id = id;\n      if (displayName) node.displayName = displayName;\n      if (fn) {\n        node.fn = fn;\n        this._addToMap(name, fn);\n      }\n\n      let spec: SerializedPipelineStructure = {\n        name: name ?? id,\n        type: 'stage',\n        isParallelChild: true,\n        parallelGroupId: forkId,\n      };\n      if (id) spec.id = id;\n      if (displayName) spec.displayName = displayName;\n      spec = this._applyExtractorToNode(spec);\n\n      cur.children = cur.children || [];\n      cur.children.push(node);\n      curSpec.children = curSpec.children || [];\n      curSpec.children.push(spec);\n    }\n\n    const childNames = children.map((c) => c.displayName || c.name || c.id).join(', ');\n    this._stepCounter++;\n    this._descriptionParts.push(`${this._stepCounter}. Runs in parallel: ${childNames}`);\n\n    return this;\n  }\n\n  // ── Subflow Mounting ──\n\n  addSubFlowChart(\n    id: string,\n    subflow: FlowChart<TOut, TScope>,\n    mountName?: string,\n    options?: SubflowMountOptions,\n  ): this {\n    const cur = this._needCursor();\n    const curSpec = this._needCursorSpec();\n\n    if (cur.children?.some((c) => c.id === id)) {\n      fail(`duplicate child id '${id}' under '${cur.name}'`);\n    }\n\n    const displayName = mountName || id;\n    const forkId = cur.id ?? cur.name;\n    const prefixedRoot = this._prefixNodeTree(subflow.root, id);\n\n    if (!this._subflowDefs.has(id)) {\n      this._subflowDefs.set(id, { root: prefixedRoot });\n    }\n\n    const node: StageNode<TOut, TScope> = {\n      name: displayName,\n      id,\n      isSubflowRoot: true,\n      subflowId: id,\n      subflowName: displayName,\n    };\n    if (options) node.subflowMountOptions = options;\n\n    let spec: SerializedPipelineStructure = {\n      name: displayName,\n      type: 'stage',\n      id,\n      displayName,\n      isSubflowRoot: true,\n      subflowId: id,\n      subflowName: displayName,\n      isParallelChild: true,\n      parallelGroupId: forkId,\n      subflowStructure: subflow.buildTimeStructure,\n    };\n    spec = this._applyExtractorToNode(spec);\n\n    curSpec.type = 'fork';\n    cur.children = cur.children || [];\n    cur.children.push(node);\n    curSpec.children = curSpec.children || [];\n    curSpec.children.push(spec);\n\n    this._mergeStageMap(subflow.stageMap, id);\n    this._mergeSubflows(subflow.subflows, id);\n    this._appendSubflowDescription(id, displayName, subflow);\n\n    return this;\n  }\n\n  addSubFlowChartNext(\n    id: string,\n    subflow: FlowChart<TOut, TScope>,\n    mountName?: string,\n    options?: SubflowMountOptions,\n  ): this {\n    const cur = this._needCursor();\n    const curSpec = this._needCursorSpec();\n\n    if (cur.next) {\n      fail(`cannot add subflow as next when next is already defined at '${cur.name}'`);\n    }\n\n    const displayName = mountName || id;\n    const prefixedRoot = this._prefixNodeTree(subflow.root, id);\n\n    if (!this._subflowDefs.has(id)) {\n      this._subflowDefs.set(id, { root: prefixedRoot });\n    }\n\n    const node: StageNode<TOut, TScope> = {\n      name: displayName,\n      id,\n      isSubflowRoot: true,\n      subflowId: id,\n      subflowName: displayName,\n    };\n    if (options) node.subflowMountOptions = options;\n\n    let attachedSpec: SerializedPipelineStructure = {\n      name: displayName,\n      type: 'stage',\n      id,\n      displayName,\n      isSubflowRoot: true,\n      subflowId: id,\n      subflowName: displayName,\n      subflowStructure: subflow.buildTimeStructure,\n    };\n    attachedSpec = this._applyExtractorToNode(attachedSpec);\n\n    cur.next = node;\n    curSpec.next = attachedSpec;\n    this._cursor = node;\n    this._cursorSpec = attachedSpec;\n\n    this._mergeStageMap(subflow.stageMap, id);\n    this._mergeSubflows(subflow.subflows, id);\n    this._appendSubflowDescription(id, displayName, subflow);\n\n    return this;\n  }\n\n  // ── Loop ──\n\n  loopTo(stageId: string): this {\n    const cur = this._needCursor();\n    const curSpec = this._needCursorSpec();\n\n    if (curSpec.loopTarget) fail(`loopTo already defined at '${cur.name}'`);\n    if (cur.next) fail(`cannot set loopTo when next is already defined at '${cur.name}'`);\n\n    cur.next = { name: stageId, id: stageId };\n    curSpec.loopTarget = stageId;\n    curSpec.next = { name: stageId, id: stageId, type: 'stage' };\n\n    const targetStep = this._stageStepMap.get(stageId);\n    if (targetStep !== undefined) {\n      this._descriptionParts.push(`→ loops back to step ${targetStep}`);\n    } else {\n      this._descriptionParts.push(`→ loops back to ${stageId}`);\n    }\n\n    return this;\n  }\n\n  // ── Streaming ──\n\n  onStream(handler: StreamTokenHandler): this {\n    this._streamHandlers.onToken = handler;\n    return this;\n  }\n\n  onStreamStart(handler: StreamLifecycleHandler): this {\n    this._streamHandlers.onStart = handler;\n    return this;\n  }\n\n  onStreamEnd(handler: StreamLifecycleHandler): this {\n    this._streamHandlers.onEnd = handler;\n    return this;\n  }\n\n  // ── Extractors ──\n\n  addTraversalExtractor<TResult = unknown>(extractor: TraversalExtractor<TResult>): this {\n    this._extractor = extractor;\n    return this;\n  }\n\n  addBuildTimeExtractor<TResult = FlowChartSpec>(extractor: BuildTimeExtractor<TResult>): this {\n    this._buildTimeExtractor = extractor;\n    return this;\n  }\n\n  getBuildTimeExtractorErrors(): Array<{ message: string; error: unknown }> {\n    return this._buildTimeExtractorErrors;\n  }\n\n  // ── Output ──\n\n  build(): FlowChart<TOut, TScope> {\n    const root = this._root ?? fail('empty tree; call start() first');\n    const rootSpec = this._rootSpec ?? fail('empty spec; call start() first');\n\n    const subflows: Record<string, { root: StageNode<TOut, TScope> }> = {};\n    for (const [key, def] of this._subflowDefs) {\n      subflows[key] = def;\n    }\n\n    const rootName = this._root?.displayName ?? this._root?.name ?? 'FlowChart';\n    const description =\n      this._descriptionParts.length > 0 ? `FlowChart: ${rootName}\\nSteps:\\n${this._descriptionParts.join('\\n')}` : '';\n\n    return {\n      root,\n      stageMap: this._stageMap,\n      extractor: this._extractor,\n      buildTimeStructure: rootSpec,\n      ...(Object.keys(subflows).length > 0 ? { subflows } : {}),\n      ...(this._enableNarrative ? { enableNarrative: true } : {}),\n      ...(this._logger ? { logger: this._logger } : {}),\n      description,\n      stageDescriptions: new Map(this._stageDescriptions),\n    };\n  }\n\n  toSpec<TResult = SerializedPipelineStructure>(): TResult {\n    const rootSpec = this._rootSpec ?? fail('empty tree; call start() first');\n    return rootSpec as TResult;\n  }\n\n  toMermaid(): string {\n    const lines: string[] = ['flowchart TD'];\n    const idOf = (k: string) => (k || '').replace(/[^a-zA-Z0-9_]/g, '_') || '_';\n    const root = this._root ?? fail('empty tree; call start() first');\n\n    const walk = (n: StageNode<TOut, TScope>) => {\n      const nid = idOf(n.id ?? n.name);\n      lines.push(`${nid}[\"${n.name}\"]`);\n      for (const c of n.children || []) {\n        const cid = idOf(c.id ?? c.name);\n        lines.push(`${nid} --> ${cid}`);\n        walk(c);\n      }\n      if (n.next) {\n        const mid = idOf(n.next.id ?? n.next.name);\n        lines.push(`${nid} --> ${mid}`);\n        walk(n.next);\n      }\n    };\n    walk(root);\n    return lines.join('\\n');\n  }\n\n  // ── Internals (exposed for helper classes) ──\n\n  private _needCursor(): StageNode<TOut, TScope> {\n    return this._cursor ?? fail('cursor undefined; call start() first');\n  }\n\n  private _needCursorSpec(): SerializedPipelineStructure {\n    return this._cursorSpec ?? fail('cursor undefined; call start() first');\n  }\n\n  _applyExtractorToNode(spec: SerializedPipelineStructure): SerializedPipelineStructure {\n    if (!this._buildTimeExtractor) return spec;\n    try {\n      return this._buildTimeExtractor(spec as any) as SerializedPipelineStructure;\n    } catch (error: any) {\n      this._buildTimeExtractorErrors.push({\n        message: error?.message ?? String(error),\n        error,\n      });\n      return spec;\n    }\n  }\n\n  _addToMap(name: string, fn: PipelineStageFunction<TOut, TScope>) {\n    if (this._stageMap.has(name)) {\n      const existing = this._stageMap.get(name);\n      if (existing !== fn) fail(`stageMap collision for '${name}'`);\n    }\n    this._stageMap.set(name, fn);\n  }\n\n  _mergeStageMap(other: Map<string, PipelineStageFunction<TOut, TScope>>, prefix?: string) {\n    for (const [k, v] of other) {\n      const key = prefix ? `${prefix}/${k}` : k;\n      if (this._stageMap.has(key)) {\n        const existing = this._stageMap.get(key);\n        if (existing !== v) fail(`stageMap collision while mounting flowchart at '${key}'`);\n      } else {\n        this._stageMap.set(key, v);\n      }\n    }\n  }\n\n  _prefixNodeTree(node: StageNode<TOut, TScope>, prefix: string): StageNode<TOut, TScope> {\n    if (!node) return node;\n    const clone: StageNode<TOut, TScope> = { ...node };\n    clone.name = `${prefix}/${node.name}`;\n    if (clone.subflowId) clone.subflowId = `${prefix}/${clone.subflowId}`;\n    if (clone.next) clone.next = this._prefixNodeTree(clone.next, prefix);\n    if (clone.children) {\n      clone.children = clone.children.map((c) => this._prefixNodeTree(c, prefix));\n    }\n    return clone;\n  }\n\n  _mergeSubflows(subflows: Record<string, { root: StageNode<TOut, TScope> }> | undefined, prefix: string) {\n    if (!subflows) return;\n    for (const [key, def] of Object.entries(subflows)) {\n      const prefixedKey = `${prefix}/${key}`;\n      if (!this._subflowDefs.has(prefixedKey)) {\n        this._subflowDefs.set(prefixedKey, {\n          root: this._prefixNodeTree(def.root as StageNode<TOut, TScope>, prefix),\n        });\n      }\n    }\n  }\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Factory Function\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport function flowChart<TOut = any, TScope = any>(\n  name: string,\n  fn?: PipelineStageFunction<TOut, TScope>,\n  id?: string,\n  displayName?: string,\n  buildTimeExtractor?: BuildTimeExtractor<any>,\n  description?: string,\n): FlowChartBuilder<TOut, TScope> {\n  return new FlowChartBuilder<TOut, TScope>(buildTimeExtractor).start(name, fn, id, displayName, description);\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Spec to StageNode Converter\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport function specToStageNode(spec: FlowChartSpec): StageNode<any, any> {\n  const inflate = (s: FlowChartSpec): StageNode<any, any> => ({\n    name: s.name,\n    id: s.id,\n    children: s.children?.length ? s.children.map(inflate) : undefined,\n    next: s.next ? inflate(s.next) : undefined,\n  });\n  return inflate(spec);\n}\n"]}