footprintjs 0.18.1 → 1.0.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 (117) hide show
  1. package/CLAUDE.md +77 -59
  2. package/README.md +41 -32
  3. package/dist/advanced.js +31 -25
  4. package/dist/esm/advanced.js +3 -2
  5. package/dist/esm/index.js +6 -3
  6. package/dist/esm/lib/builder/FlowChartBuilder.js +1 -1
  7. package/dist/esm/lib/builder/index.js +1 -1
  8. package/dist/esm/lib/builder/typedFlowChart.js +36 -0
  9. package/dist/esm/lib/builder/types.js +1 -1
  10. package/dist/esm/lib/contract/index.js +2 -2
  11. package/dist/esm/lib/contract/schema.js +2 -6
  12. package/dist/esm/lib/decide/decide.js +170 -0
  13. package/dist/esm/lib/decide/evaluator.js +103 -0
  14. package/dist/esm/lib/decide/evidence.js +35 -0
  15. package/dist/esm/lib/decide/index.js +16 -0
  16. package/dist/esm/lib/decide/types.js +10 -0
  17. package/dist/esm/lib/engine/handlers/DeciderHandler.js +12 -3
  18. package/dist/esm/lib/engine/handlers/SelectorHandler.js +15 -3
  19. package/dist/esm/lib/engine/handlers/StageRunner.js +16 -6
  20. package/dist/esm/lib/engine/index.js +1 -2
  21. package/dist/esm/lib/engine/narrative/CombinedNarrativeBuilder.js +5 -184
  22. package/dist/esm/lib/engine/narrative/CombinedNarrativeRecorder.js +43 -30
  23. package/dist/esm/lib/engine/narrative/ControlFlowNarrativeGenerator.js +20 -3
  24. package/dist/esm/lib/engine/narrative/FlowRecorderDispatcher.js +5 -4
  25. package/dist/esm/lib/engine/narrative/NarrativeFlowRecorder.js +1 -12
  26. package/dist/esm/lib/engine/narrative/index.js +1 -2
  27. package/dist/esm/lib/engine/narrative/types.js +2 -3
  28. package/dist/esm/lib/reactive/allowlist.js +83 -0
  29. package/dist/esm/lib/reactive/arrayTraps.js +116 -0
  30. package/dist/esm/lib/reactive/createTypedScope.js +306 -0
  31. package/dist/esm/lib/reactive/index.js +17 -0
  32. package/dist/esm/lib/reactive/pathBuilder.js +42 -0
  33. package/dist/esm/lib/reactive/types.js +52 -0
  34. package/dist/esm/lib/runner/FlowChartExecutor.js +48 -38
  35. package/dist/esm/lib/scope/ScopeFacade.js +36 -5
  36. package/dist/esm/lib/scope/detectCircular.js +56 -0
  37. package/dist/esm/lib/scope/index.js +2 -3
  38. package/dist/esm/lib/scope/providers/baseStateCompatible.js +1 -4
  39. package/dist/esm/lib/scope/providers/index.js +2 -2
  40. package/dist/esm/lib/scope/recorders/NarrativeRecorder.js +2 -25
  41. package/dist/esm/lib/scope/recorders/index.js +1 -2
  42. package/dist/esm/lib/scope/recorders/summarizeValue.js +31 -0
  43. package/dist/esm/lib/scope/state/zod/utils/validateHelper.js +2 -2
  44. package/dist/index.js +26 -18
  45. package/dist/lib/builder/FlowChartBuilder.js +1 -1
  46. package/dist/lib/builder/index.js +1 -1
  47. package/dist/lib/builder/typedFlowChart.js +41 -0
  48. package/dist/lib/builder/types.js +1 -1
  49. package/dist/lib/contract/index.js +2 -3
  50. package/dist/lib/contract/schema.js +3 -8
  51. package/dist/lib/decide/decide.js +175 -0
  52. package/dist/lib/decide/evaluator.js +107 -0
  53. package/dist/lib/decide/evidence.js +39 -0
  54. package/dist/lib/decide/index.js +24 -0
  55. package/dist/lib/decide/types.js +13 -0
  56. package/dist/lib/engine/handlers/DeciderHandler.js +12 -3
  57. package/dist/lib/engine/handlers/SelectorHandler.js +15 -3
  58. package/dist/lib/engine/handlers/StageRunner.js +16 -6
  59. package/dist/lib/engine/index.js +2 -4
  60. package/dist/lib/engine/narrative/CombinedNarrativeBuilder.js +4 -186
  61. package/dist/lib/engine/narrative/CombinedNarrativeRecorder.js +45 -32
  62. package/dist/lib/engine/narrative/ControlFlowNarrativeGenerator.js +20 -3
  63. package/dist/lib/engine/narrative/FlowRecorderDispatcher.js +5 -4
  64. package/dist/lib/engine/narrative/NarrativeFlowRecorder.js +1 -12
  65. package/dist/lib/engine/narrative/index.js +2 -4
  66. package/dist/lib/engine/narrative/types.js +2 -3
  67. package/dist/lib/reactive/allowlist.js +87 -0
  68. package/dist/lib/reactive/arrayTraps.js +120 -0
  69. package/dist/lib/reactive/createTypedScope.js +313 -0
  70. package/dist/lib/reactive/index.js +29 -0
  71. package/dist/lib/reactive/pathBuilder.js +47 -0
  72. package/dist/lib/reactive/types.js +55 -0
  73. package/dist/lib/runner/FlowChartExecutor.js +48 -38
  74. package/dist/lib/scope/ScopeFacade.js +36 -5
  75. package/dist/lib/scope/detectCircular.js +63 -0
  76. package/dist/lib/scope/index.js +2 -5
  77. package/dist/lib/scope/providers/baseStateCompatible.js +2 -5
  78. package/dist/lib/scope/providers/index.js +2 -3
  79. package/dist/lib/scope/recorders/NarrativeRecorder.js +4 -27
  80. package/dist/lib/scope/recorders/index.js +2 -4
  81. package/dist/lib/scope/recorders/summarizeValue.js +35 -0
  82. package/dist/lib/scope/state/zod/utils/validateHelper.js +2 -2
  83. package/dist/types/advanced.d.ts +4 -2
  84. package/dist/types/index.d.ts +8 -3
  85. package/dist/types/lib/builder/FlowChartBuilder.d.ts +13 -13
  86. package/dist/types/lib/builder/index.d.ts +1 -1
  87. package/dist/types/lib/builder/typedFlowChart.d.ts +34 -0
  88. package/dist/types/lib/builder/types.d.ts +0 -2
  89. package/dist/types/lib/contract/index.d.ts +1 -1
  90. package/dist/types/lib/contract/schema.d.ts +0 -2
  91. package/dist/types/lib/decide/decide.d.ts +26 -0
  92. package/dist/types/lib/decide/evaluator.d.ts +22 -0
  93. package/dist/types/lib/decide/evidence.d.ts +22 -0
  94. package/dist/types/lib/decide/index.d.ts +12 -0
  95. package/dist/types/lib/decide/types.d.ts +91 -0
  96. package/dist/types/lib/engine/index.d.ts +0 -1
  97. package/dist/types/lib/engine/narrative/CombinedNarrativeBuilder.d.ts +3 -31
  98. package/dist/types/lib/engine/narrative/ControlFlowNarrativeGenerator.d.ts +2 -1
  99. package/dist/types/lib/engine/narrative/FlowRecorderDispatcher.d.ts +3 -2
  100. package/dist/types/lib/engine/narrative/NarrativeFlowRecorder.d.ts +0 -9
  101. package/dist/types/lib/engine/narrative/index.d.ts +0 -1
  102. package/dist/types/lib/engine/narrative/types.d.ts +13 -3
  103. package/dist/types/lib/reactive/allowlist.d.ts +30 -0
  104. package/dist/types/lib/reactive/arrayTraps.d.ts +23 -0
  105. package/dist/types/lib/reactive/createTypedScope.d.ts +24 -0
  106. package/dist/types/lib/reactive/index.d.ts +14 -0
  107. package/dist/types/lib/reactive/pathBuilder.d.ts +31 -0
  108. package/dist/types/lib/reactive/types.d.ts +60 -0
  109. package/dist/types/lib/scope/ScopeFacade.d.ts +6 -2
  110. package/dist/types/lib/scope/detectCircular.d.ts +20 -0
  111. package/dist/types/lib/scope/index.d.ts +1 -2
  112. package/dist/types/lib/scope/providers/baseStateCompatible.d.ts +0 -4
  113. package/dist/types/lib/scope/providers/index.d.ts +1 -1
  114. package/dist/types/lib/scope/recorders/index.d.ts +0 -1
  115. package/dist/types/lib/scope/recorders/summarizeValue.d.ts +7 -0
  116. package/dist/types/lib/scope/state/zod/utils/validateHelper.d.ts +1 -1
  117. package/package.json +5 -2
package/CLAUDE.md CHANGED
@@ -13,13 +13,15 @@ src/lib/
13
13
  ├── memory/ → Transactional state (SharedMemory, StageContext, TransactionBuffer, EventLog)
14
14
  ├── schema/ → Validation abstraction (Zod optional, duck-typed detection)
15
15
  ├── builder/ → Fluent DSL (FlowChartBuilder, flowChart(), DeciderList, SelectorFnList)
16
- ├── scope/ → Per-stage facades + recorders + providers (largest module)
16
+ ├── scope/ → Per-stage facades + recorders + providers
17
+ ├── reactive/ → TypedScope<T> deep Proxy (typed property access, $-methods, cycle-safe)
18
+ ├── decide/ → decide()/select() decision evidence capture (filter + function)
17
19
  ├── engine/ → DFS traversal + narrative + 13 handlers
18
20
  ├── runner/ → High-level executor (FlowChartExecutor)
19
21
  └── contract/ → I/O schema + OpenAPI generation
20
22
  ```
21
23
 
22
- Dependency DAG: `memory scope engine runner`, `schema engine`, `builder (standalone) engine`, `contract schema`
24
+ Dependency DAG: `memory <- scope <- reactive <- engine <- runner`, `schema <- engine`, `builder (standalone) -> engine`, `contract <- schema`, `decide -> scope`
23
25
 
24
26
  Two entry points:
25
27
  - `import { ... } from 'footprintjs'` — public API
@@ -27,12 +29,61 @@ Two entry points:
27
29
 
28
30
  ## Key API
29
31
 
32
+ ### TypedScope (Recommended)
33
+
34
+ ```typescript
35
+ import { typedFlowChart, createTypedScopeFactory, FlowChartExecutor } from 'footprintjs';
36
+
37
+ interface LoanState {
38
+ creditTier: string;
39
+ amount: number;
40
+ customer: { name: string; address: { zip: string } };
41
+ tags: string[];
42
+ approved?: boolean;
43
+ }
44
+
45
+ const chart = typedFlowChart<LoanState>('Intake', async (scope) => {
46
+ scope.creditTier = 'A'; // typed write
47
+ scope.amount = 50000; // typed write
48
+ scope.customer.address.zip = '90210'; // deep write (updateValue)
49
+ scope.tags.push('vip'); // array copy-on-write
50
+ scope.approved = true; // optional field
51
+
52
+ // $-prefixed escape hatches
53
+ scope.$debug('checkpoint', { step: 1 });
54
+ scope.$metric('latency', 42);
55
+ const args = scope.$getArgs<{ requestId: string }>();
56
+ const env = scope.$getEnv();
57
+ scope.$break(); // stop pipeline
58
+ }, 'intake')
59
+ .setEnableNarrative()
60
+ .build();
61
+
62
+ const executor = new FlowChartExecutor(chart, createTypedScopeFactory<LoanState>());
63
+ await executor.run({ input: { requestId: 'req-123' } });
64
+ ```
65
+
66
+ ### decide() / select() — Decision Evidence Capture
67
+
68
+ ```typescript
69
+ import { decide, select } from 'footprintjs';
70
+
71
+ // Inside a decider function — auto-captures which values led to the decision
72
+ .addDeciderFunction('ClassifyRisk', (scope) => {
73
+ return decide(scope, [
74
+ { when: { creditScore: { gt: 700 }, dti: { lt: 0.43 } }, then: 'approved', label: 'Good credit' },
75
+ { when: (s) => s.creditScore > 600, then: 'manual-review', label: 'Marginal' },
76
+ ], 'rejected');
77
+ }, 'classify-risk')
78
+
79
+ // Narrative: "It evaluated Rule 0 'Good credit': creditScore 750 gt 700, and chose approved."
80
+ ```
81
+
30
82
  ### Builder
31
83
 
32
84
  ```typescript
