footprintjs 4.1.0 → 4.3.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 (82) hide show
  1. package/CLAUDE.md +49 -1
  2. package/dist/esm/index.js +6 -1
  3. package/dist/esm/lib/builder/FlowChartBuilder.js +53 -1
  4. package/dist/esm/lib/builder/types.js +1 -1
  5. package/dist/esm/lib/engine/graph/StageNode.js +1 -1
  6. package/dist/esm/lib/engine/handlers/ChildrenExecutor.js +14 -1
  7. package/dist/esm/lib/engine/handlers/DeciderHandler.js +7 -1
  8. package/dist/esm/lib/engine/handlers/SelectorHandler.js +7 -1
  9. package/dist/esm/lib/engine/handlers/StageRunner.js +13 -1
  10. package/dist/esm/lib/engine/handlers/SubflowExecutor.js +8 -1
  11. package/dist/esm/lib/engine/narrative/CombinedNarrativeRecorder.js +39 -1
  12. package/dist/esm/lib/engine/narrative/FlowRecorderDispatcher.js +31 -1
  13. package/dist/esm/lib/engine/narrative/NarrativeFlowRecorder.js +10 -1
  14. package/dist/esm/lib/engine/narrative/NullControlFlowNarrativeGenerator.js +3 -1
  15. package/dist/esm/lib/engine/narrative/narrativeTypes.js +1 -1
  16. package/dist/esm/lib/engine/narrative/types.js +1 -1
  17. package/dist/esm/lib/engine/traversal/FlowchartTraverser.js +8 -1
  18. package/dist/esm/lib/engine/types.js +2 -1
  19. package/dist/esm/lib/pause/index.js +2 -0
  20. package/dist/esm/lib/pause/types.js +58 -0
  21. package/dist/esm/lib/reactive/types.js +2 -1
  22. package/dist/esm/lib/recorder/CompositeRecorder.js +172 -0
  23. package/dist/esm/lib/recorder/index.js +2 -0
  24. package/dist/esm/lib/runner/ExecutionRuntime.js +11 -2
  25. package/dist/esm/lib/runner/FlowChartExecutor.js +260 -8
  26. package/dist/esm/lib/scope/ScopeFacade.js +23 -1
  27. package/dist/esm/lib/scope/recorders/DebugRecorder.js +36 -2
  28. package/dist/esm/lib/scope/recorders/MetricRecorder.js +60 -4
  29. package/dist/esm/lib/scope/types.js +1 -1
  30. package/dist/esm/recorders.js +4 -3
  31. package/dist/index.js +21 -15
  32. package/dist/lib/builder/FlowChartBuilder.js +53 -1
  33. package/dist/lib/builder/types.js +1 -1
  34. package/dist/lib/engine/graph/StageNode.js +1 -1
  35. package/dist/lib/engine/handlers/ChildrenExecutor.js +14 -1
  36. package/dist/lib/engine/handlers/DeciderHandler.js +7 -1
  37. package/dist/lib/engine/handlers/SelectorHandler.js +7 -1
  38. package/dist/lib/engine/handlers/StageRunner.js +17 -5
  39. package/dist/lib/engine/handlers/SubflowExecutor.js +8 -1
  40. package/dist/lib/engine/narrative/CombinedNarrativeRecorder.js +39 -1
  41. package/dist/lib/engine/narrative/FlowRecorderDispatcher.js +31 -1
  42. package/dist/lib/engine/narrative/NarrativeFlowRecorder.js +10 -1
  43. package/dist/lib/engine/narrative/NullControlFlowNarrativeGenerator.js +3 -1
  44. package/dist/lib/engine/narrative/narrativeTypes.js +1 -1
  45. package/dist/lib/engine/narrative/types.js +1 -1
  46. package/dist/lib/engine/traversal/FlowchartTraverser.js +8 -1
  47. package/dist/lib/engine/types.js +6 -2
  48. package/dist/lib/pause/index.js +8 -0
  49. package/dist/lib/pause/types.js +64 -0
  50. package/dist/lib/reactive/types.js +2 -1
  51. package/dist/lib/recorder/CompositeRecorder.js +176 -0
  52. package/dist/lib/recorder/index.js +6 -0
  53. package/dist/lib/runner/ExecutionRuntime.js +11 -2
  54. package/dist/lib/runner/FlowChartExecutor.js +260 -8
  55. package/dist/lib/scope/ScopeFacade.js +23 -1
  56. package/dist/lib/scope/recorders/DebugRecorder.js +36 -2
  57. package/dist/lib/scope/recorders/MetricRecorder.js +60 -4
  58. package/dist/lib/scope/types.js +1 -1
  59. package/dist/recorders.js +6 -4
  60. package/dist/types/index.d.ts +8 -1
  61. package/dist/types/lib/builder/FlowChartBuilder.d.ts +22 -0
  62. package/dist/types/lib/builder/types.d.ts +3 -1
  63. package/dist/types/lib/engine/graph/StageNode.d.ts +9 -0
  64. package/dist/types/lib/engine/narrative/CombinedNarrativeRecorder.d.ts +9 -1
  65. package/dist/types/lib/engine/narrative/FlowRecorderDispatcher.d.ts +2 -0
  66. package/dist/types/lib/engine/narrative/NarrativeFlowRecorder.d.ts +3 -1
  67. package/dist/types/lib/engine/narrative/NullControlFlowNarrativeGenerator.d.ts +2 -0
  68. package/dist/types/lib/engine/narrative/narrativeTypes.d.ts +1 -1
  69. package/dist/types/lib/engine/narrative/types.d.ts +24 -0
  70. package/dist/types/lib/engine/types.d.ts +23 -0
  71. package/dist/types/lib/pause/index.d.ts +2 -0
  72. package/dist/types/lib/pause/types.d.ts +175 -0
  73. package/dist/types/lib/recorder/CompositeRecorder.d.ts +95 -0
  74. package/dist/types/lib/recorder/index.d.ts +2 -0
  75. package/dist/types/lib/runner/ExecutionRuntime.d.ts +4 -0
  76. package/dist/types/lib/runner/FlowChartExecutor.d.ts +78 -2
  77. package/dist/types/lib/scope/ScopeFacade.d.ts +4 -0
  78. package/dist/types/lib/scope/recorders/DebugRecorder.d.ts +20 -2
  79. package/dist/types/lib/scope/recorders/MetricRecorder.d.ts +51 -3
  80. package/dist/types/lib/scope/types.d.ts +10 -0
  81. package/dist/types/recorders.d.ts +5 -2
  82. package/package.json +1 -1
