footprintjs 0.18.0 → 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.
- package/CLAUDE.md +77 -59
- package/README.md +41 -32
- package/dist/advanced.js +31 -25
- package/dist/esm/advanced.js +3 -2
- package/dist/esm/index.js +6 -3
- package/dist/esm/lib/builder/FlowChartBuilder.js +1 -1
- package/dist/esm/lib/builder/index.js +1 -1
- package/dist/esm/lib/builder/typedFlowChart.js +36 -0
- package/dist/esm/lib/builder/types.js +1 -1
- package/dist/esm/lib/contract/index.js +2 -2
- package/dist/esm/lib/contract/schema.js +2 -6
- package/dist/esm/lib/decide/decide.js +170 -0
- package/dist/esm/lib/decide/evaluator.js +103 -0
- package/dist/esm/lib/decide/evidence.js +35 -0
- package/dist/esm/lib/decide/index.js +16 -0
- package/dist/esm/lib/decide/types.js +10 -0
- package/dist/esm/lib/engine/handlers/DeciderHandler.js +12 -3
- package/dist/esm/lib/engine/handlers/SelectorHandler.js +15 -3
- package/dist/esm/lib/engine/handlers/StageRunner.js +16 -6
- package/dist/esm/lib/engine/index.js +1 -2
- package/dist/esm/lib/engine/narrative/CombinedNarrativeBuilder.js +5 -184
- package/dist/esm/lib/engine/narrative/CombinedNarrativeRecorder.js +43 -30
- package/dist/esm/lib/engine/narrative/ControlFlowNarrativeGenerator.js +20 -3
- package/dist/esm/lib/engine/narrative/FlowRecorderDispatcher.js +5 -4
- package/dist/esm/lib/engine/narrative/NarrativeFlowRecorder.js +1 -12
- package/dist/esm/lib/engine/narrative/index.js +1 -2
- package/dist/esm/lib/engine/narrative/types.js +2 -3
- package/dist/esm/lib/reactive/allowlist.js +83 -0
- package/dist/esm/lib/reactive/arrayTraps.js +116 -0
- package/dist/esm/lib/reactive/createTypedScope.js +306 -0
- package/dist/esm/lib/reactive/index.js +17 -0
- package/dist/esm/lib/reactive/pathBuilder.js +42 -0
- package/dist/esm/lib/reactive/types.js +52 -0
- package/dist/esm/lib/runner/FlowChartExecutor.js +58 -39
- package/dist/esm/lib/scope/ScopeFacade.js +36 -5
- package/dist/esm/lib/scope/detectCircular.js +56 -0
- package/dist/esm/lib/scope/index.js +2 -3
- package/dist/esm/lib/scope/providers/baseStateCompatible.js +1 -4
- package/dist/esm/lib/scope/providers/index.js +2 -2
- package/dist/esm/lib/scope/recorders/MetricRecorder.js +4 -1
- package/dist/esm/lib/scope/recorders/NarrativeRecorder.js +2 -25
- package/dist/esm/lib/scope/recorders/index.js +1 -2
- package/dist/esm/lib/scope/recorders/summarizeValue.js +31 -0
- package/dist/esm/lib/scope/state/zod/utils/validateHelper.js +2 -2
- package/dist/esm/lib/scope/types.js +1 -1
- package/dist/index.js +26 -18
- package/dist/lib/builder/FlowChartBuilder.js +1 -1
- package/dist/lib/builder/index.js +1 -1
- package/dist/lib/builder/typedFlowChart.js +41 -0
- package/dist/lib/builder/types.js +1 -1
- package/dist/lib/contract/index.js +2 -3
- package/dist/lib/contract/schema.js +3 -8
- package/dist/lib/decide/decide.js +175 -0
- package/dist/lib/decide/evaluator.js +107 -0
- package/dist/lib/decide/evidence.js +39 -0
- package/dist/lib/decide/index.js +24 -0
- package/dist/lib/decide/types.js +13 -0
- package/dist/lib/engine/handlers/DeciderHandler.js +12 -3
- package/dist/lib/engine/handlers/SelectorHandler.js +15 -3
- package/dist/lib/engine/handlers/StageRunner.js +16 -6
- package/dist/lib/engine/index.js +2 -4
- package/dist/lib/engine/narrative/CombinedNarrativeBuilder.js +4 -186
- package/dist/lib/engine/narrative/CombinedNarrativeRecorder.js +45 -32
- package/dist/lib/engine/narrative/ControlFlowNarrativeGenerator.js +20 -3
- package/dist/lib/engine/narrative/FlowRecorderDispatcher.js +5 -4
- package/dist/lib/engine/narrative/NarrativeFlowRecorder.js +1 -12
- package/dist/lib/engine/narrative/index.js +2 -4
- package/dist/lib/engine/narrative/types.js +2 -3
- package/dist/lib/reactive/allowlist.js +87 -0
- package/dist/lib/reactive/arrayTraps.js +120 -0
- package/dist/lib/reactive/createTypedScope.js +313 -0
- package/dist/lib/reactive/index.js +29 -0
- package/dist/lib/reactive/pathBuilder.js +47 -0
- package/dist/lib/reactive/types.js +55 -0
- package/dist/lib/runner/FlowChartExecutor.js +58 -39
- package/dist/lib/scope/ScopeFacade.js +36 -5
- package/dist/lib/scope/detectCircular.js +63 -0
- package/dist/lib/scope/index.js +2 -5
- package/dist/lib/scope/providers/baseStateCompatible.js +2 -5
- package/dist/lib/scope/providers/index.js +2 -3
- package/dist/lib/scope/recorders/MetricRecorder.js +4 -1
- package/dist/lib/scope/recorders/NarrativeRecorder.js +4 -27
- package/dist/lib/scope/recorders/index.js +2 -4
- package/dist/lib/scope/recorders/summarizeValue.js +35 -0
- package/dist/lib/scope/state/zod/utils/validateHelper.js +2 -2
- package/dist/lib/scope/types.js +1 -1
- package/dist/types/advanced.d.ts +4 -2
- package/dist/types/index.d.ts +8 -3
- package/dist/types/lib/builder/FlowChartBuilder.d.ts +13 -13
- package/dist/types/lib/builder/index.d.ts +1 -1
- package/dist/types/lib/builder/typedFlowChart.d.ts +34 -0
- package/dist/types/lib/builder/types.d.ts +0 -2
- package/dist/types/lib/contract/index.d.ts +1 -1
- package/dist/types/lib/contract/schema.d.ts +0 -2
- package/dist/types/lib/decide/decide.d.ts +26 -0
- package/dist/types/lib/decide/evaluator.d.ts +22 -0
- package/dist/types/lib/decide/evidence.d.ts +22 -0
- package/dist/types/lib/decide/index.d.ts +12 -0
- package/dist/types/lib/decide/types.d.ts +91 -0
- package/dist/types/lib/engine/index.d.ts +0 -1
- package/dist/types/lib/engine/narrative/CombinedNarrativeBuilder.d.ts +3 -31
- package/dist/types/lib/engine/narrative/ControlFlowNarrativeGenerator.d.ts +2 -1
- package/dist/types/lib/engine/narrative/FlowRecorderDispatcher.d.ts +3 -2
- package/dist/types/lib/engine/narrative/NarrativeFlowRecorder.d.ts +0 -9
- package/dist/types/lib/engine/narrative/index.d.ts +0 -1
- package/dist/types/lib/engine/narrative/types.d.ts +13 -3
- package/dist/types/lib/reactive/allowlist.d.ts +30 -0
- package/dist/types/lib/reactive/arrayTraps.d.ts +23 -0
- package/dist/types/lib/reactive/createTypedScope.d.ts +24 -0
- package/dist/types/lib/reactive/index.d.ts +14 -0
- package/dist/types/lib/reactive/pathBuilder.d.ts +31 -0
- package/dist/types/lib/reactive/types.d.ts +60 -0
- package/dist/types/lib/scope/ScopeFacade.d.ts +6 -2
- package/dist/types/lib/scope/detectCircular.d.ts +20 -0
- package/dist/types/lib/scope/index.d.ts +1 -2
- package/dist/types/lib/scope/providers/baseStateCompatible.d.ts +0 -4
- package/dist/types/lib/scope/providers/index.d.ts +1 -1
- package/dist/types/lib/scope/recorders/MetricRecorder.d.ts +1 -0
- package/dist/types/lib/scope/recorders/index.d.ts +0 -1
- package/dist/types/lib/scope/recorders/summarizeValue.d.ts +7 -0
- package/dist/types/lib/scope/state/zod/utils/validateHelper.d.ts +1 -1
- package/dist/types/lib/scope/types.d.ts +7 -0
- 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
|
|
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
|
|
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
|
-
###
|
|
100
|
+
### ScopeFacade (Internal — use TypedScope for new code)
|
|
50
101
|
|
|
51
102
|
```typescript
|
|
52
|
-
|
|
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
|
|
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
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
executor.
|
|
88
|
-
executor.
|
|
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 }
|
|
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: `
|
|
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`
|
|
132
|
-
-
|
|
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
|
-
-
|
|
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
|
|
156
|
-
- Don't put infrastructure data
|
|
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
|
|
53
|
-
Stage 2: Next
|
|
54
|
-
Step 1: Read
|
|
55
|
-
Step 2: Write
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
Step
|
|
59
|
-
|
|
60
|
-
Stage 4: Next
|
|
61
|
-
Step 1:
|
|
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"` ← `dtiStatus="excessive"` ← `dtiRatio=0.6` ← `app.monthlyDebts=2100`. Every variable links to its cause:
|
|
@@ -75,40 +73,49 @@ That answer came from the trace — not from the LLM's imagination.
|
|
|
75
73
|
## Quick Start
|
|
76
74
|
|
|
77
75
|
```typescript
|
|
78
|
-
import {
|
|
76
|
+
import { typedFlowChart, createTypedScopeFactory, FlowChartExecutor, decide } from 'footprintjs';
|
|
79
77
|
|
|
80
|
-
|
|
81
|
-
|
|
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
|
|
84
|
-
|
|
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
|
|
89
|
-
return (scope
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
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
|
|
95
|
-
scope.
|
|
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
|
|
111
|
+
// Step 1: Write user = {name, tier}
|
|
108
112
|
// Stage 2: Next, it moved on to ApplyDiscount.
|
|
109
|
-
// Step 1: Read user = {name
|
|
113
|
+
// Step 1: Read user = {name, tier}
|
|
110
114
|
// Step 2: Write discount = 0.2
|
|
111
|
-
// Stage 3:
|
|
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 — LLMs backtrack through variables to find causes |
|
|
133
|
+
| **Decision Evidence** | `decide()` / `select()` auto-capture WHY a branch was chosen — operators, thresholds, pass/fail |
|
|
134
|
+
| **TypedScope<T>** | Typed property access — `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 — [guide](docs/guides/patterns.md) |
|
|
128
137
|
| **Transactional State** | Atomic commits, safe merges, time-travel replay — [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) · [Scope](docs/guides/scope.md) · [Execution](docs/guides/execution.md) · [Errors](docs/guides/error-handling.md) · [Flow Recorders](docs/guides/flow-recorders.md) · [Contracts](docs/guides/contracts.md) |
|
|
161
|
-
| **Reference** | [API Reference](docs/guides/api-reference.md) · [Performance Benchmarks](docs/guides/performance.md) |
|
|
170
|
+
| **Reference** | [API Docs](https://footprintjs.github.io/footPrint/) · [API Reference](docs/guides/api-reference.md) · [Performance Benchmarks](docs/guides/performance.md) |
|
|
162
171
|
| **Architecture** | [Internals](docs/internals/) — six independent libraries, each with its own README |
|
|
163
172
|
| **Try it** | [Interactive Playground](https://footprintjs.github.io/footprint-playground/) · [Live Demo](https://footprintjs.github.io/footprint-demo/) · [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.
|
|
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/
|
|
60
|
-
Object.defineProperty(exports, "
|
|
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, "
|
|
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, "
|
|
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, "
|
|
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, "
|
|
69
|
-
|
|
70
|
-
Object.defineProperty(exports, "
|
|
71
|
-
Object.defineProperty(exports, "
|
|
72
|
-
Object.defineProperty(exports, "
|
|
73
|
-
Object.defineProperty(exports, "
|
|
74
|
-
Object.defineProperty(exports, "
|
|
75
|
-
Object.defineProperty(exports, "
|
|
76
|
-
Object.defineProperty(exports, "
|
|
77
|
-
Object.defineProperty(exports, "
|
|
78
|
-
Object.defineProperty(exports, "
|
|
79
|
-
Object.defineProperty(exports, "
|
|
80
|
-
Object.defineProperty(exports, "
|
|
81
|
-
Object.defineProperty(exports, "
|
|
82
|
-
Object.defineProperty(exports, "
|
|
83
|
-
Object.defineProperty(exports, "
|
|
84
|
-
|
|
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"]}
|
package/dist/esm/advanced.js
CHANGED
|
@@ -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 {
|
|
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,
|
|
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"]}
|