33
85
  import { flowChart, FlowChartBuilder } from 'footprintjs';
34
86
 
35
- // flowChart(name, fn, id, buildTimeExtractor?, description?)
36
87
  const chart = flowChart('Stage1', fn1, 'stage-1', undefined, 'Description')
37
88
  .addFunction('Stage2', fn2, 'stage-2', 'Description')
38
89
  .addDeciderFunction('Decide', deciderFn, 'decide', 'Route based on risk')
@@ -46,95 +97,60 @@ const chart = flowChart('Stage1', fn1, 'stage-1', undefined, 'Description')
46
97
 
47
98
  Methods: `start()`, `addFunction()`, `addStreamingFunction()`, `addDeciderFunction()`, `addSelectorFunction()`, `addListOfFunction()`, `addSubFlowChart()`, `addSubFlowChartNext()`, `loopTo()`, `setEnableNarrative()`, `setInputSchema()`, `setOutputSchema()`, `setOutputMapper()`, `build()`, `toSpec()`, `toMermaid()`
48
99
 
49
- ### Stage Functions
100
+ ### ScopeFacade (Internal — use TypedScope for new code)
50
101
 
51
102
  ```typescript
52
- type PipelineStageFunction = (
53
- scope: ScopeFacade,
54
- breakPipeline: () => void,
55
- streamCallback?: StreamCallback,
56
- ) => Promise<void> | void;
57
- ```
58
-
59
- ### ScopeFacade
60
-
61
- ```typescript
62
- scope.getValue('key') // tracked read (appears in narrative)
103
+ scope.getValue('key') // tracked read
63
104
  scope.setValue('key', value) // tracked write
64
- scope.updateValue('key', partial) // deep merge
65
- scope.deleteValue('key') // tracked delete
66
105
  scope.getArgs<T>() // frozen readonly input (NOT tracked)
67
106
  scope.getEnv() // frozen execution environment (NOT tracked)
68
- scope.attachRecorder(recorder) // plug observer
69
107
  ```
70
108
 
71
109
  **Three access tiers:**
72
110
  - `getValue`/`setValue` — mutable shared state, tracked in narrative
73
111
  - `getArgs()` — frozen business input from `run({ input })`, NOT tracked
74
- - `getEnv()` — frozen infrastructure context from `run({ env })`, NOT tracked. Returns `ExecutionEnv { signal?, timeoutMs?, traceId? }`. Auto-inherited by subflows. Closed type — not extensible.
112
+ - `getEnv()` — frozen infrastructure context from `run({ env })`, NOT tracked. Returns `ExecutionEnv { signal?, timeoutMs?, traceId? }`. Auto-inherited by subflows. Closed type.
75
113
 
76
114
  ### Executor
77
115
 
78
116
  ```typescript
79
- const executor = new FlowChartExecutor(chart);
80
- await executor.run({
81
- input: data,
82
- timeoutMs: 5000,
83
- signal: abortSignal,
84
- env: { traceId: 'req-123', signal: abortSignal, timeoutMs: 5000 },
85
- });
86
-
87
- executor.attachRecorder(recorder) // plug scope observer (one-liner, no scopeFactory needed)
88
- executor.getNarrative() // combined flow + data narrative
89
- executor.getNarrativeEntries() // structured entries with type/depth/stageName/stageId
90
- executor.getFlowNarrative() // flow-only (no data ops)
91
- executor.getSnapshot() // full memory state (includes recorder snapshots)
92
- executor.attachFlowRecorder(r) // plug flow observer
93
- executor.setRedactionPolicy({}) // PII protection
117
+ const executor = new FlowChartExecutor(chart, createTypedScopeFactory<State>());
118
+ await executor.run({ input: data, env: { traceId: 'req-123' } });
119
+
120
+ executor.attachRecorder(recorder) // plug scope observer
121
+ executor.getNarrative() // combined flow + data narrative
122
+ executor.getNarrativeEntries() // structured entries with type/depth/stageName/stageId
123
+ executor.getFlowNarrative() // flow-only (no data ops)
124
+ executor.getSnapshot() // full memory state (includes recorder snapshots)
125
+ executor.attachFlowRecorder(r) // plug flow observer
126
+ executor.setRedactionPolicy({}) // PII protection
94
127
  ```
95
128
 
96
129
  ### ComposableRunner & Snapshot Navigation
97
130
 
98
131
  ```typescript
99
132
  import type { ComposableRunner } from 'footprintjs';
100
- import { getSubtreeSnapshot } from 'footprintjs';
101
-
102
- // Interface for runners that expose their internal flowChart
103
- interface ComposableRunner<TIn, TOut> {
104
- toFlowChart(): FlowChart;
105
- run(input: TIn, options?: RunOptions): Promise<TOut>;
106
- }
133
+ import { getSubtreeSnapshot, listSubflowPaths } from 'footprintjs';
107
134
 
108
- // Drill into subflow subtrees by path
109
135
  const subtree = getSubtreeSnapshot(snapshot, 'sf-payment');
110
- const nested = getSubtreeSnapshot(snapshot, 'sf-outer/sf-inner');
111
- // Returns { subflowId, executionTree, sharedState, narrativeEntries } or undefined
112
-
113
- // Pass narrative entries for scoped narrative
114
- const subtreeWithNarrative = getSubtreeSnapshot(snapshot, 'sf-payment', executor.getNarrativeEntries());
115
-
116
- // Discover available drill-down targets
117
- import { listSubflowPaths } from 'footprintjs';
118
136
  listSubflowPaths(snapshot); // ['sf-payment', 'sf-outer/sf-inner']
119
137
  ```
120
138
 
121
139
  ## Two Observer Systems
122
140
 
123
- Both use `{ id, hooks } dispatcher error isolation attach/detach`. Intentionally NOT unified.
141
+ Both use `{ id, hooks } -> dispatcher -> error isolation -> attach/detach`. Intentionally NOT unified.
124
142
 
125
143
  **Scope Recorder** (data ops — fires DURING stage execution):
126
144
  - `onRead`, `onWrite`, `onCommit`, `onError`, `onStageStart`, `onStageEnd`
127
- - Built-in: `NarrativeRecorder`, `MetricRecorder`, `DebugRecorder`
145
+ - Built-in: `MetricRecorder`, `DebugRecorder`
128
146
 
129
147
  **FlowRecorder** (control flow — fires AFTER stage execution):
130
148
  - `onStageExecuted`, `onNext`, `onDecision`, `onFork`, `onSelected`, `onSubflowEntry/Exit`, `onLoop`, `onBreak`, `onError`
131
- - All events carry `traversalContext: TraversalContext` (stageId, stageName, parentStageId, subflowId, subflowPath, depth, loopIteration, forkBranch)
132
- - Optional `toSnapshot(): { name, data }` expose collected data for inclusion in `getSnapshot().recorders`
149
+ - All events carry `traversalContext: TraversalContext`
150
+ - `onDecision`/`onSelected` carry optional `evidence` from decide()/select()
133
151
  - Built-in: 8 strategies (Narrative, Adaptive, Windowed, RLE, Milestone, Progressive, Separate, Manifest, Silent)
134
- - All event types exported: `FlowStageEvent`, `FlowNextEvent`, `FlowDecisionEvent`, `FlowForkEvent`, `FlowSelectedEvent`, `FlowSubflowEvent`, `FlowSubflowRegisteredEvent`, `FlowLoopEvent`, `FlowBreakEvent`, `FlowErrorEvent`, `TraversalContext`
135
152
 
136
153
  **CombinedNarrativeRecorder** implements BOTH interfaces. Auto-attached by `setEnableNarrative()`.
137
- - All `CombinedNarrativeEntry` objects carry `stageId?: string` for UI sync (matches spec node id).
138
154
 
139
155
  ## Event Ordering
140
156
 
@@ -150,10 +166,12 @@ Both use `{ id, hooks } → dispatcher → error isolation → attach/detach`. I
150
166
  ## Anti-Patterns
151
167
 
152
168
  - Never post-process the tree — use recorders
153
- - Never use deprecated `CombinedNarrativeBuilder` — use `CombinedNarrativeRecorder`
169
+ - Don't use `getValue()`/`setValue()` in TypedScope stages — use typed property access
170
+ - Don't use `$`-prefixed state keys (e.g., `$break`) — they collide with ScopeMethods
171
+ - Don't use deprecated `CombinedNarrativeBuilder` — use `CombinedNarrativeRecorder`
154
172
  - Don't extract shared base for Recorder/FlowRecorder — two instances = coincidence
155
- - Don't use `getArgs()` for tracked data — use `getValue()`/`setValue()`
156
- - Don't put infrastructure data (signal, traceId) in `getArgs()` — use `getEnv()` via `run({ env })`
173
+ - Don't use `getArgs()` for tracked data — use typed scope properties
174
+ - Don't put infrastructure data in `getArgs()` — use `getEnv()` via `run({ env })`
157
175
  - Don't manually create `CombinedNarrativeRecorder` — `setEnableNarrative()` handles it
158
176
 
159
177
  ## Build & Test
package/README.md CHANGED
@@ -12,6 +12,7 @@
12
12
  <a href="https://www.npmjs.com/package/footprintjs"><img src="https://img.shields.io/npm/dm/footprintjs.svg" alt="Downloads"></a>
13
13
  <a href="https://footprintjs.github.io/footprint-demo/"><img src="https://img.shields.io/badge/Live_Demo-View_App-10b981?style=flat&logo=data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0IiBmaWxsPSJ3aGl0ZSI+PHBhdGggZD0iTTggNXYxNGwxMS03eiIvPjwvc3ZnPg==" alt="Live Demo"></a>
14
14
  <a href="https://footprintjs.github.io/footprint-playground/"><img src="https://img.shields.io/badge/Playground-Try_it-6366f1?style=flat&logo=data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0IiBmaWxsPSJ3aGl0ZSI+PHBhdGggZD0iTTggNXYxNGwxMS03eiIvPjwvc3ZnPg==" alt="Interactive Playground"></a>
15
+ <a href="https://footprintjs.github.io/footPrint/"><img src="https://img.shields.io/badge/API_Docs-TypeDoc-3178c6?style=flat&logo=typescript&logoColor=white" alt="API Docs"></a>
15
16
  </p>
16
17
 
17
18
  <br>
@@ -49,19 +50,16 @@ The runtime auto-generates this trace from what the code actually did:
49
50
 
