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,326 @@
1
+ "use strict";
2
+ /**
3
+ * SubflowExecutor — Isolated recursive execution with I/O mapping.
4
+ *
5
+ * Responsibilities:
6
+ * - Execute subflows with isolated ExecutionRuntime contexts
7
+ * - Apply input/output mapping via SubflowInputMapper
8
+ * - Handle nested subflow detection and delegation
9
+ * - Track subflow results for debugging/visualization
10
+ *
11
+ * Each subflow gets its own GlobalStore for isolation.
12
+ * The subflow's `next` chain after children is NOT executed inside —
13
+ * the parent's executeNode continues with node.next after return.
14
+ */
15
+ Object.defineProperty(exports, "__esModule", { value: true });
16
+ exports.SubflowExecutor = void 0;
17
+ const StageNode_1 = require("../graph/StageNode");
18
+ const StageRunner_1 = require("./StageRunner");
19
+ const SubflowInputMapper_1 = require("./SubflowInputMapper");
20
+ class SubflowExecutor {
21
+ constructor(deps, nodeResolver, executeStage, callExtractor, getStageFn) {
22
+ this.deps = deps;
23
+ this.nodeResolver = nodeResolver;
24
+ this.executeStage = executeStage;
25
+ this.callExtractor = callExtractor;
26
+ this.getStageFn = getStageFn;
27
+ }
28
+ /**
29
+ * Execute a subflow with isolated context.
30
+ *
31
+ * 1. Creates a fresh ExecutionRuntime for the subflow
32
+ * 2. Applies input mapping to seed the subflow's GlobalStore
33
+ * 3. Executes the subflow's internal structure
34
+ * 4. Applies output mapping to write results back to parent scope
35
+ * 5. Stores execution data for debugging/visualization
36
+ */
37
+ async executeSubflow(node, parentContext, breakFlag, branchPath, subflowResultsMap) {
38
+ var _a, _b;
39
+ const subflowId = node.subflowId;
40
+ const subflowName = (_a = node.subflowName) !== null && _a !== void 0 ? _a : node.name;
41
+ parentContext.addFlowDebugMessage('subflow', `Entering ${subflowName} subflow`, {
42
+ targetStage: subflowId,
43
+ });
44
+ this.deps.narrativeGenerator.onSubflowEntry(subflowName);
45
+ parentContext.addLog('isSubflowContainer', true);
46
+ parentContext.addLog('subflowId', subflowId);
47
+ parentContext.addLog('subflowName', subflowName);
48
+ // ─── Input Mapping ───
49
+ const mountOptions = node.subflowMountOptions;
50
+ let mappedInput = {};
51
+ if (mountOptions) {
52
+ try {
53
+ const parentScope = parentContext.getScope();
54
+ mappedInput = (0, SubflowInputMapper_1.getInitialScopeValues)(parentScope, mountOptions);
55
+ if (Object.keys(mappedInput).length > 0) {
56
+ parentContext.addLog('mappedInput', mappedInput);
57
+ }
58
+ }
59
+ catch (error) {
60
+ parentContext.addError('inputMapperError', error.toString());
61
+ this.deps.logger.error(`Error in inputMapper for subflow (${subflowId}):`, { error });
62
+ throw error;
63
+ }
64
+ }
65
+ // Create isolated runtime via dynamic construction (avoids circular import)
66
+ const ExecutionRuntimeClass = this.deps.executionRuntime.constructor;
67
+ const nestedRuntime = new ExecutionRuntimeClass(node.name);
68
+ let nestedRootContext = nestedRuntime.rootStageContext;
69
+ // Seed GlobalStore with input
70
+ if (Object.keys(mappedInput).length > 0) {
71
+ (0, SubflowInputMapper_1.seedSubflowGlobalStore)(nestedRuntime, mappedInput);
72
+ // Refresh rootStageContext so WriteBuffer sees committed data
73
+ const StageContextClass = nestedRootContext.constructor;
74
+ nestedRootContext = new StageContextClass('', nestedRootContext.stageName, nestedRuntime.globalStore, '', nestedRuntime.executionHistory);
75
+ nestedRuntime.rootStageContext = nestedRootContext;
76
+ }
77
+ // Create subflow HandlerDeps
78
+ const subflowDeps = (0, SubflowInputMapper_1.createSubflowHandlerDeps)(this.deps, nestedRuntime, mappedInput);
79
+ parentContext.addLog('subflowReadOnlyContext', mappedInput);
80
+ const subflowBreakFlag = { shouldBreak: false };
81
+ const hasChildren = Boolean(node.children && node.children.length > 0);
82
+ const subflowNode = {
83
+ ...node,
84
+ isSubflowRoot: false,
85
+ next: hasChildren ? undefined : node.next,
86
+ };
87
+ let subflowOutput;
88
+ let subflowError;
89
+ try {
90
+ this.subflowResultsMap = subflowResultsMap;
91
+ this.currentSubflowRoot = subflowNode;
92
+ this.currentSubflowDeps = subflowDeps;
93
+ subflowOutput = await this.executeSubflowInternal(subflowNode, nestedRootContext, subflowBreakFlag, subflowId);
94
+ }
95
+ catch (error) {
96
+ subflowError = error;
97
+ parentContext.addError('subflowError', error.toString());
98
+ this.deps.logger.error(`Error in subflow (${subflowId}):`, { error });
99
+ }
100
+ finally {
101
+ this.currentSubflowRoot = undefined;
102
+ this.currentSubflowDeps = undefined;
103
+ }
104
+ const subflowTreeContext = nestedRuntime.getSnapshot();
105
+ // ─── Output Mapping ───
106
+ if (!subflowError && (mountOptions === null || mountOptions === void 0 ? void 0 : mountOptions.outputMapper)) {
107
+ try {
108
+ let outputContext = parentContext;
109
+ if (parentContext.branchId && parentContext.branchId !== '' && parentContext.parent) {
110
+ outputContext = parentContext.parent;
111
+ }
112
+ const parentScope = outputContext.getScope();
113
+ const mappedOutput = (0, SubflowInputMapper_1.applyOutputMapping)(subflowOutput, parentScope, outputContext, mountOptions);
114
+ if (mappedOutput && Object.keys(mappedOutput).length > 0) {
115
+ parentContext.addLog('mappedOutput', mappedOutput);
116
+ parentContext.addLog('outputMappingTarget', outputContext.branchId || '(root)');
117
+ }
118
+ outputContext.commit();
119
+ }
120
+ catch (error) {
121
+ parentContext.addError('outputMapperError', error.toString());
122
+ this.deps.logger.error(`Error in outputMapper for subflow (${subflowId}):`, { error });
123
+ }
124
+ }
125
+ const subflowResult = {
126
+ subflowId,
127
+ subflowName,
128
+ treeContext: {
129
+ globalContext: subflowTreeContext.sharedState,
130
+ stageContexts: subflowTreeContext.executionTree,
131
+ history: subflowTreeContext.commitLog,
132
+ },
133
+ parentStageId: parentContext.getStageId(),
134
+ };
135
+ const subflowDef = (_b = this.deps.subflows) === null || _b === void 0 ? void 0 : _b[subflowId];
136
+ if (subflowDef && subflowDef.buildTimeStructure) {
137
+ subflowResult.pipelineStructure = subflowDef.buildTimeStructure;
138
+ }
139
+ parentContext.addLog('subflowResult', subflowResult);
140
+ parentContext.addLog('hasSubflowData', true);
141
+ subflowResultsMap.set(subflowId, subflowResult);
142
+ parentContext.addFlowDebugMessage('subflow', `Exiting ${subflowName} subflow`, {
143
+ targetStage: subflowId,
144
+ });
145
+ this.deps.narrativeGenerator.onSubflowExit(subflowName);
146
+ parentContext.commit();
147
+ if (subflowError) {
148
+ throw subflowError;
149
+ }
150
+ return subflowOutput;
151
+ }
152
+ /**
153
+ * Internal execution within subflow context.
154
+ * Mirrors the traverser's executeNode but within the subflow's isolated runtime.
155
+ */
156
+ async executeSubflowInternal(node, context, breakFlag, branchPath) {
157
+ var _a;
158
+ // Detect nested subflows
159
+ if (node.isSubflowRoot && node.subflowId) {
160
+ const resolvedNode = this.nodeResolver.resolveSubflowReference(node);
161
+ return await this.executeSubflow(resolvedNode, context, breakFlag, branchPath, this.subflowResultsMap);
162
+ }
163
+ const stageFunc = this.getStageFn(node);
164
+ const breakFn = () => (breakFlag.shouldBreak = true);
165
+ let stageOutput;
166
+ if (stageFunc) {
167
+ try {
168
+ if (this.currentSubflowDeps) {
169
+ const subflowStageRunner = new StageRunner_1.StageRunner(this.currentSubflowDeps);
170
+ stageOutput = await subflowStageRunner.run(node, stageFunc, context, breakFn);
171
+ }
172
+ else {
173
+ stageOutput = await this.executeStage(node, stageFunc, context, breakFn);
174
+ }
175
+ }
176
+ catch (error) {
177
+ context.commit();
178
+ this.callExtractor(node, context, this.getStagePath(node, branchPath, context.stageName), undefined, {
179
+ type: 'stageExecutionError',
180
+ message: error.toString(),
181
+ });
182
+ context.addError('stageExecutionError', error.toString());
183
+ throw error;
184
+ }
185
+ context.commit();
186
+ this.callExtractor(node, context, this.getStagePath(node, branchPath, context.stageName), stageOutput);
187
+ if (breakFlag.shouldBreak) {
188
+ return stageOutput;
189
+ }
190
+ // Handle dynamic StageNode return
191
+ if (stageOutput && typeof stageOutput === 'object' && (0, StageNode_1.isStageNodeReturn)(stageOutput)) {
192
+ const dynamicNode = stageOutput;
193
+ context.addLog('isDynamic', true);
194
+ context.addLog('dynamicPattern', 'StageNodeReturn');
195
+ if (dynamicNode.children && dynamicNode.children.length > 0) {
196
+ node.children = dynamicNode.children;
197
+ context.addLog('dynamicChildCount', dynamicNode.children.length);
198
+ context.addLog('dynamicChildIds', dynamicNode.children.map((c) => c.id || c.name));
199
+ if (typeof dynamicNode.nextNodeSelector === 'function') {
200
+ node.nextNodeSelector = dynamicNode.nextNodeSelector;
201
+ context.addLog('hasSelector', true);
202
+ }
203
+ }
204
+ if (dynamicNode.next) {
205
+ node.next = dynamicNode.next;
206
+ context.addLog('hasDynamicNext', true);
207
+ const loopTargetId = dynamicNode.next.id || dynamicNode.next.name;
208
+ if (loopTargetId) {
209
+ context.addLog('loopTarget', loopTargetId);
210
+ }
211
+ }
212
+ stageOutput = undefined;
213
+ }
214
+ }
215
+ // ─── Children dispatch ───
216
+ const hasChildrenAfterStage = Boolean((_a = node.children) === null || _a === void 0 ? void 0 : _a.length);
217
+ const hasNextAfterStage = Boolean(node.next);
218
+ if (hasChildrenAfterStage) {
219
+ if (node.nextNodeSelector) {
220
+ const results = await this.executeSelectedChildrenInternal(node.nextNodeSelector, node.children, stageOutput, context, branchPath, breakFlag);
221
+ if (!hasNextAfterStage)
222
+ return results;
223
+ }
224
+ else {
225
+ const results = await this.executeNodeChildrenInternal(node, context, branchPath, breakFlag);
226
+ if (!hasNextAfterStage)
227
+ return results;
228
+ }
229
+ }
230
+ // ─── Linear next ───
231
+ if (hasNextAfterStage) {
232
+ let nextNode = node.next;
233
+ // Resolve reference nodes (has id but no fn)
234
+ if (nextNode.id && !nextNode.fn) {
235
+ let resolvedNode;
236
+ if (this.currentSubflowRoot) {
237
+ resolvedNode = this.nodeResolver.findNodeById(nextNode.id, this.currentSubflowRoot);
238
+ if (resolvedNode)
239
+ context.addLog('dynamicNextResolvedFrom', 'subflow');
240
+ }
241
+ if (!resolvedNode) {
242
+ resolvedNode = this.nodeResolver.findNodeById(nextNode.id);
243
+ if (resolvedNode)
244
+ context.addLog('dynamicNextResolvedFrom', 'mainPipeline');
245
+ }
246
+ if (resolvedNode) {
247
+ nextNode = resolvedNode;
248
+ context.addLog('dynamicNextResolved', true);
249
+ context.addLog('dynamicNextTarget', nextNode.id);
250
+ }
251
+ else {
252
+ this.deps.logger.info(`Dynamic next node '${nextNode.id}' not found in subflow or main pipeline`);
253
+ context.addLog('dynamicNextResolved', false);
254
+ context.addLog('dynamicNextNotFound', nextNode.id);
255
+ }
256
+ }
257
+ const nextCtx = context.createNext('', nextNode.name);
258
+ return await this.executeSubflowInternal(nextNode, nextCtx, breakFlag, branchPath);
259
+ }
260
+ return stageOutput;
261
+ }
262
+ getStagePath(node, branchPath, contextStageName) {
263
+ var _a;
264
+ const baseName = (_a = node.id) !== null && _a !== void 0 ? _a : node.name;
265
+ const nodeId = contextStageName && contextStageName !== node.name ? contextStageName : baseName;
266
+ if (!branchPath)
267
+ return nodeId;
268
+ return `${branchPath}.${nodeId}`;
269
+ }
270
+ async executeNodeChildrenInternal(node, context, branchPath, breakFlag) {
271
+ var _a;
272
+ const childPromises = ((_a = node.children) !== null && _a !== void 0 ? _a : []).map((child) => {
273
+ const childContext = context.createChild('', child.id, child.name);
274
+ const childBreakFlag = { shouldBreak: false };
275
+ return this.executeSubflowInternal(child, childContext, childBreakFlag, branchPath)
276
+ .then((result) => {
277
+ childContext.commit();
278
+ return { id: child.id, result, isError: false };
279
+ })
280
+ .catch((error) => {
281
+ childContext.commit();
282
+ this.deps.logger.info(`TREE PIPELINE: executeNodeChildrenInternal - Error for id: ${child === null || child === void 0 ? void 0 : child.id}`, { error });
283
+ return { id: child.id, result: error, isError: true };
284
+ });
285
+ });
286
+ const settled = await Promise.allSettled(childPromises);
287
+ const childrenResults = {};
288
+ settled.forEach((s) => {
289
+ if (s.status === 'fulfilled') {
290
+ const { id, result, isError } = s.value;
291
+ childrenResults[id] = { id, result, isError };
292
+ }
293
+ else {
294
+ this.deps.logger.error(`Execution failed: ${s.reason}`);
295
+ }
296
+ });
297
+ return childrenResults;
298
+ }
299
+ async executeSelectedChildrenInternal(selector, children, input, context, branchPath, breakFlag) {
300
+ const selectorResult = await selector(input);
301
+ const selectedIds = Array.isArray(selectorResult) ? selectorResult : [selectorResult];
302
+ context.addLog('selectedChildIds', selectedIds);
303
+ context.addLog('selectorPattern', 'multi-choice');
304
+ if (selectedIds.length === 0) {
305
+ context.addLog('skippedAllChildren', true);
306
+ return {};
307
+ }
308
+ const selectedChildren = children.filter((c) => selectedIds.includes(c.id));
309
+ if (selectedChildren.length !== selectedIds.length) {
310
+ const childIds = children.map((c) => c.id);
311
+ const missing = selectedIds.filter((id) => !childIds.includes(id));
312
+ const errorMessage = `Selector returned unknown child IDs: ${missing.join(', ')}. Available: ${childIds.join(', ')}`;
313
+ this.deps.logger.error(`Error in subflow (${branchPath}):`, { error: errorMessage });
314
+ context.addError('selectorError', errorMessage);
315
+ throw new Error(errorMessage);
316
+ }
317
+ const skippedIds = children.filter((c) => !selectedIds.includes(c.id)).map((c) => c.id);
318
+ if (skippedIds.length > 0) {
319
+ context.addLog('skippedChildIds', skippedIds);
320
+ }
321
+ const tempNode = { name: 'selector-temp', children: selectedChildren };
322
+ return await this.executeNodeChildrenInternal(tempNode, context, branchPath, breakFlag);
323
+ }
324
+ }
325
+ exports.SubflowExecutor = SubflowExecutor;
326
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SubflowExecutor.js","sourceRoot":"","sources":["../../../../src/lib/engine/handlers/SubflowExecutor.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * SubflowExecutor — Isolated recursive execution with I/O mapping.\n *\n * Responsibilities:\n * - Execute subflows with isolated ExecutionRuntime contexts\n * - Apply input/output mapping via SubflowInputMapper\n * - Handle nested subflow detection and delegation\n * - Track subflow results for debugging/visualization\n *\n * Each subflow gets its own GlobalStore for isolation.\n * The subflow's `next` chain after children is NOT executed inside —\n * the parent's executeNode continues with node.next after return.\n */\n\nimport type { StageContext } from '../../memory/StageContext';\nimport type { Selector, StageNode } from '../graph/StageNode';\nimport { isStageNodeReturn } from '../graph/StageNode';\nimport type { HandlerDeps, IExecutionRuntime, NodeResultType, StageFunction, SubflowResult } from '../types';\nimport type { NodeResolver } from './NodeResolver';\nimport { StageRunner } from './StageRunner';\nimport {\n  applyOutputMapping,\n  createSubflowHandlerDeps,\n  getInitialScopeValues,\n  seedSubflowGlobalStore,\n} from './SubflowInputMapper';\n\n/** Callback for running a stage function. Avoids circular dep with traverser. */\nexport type ExecuteStageFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  stageFunc: StageFunction<TOut, TScope>,\n  context: StageContext,\n  breakFn: () => void,\n) => Promise<TOut>;\n\n/** Callback for calling the traversal extractor. */\nexport type CallExtractorFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  context: StageContext,\n  stagePath: string,\n  stageOutput?: unknown,\n  errorInfo?: { type: string; message: string },\n) => void;\n\n/** Callback for getting a stage function from the stage map. */\nexport type GetStageFnFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n) => StageFunction<TOut, TScope> | undefined;\n\nexport class SubflowExecutor<TOut = any, TScope = any> {\n  private currentSubflowDeps?: HandlerDeps<TOut, TScope>;\n  private currentSubflowRoot?: StageNode<TOut, TScope>;\n  private subflowResultsMap?: Map<string, SubflowResult>;\n\n  constructor(\n    private deps: HandlerDeps<TOut, TScope>,\n    private nodeResolver: NodeResolver<TOut, TScope>,\n    private executeStage: ExecuteStageFn<TOut, TScope>,\n    private callExtractor: CallExtractorFn<TOut, TScope>,\n    private getStageFn: GetStageFnFn<TOut, TScope>,\n  ) {}\n\n  /**\n   * Execute a subflow with isolated context.\n   *\n   * 1. Creates a fresh ExecutionRuntime for the subflow\n   * 2. Applies input mapping to seed the subflow's GlobalStore\n   * 3. Executes the subflow's internal structure\n   * 4. Applies output mapping to write results back to parent scope\n   * 5. Stores execution data for debugging/visualization\n   */\n  async executeSubflow(\n    node: StageNode<TOut, TScope>,\n    parentContext: StageContext,\n    breakFlag: { shouldBreak: boolean },\n    branchPath: string | undefined,\n    subflowResultsMap: Map<string, SubflowResult>,\n  ): Promise<any> {\n    const subflowId = node.subflowId!;\n    const subflowName = node.subflowName ?? node.name;\n\n    parentContext.addFlowDebugMessage('subflow', `Entering ${subflowName} subflow`, {\n      targetStage: subflowId,\n    });\n    this.deps.narrativeGenerator.onSubflowEntry(subflowName);\n\n    parentContext.addLog('isSubflowContainer', true);\n    parentContext.addLog('subflowId', subflowId);\n    parentContext.addLog('subflowName', subflowName);\n\n    // ─── Input Mapping ───\n    const mountOptions = node.subflowMountOptions;\n    let mappedInput: Record<string, unknown> = {};\n\n    if (mountOptions) {\n      try {\n        const parentScope = parentContext.getScope();\n        mappedInput = getInitialScopeValues(parentScope, mountOptions);\n        if (Object.keys(mappedInput).length > 0) {\n          parentContext.addLog('mappedInput', mappedInput);\n        }\n      } catch (error: any) {\n        parentContext.addError('inputMapperError', error.toString());\n        this.deps.logger.error(`Error in inputMapper for subflow (${subflowId}):`, { error });\n        throw error;\n      }\n    }\n\n    // Create isolated runtime via dynamic construction (avoids circular import)\n    const ExecutionRuntimeClass = this.deps.executionRuntime.constructor as new (name: string) => IExecutionRuntime;\n    const nestedRuntime = new ExecutionRuntimeClass(node.name);\n    let nestedRootContext = nestedRuntime.rootStageContext;\n\n    // Seed GlobalStore with input\n    if (Object.keys(mappedInput).length > 0) {\n      seedSubflowGlobalStore(nestedRuntime, mappedInput);\n      // Refresh rootStageContext so WriteBuffer sees committed data\n      const StageContextClass = nestedRootContext.constructor as new (...args: any[]) => StageContext;\n      nestedRootContext = new StageContextClass(\n        '',\n        nestedRootContext.stageName,\n        nestedRuntime.globalStore,\n        '',\n        nestedRuntime.executionHistory,\n      );\n      nestedRuntime.rootStageContext = nestedRootContext;\n    }\n\n    // Create subflow HandlerDeps\n    const subflowDeps = createSubflowHandlerDeps(this.deps, nestedRuntime, mappedInput);\n    parentContext.addLog('subflowReadOnlyContext', mappedInput);\n\n    const subflowBreakFlag = { shouldBreak: false };\n\n    const hasChildren = Boolean(node.children && node.children.length > 0);\n    const subflowNode: StageNode<TOut, TScope> = {\n      ...node,\n      isSubflowRoot: false,\n      next: hasChildren ? undefined : node.next,\n    };\n\n    let subflowOutput: any;\n    let subflowError: Error | undefined;\n\n    try {\n      this.subflowResultsMap = subflowResultsMap;\n      this.currentSubflowRoot = subflowNode;\n      this.currentSubflowDeps = subflowDeps;\n\n      subflowOutput = await this.executeSubflowInternal(subflowNode, nestedRootContext, subflowBreakFlag, subflowId);\n    } catch (error: any) {\n      subflowError = error;\n      parentContext.addError('subflowError', error.toString());\n      this.deps.logger.error(`Error in subflow (${subflowId}):`, { error });\n    } finally {\n      this.currentSubflowRoot = undefined;\n      this.currentSubflowDeps = undefined;\n    }\n\n    const subflowTreeContext = nestedRuntime.getSnapshot();\n\n    // ─── Output Mapping ───\n    if (!subflowError && mountOptions?.outputMapper) {\n      try {\n        let outputContext = parentContext;\n        if (parentContext.branchId && parentContext.branchId !== '' && parentContext.parent) {\n          outputContext = parentContext.parent;\n        }\n\n        const parentScope = outputContext.getScope();\n        const mappedOutput = applyOutputMapping(subflowOutput, parentScope, outputContext, mountOptions);\n\n        if (mappedOutput && Object.keys(mappedOutput).length > 0) {\n          parentContext.addLog('mappedOutput', mappedOutput);\n          parentContext.addLog('outputMappingTarget', outputContext.branchId || '(root)');\n        }\n\n        outputContext.commit();\n      } catch (error: any) {\n        parentContext.addError('outputMapperError', error.toString());\n        this.deps.logger.error(`Error in outputMapper for subflow (${subflowId}):`, { error });\n      }\n    }\n\n    const subflowResult: SubflowResult = {\n      subflowId,\n      subflowName,\n      treeContext: {\n        globalContext: subflowTreeContext.sharedState,\n        stageContexts: subflowTreeContext.executionTree as unknown as Record<string, unknown>,\n        history: subflowTreeContext.commitLog,\n      },\n      parentStageId: parentContext.getStageId(),\n    };\n\n    const subflowDef = this.deps.subflows?.[subflowId];\n    if (subflowDef && (subflowDef as any).buildTimeStructure) {\n      subflowResult.pipelineStructure = (subflowDef as any).buildTimeStructure;\n    }\n\n    parentContext.addLog('subflowResult', subflowResult);\n    parentContext.addLog('hasSubflowData', true);\n    subflowResultsMap.set(subflowId, subflowResult);\n\n    parentContext.addFlowDebugMessage('subflow', `Exiting ${subflowName} subflow`, {\n      targetStage: subflowId,\n    });\n    this.deps.narrativeGenerator.onSubflowExit(subflowName);\n\n    parentContext.commit();\n\n    if (subflowError) {\n      throw subflowError;\n    }\n\n    return subflowOutput;\n  }\n\n  /**\n   * Internal execution within subflow context.\n   * Mirrors the traverser's executeNode but within the subflow's isolated runtime.\n   */\n  private async executeSubflowInternal(\n    node: StageNode<TOut, TScope>,\n    context: StageContext,\n    breakFlag: { shouldBreak: boolean },\n    branchPath: string,\n  ): Promise<any> {\n    // Detect nested subflows\n    if (node.isSubflowRoot && node.subflowId) {\n      const resolvedNode = this.nodeResolver.resolveSubflowReference(node);\n      return await this.executeSubflow(resolvedNode, context, breakFlag, branchPath, this.subflowResultsMap!);\n    }\n\n    const stageFunc = this.getStageFn(node);\n    const breakFn = () => (breakFlag.shouldBreak = true);\n\n    let stageOutput: TOut | undefined;\n    if (stageFunc) {\n      try {\n        if (this.currentSubflowDeps) {\n          const subflowStageRunner = new StageRunner<TOut, TScope>(this.currentSubflowDeps);\n          stageOutput = await subflowStageRunner.run(node, stageFunc, context, breakFn);\n        } else {\n          stageOutput = await this.executeStage(node, stageFunc, context, breakFn);\n        }\n      } catch (error: any) {\n        context.commit();\n        this.callExtractor(node, context, this.getStagePath(node, branchPath, context.stageName), undefined, {\n          type: 'stageExecutionError',\n          message: error.toString(),\n        });\n        context.addError('stageExecutionError', error.toString());\n        throw error;\n      }\n      context.commit();\n      this.callExtractor(node, context, this.getStagePath(node, branchPath, context.stageName), stageOutput);\n\n      if (breakFlag.shouldBreak) {\n        return stageOutput;\n      }\n\n      // Handle dynamic StageNode return\n      if (stageOutput && typeof stageOutput === 'object' && isStageNodeReturn(stageOutput)) {\n        const dynamicNode = stageOutput as StageNode<TOut, TScope>;\n        context.addLog('isDynamic', true);\n        context.addLog('dynamicPattern', 'StageNodeReturn');\n\n        if (dynamicNode.children && dynamicNode.children.length > 0) {\n          node.children = dynamicNode.children;\n          context.addLog('dynamicChildCount', dynamicNode.children.length);\n          context.addLog(\n            'dynamicChildIds',\n            dynamicNode.children.map((c) => c.id || c.name),\n          );\n\n          if (typeof dynamicNode.nextNodeSelector === 'function') {\n            node.nextNodeSelector = dynamicNode.nextNodeSelector;\n            context.addLog('hasSelector', true);\n          }\n        }\n\n        if (dynamicNode.next) {\n          node.next = dynamicNode.next;\n          context.addLog('hasDynamicNext', true);\n          const loopTargetId = dynamicNode.next.id || dynamicNode.next.name;\n          if (loopTargetId) {\n            context.addLog('loopTarget', loopTargetId);\n          }\n        }\n\n        stageOutput = undefined;\n      }\n    }\n\n    // ─── Children dispatch ───\n    const hasChildrenAfterStage = Boolean(node.children?.length);\n    const hasNextAfterStage = Boolean(node.next);\n\n    if (hasChildrenAfterStage) {\n      if (node.nextNodeSelector) {\n        const results = await this.executeSelectedChildrenInternal(\n          node.nextNodeSelector,\n          node.children!,\n          stageOutput,\n          context,\n          branchPath,\n          breakFlag,\n        );\n        if (!hasNextAfterStage) return results;\n      } else {\n        const results = await this.executeNodeChildrenInternal(node, context, branchPath, breakFlag);\n        if (!hasNextAfterStage) return results;\n      }\n    }\n\n    // ─── Linear next ───\n    if (hasNextAfterStage) {\n      let nextNode = node.next!;\n\n      // Resolve reference nodes (has id but no fn)\n      if (nextNode.id && !nextNode.fn) {\n        let resolvedNode: StageNode<TOut, TScope> | undefined;\n        if (this.currentSubflowRoot) {\n          resolvedNode = this.nodeResolver.findNodeById(nextNode.id, this.currentSubflowRoot);\n          if (resolvedNode) context.addLog('dynamicNextResolvedFrom', 'subflow');\n        }\n        if (!resolvedNode) {\n          resolvedNode = this.nodeResolver.findNodeById(nextNode.id);\n          if (resolvedNode) context.addLog('dynamicNextResolvedFrom', 'mainPipeline');\n        }\n        if (resolvedNode) {\n          nextNode = resolvedNode;\n          context.addLog('dynamicNextResolved', true);\n          context.addLog('dynamicNextTarget', nextNode.id);\n        } else {\n          this.deps.logger.info(`Dynamic next node '${nextNode.id}' not found in subflow or main pipeline`);\n          context.addLog('dynamicNextResolved', false);\n          context.addLog('dynamicNextNotFound', nextNode.id);\n        }\n      }\n\n      const nextCtx = context.createNext('', nextNode.name);\n      return await this.executeSubflowInternal(nextNode, nextCtx, breakFlag, branchPath);\n    }\n\n    return stageOutput;\n  }\n\n  private getStagePath(node: StageNode<TOut, TScope>, branchPath?: string, contextStageName?: string): string {\n    const baseName = node.id ?? node.name;\n    const nodeId = contextStageName && contextStageName !== node.name ? contextStageName : baseName;\n    if (!branchPath) return nodeId;\n    return `${branchPath}.${nodeId}`;\n  }\n\n  private async executeNodeChildrenInternal(\n    node: StageNode<TOut, TScope>,\n    context: StageContext,\n    branchPath: string,\n    breakFlag: { shouldBreak: boolean },\n  ): Promise<Record<string, NodeResultType>> {\n    const childPromises: Promise<NodeResultType>[] = (node.children ?? []).map((child) => {\n      const childContext = context.createChild('', child.id as string, child.name);\n      const childBreakFlag = { shouldBreak: false };\n\n      return this.executeSubflowInternal(child, childContext, childBreakFlag, branchPath)\n        .then((result) => {\n          childContext.commit();\n          return { id: child.id!, result, isError: false };\n        })\n        .catch((error) => {\n          childContext.commit();\n          this.deps.logger.info(`TREE PIPELINE: executeNodeChildrenInternal - Error for id: ${child?.id}`, { error });\n          return { id: child.id!, result: error, isError: true };\n        });\n    });\n\n    const settled = await Promise.allSettled(childPromises);\n    const childrenResults: Record<string, NodeResultType> = {};\n    settled.forEach((s) => {\n      if (s.status === 'fulfilled') {\n        const { id, result, isError } = s.value;\n        childrenResults[id] = { id, result, isError };\n      } else {\n        this.deps.logger.error(`Execution failed: ${s.reason}`);\n      }\n    });\n    return childrenResults;\n  }\n\n  private async executeSelectedChildrenInternal(\n    selector: Selector,\n    children: StageNode<TOut, TScope>[],\n    input: any,\n    context: StageContext,\n    branchPath: string,\n    breakFlag: { shouldBreak: boolean },\n  ): Promise<Record<string, NodeResultType>> {\n    const selectorResult = await selector(input);\n    const selectedIds = Array.isArray(selectorResult) ? selectorResult : [selectorResult];\n\n    context.addLog('selectedChildIds', selectedIds);\n    context.addLog('selectorPattern', 'multi-choice');\n\n    if (selectedIds.length === 0) {\n      context.addLog('skippedAllChildren', true);\n      return {};\n    }\n\n    const selectedChildren = children.filter((c) => selectedIds.includes(c.id!));\n    if (selectedChildren.length !== selectedIds.length) {\n      const childIds = children.map((c) => c.id);\n      const missing = selectedIds.filter((id) => !childIds.includes(id));\n      const errorMessage = `Selector returned unknown child IDs: ${missing.join(', ')}. Available: ${childIds.join(\n        ', ',\n      )}`;\n      this.deps.logger.error(`Error in subflow (${branchPath}):`, { error: errorMessage });\n      context.addError('selectorError', errorMessage);\n      throw new Error(errorMessage);\n    }\n\n    const skippedIds = children.filter((c) => !selectedIds.includes(c.id!)).map((c) => c.id);\n    if (skippedIds.length > 0) {\n      context.addLog('skippedChildIds', skippedIds);\n    }\n\n    const tempNode: StageNode<TOut, TScope> = { name: 'selector-temp', children: selectedChildren };\n    return await this.executeNodeChildrenInternal(tempNode, context, branchPath, breakFlag);\n  }\n}\n"]}
@@ -0,0 +1,121 @@
1
+ "use strict";
2
+ /**
3
+ * SubflowInputMapper — Pure functions for subflow data contracts.
4
+ *
5
+ * Mental model: Subflow = Pure Function
6
+ * - Isolated scope (own GlobalStore)
7
+ * - Explicit inputs via inputMapper
8
+ * - Explicit outputs via outputMapper
9
+ *
10
+ * | Scenario | Behavior |
11
+ * |-----------------|-------------------------------------------|
12
+ * | No inputMapper | Subflow starts with empty scope |
13
+ * | No outputMapper | Subflow scope changes discarded |
14
+ * | Both present | Full data contract (args in, results out) |
15
+ * | Neither present | Complete isolation (side effects only) |
16
+ */
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ exports.applyOutputMapping = exports.seedSubflowGlobalStore = exports.createSubflowHandlerDeps = exports.getInitialScopeValues = exports.extractParentScopeValues = void 0;
19
+ /** Extract values from parent scope using inputMapper. */
20
+ function extractParentScopeValues(parentScope, options) {
21
+ if (!(options === null || options === void 0 ? void 0 : options.inputMapper)) {
22
+ return {};
23
+ }
24
+ const result = options.inputMapper(parentScope);
25
+ if (result === null || result === undefined) {
26
+ return {};
27
+ }
28
+ return result;
29
+ }
30
+ exports.extractParentScopeValues = extractParentScopeValues;
31
+ /**
32
+ * Get the initial scope values for a subflow.
33
+ * Always isolated — only inputMapper values are included.
34
+ */
35
+ function getInitialScopeValues(parentScope, options) {
36
+ return extractParentScopeValues(parentScope, options);
37
+ }
38
+ exports.getInitialScopeValues = getInitialScopeValues;
39
+ /**
40
+ * Create a new HandlerDeps for subflow execution.
41
+ * Key: sets readOnlyContext to mapped input so StageRunner passes it to ScopeFactory.
42
+ */
43
+ function createSubflowHandlerDeps(parentDeps, subflowRuntime, mappedInput) {
44
+ return {
45
+ stageMap: parentDeps.stageMap,
46
+ root: parentDeps.root,
47
+ ScopeFactory: parentDeps.ScopeFactory,
48
+ subflows: parentDeps.subflows,
49
+ throttlingErrorChecker: parentDeps.throttlingErrorChecker,
50
+ streamHandlers: parentDeps.streamHandlers,
51
+ scopeProtectionMode: parentDeps.scopeProtectionMode,
52
+ executionRuntime: subflowRuntime,
53
+ readOnlyContext: mappedInput,
54
+ narrativeGenerator: parentDeps.narrativeGenerator,
55
+ logger: parentDeps.logger,
56
+ };
57
+ }
58
+ exports.createSubflowHandlerDeps = createSubflowHandlerDeps;
59
+ /**
60
+ * Seed the subflow's GlobalStore with initial values.
61
+ * Called before subflow execution to make inputMapper values available.
62
+ */
63
+ function seedSubflowGlobalStore(subflowRuntime, initialValues) {
64
+ const rootContext = subflowRuntime.rootStageContext;
65
+ for (const [key, value] of Object.entries(initialValues)) {
66
+ if (typeof value === 'object' && value !== null && !Array.isArray(value)) {
67
+ for (const [nestedKey, nestedValue] of Object.entries(value)) {
68
+ rootContext.setObject([key], nestedKey, nestedValue);
69
+ }
70
+ }
71
+ else {
72
+ rootContext.setGlobal(key, value);
73
+ }
74
+ }
75
+ rootContext.commit();
76
+ }
77
+ exports.seedSubflowGlobalStore = seedSubflowGlobalStore;
78
+ /**
79
+ * Apply output mapping after subflow completion.
80
+ * Writes mapped values back to parent scope using merge semantics:
81
+ * arrays are appended, objects are shallow-merged, scalars are replaced.
82
+ */
83
+ function applyOutputMapping(subflowOutput, parentScope, parentContext, options) {
84
+ if (!(options === null || options === void 0 ? void 0 : options.outputMapper)) {
85
+ return undefined;
86
+ }
87
+ const mappedOutput = options.outputMapper(subflowOutput, parentScope);
88
+ if (mappedOutput === null || mappedOutput === undefined) {
89
+ return undefined;
90
+ }
91
+ for (const [key, value] of Object.entries(mappedOutput)) {
92
+ if (typeof value === 'object' && value !== null && !Array.isArray(value)) {
93
+ for (const [nestedKey, nestedValue] of Object.entries(value)) {
94
+ if (Array.isArray(nestedValue)) {
95
+ parentContext.appendToArray([key], nestedKey, nestedValue);
96
+ }
97
+ else if (typeof nestedValue === 'object' && nestedValue !== null) {
98
+ parentContext.mergeObject([key], nestedKey, nestedValue);
99
+ }
100
+ else {
101
+ parentContext.setObject([key], nestedKey, nestedValue);
102
+ }
103
+ }
104
+ }
105
+ else if (Array.isArray(value)) {
106
+ const existing = parentContext.getGlobal(key);
107
+ if (Array.isArray(existing)) {
108
+ parentContext.setGlobal(key, [...existing, ...value]);
109
+ }
110
+ else {
111
+ parentContext.setGlobal(key, value);
112
+ }
113
+ }
114
+ else {
115
+ parentContext.setGlobal(key, value);
116
+ }
117
+ }
118
+ return mappedOutput;
119
+ }
120
+ exports.applyOutputMapping = applyOutputMapping;
121
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SubflowInputMapper.js","sourceRoot":"","sources":["../../../../src/lib/engine/handlers/SubflowInputMapper.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * SubflowInputMapper — Pure functions for subflow data contracts.\n *\n * Mental model: Subflow = Pure Function\n * - Isolated scope (own GlobalStore)\n * - Explicit inputs via inputMapper\n * - Explicit outputs via outputMapper\n *\n * | Scenario        | Behavior                                  |\n * |-----------------|-------------------------------------------|\n * | No inputMapper  | Subflow starts with empty scope           |\n * | No outputMapper | Subflow scope changes discarded           |\n * | Both present    | Full data contract (args in, results out) |\n * | Neither present | Complete isolation (side effects only)    |\n */\n\nimport type { StageContext } from '../../memory/StageContext';\nimport type { HandlerDeps, IExecutionRuntime, SubflowMountOptions } from '../types';\n\n/** Extract values from parent scope using inputMapper. */\nexport function extractParentScopeValues<TParentScope, TSubflowInput>(\n  parentScope: TParentScope,\n  options?: SubflowMountOptions<TParentScope, TSubflowInput>,\n): TSubflowInput | Record<string, unknown> {\n  if (!options?.inputMapper) {\n    return {};\n  }\n\n  const result = options.inputMapper(parentScope);\n  if (result === null || result === undefined) {\n    return {};\n  }\n\n  return result;\n}\n\n/**\n * Get the initial scope values for a subflow.\n * Always isolated — only inputMapper values are included.\n */\nexport function getInitialScopeValues<TParentScope, TSubflowInput>(\n  parentScope: TParentScope,\n  options?: SubflowMountOptions<TParentScope, TSubflowInput>,\n): Record<string, unknown> {\n  return extractParentScopeValues(parentScope, options) as Record<string, unknown>;\n}\n\n/**\n * Create a new HandlerDeps for subflow execution.\n * Key: sets readOnlyContext to mapped input so StageRunner passes it to ScopeFactory.\n */\nexport function createSubflowHandlerDeps<TOut = any, TScope = any>(\n  parentDeps: HandlerDeps<TOut, TScope>,\n  subflowRuntime: IExecutionRuntime,\n  mappedInput: Record<string, unknown>,\n): HandlerDeps<TOut, TScope> {\n  return {\n    stageMap: parentDeps.stageMap,\n    root: parentDeps.root,\n    ScopeFactory: parentDeps.ScopeFactory,\n    subflows: parentDeps.subflows,\n    throttlingErrorChecker: parentDeps.throttlingErrorChecker,\n    streamHandlers: parentDeps.streamHandlers,\n    scopeProtectionMode: parentDeps.scopeProtectionMode,\n    executionRuntime: subflowRuntime,\n    readOnlyContext: mappedInput,\n    narrativeGenerator: parentDeps.narrativeGenerator,\n    logger: parentDeps.logger,\n  };\n}\n\n/**\n * Seed the subflow's GlobalStore with initial values.\n * Called before subflow execution to make inputMapper values available.\n */\nexport function seedSubflowGlobalStore(\n  subflowRuntime: IExecutionRuntime,\n  initialValues: Record<string, unknown>,\n): void {\n  const rootContext = subflowRuntime.rootStageContext;\n\n  for (const [key, value] of Object.entries(initialValues)) {\n    if (typeof value === 'object' && value !== null && !Array.isArray(value)) {\n      for (const [nestedKey, nestedValue] of Object.entries(value as Record<string, unknown>)) {\n        rootContext.setObject([key], nestedKey, nestedValue);\n      }\n    } else {\n      rootContext.setGlobal(key, value);\n    }\n  }\n\n  rootContext.commit();\n}\n\n/**\n * Apply output mapping after subflow completion.\n * Writes mapped values back to parent scope using merge semantics:\n * arrays are appended, objects are shallow-merged, scalars are replaced.\n */\nexport function applyOutputMapping<TParentScope, TSubflowOutput>(\n  subflowOutput: TSubflowOutput,\n  parentScope: TParentScope,\n  parentContext: StageContext,\n  options?: SubflowMountOptions<TParentScope, any, TSubflowOutput>,\n): Record<string, unknown> | undefined {\n  if (!options?.outputMapper) {\n    return undefined;\n  }\n\n  const mappedOutput = options.outputMapper(subflowOutput, parentScope);\n\n  if (mappedOutput === null || mappedOutput === undefined) {\n    return undefined;\n  }\n\n  for (const [key, value] of Object.entries(mappedOutput)) {\n    if (typeof value === 'object' && value !== null && !Array.isArray(value)) {\n      for (const [nestedKey, nestedValue] of Object.entries(value as Record<string, unknown>)) {\n        if (Array.isArray(nestedValue)) {\n          parentContext.appendToArray([key], nestedKey, nestedValue);\n        } else if (typeof nestedValue === 'object' && nestedValue !== null) {\n          parentContext.mergeObject([key], nestedKey, nestedValue as Record<string, unknown>);\n        } else {\n          parentContext.setObject([key], nestedKey, nestedValue);\n        }\n      }\n    } else if (Array.isArray(value)) {\n      const existing = parentContext.getGlobal(key);\n      if (Array.isArray(existing)) {\n        parentContext.setGlobal(key, [...existing, ...value]);\n      } else {\n        parentContext.setGlobal(key, value);\n      }\n    } else {\n      parentContext.setGlobal(key, value);\n    }\n  }\n\n  return mappedOutput;\n}\n"]}
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ /* istanbul ignore file */
3
+ /**
4
+ * Barrel export for all engine handler modules.
5
+ */
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.RuntimeStructureManager = exports.computeNodeType = exports.ExtractorRunner = exports.seedSubflowGlobalStore = exports.getInitialScopeValues = exports.extractParentScopeValues = exports.createSubflowHandlerDeps = exports.applyOutputMapping = exports.SubflowExecutor = exports.DEFAULT_MAX_ITERATIONS = exports.ContinuationResolver = exports.SelectorHandler = exports.DeciderHandler = exports.ChildrenExecutor = exports.NodeResolver = exports.StageRunner = void 0;
8
+ // Stage execution
9
+ var StageRunner_1 = require("./StageRunner");
10
+ Object.defineProperty(exports, "StageRunner", { enumerable: true, get: function () { return StageRunner_1.StageRunner; } });
11
+ // Node resolution and subflow reference handling
12
+ var NodeResolver_1 = require("./NodeResolver");
13
+ Object.defineProperty(exports, "NodeResolver", { enumerable: true, get: function () { return NodeResolver_1.NodeResolver; } });
14
+ var ChildrenExecutor_1 = require("./ChildrenExecutor");
15
+ Object.defineProperty(exports, "ChildrenExecutor", { enumerable: true, get: function () { return ChildrenExecutor_1.ChildrenExecutor; } });
16
+ var DeciderHandler_1 = require("./DeciderHandler");
17
+ Object.defineProperty(exports, "DeciderHandler", { enumerable: true, get: function () { return DeciderHandler_1.DeciderHandler; } });
18
+ // Multi-choice filtered fan-out
19
+ var SelectorHandler_1 = require("./SelectorHandler");
20
+ Object.defineProperty(exports, "SelectorHandler", { enumerable: true, get: function () { return SelectorHandler_1.SelectorHandler; } });
21
+ // Back-edge resolution + iteration counting (was LoopHandler)
22
+ var ContinuationResolver_1 = require("./ContinuationResolver");
23
+ Object.defineProperty(exports, "ContinuationResolver", { enumerable: true, get: function () { return ContinuationResolver_1.ContinuationResolver; } });
24
+ Object.defineProperty(exports, "DEFAULT_MAX_ITERATIONS", { enumerable: true, get: function () { return ContinuationResolver_1.DEFAULT_MAX_ITERATIONS; } });
25
+ // Subflow execution with isolated contexts
26
+ var SubflowExecutor_1 = require("./SubflowExecutor");
27
+ Object.defineProperty(exports, "SubflowExecutor", { enumerable: true, get: function () { return SubflowExecutor_1.SubflowExecutor; } });
28
+ // Subflow input/output mapping
29
+ var SubflowInputMapper_1 = require("./SubflowInputMapper");
30
+ Object.defineProperty(exports, "applyOutputMapping", { enumerable: true, get: function () { return SubflowInputMapper_1.applyOutputMapping; } });
31
+ Object.defineProperty(exports, "createSubflowHandlerDeps", { enumerable: true, get: function () { return SubflowInputMapper_1.createSubflowHandlerDeps; } });
32
+ Object.defineProperty(exports, "extractParentScopeValues", { enumerable: true, get: function () { return SubflowInputMapper_1.extractParentScopeValues; } });
33
+ Object.defineProperty(exports, "getInitialScopeValues", { enumerable: true, get: function () { return SubflowInputMapper_1.getInitialScopeValues; } });
34
+ Object.defineProperty(exports, "seedSubflowGlobalStore", { enumerable: true, get: function () { return SubflowInputMapper_1.seedSubflowGlobalStore; } });
35
+ // Traversal extractor coordination
36
+ var ExtractorRunner_1 = require("./ExtractorRunner");
37
+ Object.defineProperty(exports, "ExtractorRunner", { enumerable: true, get: function () { return ExtractorRunner_1.ExtractorRunner; } });
38
+ // Runtime structure management (dynamic pipeline structure tracking)
39
+ var RuntimeStructureManager_1 = require("./RuntimeStructureManager");
40
+ Object.defineProperty(exports, "computeNodeType", { enumerable: true, get: function () { return RuntimeStructureManager_1.computeNodeType; } });
41
+ Object.defineProperty(exports, "RuntimeStructureManager", { enumerable: true, get: function () { return RuntimeStructureManager_1.RuntimeStructureManager; } });
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL2VuZ2luZS9oYW5kbGVycy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsMEJBQTBCO0FBQzFCOztHQUVHOzs7QUFFSCxrQkFBa0I7QUFDbEIsNkNBQTRDO0FBQW5DLDBHQUFBLFdBQVcsT0FBQTtBQUVwQixpREFBaUQ7QUFDakQsK0NBQThDO0FBQXJDLDRHQUFBLFlBQVksT0FBQTtBQUlyQix1REFBc0Q7QUFBN0Msb0hBQUEsZ0JBQWdCLE9BQUE7QUFJekIsbURBQWtEO0FBQXpDLGdIQUFBLGNBQWMsT0FBQTtBQUV2QixnQ0FBZ0M7QUFDaEMscURBQW9EO0FBQTNDLGtIQUFBLGVBQWUsT0FBQTtBQUV4Qiw4REFBOEQ7QUFDOUQsK0RBQXNGO0FBQTdFLDRIQUFBLG9CQUFvQixPQUFBO0FBQUUsOEhBQUEsc0JBQXNCLE9BQUE7QUFFckQsMkNBQTJDO0FBQzNDLHFEQUFvRDtBQUEzQyxrSEFBQSxlQUFlLE9BQUE7QUFFeEIsK0JBQStCO0FBQy9CLDJEQU04QjtBQUw1Qix3SEFBQSxrQkFBa0IsT0FBQTtBQUNsQiw4SEFBQSx3QkFBd0IsT0FBQTtBQUN4Qiw4SEFBQSx3QkFBd0IsT0FBQTtBQUN4QiwySEFBQSxxQkFBcUIsT0FBQTtBQUNyQiw0SEFBQSxzQkFBc0IsT0FBQTtBQUd4QixtQ0FBbUM7QUFDbkMscURBQW9EO0FBQTNDLGtIQUFBLGVBQWUsT0FBQTtBQUV4QixxRUFBcUU7QUFDckUscUVBQXFGO0FBQTVFLDBIQUFBLGVBQWUsT0FBQTtBQUFFLGtJQUFBLHVCQUF1QixPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLyogaXN0YW5idWwgaWdub3JlIGZpbGUgKi9cbi8qKlxuICogQmFycmVsIGV4cG9ydCBmb3IgYWxsIGVuZ2luZSBoYW5kbGVyIG1vZHVsZXMuXG4gKi9cblxuLy8gU3RhZ2UgZXhlY3V0aW9uXG5leHBvcnQgeyBTdGFnZVJ1bm5lciB9IGZyb20gJy4vU3RhZ2VSdW5uZXInO1xuXG4vLyBOb2RlIHJlc29sdXRpb24gYW5kIHN1YmZsb3cgcmVmZXJlbmNlIGhhbmRsaW5nXG5leHBvcnQgeyBOb2RlUmVzb2x2ZXIgfSBmcm9tICcuL05vZGVSZXNvbHZlcic7XG5cbi8vIFBhcmFsbGVsIGNoaWxkcmVuIGV4ZWN1dGlvblxuZXhwb3J0IHR5cGUgeyBFeGVjdXRlTm9kZUZuIH0gZnJvbSAnLi9DaGlsZHJlbkV4ZWN1dG9yJztcbmV4cG9ydCB7IENoaWxkcmVuRXhlY3V0b3IgfSBmcm9tICcuL0NoaWxkcmVuRXhlY3V0b3InO1xuXG4vLyBTaW5nbGUtY2hvaWNlIGNvbmRpdGlvbmFsIGJyYW5jaGluZ1xuZXhwb3J0IHR5cGUgeyBDYWxsRXh0cmFjdG9yRm4sIEdldFN0YWdlUGF0aEZuLCBSdW5TdGFnZUZuIH0gZnJvbSAnLi9EZWNpZGVySGFuZGxlcic7XG5leHBvcnQgeyBEZWNpZGVySGFuZGxlciB9IGZyb20gJy4vRGVjaWRlckhhbmRsZXInO1xuXG4vLyBNdWx0aS1jaG9pY2UgZmlsdGVyZWQgZmFuLW91dFxuZXhwb3J0IHsgU2VsZWN0b3JIYW5kbGVyIH0gZnJvbSAnLi9TZWxlY3RvckhhbmRsZXInO1xuXG4vLyBCYWNrLWVkZ2UgcmVzb2x1dGlvbiArIGl0ZXJhdGlvbiBjb3VudGluZyAod2FzIExvb3BIYW5kbGVyKVxuZXhwb3J0IHsgQ29udGludWF0aW9uUmVzb2x2ZXIsIERFRkFVTFRfTUFYX0lURVJBVElPTlMgfSBmcm9tICcuL0NvbnRpbnVhdGlvblJlc29sdmVyJztcblxuLy8gU3ViZmxvdyBleGVjdXRpb24gd2l0aCBpc29sYXRlZCBjb250ZXh0c1xuZXhwb3J0IHsgU3ViZmxvd0V4ZWN1dG9yIH0gZnJvbSAnLi9TdWJmbG93RXhlY3V0b3InO1xuXG4vLyBTdWJmbG93IGlucHV0L291dHB1dCBtYXBwaW5nXG5leHBvcnQge1xuICBhcHBseU91dHB1dE1hcHBpbmcsXG4gIGNyZWF0ZVN1YmZsb3dIYW5kbGVyRGVwcyxcbiAgZXh0cmFjdFBhcmVudFNjb3BlVmFsdWVzLFxuICBnZXRJbml0aWFsU2NvcGVWYWx1ZXMsXG4gIHNlZWRTdWJmbG93R2xvYmFsU3RvcmUsXG59IGZyb20gJy4vU3ViZmxvd0lucHV0TWFwcGVyJztcblxuLy8gVHJhdmVyc2FsIGV4dHJhY3RvciBjb29yZGluYXRpb25cbmV4cG9ydCB7IEV4dHJhY3RvclJ1bm5lciB9IGZyb20gJy4vRXh0cmFjdG9yUnVubmVyJztcblxuLy8gUnVudGltZSBzdHJ1Y3R1cmUgbWFuYWdlbWVudCAoZHluYW1pYyBwaXBlbGluZSBzdHJ1Y3R1cmUgdHJhY2tpbmcpXG5leHBvcnQgeyBjb21wdXRlTm9kZVR5cGUsIFJ1bnRpbWVTdHJ1Y3R1cmVNYW5hZ2VyIH0gZnJvbSAnLi9SdW50aW1lU3RydWN0dXJlTWFuYWdlcic7XG4iXX0=
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ /* istanbul ignore file */
3
+ /**
4
+ * engine/ — Graph traversal engine library.
5
+ *
6
+ * Executes flowcharts built by FlowChartBuilder via pre-order DFS traversal.
7
+ * Handles linear, fork, decider, selector, loop, and subflow node shapes.
8
+ */
9
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ var desc = Object.getOwnPropertyDescriptor(m, k);
12
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
13
+ desc = { enumerable: true, get: function() { return m[k]; } };
14
+ }
15
+ Object.defineProperty(o, k2, desc);
16
+ }) : (function(o, m, k, k2) {
17
+ if (k2 === undefined) k2 = k;
18
+ o[k2] = m[k];
19
+ }));
20
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
21
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
22
+ };
23
+ Object.defineProperty(exports, "__esModule", { value: true });
24
+ exports.NullControlFlowNarrativeGenerator = exports.ControlFlowNarrativeGenerator = exports.CombinedNarrativeBuilder = exports.isStageNodeReturn = exports.FlowchartTraverser = void 0;
25
+ var FlowchartTraverser_1 = require("./traversal/FlowchartTraverser");
26
+ Object.defineProperty(exports, "FlowchartTraverser", { enumerable: true, get: function () { return FlowchartTraverser_1.FlowchartTraverser; } });
27
+ // Graph node types (Decider, Selector, StageNode re-exported via ./types)
28
+ var StageNode_1 = require("./graph/StageNode");
29
+ Object.defineProperty(exports, "isStageNodeReturn", { enumerable: true, get: function () { return StageNode_1.isStageNodeReturn; } });
30
+ // Types
31
+ __exportStar(require("./types"), exports);
32
+ // Handlers (for advanced use cases and testing)
33
+ __exportStar(require("./handlers"), exports);
34
+ var CombinedNarrativeBuilder_1 = require("./narrative/CombinedNarrativeBuilder");
35
+ Object.defineProperty(exports, "CombinedNarrativeBuilder", { enumerable: true, get: function () { return CombinedNarrativeBuilder_1.CombinedNarrativeBuilder; } });
36
+ var ControlFlowNarrativeGenerator_1 = require("./narrative/ControlFlowNarrativeGenerator");
37
+ Object.defineProperty(exports, "ControlFlowNarrativeGenerator", { enumerable: true, get: function () { return ControlFlowNarrativeGenerator_1.ControlFlowNarrativeGenerator; } });
38
+ var NullControlFlowNarrativeGenerator_1 = require("./narrative/NullControlFlowNarrativeGenerator");
39
+ Object.defineProperty(exports, "NullControlFlowNarrativeGenerator", { enumerable: true, get: function () { return NullControlFlowNarrativeGenerator_1.NullControlFlowNarrativeGenerator; } });
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2VuZ2luZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsMEJBQTBCO0FBQzFCOzs7OztHQUtHOzs7Ozs7Ozs7Ozs7Ozs7OztBQUlILHFFQUFvRTtBQUEzRCx3SEFBQSxrQkFBa0IsT0FBQTtBQUUzQiwwRUFBMEU7QUFDMUUsK0NBQXNEO0FBQTdDLDhHQUFBLGlCQUFpQixPQUFBO0FBRTFCLFFBQVE7QUFDUiwwQ0FBd0I7QUFFeEIsZ0RBQWdEO0FBQ2hELDZDQUEyQjtBQUkzQixpRkFBZ0Y7QUFBdkUsb0lBQUEsd0JBQXdCLE9BQUE7QUFDakMsMkZBQTBGO0FBQWpGLDhJQUFBLDZCQUE2QixPQUFBO0FBQ3RDLG1HQUFrRztBQUF6RixzSkFBQSxpQ0FBaUMsT0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8qIGlzdGFuYnVsIGlnbm9yZSBmaWxlICovXG4vKipcbiAqIGVuZ2luZS8g4oCUIEdyYXBoIHRyYXZlcnNhbCBlbmdpbmUgbGlicmFyeS5cbiAqXG4gKiBFeGVjdXRlcyBmbG93Y2hhcnRzIGJ1aWx0IGJ5IEZsb3dDaGFydEJ1aWxkZXIgdmlhIHByZS1vcmRlciBERlMgdHJhdmVyc2FsLlxuICogSGFuZGxlcyBsaW5lYXIsIGZvcmssIGRlY2lkZXIsIHNlbGVjdG9yLCBsb29wLCBhbmQgc3ViZmxvdyBub2RlIHNoYXBlcy5cbiAqL1xuXG4vLyBDb3JlIHRyYXZlcnNlclxuZXhwb3J0IHR5cGUgeyBUcmF2ZXJzZXJPcHRpb25zIH0gZnJvbSAnLi90cmF2ZXJzYWwvRmxvd2NoYXJ0VHJhdmVyc2VyJztcbmV4cG9ydCB7IEZsb3djaGFydFRyYXZlcnNlciB9IGZyb20gJy4vdHJhdmVyc2FsL0Zsb3djaGFydFRyYXZlcnNlcic7XG5cbi8vIEdyYXBoIG5vZGUgdHlwZXMgKERlY2lkZXIsIFNlbGVjdG9yLCBTdGFnZU5vZGUgcmUtZXhwb3J0ZWQgdmlhIC4vdHlwZXMpXG5leHBvcnQgeyBpc1N0YWdlTm9kZVJldHVybiB9IGZyb20gJy4vZ3JhcGgvU3RhZ2VOb2RlJztcblxuLy8gVHlwZXNcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnO1xuXG4vLyBIYW5kbGVycyAoZm9yIGFkdmFuY2VkIHVzZSBjYXNlcyBhbmQgdGVzdGluZylcbmV4cG9ydCAqIGZyb20gJy4vaGFuZGxlcnMnO1xuXG4vLyBOYXJyYXRpdmUgZ2VuZXJhdGlvblxuZXhwb3J0IHR5cGUgeyBDb21iaW5lZE5hcnJhdGl2ZUVudHJ5LCBDb21iaW5lZE5hcnJhdGl2ZU9wdGlvbnMgfSBmcm9tICcuL25hcnJhdGl2ZS9Db21iaW5lZE5hcnJhdGl2ZUJ1aWxkZXInO1xuZXhwb3J0IHsgQ29tYmluZWROYXJyYXRpdmVCdWlsZGVyIH0gZnJvbSAnLi9uYXJyYXRpdmUvQ29tYmluZWROYXJyYXRpdmVCdWlsZGVyJztcbmV4cG9ydCB7IENvbnRyb2xGbG93TmFycmF0aXZlR2VuZXJhdG9yIH0gZnJvbSAnLi9uYXJyYXRpdmUvQ29udHJvbEZsb3dOYXJyYXRpdmVHZW5lcmF0b3InO1xuZXhwb3J0IHsgTnVsbENvbnRyb2xGbG93TmFycmF0aXZlR2VuZXJhdG9yIH0gZnJvbSAnLi9uYXJyYXRpdmUvTnVsbENvbnRyb2xGbG93TmFycmF0aXZlR2VuZXJhdG9yJztcbmV4cG9ydCB0eXBlIHsgSUNvbnRyb2xGbG93TmFycmF0aXZlIH0gZnJvbSAnLi9uYXJyYXRpdmUvdHlwZXMnO1xuIl19