package/CLAUDE.md CHANGED
@@ -16,6 +16,8 @@ src/lib/
16
16
  ├── scope/ → Per-stage facades + recorders + providers
17
17
  ├── reactive/ → TypedScope<T> deep Proxy (typed property access, $-methods, cycle-safe)
18
18
  ├── decide/ → decide()/select() decision evidence capture (filter + function)
19
+ ├── recorder/ → CompositeRecorder composition primitives (domain presets)
20
+ ├── pause/ → Pause/Resume (PauseSignal, FlowchartCheckpoint, PausableHandler)
19
21
  ├── engine/ → DFS traversal + narrative + 13 handlers
20
22
  ├── runner/ → High-level executor (FlowChartExecutor)
21
23
  └── contract/ → I/O schema + OpenAPI generation
@@ -96,7 +98,7 @@ const chart = flowChart('Stage1', fn1, 'stage-1', undefined, 'Description')
96
98
  .build();
97
99
  ```
98
100
 
99
- Methods: `start()`, `addFunction()`, `addStreamingFunction()`, `addDeciderFunction()`, `addSelectorFunction()`, `addListOfFunction()`, `addSubFlowChart()`, `addSubFlowChartNext()`, `loopTo()`, `contract()`, `build()`, `toSpec()`, `toMermaid()`
101
+ Methods: `start()`, `addFunction()`, `addStreamingFunction()`, `addDeciderFunction()`, `addSelectorFunction()`, `addListOfFunction()`, `addPausableFunction()`, `addSubFlowChart()`, `addSubFlowChartNext()`, `loopTo()`, `contract()`, `build()`, `toSpec()`, `toMermaid()`
100
102
 
101
103
  ### ScopeFacade (Internal — use TypedScope for new code)
102
104
 
@@ -127,8 +129,49 @@ executor.getFlowNarrative() // flow-only (no data ops)
127
129
  executor.getSnapshot() // full memory state (includes recorder snapshots)
128
130
  executor.attachFlowRecorder(r) // plug flow observer
129
131
  executor.setRedactionPolicy({}) // PII protection
132
+
133
+ // Pause/Resume — human-in-the-loop
134
+ executor.isPaused() // true if last run paused
135
+ executor.getCheckpoint() // JSON-safe checkpoint (store in Redis/Postgres/etc.)
136
+ executor.resume(checkpoint, input) // continue from checkpoint with human's answer
130
137
  ```