50
51
  ```
51
52
  Stage 1: The process began with ReceiveApplication.
52
- Step 1: Write app = {applicantName, annualIncome, monthlyDebts, creditScore, ...}
53
- Stage 2: Next, it moved on to PullCreditReport.
54
- Step 1: Read app = {applicantName, annualIncome, monthlyDebts, creditScore, ...}
55
- Step 2: Write creditTier = "fair"
56
- Stage 3: Next, it moved on to CalculateDTI.
57
- Step 1: Read app = {applicantName, annualIncome, monthlyDebts, creditScore, ...}
58
- Step 2: Write dtiRatio = 0.6
59
- Step 3: Write dtiStatus = "excessive"
60
- Stage 4: Next, it moved on to AssessRisk.
61
- Step 1: Read creditTier = "fair"
62
- Step 2: Read dtiStatus = "excessive"
63
- Step 3: Write riskTier = "high"
64
- [Condition]: A decision was made, and the path taken was RejectApplication.
53
+ Step 1: Write creditScore = 580, dti = 0.6, employmentStatus = "self-employed"
54
+ Stage 2: Next step: Evaluate risk tier from all flags.
55
+ Step 1: Read creditScore = 580
56
+ Step 2: Write riskTier = "high"
57
+ Step 3: Write riskFactors = (3 items)
58
+ Stage 3: Next step: Route based on risk tier.
59
+ Step 1: Read riskTier = "high"
60
+ [Condition]: It evaluated "High risk": riskTier "high" eq "high" ✓, and chose RejectApplication.
61
+ Stage 4: Next step: Generate rejection.
62
+ Step 1: Write decision = "REJECTED — below-average credit; DTI exceeds 43%; Self-employed < 2yr"
65
63
  ```
66
64
 
67
65
  The LLM backtracks: `riskTier="high"` &larr; `dtiStatus="excessive"` &larr; `dtiRatio=0.6` &larr; `app.monthlyDebts=2100`. Every variable links to its cause:
@@ -75,40 +73,49 @@ That answer came from the trace &mdash; not from the LLM's imagination.
75
73
  ## Quick Start
76
74
 
77
75
  ```typescript
78
- import { flowChart, FlowChartExecutor, ScopeFacade } from 'footprintjs';
76
+ import { typedFlowChart, createTypedScopeFactory, FlowChartExecutor, decide } from 'footprintjs';
79
77
 
80
- const chart = flowChart('FetchUser', (scope: ScopeFacade) => {
81
- scope.setValue('user', { name: 'Alice', tier: 'premium' });
78
+ interface State {
79
+ user: { name: string; tier: string };
80
+ discount: number;
81
+ lane: string;
82
+ }
83
+
84
+ const chart = typedFlowChart<State>('FetchUser', async (scope) => {
85
+ scope.user = { name: 'Alice', tier: 'premium' };
82
86
  }, 'fetch-user')
83
- .addFunction('ApplyDiscount', (scope: ScopeFacade) => {
84
- const user = scope.getValue('user') as any;
85
- const discount = user.tier === 'premium' ? 0.2 : 0.05;
86
- scope.setValue('discount', discount);
87
+ .addFunction('ApplyDiscount', async (scope) => {
88
+ scope.discount = scope.user.tier === 'premium' ? 0.2 : 0.05;
87
89
  }, 'apply-discount')
88
- .addDeciderFunction('Route', (scope: ScopeFacade): string => {
89
- return (scope.getValue('discount') as number) > 0.1 ? 'vip' : 'standard';
90
- }, 'route')
91
- .addFunctionBranch('vip', 'VIPCheckout', (scope: ScopeFacade) => {
92
- scope.setValue('lane', 'VIP express');
90
+ .addDeciderFunction('Route', (scope) => {
91
+ return decide(scope, [
92
+ { when: { discount: { gt: 0.1 } }, then: 'vip', label: 'High discount' },
93
+ ], 'standard');
94
+ }, 'route', 'Route by discount tier')
95
+ .addFunctionBranch('vip', 'VIPCheckout', async (scope) => {
96
+ scope.lane = 'VIP express';
93
97
  })
94
- .addFunctionBranch('standard', 'StandardCheckout', (scope: ScopeFacade) => {
95
- scope.setValue('lane', 'Standard');
98
+ .addFunctionBranch('standard', 'StandardCheckout', async (scope) => {
99
+ scope.lane = 'Standard';
96
100
  })
97
101
  .setDefault('standard')
98
102
  .end()
99
103
  .setEnableNarrative()
100
104
  .build();
101
105
 
102
- const executor = new FlowChartExecutor(chart);
106
+ const executor = new FlowChartExecutor(chart, createTypedScopeFactory<State>());
103
107
  await executor.run();
104
108
 
105
109
  console.log(executor.getNarrative());
106
110
  // Stage 1: The process began with FetchUser.
107
- // Step 1: Write user = {name: "Alice", tier: "premium"}
111
+ // Step 1: Write user = {name, tier}
108
112
  // Stage 2: Next, it moved on to ApplyDiscount.
109
- // Step 1: Read user = {name: "Alice", tier: "premium"}
113
+ // Step 1: Read user = {name, tier}
110
114
  // Step 2: Write discount = 0.2
111
- // Stage 3: A decision was made, and the path taken was VIPCheckout.
115
+ // Stage 3: Next step: Route by discount tier.
116
+ // Step 1: Read discount = 0.2
117
+ // [Condition]: It evaluated "High discount": discount 0.2 gt 0.1 ✓, and chose VIPCheckout.
118
+ // Stage 4: Next, it moved on to VIPCheckout.
112
119
  // Step 1: Write lane = "VIP express"
113
120
  ```
114
121
 
@@ -123,6 +130,8 @@ console.log(executor.getNarrative());
123
130
  | Feature | Description |
124
131
  |---------|-------------|
125
132
  | **Causal Traces** | Every read/write captured &mdash; LLMs backtrack through variables to find causes |
133
+ | **Decision Evidence** | `decide()` / `select()` auto-capture WHY a branch was chosen &mdash; operators, thresholds, pass/fail |
134
+ | **TypedScope&lt;T&gt;** | Typed property access &mdash; `scope.creditScore = 750` instead of `scope.setValue('creditScore', 750)` |
126
135
  | **Auto Narrative** | Build-time descriptions for tool selection, runtime traces for explanation |
127
136
  | **7 Patterns** | Linear, parallel fork, conditional, multi-select, subflow, streaming, loops &mdash; [guide](docs/guides/patterns.md) |
128
137
  | **Transactional State** | Atomic commits, safe merges, time-travel replay &mdash; [guide](docs/guides/scope.md) |
@@ -158,7 +167,7 @@ npx footprintjs-setup
158
167
  | Resource | Link |
159
168
  |----------|------|
160
169
  | **Guides** | [Patterns](docs/guides/patterns.md) &middot; [Scope](docs/guides/scope.md) &middot; [Execution](docs/guides/execution.md) &middot; [Errors](docs/guides/error-handling.md) &middot; [Flow Recorders](docs/guides/flow-recorders.md) &middot; [Contracts](docs/guides/contracts.md) |
161
- | **Reference** | [API Reference](docs/guides/api-reference.md) &middot; [Performance Benchmarks](docs/guides/performance.md) |
170
+ | **Reference** | [API Docs](https://footprintjs.github.io/footPrint/) &middot; [API Reference](docs/guides/api-reference.md) &middot; [Performance Benchmarks](docs/guides/performance.md) |
162
171
  | **Architecture** | [Internals](docs/internals/) &mdash; six independent libraries, each with its own README |
163
172
  | **Try it** | [Interactive Playground](https://footprintjs.github.io/footprint-playground/) &middot; [Live Demo](https://footprintjs.github.io/footprint-demo/) &middot; [25+ Examples](https://github.com/footprintjs/footPrint-samples) |
164
173
 
package/dist/advanced.js CHANGED
@@ -8,8 +8,8 @@
8
8
  * Import via: import { ... } from 'footprint/advanced'
9
9
  */
10
10
  Object.defineProperty(exports, "__esModule", { value: true });
11
- exports.RuntimeStructureManager = exports.NodeResolver = exports.getInitialScopeValues = exports.extractParentScopeValues = exports.ExtractorRunner = exports.DEFAULT_MAX_ITERATIONS = exports.DeciderHandler = exports.createSubflowHandlerDeps = exports.ContinuationResolver = exports.computeNodeType = exports.ChildrenExecutor = exports.applyOutputMapping = exports.NullControlFlowNarrativeGenerator = exports.ControlFlowNarrativeGenerator = exports.isStageNodeReturn = exports.FlowchartTraverser = exports.ExecutionRuntime = exports.ZodScopeResolver = exports.isScopeSchema = exports.defineScopeSchema = exports.createScopeProxyFromZod = exports.toScopeFactory = exports.resolveScopeProvider = exports.registerScopeResolver = exports.makeFactoryProvider = exports.makeClassProvider = exports.looksLikeFactory = exports.looksLikeClassCtor = exports.isSubclassOfScopeFacade = exports.attachScopeMethods = exports.attachBaseStateCompat = exports.createProtectedScope = exports.createErrorMessage = exports.specToStageNode = exports.SelectorFnList = exports.DeciderList = exports.updateValue = exports.updateNestedValue = exports.setNestedValue = exports.redactPatch = exports.normalisePath = exports.getRunAndGlobalPaths = exports.getNestedValue = exports.deepSmartMerge = exports.applySmartMerge = exports.DiagnosticCollector = exports.TransactionBuffer = exports.EventLog = exports.StageContext = exports.SharedMemory = void 0;
12
- exports.SubflowExecutor = exports.StageRunner = exports.SelectorHandler = exports.seedSubflowGlobalStore = void 0;
11
+ exports.DEFAULT_MAX_ITERATIONS = exports.DeciderHandler = exports.createSubflowHandlerDeps = exports.ContinuationResolver = exports.computeNodeType = exports.ChildrenExecutor = exports.applyOutputMapping = exports.NullControlFlowNarrativeGenerator = exports.ControlFlowNarrativeGenerator = exports.isStageNodeReturn = exports.FlowchartTraverser = exports.shouldWrapWithProxy = exports.SCOPE_METHOD_NAMES = exports.joinPath = exports.createArrayProxy = exports.buildNestedPatch = exports.BREAK_SETTER = exports.ExecutionRuntime = exports.ZodScopeResolver = exports.isScopeSchema = exports.defineScopeSchema = exports.createScopeProxyFromZod = exports.toScopeFactory = exports.resolveScopeProvider = exports.registerScopeResolver = exports.makeFactoryProvider = exports.makeClassProvider = exports.looksLikeFactory = exports.looksLikeClassCtor = exports.isSubclassOfScopeFacade = exports.attachScopeMethods = exports.createProtectedScope = exports.createErrorMessage = exports.specToStageNode = exports.SelectorFnList = exports.DeciderList = exports.updateValue = exports.updateNestedValue = exports.setNestedValue = exports.redactPatch = exports.normalisePath = exports.getRunAndGlobalPaths = exports.getNestedValue = exports.deepSmartMerge = exports.applySmartMerge = exports.DiagnosticCollector = exports.TransactionBuffer = exports.EventLog = exports.StageContext = exports.SharedMemory = void 0;
12
+ exports.SubflowExecutor = exports.StageRunner = exports.SelectorHandler = exports.seedSubflowGlobalStore = exports.RuntimeStructureManager = exports.NodeResolver = exports.getInitialScopeValues = exports.extractParentScopeValues = exports.ExtractorRunner = void 0;
13
13
  var index_js_1 = require("./lib/memory/index.js");
14
14
  Object.defineProperty(exports, "SharedMemory", { enumerable: true, get: function () { return index_js_1.SharedMemory; } });
15
15
  var index_js_2 = require("./lib/memory/index.js");
@@ -38,7 +38,6 @@ var index_js_8 = require("./lib/scope/index.js");
38
38
  Object.defineProperty(exports, "createErrorMessage", { enumerable: true, get: function () { return index_js_8.createErrorMessage; } });
39
39
  Object.defineProperty(exports, "createProtectedScope", { enumerable: true, get: function () { return index_js_8.createProtectedScope; } });
40
40
  var index_js_9 = require("./lib/scope/index.js");
41
- Object.defineProperty(exports, "attachBaseStateCompat", { enumerable: true, get: function () { return index_js_9.attachBaseStateCompat; } });
42
41
  Object.defineProperty(exports, "attachScopeMethods", { enumerable: true, get: function () { return index_js_9.attachScopeMethods; } });
43
42
  Object.defineProperty(exports, "isSubclassOfScopeFacade", { enumerable: true, get: function () { return index_js_9.isSubclassOfScopeFacade; } });
44
43
  Object.defineProperty(exports, "looksLikeClassCtor", { enumerable: true, get: function () { return index_js_9.looksLikeClassCtor; } });
@@ -56,29 +55,36 @@ Object.defineProperty(exports, "isScopeSchema", { enumerable: true, get: functio
56
55
  Object.defineProperty(exports, "ZodScopeResolver", { enumerable: true, get: function () { return index_js_10.ZodScopeResolver; } });
57
56
  var index_js_11 = require("./lib/runner/index.js");
58
57
  Object.defineProperty(exports, "ExecutionRuntime", { enumerable: true, get: function () { return index_js_11.ExecutionRuntime; } });
59
- var index_js_12 = require("./lib/engine/index.js");
60
- Object.defineProperty(exports, "FlowchartTraverser", { enumerable: true, get: function () { return index_js_12.FlowchartTraverser; } });
58
+ var index_js_12 = require("./lib/reactive/index.js");
59
+ Object.defineProperty(exports, "BREAK_SETTER", { enumerable: true, get: function () { return index_js_12.BREAK_SETTER; } });
60
+ Object.defineProperty(exports, "buildNestedPatch", { enumerable: true, get: function () { return index_js_12.buildNestedPatch; } });
61
+ Object.defineProperty(exports, "createArrayProxy", { enumerable: true, get: function () { return index_js_12.createArrayProxy; } });
62
+ Object.defineProperty(exports, "joinPath", { enumerable: true, get: function () { return index_js_12.joinPath; } });
63
+ Object.defineProperty(exports, "SCOPE_METHOD_NAMES", { enumerable: true, get: function () { return index_js_12.SCOPE_METHOD_NAMES; } });
64
+ Object.defineProperty(exports, "shouldWrapWithProxy", { enumerable: true, get: function () { return index_js_12.shouldWrapWithProxy; } });
61
65
  var index_js_13 = require("./lib/engine/index.js");
62
- Object.defineProperty(exports, "isStageNodeReturn", { enumerable: true, get: function () { return index_js_13.isStageNodeReturn; } });
66
+ Object.defineProperty(exports, "FlowchartTraverser", { enumerable: true, get: function () { return index_js_13.FlowchartTraverser; } });
63
67
  var index_js_14 = require("./lib/engine/index.js");
64
- Object.defineProperty(exports, "ControlFlowNarrativeGenerator", { enumerable: true, get: function () { return index_js_14.ControlFlowNarrativeGenerator; } });
68
+ Object.defineProperty(exports, "isStageNodeReturn", { enumerable: true, get: function () { return index_js_14.isStageNodeReturn; } });
65
69
  var index_js_15 = require("./lib/engine/index.js");
66
- Object.defineProperty(exports, "NullControlFlowNarrativeGenerator", { enumerable: true, get: function () { return index_js_15.NullControlFlowNarrativeGenerator; } });
70
+ Object.defineProperty(exports, "ControlFlowNarrativeGenerator", { enumerable: true, get: function () { return index_js_15.ControlFlowNarrativeGenerator; } });
67
71
  var index_js_16 = require("./lib/engine/index.js");
68
- Object.defineProperty(exports, "applyOutputMapping", { enumerable: true, get: function () { return index_js_16.applyOutputMapping; } });
69
- Object.defineProperty(exports, "ChildrenExecutor", { enumerable: true, get: function () { return index_js_16.ChildrenExecutor; } });
70
- Object.defineProperty(exports, "computeNodeType", { enumerable: true, get: function () { return index_js_16.computeNodeType; } });
71
- Object.defineProperty(exports, "ContinuationResolver", { enumerable: true, get: function () { return index_js_16.ContinuationResolver; } });
72
- Object.defineProperty(exports, "createSubflowHandlerDeps", { enumerable: true, get: function () { return index_js_16.createSubflowHandlerDeps; } });
73
- Object.defineProperty(exports, "DeciderHandler", { enumerable: true, get: function () { return index_js_16.DeciderHandler; } });
74
- Object.defineProperty(exports, "DEFAULT_MAX_ITERATIONS", { enumerable: true, get: function () { return index_js_16.DEFAULT_MAX_ITERATIONS; } });
75
- Object.defineProperty(exports, "ExtractorRunner", { enumerable: true, get: function () { return index_js_16.ExtractorRunner; } });
76
- Object.defineProperty(exports, "extractParentScopeValues", { enumerable: true, get: function () { return index_js_16.extractParentScopeValues; } });
77
- Object.defineProperty(exports, "getInitialScopeValues", { enumerable: true, get: function () { return index_js_16.getInitialScopeValues; } });
78
- Object.defineProperty(exports, "NodeResolver", { enumerable: true, get: function () { return index_js_16.NodeResolver; } });
79
- Object.defineProperty(exports, "RuntimeStructureManager", { enumerable: true, get: function () { return index_js_16.RuntimeStructureManager; } });
80
- Object.defineProperty(exports, "seedSubflowGlobalStore", { enumerable: true, get: function () { return index_js_16.seedSubflowGlobalStore; } });
81
- Object.defineProperty(exports, "SelectorHandler", { enumerable: true, get: function () { return index_js_16.SelectorHandler; } });
82
- Object.defineProperty(exports, "StageRunner", { enumerable: true, get: function () { return index_js_16.StageRunner; } });
83
- Object.defineProperty(exports, "SubflowExecutor", { enumerable: true, get: function () { return index_js_16.SubflowExecutor; } });
84
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"advanced.js","sourceRoot":"","sources":["../src/advanced.ts"],"names":[],"mappings":";AAAA;;;;;;;GAOG;;;;AAeH,kDAAqD;AAA5C,wGAAA,YAAY,OAAA;AACrB,kDAAqD;AAA5C,wGAAA,YAAY,OAAA;AACrB,kDAAiD;AAAxC,oGAAA,QAAQ,OAAA;AACjB,kDAA0D;AAAjD,6GAAA,iBAAiB,OAAA;AAC1B,kDAA4D;AAAnD,+GAAA,mBAAmB,OAAA;AAC5B,kDAU+B;AAT7B,2GAAA,eAAe,OAAA;AACf,0GAAA,cAAc,OAAA;AACd,0GAAA,cAAc,OAAA;AACd,gHAAA,oBAAoB,OAAA;AACpB,yGAAA,aAAa,OAAA;AACb,uGAAA,WAAW,OAAA;AACX,0GAAA,cAAc,OAAA;AACd,6GAAA,iBAAiB,OAAA;AACjB,uGAAA,WAAW,OAAA;AAyBb,mDAAsF;AAA7E,uGAAA,WAAW,OAAA;AAAE,0GAAA,cAAc,OAAA;AAAE,2GAAA,eAAe,OAAA;AAarD,iDAAgF;AAAvE,8GAAA,kBAAkB,OAAA;AAAE,gHAAA,oBAAoB,OAAA;AACjD,iDAW8B;AAV5B,iHAAA,qBAAqB,OAAA;AACrB,8GAAA,kBAAkB,OAAA;AAClB,mHAAA,uBAAuB,OAAA;AACvB,8GAAA,kBAAkB,OAAA;AAClB,4GAAA,gBAAgB,OAAA;AAChB,6GAAA,iBAAiB,OAAA;AACjB,+GAAA,mBAAmB,OAAA;AACnB,iHAAA,qBAAqB,OAAA;AACrB,gHAAA,oBAAoB,OAAA;AACpB,0GAAA,cAAc,OAAA;AAmBhB,gBAAgB;AAChB,kDAAmH;AAA1G,oHAAA,uBAAuB,OAAA;AAAE,8GAAA,iBAAiB,OAAA;AAAE,0GAAA,aAAa,OAAA;AAAE,6GAAA,gBAAgB,OAAA;AAOpF,mDAAyD;AAAhD,6GAAA,gBAAgB,OAAA;AAQzB,mDAA2D;AAAlD,+GAAA,kBAAkB,OAAA;AAC3B,mDAA0D;AAAjD,8GAAA,iBAAiB,OAAA;AAqB1B,mDAAsE;AAA7D,0HAAA,6BAA6B,OAAA;AACtC,mDAA0E;AAAjE,8HAAA,iCAAiC,OAAA;AAI1C,mDAiB+B;AAhB7B,+GAAA,kBAAkB,OAAA;AAClB,6GAAA,gBAAgB,OAAA;AAChB,4GAAA,eAAe,OAAA;AACf,iHAAA,oBAAoB,OAAA;AACpB,qHAAA,wBAAwB,OAAA;AACxB,2GAAA,cAAc,OAAA;AACd,mHAAA,sBAAsB,OAAA;AACtB,4GAAA,eAAe,OAAA;AACf,qHAAA,wBAAwB,OAAA;AACxB,kHAAA,qBAAqB,OAAA;AACrB,yGAAA,YAAY,OAAA;AACZ,oHAAA,uBAAuB,OAAA;AACvB,mHAAA,sBAAsB,OAAA;AACtB,4GAAA,eAAe,OAAA;AACf,wGAAA,WAAW,OAAA;AACX,4GAAA,eAAe,OAAA","sourcesContent":["/**\n * FootPrint — Advanced / Internal API\n *\n * These exports are for advanced use cases, testing, and building\n * custom execution engines. Most users should use the main 'footprint' entry point.\n *\n * Import via: import { ... } from 'footprint/advanced'\n */\n\n// ============================================================================\n// Memory — Low-level transactional state primitives\n// ============================================================================\n\nexport type {\n  CommitBundle,\n  FlowControlType,\n  FlowMessage,\n  MemoryPatch,\n  ScopeFactory,\n  StageSnapshot,\n  TraceEntry,\n} from './lib/memory/index.js';\nexport { SharedMemory } from './lib/memory/index.js';\nexport { StageContext } from './lib/memory/index.js';\nexport { EventLog } from './lib/memory/index.js';\nexport { TransactionBuffer } from './lib/memory/index.js';\nexport { DiagnosticCollector } from './lib/memory/index.js';\nexport {\n  applySmartMerge,\n  deepSmartMerge,\n  getNestedValue,\n  getRunAndGlobalPaths,\n  normalisePath,\n  redactPatch,\n  setNestedValue,\n  updateNestedValue,\n  updateValue,\n} from './lib/memory/index.js';\n\n// ============================================================================\n// Builder — Types and internals\n// ============================================================================\n\nexport type {\n  BuildTimeExtractor,\n  BuildTimeNodeMetadata,\n  ExecOptions,\n  FlowChartSpec,\n  ILogger,\n  PipelineStageFunction,\n  ScopeProtectionMode,\n  SerializedPipelineStructure,\n  SimplifiedParallelSpec,\n  StageFn,\n  StageNode,\n  StreamCallback,\n  StreamLifecycleHandler,\n  StreamTokenHandler,\n  SubflowMountOptions,\n  SubflowRef,\n} from './lib/builder/index.js';\nexport { DeciderList, SelectorFnList, specToStageNode } from './lib/builder/index.js';\n\n// ============================================================================\n// Scope — Providers, protection, recorder options, and event types\n// ============================================================================\n\nexport type {\n  ProviderResolver,\n  ResolveOptions,\n  ScopeProvider,\n  StageContextLike,\n  StrictMode,\n} from './lib/scope/index.js';\nexport { createErrorMessage, createProtectedScope } from './lib/scope/index.js';\nexport {\n  attachBaseStateCompat,\n  attachScopeMethods,\n  isSubclassOfScopeFacade,\n  looksLikeClassCtor,\n  looksLikeFactory,\n  makeClassProvider,\n  makeFactoryProvider,\n  registerScopeResolver,\n  resolveScopeProvider,\n  toScopeFactory,\n} from './lib/scope/index.js';\n\n// Recorder config/option types\nexport type {\n  AggregatedMetrics,\n  DebugEntry,\n  DebugRecorderOptions,\n  DebugVerbosity,\n  DefineScopeOptions,\n  NarrativeDetail,\n  NarrativeOperation,\n  NarrativeRecorderOptions,\n  RecorderContext,\n  StageEvent,\n  StageMetrics,\n  StageNarrativeData,\n} from './lib/scope/index.js';\n\n// Zod internals\nexport { createScopeProxyFromZod, defineScopeSchema, isScopeSchema, ZodScopeResolver } from './lib/scope/index.js';\n\n// ============================================================================\n// Runner — Internals\n// ============================================================================\n\nexport type { NarrativeEntry, RuntimeSnapshot } from './lib/runner/index.js';\nexport { ExecutionRuntime } from './lib/runner/index.js';\n\n// ============================================================================\n// Engine — DFS graph traversal internals\n// ============================================================================\n\nexport type { TraverserOptions } from './lib/engine/index.js';\nexport type { Decider } from './lib/engine/index.js';\nexport { FlowchartTraverser } from './lib/engine/index.js';\nexport { isStageNodeReturn } from './lib/engine/index.js';\n\n// Narrative internals\nexport type { IControlFlowNarrative } from './lib/engine/index.js';\nexport type { CombinedNarrativeEntry, CombinedNarrativeOptions } from './lib/engine/index.js';\nexport type {\n  BranchResult,\n  BranchResults,\n  SerializedPipelineStructure as EngineSerializedPipelineStructure,\n  StageSnapshot as EngineStageSnapshot,\n  ExtractorError,\n  HandlerDeps,\n  IExecutionRuntime,\n  NodeResultType,\n  RuntimeStructureMetadata,\n  SerializedPipelineNode,\n  StageFunction,\n  SubflowResult,\n  TraversalExtractor,\n  TraversalResult,\n} from './lib/engine/index.js';\nexport { ControlFlowNarrativeGenerator } from './lib/engine/index.js';\nexport { NullControlFlowNarrativeGenerator } from './lib/engine/index.js';\n\n// Handlers (testing / custom engines)\nexport type { CallExtractorFn, ExecuteNodeFn, GetStagePathFn, RunStageFn } from './lib/engine/index.js';\nexport {\n  applyOutputMapping,\n  ChildrenExecutor,\n  computeNodeType,\n  ContinuationResolver,\n  createSubflowHandlerDeps,\n  DeciderHandler,\n  DEFAULT_MAX_ITERATIONS,\n  ExtractorRunner,\n  extractParentScopeValues,\n  getInitialScopeValues,\n  NodeResolver,\n  RuntimeStructureManager,\n  seedSubflowGlobalStore,\n  SelectorHandler,\n  StageRunner,\n  SubflowExecutor,\n} from './lib/engine/index.js';\n"]}
72
+ Object.defineProperty(exports, "NullControlFlowNarrativeGenerator", { enumerable: true, get: function () { return index_js_16.NullControlFlowNarrativeGenerator; } });
73
+ var index_js_17 = require("./lib/engine/index.js");
74
+ Object.defineProperty(exports, "applyOutputMapping", { enumerable: true, get: function () { return index_js_17.applyOutputMapping; } });
75
+ Object.defineProperty(exports, "ChildrenExecutor", { enumerable: true, get: function () { return index_js_17.ChildrenExecutor; } });
76
+ Object.defineProperty(exports, "computeNodeType", { enumerable: true, get: function () { return index_js_17.computeNodeType; } });
77
+ Object.defineProperty(exports, "ContinuationResolver", { enumerable: true, get: function () { return index_js_17.ContinuationResolver; } });
78
+ Object.defineProperty(exports, "createSubflowHandlerDeps", { enumerable: true, get: function () { return index_js_17.createSubflowHandlerDeps; } });
79
+ Object.defineProperty(exports, "DeciderHandler", { enumerable: true, get: function () { return index_js_17.DeciderHandler; } });
80
+ Object.defineProperty(exports, "DEFAULT_MAX_ITERATIONS", { enumerable: true, get: function () { return index_js_17.DEFAULT_MAX_ITERATIONS; } });
81
+ Object.defineProperty(exports, "ExtractorRunner", { enumerable: true, get: function () { return index_js_17.ExtractorRunner; } });
82
+ Object.defineProperty(exports, "extractParentScopeValues", { enumerable: true, get: function () { return index_js_17.extractParentScopeValues; } });
83
+ Object.defineProperty(exports, "getInitialScopeValues", { enumerable: true, get: function () { return index_js_17.getInitialScopeValues; } });
84
+ Object.defineProperty(exports, "NodeResolver", { enumerable: true, get: function () { return index_js_17.NodeResolver; } });
85
+ Object.defineProperty(exports, "RuntimeStructureManager", { enumerable: true, get: function () { return index_js_17.RuntimeStructureManager; } });
86
+ Object.defineProperty(exports, "seedSubflowGlobalStore", { enumerable: true, get: function () { return index_js_17.seedSubflowGlobalStore; } });
87
+ Object.defineProperty(exports, "SelectorHandler", { enumerable: true, get: function () { return index_js_17.SelectorHandler; } });
88
+ Object.defineProperty(exports, "StageRunner", { enumerable: true, get: function () { return index_js_17.StageRunner; } });
89
+ Object.defineProperty(exports, "SubflowExecutor", { enumerable: true, get: function () { return index_js_17.SubflowExecutor; } });
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"advanced.js","sourceRoot":"","sources":["../src/advanced.ts"],"names":[],"mappings":";AAAA;;;;;;;GAOG;;;;AAeH,kDAAqD;AAA5C,wGAAA,YAAY,OAAA;AACrB,kDAAqD;AAA5C,wGAAA,YAAY,OAAA;AACrB,kDAAiD;AAAxC,oGAAA,QAAQ,OAAA;AACjB,kDAA0D;AAAjD,6GAAA,iBAAiB,OAAA;AAC1B,kDAA4D;AAAnD,+GAAA,mBAAmB,OAAA;AAC5B,kDAU+B;AAT7B,2GAAA,eAAe,OAAA;AACf,0GAAA,cAAc,OAAA;AACd,0GAAA,cAAc,OAAA;AACd,gHAAA,oBAAoB,OAAA;AACpB,yGAAA,aAAa,OAAA;AACb,uGAAA,WAAW,OAAA;AACX,0GAAA,cAAc,OAAA;AACd,6GAAA,iBAAiB,OAAA;AACjB,uGAAA,WAAW,OAAA;AAwBb,mDAAsF;AAA7E,uGAAA,WAAW,OAAA;AAAE,0GAAA,cAAc,OAAA;AAAE,2GAAA,eAAe,OAAA;AAarD,iDAAgF;AAAvE,8GAAA,kBAAkB,OAAA;AAAE,gHAAA,oBAAoB,OAAA;AACjD,iDAU8B;AAT5B,8GAAA,kBAAkB,OAAA;AAClB,mHAAA,uBAAuB,OAAA;AACvB,8GAAA,kBAAkB,OAAA;AAClB,4GAAA,gBAAgB,OAAA;AAChB,6GAAA,iBAAiB,OAAA;AACjB,+GAAA,mBAAmB,OAAA;AACnB,iHAAA,qBAAqB,OAAA;AACrB,gHAAA,oBAAoB,OAAA;AACpB,0GAAA,cAAc,OAAA;AAmBhB,gBAAgB;AAChB,kDAAmH;AAA1G,oHAAA,uBAAuB,OAAA;AAAE,8GAAA,iBAAiB,OAAA;AAAE,0GAAA,aAAa,OAAA;AAAE,6GAAA,gBAAgB,OAAA;AAOpF,mDAAyD;AAAhD,6GAAA,gBAAgB,OAAA;AAOzB,qDAOiC;AAN/B,yGAAA,YAAY,OAAA;AACZ,6GAAA,gBAAgB,OAAA;AAChB,6GAAA,gBAAgB,OAAA;AAChB,qGAAA,QAAQ,OAAA;AACR,+GAAA,kBAAkB,OAAA;AAClB,gHAAA,mBAAmB,OAAA;AASrB,mDAA2D;AAAlD,+GAAA,kBAAkB,OAAA;AAC3B,mDAA0D;AAAjD,8GAAA,iBAAiB,OAAA;AAqB1B,mDAAsE;AAA7D,0HAAA,6BAA6B,OAAA;AACtC,mDAA0E;AAAjE,8HAAA,iCAAiC,OAAA;AAI1C,mDAiB+B;AAhB7B,+GAAA,kBAAkB,OAAA;AAClB,6GAAA,gBAAgB,OAAA;AAChB,4GAAA,eAAe,OAAA;AACf,iHAAA,oBAAoB,OAAA;AACpB,qHAAA,wBAAwB,OAAA;AACxB,2GAAA,cAAc,OAAA;AACd,mHAAA,sBAAsB,OAAA;AACtB,4GAAA,eAAe,OAAA;AACf,qHAAA,wBAAwB,OAAA;AACxB,kHAAA,qBAAqB,OAAA;AACrB,yGAAA,YAAY,OAAA;AACZ,oHAAA,uBAAuB,OAAA;AACvB,mHAAA,sBAAsB,OAAA;AACtB,4GAAA,eAAe,OAAA;AACf,wGAAA,WAAW,OAAA;AACX,4GAAA,eAAe,OAAA","sourcesContent":["/**\n * FootPrint — Advanced / Internal API\n *\n * These exports are for advanced use cases, testing, and building\n * custom execution engines. Most users should use the main 'footprint' entry point.\n *\n * Import via: import { ... } from 'footprint/advanced'\n */\n\n// ============================================================================\n// Memory — Low-level transactional state primitives\n// ============================================================================\n\nexport type {\n  CommitBundle,\n  FlowControlType,\n  FlowMessage,\n  MemoryPatch,\n  ScopeFactory,\n  StageSnapshot,\n  TraceEntry,\n} from './lib/memory/index.js';\nexport { SharedMemory } from './lib/memory/index.js';\nexport { StageContext } from './lib/memory/index.js';\nexport { EventLog } from './lib/memory/index.js';\nexport { TransactionBuffer } from './lib/memory/index.js';\nexport { DiagnosticCollector } from './lib/memory/index.js';\nexport {\n  applySmartMerge,\n  deepSmartMerge,\n  getNestedValue,\n  getRunAndGlobalPaths,\n  normalisePath,\n  redactPatch,\n  setNestedValue,\n  updateNestedValue,\n  updateValue,\n} from './lib/memory/index.js';\n\n// ============================================================================\n// Builder — Types and internals\n// ============================================================================\n\nexport type {\n  BuildTimeExtractor,\n  BuildTimeNodeMetadata,\n  ExecOptions,\n  FlowChartSpec,\n  ILogger,\n  ScopeProtectionMode,\n  SerializedPipelineStructure,\n  SimplifiedParallelSpec,\n  StageFn,\n  StageNode,\n  StreamCallback,\n  StreamLifecycleHandler,\n  StreamTokenHandler,\n  SubflowMountOptions,\n  SubflowRef,\n} from './lib/builder/index.js';\nexport { DeciderList, SelectorFnList, specToStageNode } from './lib/builder/index.js';\n\n// ============================================================================\n// Scope — Providers, protection, recorder options, and event types\n// ============================================================================\n\nexport type {\n  ProviderResolver,\n  ResolveOptions,\n  ScopeProvider,\n  StageContextLike,\n  StrictMode,\n} from './lib/scope/index.js';\nexport { createErrorMessage, createProtectedScope } from './lib/scope/index.js';\nexport {\n  attachScopeMethods,\n  isSubclassOfScopeFacade,\n  looksLikeClassCtor,\n  looksLikeFactory,\n  makeClassProvider,\n  makeFactoryProvider,\n  registerScopeResolver,\n  resolveScopeProvider,\n  toScopeFactory,\n} from './lib/scope/index.js';\n\n// Recorder config/option types\nexport type {\n  AggregatedMetrics,\n  DebugEntry,\n  DebugRecorderOptions,\n  DebugVerbosity,\n  DefineScopeOptions,\n  NarrativeDetail,\n  NarrativeOperation,\n  NarrativeRecorderOptions,\n  RecorderContext,\n  StageEvent,\n  StageMetrics,\n  StageNarrativeData,\n} from './lib/scope/index.js';\n\n// Zod internals\nexport { createScopeProxyFromZod, defineScopeSchema, isScopeSchema, ZodScopeResolver } from './lib/scope/index.js';\n\n// ============================================================================\n// Runner — Internals\n// ============================================================================\n\nexport type { NarrativeEntry, RuntimeSnapshot } from './lib/runner/index.js';\nexport { ExecutionRuntime } from './lib/runner/index.js';\n\n// ============================================================================\n// Reactive — TypedScope internals (for custom proxy implementations)\n// ============================================================================\n\nexport type { ReactiveOptions, ReactiveTarget } from './lib/reactive/index.js';\nexport {\n  BREAK_SETTER,\n  buildNestedPatch,\n  createArrayProxy,\n  joinPath,\n  SCOPE_METHOD_NAMES,\n  shouldWrapWithProxy,\n} from './lib/reactive/index.js';\n\n// ============================================================================\n// Engine — DFS graph traversal internals\n// ============================================================================\n\nexport type { TraverserOptions } from './lib/engine/index.js';\nexport type { Decider } from './lib/engine/index.js';\nexport { FlowchartTraverser } from './lib/engine/index.js';\nexport { isStageNodeReturn } from './lib/engine/index.js';\n\n// Narrative internals\nexport type { IControlFlowNarrative } from './lib/engine/index.js';\nexport type { CombinedNarrativeEntry, CombinedNarrativeOptions } from './lib/engine/index.js';\nexport type {\n  BranchResult,\n  BranchResults,\n  SerializedPipelineStructure as EngineSerializedPipelineStructure,\n  StageSnapshot as EngineStageSnapshot,\n  ExtractorError,\n  HandlerDeps,\n  IExecutionRuntime,\n  NodeResultType,\n  RuntimeStructureMetadata,\n  SerializedPipelineNode,\n  StageFunction,\n  SubflowResult,\n  TraversalExtractor,\n  TraversalResult,\n} from './lib/engine/index.js';\nexport { ControlFlowNarrativeGenerator } from './lib/engine/index.js';\nexport { NullControlFlowNarrativeGenerator } from './lib/engine/index.js';\n\n// Handlers (testing / custom engines)\nexport type { CallExtractorFn, ExecuteNodeFn, GetStagePathFn, RunStageFn } from './lib/engine/index.js';\nexport {\n  applyOutputMapping,\n  ChildrenExecutor,\n  computeNodeType,\n  ContinuationResolver,\n  createSubflowHandlerDeps,\n  DeciderHandler,\n  DEFAULT_MAX_ITERATIONS,\n  ExtractorRunner,\n  extractParentScopeValues,\n  getInitialScopeValues,\n  NodeResolver,\n  RuntimeStructureManager,\n  seedSubflowGlobalStore,\n  SelectorHandler,\n  StageRunner,\n  SubflowExecutor,\n} from './lib/engine/index.js';\n"]}
@@ -14,13 +14,14 @@ export { DiagnosticCollector } from './lib/memory/index.js';
14
14
  export { applySmartMerge, deepSmartMerge, getNestedValue, getRunAndGlobalPaths, normalisePath, redactPatch, setNestedValue, updateNestedValue, updateValue, } from './lib/memory/index.js';
15
15
  export { DeciderList, SelectorFnList, specToStageNode } from './lib/builder/index.js';
16
16
  export { createErrorMessage, createProtectedScope } from './lib/scope/index.js';
17
- export { attachBaseStateCompat, attachScopeMethods, isSubclassOfScopeFacade, looksLikeClassCtor, looksLikeFactory, makeClassProvider, makeFactoryProvider, registerScopeResolver, resolveScopeProvider, toScopeFactory, } from './lib/scope/index.js';
17
+ export { attachScopeMethods, isSubclassOfScopeFacade, looksLikeClassCtor, looksLikeFactory, makeClassProvider, makeFactoryProvider, registerScopeResolver, resolveScopeProvider, toScopeFactory, } from './lib/scope/index.js';
18
18
  // Zod internals
19
19
  export { createScopeProxyFromZod, defineScopeSchema, isScopeSchema, ZodScopeResolver } from './lib/scope/index.js';
20
20
  export { ExecutionRuntime } from './lib/runner/index.js';
21
+ export { BREAK_SETTER, buildNestedPatch, createArrayProxy, joinPath, SCOPE_METHOD_NAMES, shouldWrapWithProxy, } from './lib/reactive/index.js';
21
22
  export { FlowchartTraverser } from './lib/engine/index.js';
22
23
  export { isStageNodeReturn } from './lib/engine/index.js';
23
24
  export { ControlFlowNarrativeGenerator } from './lib/engine/index.js';
24
25
  export { NullControlFlowNarrativeGenerator } from './lib/engine/index.js';
25
26
  export { applyOutputMapping, ChildrenExecutor, computeNodeType, ContinuationResolver, createSubflowHandlerDeps, DeciderHandler, DEFAULT_MAX_ITERATIONS, ExtractorRunner, extractParentScopeValues, getInitialScopeValues, NodeResolver, RuntimeStructureManager, seedSubflowGlobalStore, SelectorHandler, StageRunner, SubflowExecutor, } from './lib/engine/index.js';
26
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"advanced.js","sourceRoot":"","sources":["../../src/advanced.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAeH,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EACL,eAAe,EACf,cAAc,EACd,cAAc,EACd,oBAAoB,EACpB,aAAa,EACb,WAAW,EACX,cAAc,EACd,iBAAiB,EACjB,WAAW,GACZ,MAAM,uBAAuB,CAAC;AAwB/B,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAatF,OAAO,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAChF,OAAO,EACL,qBAAqB,EACrB,kBAAkB,EAClB,uBAAuB,EACvB,kBAAkB,EAClB,gBAAgB,EAChB,iBAAiB,EACjB,mBAAmB,EACnB,qBAAqB,EACrB,oBAAoB,EACpB,cAAc,GACf,MAAM,sBAAsB,CAAC;AAkB9B,gBAAgB;AAChB,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAOnH,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAQzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAqB1D,OAAO,EAAE,6BAA6B,EAAE,MAAM,uBAAuB,CAAC;AACtE,OAAO,EAAE,iCAAiC,EAAE,MAAM,uBAAuB,CAAC;AAI1E,OAAO,EACL,kBAAkB,EAClB,gBAAgB,EAChB,eAAe,EACf,oBAAoB,EACpB,wBAAwB,EACxB,cAAc,EACd,sBAAsB,EACtB,eAAe,EACf,wBAAwB,EACxB,qBAAqB,EACrB,YAAY,EACZ,uBAAuB,EACvB,sBAAsB,EACtB,eAAe,EACf,WAAW,EACX,eAAe,GAChB,MAAM,uBAAuB,CAAC","sourcesContent":["/**\n * FootPrint — Advanced / Internal API\n *\n * These exports are for advanced use cases, testing, and building\n * custom execution engines. Most users should use the main 'footprint' entry point.\n *\n * Import via: import { ... } from 'footprint/advanced'\n */\n\n// ============================================================================\n// Memory — Low-level transactional state primitives\n// ============================================================================\n\nexport type {\n  CommitBundle,\n  FlowControlType,\n  FlowMessage,\n  MemoryPatch,\n  ScopeFactory,\n  StageSnapshot,\n  TraceEntry,\n} from './lib/memory/index.js';\nexport { SharedMemory } from './lib/memory/index.js';\nexport { StageContext } from './lib/memory/index.js';\nexport { EventLog } from './lib/memory/index.js';\nexport { TransactionBuffer } from './lib/memory/index.js';\nexport { DiagnosticCollector } from './lib/memory/index.js';\nexport {\n  applySmartMerge,\n  deepSmartMerge,\n  getNestedValue,\n  getRunAndGlobalPaths,\n  normalisePath,\n  redactPatch,\n  setNestedValue,\n  updateNestedValue,\n  updateValue,\n} from './lib/memory/index.js';\n\n// ============================================================================\n// Builder — Types and internals\n// ============================================================================\n\nexport type {\n  BuildTimeExtractor,\n  BuildTimeNodeMetadata,\n  ExecOptions,\n  FlowChartSpec,\n  ILogger,\n  PipelineStageFunction,\n  ScopeProtectionMode,\n  SerializedPipelineStructure,\n  SimplifiedParallelSpec,\n  StageFn,\n  StageNode,\n  StreamCallback,\n  StreamLifecycleHandler,\n  StreamTokenHandler,\n  SubflowMountOptions,\n  SubflowRef,\n} from './lib/builder/index.js';\nexport { DeciderList, SelectorFnList, specToStageNode } from './lib/builder/index.js';\n\n// ============================================================================\n// Scope — Providers, protection, recorder options, and event types\n// ============================================================================\n\nexport type {\n  ProviderResolver,\n  ResolveOptions,\n  ScopeProvider,\n  StageContextLike,\n  StrictMode,\n} from './lib/scope/index.js';\nexport { createErrorMessage, createProtectedScope } from './lib/scope/index.js';\nexport {\n  attachBaseStateCompat,\n  attachScopeMethods,\n  isSubclassOfScopeFacade,\n  looksLikeClassCtor,\n  looksLikeFactory,\n  makeClassProvider,\n  makeFactoryProvider,\n  registerScopeResolver,\n  resolveScopeProvider,\n  toScopeFactory,\n} from './lib/scope/index.js';\n\n// Recorder config/option types\nexport type {\n  AggregatedMetrics,\n  DebugEntry,\n  DebugRecorderOptions,\n  DebugVerbosity,\n  DefineScopeOptions,\n  NarrativeDetail,\n  NarrativeOperation,\n  NarrativeRecorderOptions,\n  RecorderContext,\n  StageEvent,\n  StageMetrics,\n  StageNarrativeData,\n} from './lib/scope/index.js';\n\n// Zod internals\nexport { createScopeProxyFromZod, defineScopeSchema, isScopeSchema, ZodScopeResolver } from './lib/scope/index.js';\n\n// ============================================================================\n// Runner — Internals\n// ============================================================================\n\nexport type { NarrativeEntry, RuntimeSnapshot } from './lib/runner/index.js';\nexport { ExecutionRuntime } from './lib/runner/index.js';\n\n// ============================================================================\n// Engine — DFS graph traversal internals\n// ============================================================================\n\nexport type { TraverserOptions } from './lib/engine/index.js';\nexport type { Decider } from './lib/engine/index.js';\nexport { FlowchartTraverser } from './lib/engine/index.js';\nexport { isStageNodeReturn } from './lib/engine/index.js';\n\n// Narrative internals\nexport type { IControlFlowNarrative } from './lib/engine/index.js';\nexport type { CombinedNarrativeEntry, CombinedNarrativeOptions } from './lib/engine/index.js';\nexport type {\n  BranchResult,\n  BranchResults,\n  SerializedPipelineStructure as EngineSerializedPipelineStructure,\n  StageSnapshot as EngineStageSnapshot,\n  ExtractorError,\n  HandlerDeps,\n  IExecutionRuntime,\n  NodeResultType,\n  RuntimeStructureMetadata,\n  SerializedPipelineNode,\n  StageFunction,\n  SubflowResult,\n  TraversalExtractor,\n  TraversalResult,\n} from './lib/engine/index.js';\nexport { ControlFlowNarrativeGenerator } from './lib/engine/index.js';\nexport { NullControlFlowNarrativeGenerator } from './lib/engine/index.js';\n\n// Handlers (testing / custom engines)\nexport type { CallExtractorFn, ExecuteNodeFn, GetStagePathFn, RunStageFn } from './lib/engine/index.js';\nexport {\n  applyOutputMapping,\n  ChildrenExecutor,\n  computeNodeType,\n  ContinuationResolver,\n  createSubflowHandlerDeps,\n  DeciderHandler,\n  DEFAULT_MAX_ITERATIONS,\n  ExtractorRunner,\n  extractParentScopeValues,\n  getInitialScopeValues,\n  NodeResolver,\n  RuntimeStructureManager,\n  seedSubflowGlobalStore,\n  SelectorHandler,\n  StageRunner,\n  SubflowExecutor,\n} from './lib/engine/index.js';\n"]}
27
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"advanced.js","sourceRoot":"","sources":["../../src/advanced.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAeH,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EACL,eAAe,EACf,cAAc,EACd,cAAc,EACd,oBAAoB,EACpB,aAAa,EACb,WAAW,EACX,cAAc,EACd,iBAAiB,EACjB,WAAW,GACZ,MAAM,uBAAuB,CAAC;AAuB/B,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAatF,OAAO,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAChF,OAAO,EACL,kBAAkB,EAClB,uBAAuB,EACvB,kBAAkB,EAClB,gBAAgB,EAChB,iBAAiB,EACjB,mBAAmB,EACnB,qBAAqB,EACrB,oBAAoB,EACpB,cAAc,GACf,MAAM,sBAAsB,CAAC;AAkB9B,gBAAgB;AAChB,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAOnH,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAOzD,OAAO,EACL,YAAY,EACZ,gBAAgB,EAChB,gBAAgB,EAChB,QAAQ,EACR,kBAAkB,EAClB,mBAAmB,GACpB,MAAM,yBAAyB,CAAC;AAQjC,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAqB1D,OAAO,EAAE,6BAA6B,EAAE,MAAM,uBAAuB,CAAC;AACtE,OAAO,EAAE,iCAAiC,EAAE,MAAM,uBAAuB,CAAC;AAI1E,OAAO,EACL,kBAAkB,EAClB,gBAAgB,EAChB,eAAe,EACf,oBAAoB,EACpB,wBAAwB,EACxB,cAAc,EACd,sBAAsB,EACtB,eAAe,EACf,wBAAwB,EACxB,qBAAqB,EACrB,YAAY,EACZ,uBAAuB,EACvB,sBAAsB,EACtB,eAAe,EACf,WAAW,EACX,eAAe,GAChB,MAAM,uBAAuB,CAAC","sourcesContent":["/**\n * FootPrint — Advanced / Internal API\n *\n * These exports are for advanced use cases, testing, and building\n * custom execution engines. Most users should use the main 'footprint' entry point.\n *\n * Import via: import { ... } from 'footprint/advanced'\n */\n\n// ============================================================================\n// Memory — Low-level transactional state primitives\n// ============================================================================\n\nexport type {\n  CommitBundle,\n  FlowControlType,\n  FlowMessage,\n  MemoryPatch,\n  ScopeFactory,\n  StageSnapshot,\n  TraceEntry,\n} from './lib/memory/index.js';\nexport { SharedMemory } from './lib/memory/index.js';\nexport { StageContext } from './lib/memory/index.js';\nexport { EventLog } from './lib/memory/index.js';\nexport { TransactionBuffer } from './lib/memory/index.js';\nexport { DiagnosticCollector } from './lib/memory/index.js';\nexport {\n  applySmartMerge,\n  deepSmartMerge,\n  getNestedValue,\n  getRunAndGlobalPaths,\n  normalisePath,\n  redactPatch,\n  setNestedValue,\n  updateNestedValue,\n  updateValue,\n} from './lib/memory/index.js';\n\n// ============================================================================\n// Builder — Types and internals\n// ============================================================================\n\nexport type {\n  BuildTimeExtractor,\n  BuildTimeNodeMetadata,\n  ExecOptions,\n  FlowChartSpec,\n  ILogger,\n  ScopeProtectionMode,\n  SerializedPipelineStructure,\n  SimplifiedParallelSpec,\n  StageFn,\n  StageNode,\n  StreamCallback,\n  StreamLifecycleHandler,\n  StreamTokenHandler,\n  SubflowMountOptions,\n  SubflowRef,\n} from './lib/builder/index.js';\nexport { DeciderList, SelectorFnList, specToStageNode } from './lib/builder/index.js';\n\n// ============================================================================\n// Scope — Providers, protection, recorder options, and event types\n// ============================================================================\n\nexport type {\n  ProviderResolver,\n  ResolveOptions,\n  ScopeProvider,\n  StageContextLike,\n  StrictMode,\n} from './lib/scope/index.js';\nexport { createErrorMessage, createProtectedScope } from './lib/scope/index.js';\nexport {\n  attachScopeMethods,\n  isSubclassOfScopeFacade,\n  looksLikeClassCtor,\n  looksLikeFactory,\n  makeClassProvider,\n  makeFactoryProvider,\n  registerScopeResolver,\n  resolveScopeProvider,\n  toScopeFactory,\n} from './lib/scope/index.js';\n\n// Recorder config/option types\nexport type {\n  AggregatedMetrics,\n  DebugEntry,\n  DebugRecorderOptions,\n  DebugVerbosity,\n  DefineScopeOptions,\n  NarrativeDetail,\n  NarrativeOperation,\n  NarrativeRecorderOptions,\n  RecorderContext,\n  StageEvent,\n  StageMetrics,\n  StageNarrativeData,\n} from './lib/scope/index.js';\n\n// Zod internals\nexport { createScopeProxyFromZod, defineScopeSchema, isScopeSchema, ZodScopeResolver } from './lib/scope/index.js';\n\n// ============================================================================\n// Runner — Internals\n// ============================================================================\n\nexport type { NarrativeEntry, RuntimeSnapshot } from './lib/runner/index.js';\nexport { ExecutionRuntime } from './lib/runner/index.js';\n\n// ============================================================================\n// Reactive — TypedScope internals (for custom proxy implementations)\n// ============================================================================\n\nexport type { ReactiveOptions, ReactiveTarget } from './lib/reactive/index.js';\nexport {\n  BREAK_SETTER,\n  buildNestedPatch,\n  createArrayProxy,\n  joinPath,\n  SCOPE_METHOD_NAMES,\n  shouldWrapWithProxy,\n} from './lib/reactive/index.js';\n\n// ============================================================================\n// Engine — DFS graph traversal internals\n// ============================================================================\n\nexport type { TraverserOptions } from './lib/engine/index.js';\nexport type { Decider } from './lib/engine/index.js';\nexport { FlowchartTraverser } from './lib/engine/index.js';\nexport { isStageNodeReturn } from './lib/engine/index.js';\n\n// Narrative internals\nexport type { IControlFlowNarrative } from './lib/engine/index.js';\nexport type { CombinedNarrativeEntry, CombinedNarrativeOptions } from './lib/engine/index.js';\nexport type {\n  BranchResult,\n  BranchResults,\n  SerializedPipelineStructure as EngineSerializedPipelineStructure,\n  StageSnapshot as EngineStageSnapshot,\n  ExtractorError,\n  HandlerDeps,\n  IExecutionRuntime,\n  NodeResultType,\n  RuntimeStructureMetadata,\n  SerializedPipelineNode,\n  StageFunction,\n  SubflowResult,\n  TraversalExtractor,\n  TraversalResult,\n} from './lib/engine/index.js';\nexport { ControlFlowNarrativeGenerator } from './lib/engine/index.js';\nexport { NullControlFlowNarrativeGenerator } from './lib/engine/index.js';\n\n// Handlers (testing / custom engines)\nexport type { CallExtractorFn, ExecuteNodeFn, GetStagePathFn, RunStageFn } from './lib/engine/index.js';\nexport {\n  applyOutputMapping,\n  ChildrenExecutor,\n  computeNodeType,\n  ContinuationResolver,\n  createSubflowHandlerDeps,\n  DeciderHandler,\n  DEFAULT_MAX_ITERATIONS,\n  ExtractorRunner,\n  extractParentScopeValues,\n  getInitialScopeValues,\n  NodeResolver,\n  RuntimeStructureManager,\n  seedSubflowGlobalStore,\n  SelectorHandler,\n  StageRunner,\n  SubflowExecutor,\n} from './lib/engine/index.js';\n"]}
package/dist/esm/index.js CHANGED
@@ -9,6 +9,9 @@
9
9
  * import from 'footprint/advanced'.
10
10
  */
11
11
  export { flowChart, FlowChartBuilder } from './lib/builder/index.js';
12
+ export { createTypedScopeFactory, typedFlowChart } from './lib/builder/typedFlowChart.js';
13
+ export { createTypedScope } from './lib/reactive/index.js';
14
+ export { decide, select } from './lib/decide/index.js';
12
15
  // ============================================================================
13
16
  // Runner — Execution convenience layer
14
17
  // ============================================================================
@@ -18,13 +21,13 @@ export { getSubtreeSnapshot, listSubflowPaths } from './lib/runner/index.js';
18
21
  // Scope — Per-stage facades and recorders
19
22
  // ============================================================================
20
23
  export { ScopeFacade } from './lib/scope/index.js';
24
+ // Dev-mode diagnostics
25
+ export { disableDevMode, enableDevMode } from './lib/scope/detectCircular.js';
21
26
  // Recorders
22
27
  export { MetricRecorder } from './lib/scope/index.js';
23
28
  export { DebugRecorder } from './lib/scope/index.js';
24
- export { NarrativeRecorder } from './lib/scope/index.js';
25
29
  // Zod-based scope definitions
26
30
  export { defineScopeFromZod } from './lib/scope/index.js';
27
- export { CombinedNarrativeBuilder } from './lib/engine/index.js';
28
31
  export { NarrativeFlowRecorder } from './lib/engine/index.js';
29
32
  export { extractErrorInfo, formatErrorInfo } from './lib/engine/index.js';
30
33
  export { ManifestFlowRecorder } from './lib/engine/index.js';
@@ -40,4 +43,4 @@ export { normalizeSchema, zodToJsonSchema } from './lib/contract/index.js';
40
43
  export { generateOpenAPI } from './lib/contract/index.js';
41
44
  export { detectSchema, isValidatable, isZod } from './lib/schema/index.js';
42
45
  export { InputValidationError, validateAgainstSchema, validateOrThrow } from './lib/schema/index.js';
43
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAOH,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAErE,+EAA+E;AAC/E,uCAAuC;AACvC,+EAA+E;AAE/E,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAQ1D,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAE7E,+EAA+E;AAC/E,0CAA0C;AAC1C,+EAA+E;AAE/E,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAEnD,YAAY;AACZ,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAazD,8BAA8B;AAC9B,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAO1D,OAAO,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AAiBjE,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAI9D,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAI1E,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,EAAE,6BAA6B,EAAE,MAAM,uBAAuB,CAAC;AACtE,OAAO,EAAE,8BAA8B,EAAE,MAAM,uBAAuB,CAAC;AACvE,OAAO,EAAE,gCAAgC,EAAE,MAAM,uBAAuB,CAAC;AACzE,OAAO,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AACjE,OAAO,EAAE,6BAA6B,EAAE,MAAM,uBAAuB,CAAC;AACtE,OAAO,EAAE,2BAA2B,EAAE,MAAM,uBAAuB,CAAC;AACpE,OAAO,EAAE,6BAA6B,EAAE,MAAM,uBAAuB,CAAC;AAoBtE,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC3E,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAO1D,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAC3E,OAAO,EAAE,oBAAoB,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC","sourcesContent":["/**\n * FootPrint — Public API\n *\n * Connected causal trace library for LLM pipelines.\n * Builds flowcharts, executes them via DFS traversal, and captures\n * every stage's context (state, decisions, errors) in an auditable trace.\n *\n * For advanced/internal APIs (memory primitives, engine handlers, providers),\n * import from 'footprint/advanced'.\n */\n\n// ============================================================================\n// Builder — Flowchart construction\n// ============================================================================\n\nexport type { FlowChart, PipelineStageFunction as StageHandler, StreamHandlers } from './lib/builder/index.js';\nexport { flowChart, FlowChartBuilder } from './lib/builder/index.js';\n\n// ============================================================================\n// Runner — Execution convenience layer\n// ============================================================================\n\nexport { FlowChartExecutor } from './lib/runner/index.js';\n\n// ComposableRunner — interface for runners that expose their internal flowChart\n// for subflow composition (enables UI drill-down into nested runners)\nexport type { ComposableRunner } from './lib/runner/index.js';\n\n// Snapshot navigation — drill into subflow subtrees by path\nexport type { RecorderSnapshot, RuntimeSnapshot, SubtreeSnapshot } from './lib/runner/index.js';\nexport { getSubtreeSnapshot, listSubflowPaths } from './lib/runner/index.js';\n\n// ============================================================================\n// Scope — Per-stage facades and recorders\n// ============================================================================\n\nexport { ScopeFacade } from './lib/scope/index.js';\n\n// Recorders\nexport { MetricRecorder } from './lib/scope/index.js';\nexport { DebugRecorder } from './lib/scope/index.js';\nexport { NarrativeRecorder } from './lib/scope/index.js';\n\n// Recorder interface and core event types (needed to implement custom Recorder)\nexport type {\n  CommitEvent,\n  ErrorEvent,\n  ReadEvent,\n  Recorder,\n  RedactionPolicy,\n  RedactionReport,\n  WriteEvent,\n} from './lib/scope/index.js';\n\n// Zod-based scope definitions\nexport { defineScopeFromZod } from './lib/scope/index.js';\n\n// ============================================================================\n// Engine — Narrative (commonly used)\n// ============================================================================\n\nexport type { CombinedNarrativeEntry } from './lib/engine/index.js';\nexport { CombinedNarrativeBuilder } from './lib/engine/index.js';\n\n// FlowRecorder — Pluggable observer for control flow events (mirrors scope Recorder)\nexport type {\n  FlowBreakEvent,\n  FlowDecisionEvent,\n  FlowErrorEvent,\n  FlowForkEvent,\n  FlowLoopEvent,\n  FlowNextEvent,\n  FlowRecorder,\n  FlowSelectedEvent,\n  FlowStageEvent,\n  FlowSubflowEvent,\n  FlowSubflowRegisteredEvent,\n  TraversalContext,\n} from './lib/engine/index.js';\nexport { NarrativeFlowRecorder } from './lib/engine/index.js';\n\n// Structured error extraction — preserves field-level details through the pipeline\nexport type { StructuredErrorInfo } from './lib/engine/index.js';\nexport { extractErrorInfo, formatErrorInfo } from './lib/engine/index.js';\n\n// Built-in FlowRecorder strategies (tree-shakeable — import only what you use)\nexport type { ManifestEntry } from './lib/engine/index.js';\nexport { ManifestFlowRecorder } from './lib/engine/index.js';\nexport { AdaptiveNarrativeFlowRecorder } from './lib/engine/index.js';\nexport { MilestoneNarrativeFlowRecorder } from './lib/engine/index.js';\nexport { ProgressiveNarrativeFlowRecorder } from './lib/engine/index.js';\nexport { RLENarrativeFlowRecorder } from './lib/engine/index.js';\nexport { SeparateNarrativeFlowRecorder } from './lib/engine/index.js';\nexport { SilentNarrativeFlowRecorder } from './lib/engine/index.js';\nexport { WindowedNarrativeFlowRecorder } from './lib/engine/index.js';\n\n// ============================================================================\n// Memory — ScopeFactory type (needed for FlowChartExecutor constructor)\n// ============================================================================\n\nexport type { ExecutionEnv, RunOptions } from './lib/engine/index.js';\nexport type { ScopeFactory } from './lib/memory/index.js';\n\n// ============================================================================\n// Contract — I/O boundary, schemas, and OpenAPI generation\n// ============================================================================\n\nexport type {\n  FlowChartContract,\n  FlowChartContractOptions,\n  JsonSchema,\n  OpenAPIOptions,\n  OpenAPISpec,\n} from './lib/contract/index.js';\nexport { defineContract } from './lib/contract/index.js';\nexport { normalizeSchema, zodToJsonSchema } from './lib/contract/index.js';\nexport { generateOpenAPI } from './lib/contract/index.js';\n\n// ============================================================================\n// Schema — Unified detection, validation, and structured errors\n// ============================================================================\n\nexport type { SchemaKind, ValidationIssue, ValidationResult } from './lib/schema/index.js';\nexport { detectSchema, isValidatable, isZod } from './lib/schema/index.js';\nexport { InputValidationError, validateAgainstSchema, validateOrThrow } from './lib/schema/index.js';\n"]}
46
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAOH,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAIrE,OAAO,EAAE,uBAAuB,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AAE1F,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAW3D,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAEvD,+EAA+E;AAC/E,uCAAuC;AACvC,+EAA+E;AAE/E,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAQ1D,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAE7E,+EAA+E;AAC/E,0CAA0C;AAC1C,+EAA+E;AAE/E,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAEnD,uBAAuB;AACvB,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAE9E,YAAY;AACZ,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAarD,8BAA8B;AAC9B,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAuB1D,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAI9D,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAI1E,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,EAAE,6BAA6B,EAAE,MAAM,uBAAuB,CAAC;AACtE,OAAO,EAAE,8BAA8B,EAAE,MAAM,uBAAuB,CAAC;AACvE,OAAO,EAAE,gCAAgC,EAAE,MAAM,uBAAuB,CAAC;AACzE,OAAO,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AACjE,OAAO,EAAE,6BAA6B,EAAE,MAAM,uBAAuB,CAAC;AACtE,OAAO,EAAE,2BAA2B,EAAE,MAAM,uBAAuB,CAAC;AACpE,OAAO,EAAE,6BAA6B,EAAE,MAAM,uBAAuB,CAAC;AAoBtE,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC3E,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAO1D,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAC3E,OAAO,EAAE,oBAAoB,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC","sourcesContent":["/**\n * FootPrint — Public API\n *\n * Connected causal trace library for LLM pipelines.\n * Builds flowcharts, executes them via DFS traversal, and captures\n * every stage's context (state, decisions, errors) in an auditable trace.\n *\n * For advanced/internal APIs (memory primitives, engine handlers, providers),\n * import from 'footprint/advanced'.\n */\n\n// ============================================================================\n// Builder — Flowchart construction\n// ============================================================================\n\nexport type { FlowChart, StageFunction as StageHandler, StreamHandlers } from './lib/builder/index.js';\nexport { flowChart, FlowChartBuilder } from './lib/builder/index.js';\n\n// TypedScope — typed property access (no casts needed)\nexport type { TypedStageFunction } from './lib/builder/typedFlowChart.js';\nexport { createTypedScopeFactory, typedFlowChart } from './lib/builder/typedFlowChart.js';\nexport type { ScopeMethods, TypedScope } from './lib/reactive/index.js';\nexport { createTypedScope } from './lib/reactive/index.js';\n\n// Decision reasoning capture\nexport type {\n  DecideRule,\n  DecisionEvidence,\n  DecisionResult,\n  FilterOps,\n  SelectionResult,\n  WhereFilter,\n} from './lib/decide/index.js';\nexport { decide, select } from './lib/decide/index.js';\n\n// ============================================================================\n// Runner — Execution convenience layer\n// ============================================================================\n\nexport { FlowChartExecutor } from './lib/runner/index.js';\n\n// ComposableRunner — interface for runners that expose their internal flowChart\n// for subflow composition (enables UI drill-down into nested runners)\nexport type { ComposableRunner } from './lib/runner/index.js';\n\n// Snapshot navigation — drill into subflow subtrees by path\nexport type { RecorderSnapshot, RuntimeSnapshot, SubtreeSnapshot } from './lib/runner/index.js';\nexport { getSubtreeSnapshot, listSubflowPaths } from './lib/runner/index.js';\n\n// ============================================================================\n// Scope — Per-stage facades and recorders\n// ============================================================================\n\nexport { ScopeFacade } from './lib/scope/index.js';\n\n// Dev-mode diagnostics\nexport { disableDevMode, enableDevMode } from './lib/scope/detectCircular.js';\n\n// Recorders\nexport { MetricRecorder } from './lib/scope/index.js';\nexport { DebugRecorder } from './lib/scope/index.js';\n\n// Recorder interface and core event types (needed to implement custom Recorder)\nexport type {\n  CommitEvent,\n  ErrorEvent,\n  ReadEvent,\n  Recorder,\n  RedactionPolicy,\n  RedactionReport,\n  WriteEvent,\n} from './lib/scope/index.js';\n\n// Zod-based scope definitions\nexport { defineScopeFromZod } from './lib/scope/index.js';\n\n// ============================================================================\n// Engine — Narrative (commonly used)\n// ============================================================================\n\nexport type { CombinedNarrativeEntry } from './lib/engine/index.js';\n\n// FlowRecorder — Pluggable observer for control flow events (mirrors scope Recorder)\nexport type {\n  FlowBreakEvent,\n  FlowDecisionEvent,\n  FlowErrorEvent,\n  FlowForkEvent,\n  FlowLoopEvent,\n  FlowNextEvent,\n  FlowRecorder,\n  FlowSelectedEvent,\n  FlowStageEvent,\n  FlowSubflowEvent,\n  FlowSubflowRegisteredEvent,\n  TraversalContext,\n} from './lib/engine/index.js';\nexport { NarrativeFlowRecorder } from './lib/engine/index.js';\n\n// Structured error extraction — preserves field-level details through the pipeline\nexport type { StructuredErrorInfo } from './lib/engine/index.js';\nexport { extractErrorInfo, formatErrorInfo } from './lib/engine/index.js';\n\n// Built-in FlowRecorder strategies (tree-shakeable — import only what you use)\nexport type { ManifestEntry } from './lib/engine/index.js';\nexport { ManifestFlowRecorder } from './lib/engine/index.js';\nexport { AdaptiveNarrativeFlowRecorder } from './lib/engine/index.js';\nexport { MilestoneNarrativeFlowRecorder } from './lib/engine/index.js';\nexport { ProgressiveNarrativeFlowRecorder } from './lib/engine/index.js';\nexport { RLENarrativeFlowRecorder } from './lib/engine/index.js';\nexport { SeparateNarrativeFlowRecorder } from './lib/engine/index.js';\nexport { SilentNarrativeFlowRecorder } from './lib/engine/index.js';\nexport { WindowedNarrativeFlowRecorder } from './lib/engine/index.js';\n\n// ============================================================================\n// Memory — ScopeFactory type (needed for FlowChartExecutor constructor)\n// ============================================================================\n\nexport type { ExecutionEnv, RunOptions } from './lib/engine/index.js';\nexport type { ScopeFactory } from './lib/memory/index.js';\n\n// ============================================================================\n// Contract — I/O boundary, schemas, and OpenAPI generation\n// ============================================================================\n\nexport type {\n  FlowChartContract,\n  FlowChartContractOptions,\n  JsonSchema,\n  OpenAPIOptions,\n  OpenAPISpec,\n} from './lib/contract/index.js';\nexport { defineContract } from './lib/contract/index.js';\nexport { normalizeSchema, zodToJsonSchema } from './lib/contract/index.js';\nexport { generateOpenAPI } from './lib/contract/index.js';\n\n// ============================================================================\n// Schema — Unified detection, validation, and structured errors\n// ============================================================================\n\nexport type { SchemaKind, ValidationIssue, ValidationResult } from './lib/schema/index.js';\nexport { detectSchema, isValidatable, isZod } from './lib/schema/index.js';\nexport { InputValidationError, validateAgainstSchema, validateOrThrow } from './lib/schema/index.js';\n"]}