131
138
 
139
+ ### Pause/Resume (Human-in-the-Loop)
140
+
141
+ ```typescript
142
+ import { flowChart, FlowChartExecutor } from 'footprintjs';
143
+ import type { PausableHandler } from 'footprintjs';
144
+
145
+ const handler: PausableHandler<MyState> = {
146
+ execute: async (scope) => {
147
+ // Return data = pause. Return nothing = continue.
148
+ return { question: `Approve $${scope.amount}?` };
149
+ },
150
+ resume: async (scope, input) => {
151
+ scope.approved = input.approved;
152
+ },
153
+ };
154
+
155
+ const chart = flowChart<MyState>('Seed', seedFn, 'seed')
156
+ .addPausableFunction('Approve', handler, 'approve')
157
+ .addFunction('Process', processFn, 'process')
158
+ .build();
159
+
160
+ const executor = new FlowChartExecutor(chart);
161
+ await executor.run();
162
+
163
+ if (executor.isPaused()) {
164
+ const checkpoint = executor.getCheckpoint(); // JSON-safe, store anywhere
165
+ // Later (hours, different server):
166
+ await executor.resume(checkpoint, { approved: true });
167
+ }
168
+ ```
169
+
170
+ - `execute` returns data → pauses. Returns void → continues normally (conditional pause).
171
+ - Checkpoint is JSON-serializable — no functions, no class instances.
172
+ - `resume()` reuses the execution runtime — narrative, metrics, execution tree all accumulate.
173
+ - `FlowRecorder.onPause`/`onResume` and `Recorder.onPause`/`onResume` fire on both observer systems.
174
+
132
175
  ### ComposableRunner & Snapshot Navigation
133
176
 
134
177
  ```typescript
@@ -143,6 +186,11 @@ listSubflowPaths(snapshot); // ['sf-payment', 'sf-outer/sf-inner']
143
186
 
144
187
  Both use `{ id, hooks } -> dispatcher -> error isolation -> attach/detach`. Intentionally NOT unified.
145
188
 
189
+ **Recorder ID contract:**
190
+ - `attachRecorder` is **idempotent by ID** — same ID replaces, different IDs coexist. Prevents accidental double-counting.
191
+ - Built-in recorders use auto-increment default IDs (`metrics-1`, `debug-1`, ...) so multiple instances with different configs coexist naturally.
192
+ - Frameworks that auto-attach recorders should use a well-known ID (e.g., `new MetricRecorder('metrics')`) so the consumer can override it by passing the same ID, or add a second instance with `new MetricRecorder()` (gets unique ID).
193
+
146
194
  **Scope Recorder** (data ops — fires DURING stage execution):
147
195
  - `onRead`, `onWrite`, `onCommit`, `onError`, `onStageStart`, `onStageEnd`
148
196
  - Built-in: `MetricRecorder`, `DebugRecorder`
package/dist/esm/index.js CHANGED
@@ -47,6 +47,11 @@ export { SilentNarrativeFlowRecorder } from './lib/engine/index.js';
47
47
  export { WindowedNarrativeFlowRecorder } from './lib/engine/index.js';
48
48
  /** @category Snapshot & Composition */
49
49
  export { getSubtreeSnapshot, listSubflowPaths } from './lib/runner/index.js';
50
+ // ============================================================================
51
+ // Recorder Composition — Bundle multiple recorders into domain presets
52
+ // ============================================================================
53
+ /** @category Recorder */
54
+ export { CompositeRecorder } from './lib/recorder/index.js';
50
55
  /** @category Contract & Validation */
51
56
  export { detectSchema, isValidatable, isZod } from './lib/schema/index.js';
52
57
  /** @category Contract & Validation */
@@ -60,4 +65,4 @@ export { extractErrorInfo, formatErrorInfo } from './lib/engine/index.js';
60
65
  export { disableDevMode, enableDevMode } from './lib/scope/detectCircular.js';
61
66
  /** @category Dev Tools */
62
67
  export { defineScopeFromZod } from './lib/scope/index.js';
63
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AASH,4BAA4B;AAC5B,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAQrE,4BAA4B;AAC5B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAmB3C,mCAAmC;AACnC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAYvD,oBAAoB;AACpB,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAE1D,oBAAoB;AACpB,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAoBnD,+BAA+B;AAC/B,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,+BAA+B;AAC/B,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAyBrD,+BAA+B;AAC/B,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAK9D,+BAA+B;AAC/B,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAE7D,+BAA+B;AAC/B,OAAO,EAAE,6BAA6B,EAAE,MAAM,uBAAuB,CAAC;AAEtE,+BAA+B;AAC/B,OAAO,EAAE,8BAA8B,EAAE,MAAM,uBAAuB,CAAC;AAEvE,+BAA+B;AAC/B,OAAO,EAAE,gCAAgC,EAAE,MAAM,uBAAuB,CAAC;AAEzE,+BAA+B;AAC/B,OAAO,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AAEjE,+BAA+B;AAC/B,OAAO,EAAE,6BAA6B,EAAE,MAAM,uBAAuB,CAAC;AAEtE,+BAA+B;AAC/B,OAAO,EAAE,2BAA2B,EAAE,MAAM,uBAAuB,CAAC;AAEpE,+BAA+B;AAC/B,OAAO,EAAE,6BAA6B,EAAE,MAAM,uBAAuB,CAAC;AAyBtE,uCAAuC;AACvC,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAmB7E,sCAAsC;AACtC,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAE3E,sCAAsC;AACtC,OAAO,EAAE,oBAAoB,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AASrG,gCAAgC;AAChC,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAE1E,+EAA+E;AAC/E,iDAAiD;AACjD,+EAA+E;AAE/E,0BAA0B;AAC1B,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAE9E,0BAA0B;AAC1B,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC","sourcesContent":["/**\n * FootPrint — Public API (v3)\n *\n * The flowchart pattern for backend code.\n * Build → Run → Observe.\n *\n * **Three import paths:**\n * ```ts\n * import { flowChart, decide, narrative } from 'footprintjs';           // main — start here\n * import { metrics, debug, manifest }     from 'footprintjs/recorders'; // recorder factories\n * import { SharedMemory, StageContext }   from 'footprintjs/advanced';  // internals\n * ```\n *\n * @module\n */\n\n// ============================================================================\n// Quick Start — Everything you need for 90% of use cases\n// ============================================================================\n\n/** @category Quick Start */\nexport type { FlowChart, StageFunction as StageHandler, StreamHandlers } from './lib/builder/index.js';\n\n/** @category Quick Start */\nexport { flowChart, FlowChartBuilder } from './lib/builder/index.js';\n\n/** @category Quick Start */\nexport type { TypedStageFunction } from './lib/builder/typedFlowChart.js';\n\n/** @category Quick Start */\nexport type { ScopeMethods, TypedScope } from './lib/reactive/index.js';\n\n/** @category Quick Start */\nexport { narrative } from './recorders.js';\n\n// ============================================================================\n// Decision Branching — decide() / select() with evidence capture\n// ============================================================================\n\n/** @category Decision Branching */\nexport type {\n  DecideRule,\n  DecisionEvidence,\n  DecisionResult,\n  FilterOps,\n  RuleEvidence,\n  SelectionEvidence,\n  SelectionResult,\n  WhenClause,\n  WhereFilter,\n} from './lib/decide/index.js';\n\n/** @category Decision Branching */\nexport { decide, select } from './lib/decide/index.js';\n\n// ============================================================================\n// Run — Execute charts and collect results\n// ============================================================================\n\n/** @category Run */\nexport type { RunResult } from './lib/runner/index.js';\n\n/** @category Run */\nexport type { FlowChartExecutorOptions } from './lib/runner/index.js';\n\n/** @category Run */\nexport { FlowChartExecutor } from './lib/runner/index.js';\n\n/** @category Run */\nexport { RunContext } from './lib/runner/index.js';\n\n/** @category Run */\nexport type { ChartOpenAPIOptions, MCPToolDescription, RunnableFlowChart } from './lib/runner/RunnableChart.js';\n\n// ============================================================================\n// Observe — Data (scope recorders, fire during stage execution)\n// ============================================================================\n\n/** @category Observe — Data */\nexport type {\n  CommitEvent,\n  ErrorEvent,\n  ReadEvent,\n  Recorder,\n  RedactionPolicy,\n  RedactionReport,\n  WriteEvent,\n} from './lib/scope/index.js';\n\n/** @category Observe — Data */\nexport { MetricRecorder } from './lib/scope/index.js';\n\n/** @category Observe — Data */\nexport { DebugRecorder } from './lib/scope/index.js';\n\n// ============================================================================\n// Observe — Flow (FlowRecorder, fires after stage execution)\n// ============================================================================\n\n/** @category Observe — Flow */\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';\n\n/** @category Observe — Flow */\nexport type { CombinedNarrativeEntry } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { NarrativeFlowRecorder } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport type { ManifestEntry } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { ManifestFlowRecorder } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { AdaptiveNarrativeFlowRecorder } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { MilestoneNarrativeFlowRecorder } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { ProgressiveNarrativeFlowRecorder } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { RLENarrativeFlowRecorder } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { SeparateNarrativeFlowRecorder } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { SilentNarrativeFlowRecorder } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { WindowedNarrativeFlowRecorder } from './lib/engine/index.js';\n\n// ============================================================================\n// Self-Describing — .contract(), toOpenAPI(), toMCPTool()\n// ============================================================================\n\n/** @category Self-Describing */\nexport type {\n  FlowChartContract,\n  FlowChartContractOptions,\n  JsonSchema,\n  OpenAPIOptions,\n  OpenAPISpec,\n} from './lib/contract/index.js';\n\n// ============================================================================\n// Snapshot & Composition — Subflow navigation and ComposableRunner\n// ============================================================================\n\n/** @category Snapshot & Composition */\nexport type { ComposableRunner } from './lib/runner/index.js';\n\n/** @category Snapshot & Composition */\nexport type { RecorderSnapshot, RuntimeSnapshot, SubtreeSnapshot } from './lib/runner/index.js';\n\n/** @category Snapshot & Composition */\nexport { getSubtreeSnapshot, listSubflowPaths } from './lib/runner/index.js';\n\n// ============================================================================\n// Configuration — Types passed to FlowChartExecutor and run()\n// ============================================================================\n\n/** @category Configuration */\nexport type { ExecutionEnv, RunOptions } from './lib/engine/index.js';\n\n/** @category Configuration */\nexport type { ScopeFactory } from './lib/engine/index.js';\n\n// ============================================================================\n// Contract & Validation\n// ============================================================================\n\n/** @category Contract & Validation */\nexport type { SchemaKind, ValidationIssue, ValidationResult } from './lib/schema/index.js';\n\n/** @category Contract & Validation */\nexport { detectSchema, isValidatable, isZod } from './lib/schema/index.js';\n\n/** @category Contract & Validation */\nexport { InputValidationError, validateAgainstSchema, validateOrThrow } from './lib/schema/index.js';\n\n// ============================================================================\n// Error Utilities\n// ============================================================================\n\n/** @category Error Utilities */\nexport type { StructuredErrorInfo } from './lib/engine/index.js';\n\n/** @category Error Utilities */\nexport { extractErrorInfo, formatErrorInfo } from './lib/engine/index.js';\n\n// ============================================================================\n// Dev Tools — Mode flags and Zod scope utilities\n// ============================================================================\n\n/** @category Dev Tools */\nexport { disableDevMode, enableDevMode } from './lib/scope/detectCircular.js';\n\n/** @category Dev Tools */\nexport { defineScopeFromZod } from './lib/scope/index.js';\n"]}
68
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AASH,4BAA4B;AAC5B,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAQrE,4BAA4B;AAC5B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAmB3C,mCAAmC;AACnC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAYvD,oBAAoB;AACpB,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAE1D,oBAAoB;AACpB,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAoBnD,+BAA+B;AAC/B,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,+BAA+B;AAC/B,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAyBrD,+BAA+B;AAC/B,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAK9D,+BAA+B;AAC/B,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAE7D,+BAA+B;AAC/B,OAAO,EAAE,6BAA6B,EAAE,MAAM,uBAAuB,CAAC;AAEtE,+BAA+B;AAC/B,OAAO,EAAE,8BAA8B,EAAE,MAAM,uBAAuB,CAAC;AAEvE,+BAA+B;AAC/B,OAAO,EAAE,gCAAgC,EAAE,MAAM,uBAAuB,CAAC;AAEzE,+BAA+B;AAC/B,OAAO,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AAEjE,+BAA+B;AAC/B,OAAO,EAAE,6BAA6B,EAAE,MAAM,uBAAuB,CAAC;AAEtE,+BAA+B;AAC/B,OAAO,EAAE,2BAA2B,EAAE,MAAM,uBAAuB,CAAC;AAEpE,+BAA+B;AAC/B,OAAO,EAAE,6BAA6B,EAAE,MAAM,uBAAuB,CAAC;AAyBtE,uCAAuC;AACvC,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAE7E,+EAA+E;AAC/E,uEAAuE;AACvE,+EAA+E;AAE/E,yBAAyB;AACzB,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AA8B5D,sCAAsC;AACtC,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAE3E,sCAAsC;AACtC,OAAO,EAAE,oBAAoB,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AASrG,gCAAgC;AAChC,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAE1E,+EAA+E;AAC/E,iDAAiD;AACjD,+EAA+E;AAE/E,0BAA0B;AAC1B,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAE9E,0BAA0B;AAC1B,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC","sourcesContent":["/**\n * FootPrint — Public API (v3)\n *\n * The flowchart pattern for backend code.\n * Build → Run → Observe.\n *\n * **Three import paths:**\n * ```ts\n * import { flowChart, decide, narrative } from 'footprintjs';           // main — start here\n * import { metrics, debug, manifest }     from 'footprintjs/recorders'; // recorder factories\n * import { SharedMemory, StageContext }   from 'footprintjs/advanced';  // internals\n * ```\n *\n * @module\n */\n\n// ============================================================================\n// Quick Start — Everything you need for 90% of use cases\n// ============================================================================\n\n/** @category Quick Start */\nexport type { FlowChart, StageFunction as StageHandler, StreamHandlers } from './lib/builder/index.js';\n\n/** @category Quick Start */\nexport { flowChart, FlowChartBuilder } from './lib/builder/index.js';\n\n/** @category Quick Start */\nexport type { TypedStageFunction } from './lib/builder/typedFlowChart.js';\n\n/** @category Quick Start */\nexport type { ScopeMethods, TypedScope } from './lib/reactive/index.js';\n\n/** @category Quick Start */\nexport { narrative } from './recorders.js';\n\n// ============================================================================\n// Decision Branching — decide() / select() with evidence capture\n// ============================================================================\n\n/** @category Decision Branching */\nexport type {\n  DecideRule,\n  DecisionEvidence,\n  DecisionResult,\n  FilterOps,\n  RuleEvidence,\n  SelectionEvidence,\n  SelectionResult,\n  WhenClause,\n  WhereFilter,\n} from './lib/decide/index.js';\n\n/** @category Decision Branching */\nexport { decide, select } from './lib/decide/index.js';\n\n// ============================================================================\n// Run — Execute charts and collect results\n// ============================================================================\n\n/** @category Run */\nexport type { RunResult } from './lib/runner/index.js';\n\n/** @category Run */\nexport type { FlowChartExecutorOptions } from './lib/runner/index.js';\n\n/** @category Run */\nexport { FlowChartExecutor } from './lib/runner/index.js';\n\n/** @category Run */\nexport { RunContext } from './lib/runner/index.js';\n\n/** @category Run */\nexport type { ChartOpenAPIOptions, MCPToolDescription, RunnableFlowChart } from './lib/runner/RunnableChart.js';\n\n// ============================================================================\n// Observe — Data (scope recorders, fire during stage execution)\n// ============================================================================\n\n/** @category Observe — Data */\nexport type {\n  CommitEvent,\n  ErrorEvent,\n  ReadEvent,\n  Recorder,\n  RedactionPolicy,\n  RedactionReport,\n  WriteEvent,\n} from './lib/scope/index.js';\n\n/** @category Observe — Data */\nexport { MetricRecorder } from './lib/scope/index.js';\n\n/** @category Observe — Data */\nexport { DebugRecorder } from './lib/scope/index.js';\n\n// ============================================================================\n// Observe — Flow (FlowRecorder, fires after stage execution)\n// ============================================================================\n\n/** @category Observe — Flow */\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';\n\n/** @category Observe — Flow */\nexport type { CombinedNarrativeEntry } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { NarrativeFlowRecorder } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport type { ManifestEntry } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { ManifestFlowRecorder } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { AdaptiveNarrativeFlowRecorder } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { MilestoneNarrativeFlowRecorder } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { ProgressiveNarrativeFlowRecorder } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { RLENarrativeFlowRecorder } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { SeparateNarrativeFlowRecorder } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { SilentNarrativeFlowRecorder } from './lib/engine/index.js';\n\n/** @category Observe — Flow */\nexport { WindowedNarrativeFlowRecorder } from './lib/engine/index.js';\n\n// ============================================================================\n// Self-Describing — .contract(), toOpenAPI(), toMCPTool()\n// ============================================================================\n\n/** @category Self-Describing */\nexport type {\n  FlowChartContract,\n  FlowChartContractOptions,\n  JsonSchema,\n  OpenAPIOptions,\n  OpenAPISpec,\n} from './lib/contract/index.js';\n\n// ============================================================================\n// Snapshot & Composition — Subflow navigation and ComposableRunner\n// ============================================================================\n\n/** @category Snapshot & Composition */\nexport type { ComposableRunner } from './lib/runner/index.js';\n\n/** @category Snapshot & Composition */\nexport type { RecorderSnapshot, RuntimeSnapshot, SubtreeSnapshot } from './lib/runner/index.js';\n\n/** @category Snapshot & Composition */\nexport { getSubtreeSnapshot, listSubflowPaths } from './lib/runner/index.js';\n\n// ============================================================================\n// Recorder Composition — Bundle multiple recorders into domain presets\n// ============================================================================\n\n/** @category Recorder */\nexport { CompositeRecorder } from './lib/recorder/index.js';\n\n// ============================================================================\n// Pause/Resume — Serializable checkpoints for long-running or human-in-the-loop flows\n// ============================================================================\n\n/** @category Pause/Resume */\n/** @category Pause/Resume */\nexport type { FlowchartCheckpoint, PausableHandler } from './lib/pause/index.js';\n\n/** @category Recorder */\nexport type { CompositeSnapshot } from './lib/recorder/index.js';\n\n// ============================================================================\n// Configuration — Types passed to FlowChartExecutor and run()\n// ============================================================================\n\n/** @category Configuration */\nexport type { ExecutionEnv, ExecutorResult, PausedResult, RunOptions } from './lib/engine/index.js';\n\n/** @category Configuration */\nexport type { ScopeFactory } from './lib/engine/index.js';\n\n// ============================================================================\n// Contract & Validation\n// ============================================================================\n\n/** @category Contract & Validation */\nexport type { SchemaKind, ValidationIssue, ValidationResult } from './lib/schema/index.js';\n\n/** @category Contract & Validation */\nexport { detectSchema, isValidatable, isZod } from './lib/schema/index.js';\n\n/** @category Contract & Validation */\nexport { InputValidationError, validateAgainstSchema, validateOrThrow } from './lib/schema/index.js';\n\n// ============================================================================\n// Error Utilities\n// ============================================================================\n\n/** @category Error Utilities */\nexport type { StructuredErrorInfo } from './lib/engine/index.js';\n\n/** @category Error Utilities */\nexport { extractErrorInfo, formatErrorInfo } from './lib/engine/index.js';\n\n// ============================================================================\n// Dev Tools — Mode flags and Zod scope utilities\n// ============================================================================\n\n/** @category Dev Tools */\nexport { disableDevMode, enableDevMode } from './lib/scope/detectCircular.js';\n\n/** @category Dev Tools */\nexport { defineScopeFromZod } from './lib/scope/index.js';\n"]}