footprintjs 3.0.13 → 3.0.14

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/dist/advanced.js CHANGED
@@ -1,4 +1,17 @@
1
1
  "use strict";
2
+ /**
3
+ * footprintjs/advanced — Low-level internals for custom execution engines and testing.
4
+ *
5
+ * Most users never need this. Use `footprintjs` (main) instead.
6
+ * This entry point exposes `SharedMemory`, `StageContext`, `FlowchartTraverser`,
7
+ * and other primitives that power the engine.
8
+ *
9
+ * ```ts
10
+ * import { SharedMemory, StageContext } from 'footprintjs/advanced';
11
+ * ```
12
+ *
13
+ * @module advanced
14
+ */
2
15
  /**
3
16
  * FootPrint — Advanced / Internal API
4
17
  *
@@ -90,4 +103,4 @@ Object.defineProperty(exports, "seedSubflowGlobalStore", { enumerable: true, get
90
103
  Object.defineProperty(exports, "SelectorHandler", { enumerable: true, get: function () { return index_js_17.SelectorHandler; } });
91
104
  Object.defineProperty(exports, "StageRunner", { enumerable: true, get: function () { return index_js_17.StageRunner; } });
92
105
  Object.defineProperty(exports, "SubflowExecutor", { enumerable: true, get: function () { return index_js_17.SubflowExecutor; } });
93
- //# 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;AACrD,qEAA0F;AAAjF,4HAAA,uBAAuB,OAAA;AAAE,mHAAA,cAAc,OAAA;AAahD,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';\nexport { createTypedScopeFactory, typedFlowChart } from './lib/builder/typedFlowChart.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"]}
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"advanced.js","sourceRoot":"","sources":["../src/advanced.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;GAYG;AACH;;;;;;;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;AACrD,qEAA0F;AAAjF,4HAAA,uBAAuB,OAAA;AAAE,mHAAA,cAAc,OAAA;AAahD,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 * footprintjs/advanced — Low-level internals for custom execution engines and testing.\n *\n * Most users never need this. Use `footprintjs` (main) instead.\n * This entry point exposes `SharedMemory`, `StageContext`, `FlowchartTraverser`,\n * and other primitives that power the engine.\n *\n * ```ts\n * import { SharedMemory, StageContext } from 'footprintjs/advanced';\n * ```\n *\n * @module advanced\n */\n/**\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';\nexport { createTypedScopeFactory, typedFlowChart } from './lib/builder/typedFlowChart.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"]}
@@ -1,3 +1,16 @@
1
+ /**
2
+ * footprintjs/advanced — Low-level internals for custom execution engines and testing.
3
+ *
4
+ * Most users never need this. Use `footprintjs` (main) instead.
5
+ * This entry point exposes `SharedMemory`, `StageContext`, `FlowchartTraverser`,
6
+ * and other primitives that power the engine.
7
+ *
8
+ * ```ts
9
+ * import { SharedMemory, StageContext } from 'footprintjs/advanced';
10
+ * ```
11
+ *
12
+ * @module advanced
13
+ */
1
14
  /**
2
15
  * FootPrint — Advanced / Internal API
3
16
  *
@@ -25,4 +38,4 @@ export { isStageNodeReturn } from './lib/engine/index.js';
25
38
  export { ControlFlowNarrativeGenerator } from './lib/engine/index.js';
26
39
  export { NullControlFlowNarrativeGenerator } from './lib/engine/index.js';
27
40
  export { applyOutputMapping, ChildrenExecutor, computeNodeType, ContinuationResolver, createSubflowHandlerDeps, DeciderHandler, DEFAULT_MAX_ITERATIONS, ExtractorRunner, extractParentScopeValues, getInitialScopeValues, NodeResolver, RuntimeStructureManager, seedSubflowGlobalStore, SelectorHandler, StageRunner, SubflowExecutor, } from './lib/engine/index.js';
28
- //# 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;AACtF,OAAO,EAAE,uBAAuB,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AAa1F,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';\nexport { createTypedScopeFactory, typedFlowChart } from './lib/builder/typedFlowChart.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"]}
41
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"advanced.js","sourceRoot":"","sources":["../../src/advanced.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AACH;;;;;;;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;AACtF,OAAO,EAAE,uBAAuB,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AAa1F,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 * footprintjs/advanced — Low-level internals for custom execution engines and testing.\n *\n * Most users never need this. Use `footprintjs` (main) instead.\n * This entry point exposes `SharedMemory`, `StageContext`, `FlowchartTraverser`,\n * and other primitives that power the engine.\n *\n * ```ts\n * import { SharedMemory, StageContext } from 'footprintjs/advanced';\n * ```\n *\n * @module advanced\n */\n/**\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';\nexport { createTypedScopeFactory, typedFlowChart } from './lib/builder/typedFlowChart.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
@@ -1,39 +1,65 @@
1
1
  /**
2
- * FootPrint — Public API (v2.0)
2
+ * FootPrint — Public API (v3)
3
3
  *
4
4
  * The flowchart pattern for backend code.
5
- * Build → DescribeRun.
5
+ * Build → RunObserve.
6
6
  *
7
- * For advanced/internal APIs, import from 'footprintjs/advanced'.
8
- * For recorder factories, import from 'footprintjs/recorders'.
7
+ * **Three import paths:**
8
+ * ```ts
9
+ * import { flowChart, decide, narrative } from 'footprintjs'; // main — start here
10
+ * import { metrics, debug, manifest } from 'footprintjs/recorders'; // recorder factories
11
+ * import { SharedMemory, StageContext } from 'footprintjs/advanced'; // internals
12
+ * ```
13
+ *
14
+ * @module
9
15
  */
16
+ /** @category Quick Start */
10
17
  export { flowChart, FlowChartBuilder } from './lib/builder/index.js';
18
+ /** @category Quick Start */
19
+ export { narrative } from './recorders.js';
20
+ /** @category Decision Branching */
11
21
  export { decide, select } from './lib/decide/index.js';
22
+ /** @category Run */
12
23
  export { FlowChartExecutor } from './lib/runner/index.js';
24
+ /** @category Run */
13
25
  export { RunContext } from './lib/runner/index.js';
14
- export { narrative } from './recorders.js';
15
- export { getSubtreeSnapshot, listSubflowPaths } from './lib/runner/index.js';
16
- // ============================================================================
17
- // Scope — Per-stage facades and recorders
18
- // ============================================================================
19
- export { ScopeFacade } from './lib/scope/index.js';
20
- // Dev-mode diagnostics
21
- export { disableDevMode, enableDevMode } from './lib/scope/detectCircular.js';
22
- // Recorders (class exports — prefer factory functions from footprintjs/recorders)
26
+ /** @category Observe Data */
23
27
  export { MetricRecorder } from './lib/scope/index.js';
28
+ /** @category Observe — Data */
24
29
  export { DebugRecorder } from './lib/scope/index.js';
25
- // Zod-based scope definitions
26
- export { defineScopeFromZod } from './lib/scope/index.js';
30
+ /** @category Observe — Flow */
27
31
  export { NarrativeFlowRecorder } from './lib/engine/index.js';
28
- export { extractErrorInfo, formatErrorInfo } from './lib/engine/index.js';
32
+ /** @category Observe Flow */
29
33
  export { ManifestFlowRecorder } from './lib/engine/index.js';
34
+ /** @category Observe — Flow */
30
35
  export { AdaptiveNarrativeFlowRecorder } from './lib/engine/index.js';
36
+ /** @category Observe — Flow */
31
37
  export { MilestoneNarrativeFlowRecorder } from './lib/engine/index.js';
38
+ /** @category Observe — Flow */
32
39
  export { ProgressiveNarrativeFlowRecorder } from './lib/engine/index.js';
40
+ /** @category Observe — Flow */
33
41
  export { RLENarrativeFlowRecorder } from './lib/engine/index.js';
42
+ /** @category Observe — Flow */
34
43
  export { SeparateNarrativeFlowRecorder } from './lib/engine/index.js';
44
+ /** @category Observe — Flow */
35
45
  export { SilentNarrativeFlowRecorder } from './lib/engine/index.js';
46
+ /** @category Observe — Flow */
36
47
  export { WindowedNarrativeFlowRecorder } from './lib/engine/index.js';
48
+ /** @category Snapshot & Composition */
49
+ export { getSubtreeSnapshot, listSubflowPaths } from './lib/runner/index.js';
50
+ /** @category Contract & Validation */
37
51
  export { detectSchema, isValidatable, isZod } from './lib/schema/index.js';
52
+ /** @category Contract & Validation */
38
53
  export { InputValidationError, validateAgainstSchema, validateOrThrow } from './lib/schema/index.js';
39
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAOH,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAerE,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAUvD,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAEnD,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAO3C,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,kFAAkF;AAClF,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;AA0BtE,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 (v2.0)\n *\n * The flowchart pattern for backend code.\n * Build → Describe → Run.\n *\n * For advanced/internal APIs, import from 'footprintjs/advanced'.\n * For recorder factories, import from 'footprintjs/recorders'.\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 type { ScopeMethods, TypedScope } 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 — v2 API: chart.recorder().run()\n// ============================================================================\n\n// narrative() — core recorder factory, exported here for the common case:\n//   import { flowChart, decide, narrative } from 'footprintjs';\n//   const result = await chart.recorder(narrative()).run();\nexport type { RunResult } from './lib/runner/index.js';\nexport { FlowChartExecutor } from './lib/runner/index.js';\nexport { RunContext } from './lib/runner/index.js';\nexport type { ChartOpenAPIOptions, MCPToolDescription, RunnableFlowChart } from './lib/runner/RunnableChart.js';\nexport { narrative } from './recorders.js';\n\n// ComposableRunner — interface for subflow composition\nexport type { ComposableRunner } from './lib/runner/index.js';\n\n// Snapshot navigation\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 (class exports — prefer factory functions from footprintjs/recorders)\nexport { MetricRecorder } from './lib/scope/index.js';\nexport { DebugRecorder } from './lib/scope/index.js';\n\n// Recorder interface and event types (for custom recorders)\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 types\n// ============================================================================\n\nexport type { CombinedNarrativeEntry } from './lib/engine/index.js';\n\n// FlowRecorder — Pluggable observer for control flow events\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 errors\nexport type { StructuredErrorInfo } from './lib/engine/index.js';\nexport { extractErrorInfo, formatErrorInfo } from './lib/engine/index.js';\n\n// Built-in FlowRecorder strategies (prefer factory functions from footprintjs/recorders)\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// Engine types\n// ============================================================================\n\nexport type { ExecutionEnv, RunOptions } from './lib/engine/index.js';\nexport type { ScopeFactory } from './lib/engine/index.js';\n\n// ============================================================================\n// Contract types (use .contract() on builder + chart.toOpenAPI() instead)\n// ============================================================================\n\nexport type {\n  FlowChartContract,\n  FlowChartContractOptions,\n  JsonSchema,\n  OpenAPIOptions,\n  OpenAPISpec,\n} from './lib/contract/index.js';\n\n// ============================================================================\n// Schema — Validation\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"]}
54
+ /** @category Error Utilities */
55
+ export { extractErrorInfo, formatErrorInfo } from './lib/engine/index.js';
56
+ // ============================================================================
57
+ // Dev Tools — Mode flags and Zod scope utilities
58
+ // ============================================================================
59
+ /** @category Dev Tools */
60
+ export { disableDevMode, enableDevMode } from './lib/scope/detectCircular.js';
61
+ /** @category Dev Tools */
62
+ export { defineScopeFromZod } from './lib/scope/index.js';
63
+ /** @category Dev Tools */
64
+ export { ScopeFacade } from './lib/scope/index.js';
65
+ //# 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;AASvD,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;AAE1D,0BAA0B;AAC1B,OAAO,EAAE,WAAW,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 { 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\n/** @category Dev Tools */\nexport { ScopeFacade } from './lib/scope/index.js';\n"]}
@@ -100,4 +100,4 @@ function normalizeSchema(schema) {
100
100
  }
101
101
  return schema;
102
102
  }
103
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RunnableChart.js","sourceRoot":"","sources":["../../../../src/lib/runner/RunnableChart.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * RunnableChart -- Adds .recorder(), .redact(), .run(), .toOpenAPI(), .toMCPTool()\n * to a FlowChart object.\n *\n * Called by FlowChartBuilder.build() to enrich the compiled chart with\n * d3-style chainable run methods and self-describing outputs.\n */\n\nimport { zodToJsonSchema } from '../contract/schema.js';\nimport type { FlowRecorder } from '../engine/narrative/types.js';\nimport type { FlowChart, RunOptions, SerializedPipelineStructure } from '../engine/types.js';\nimport type { Recorder, RedactionPolicy } from '../scope/types.js';\nimport { type RunResult, RunContext } from './RunContext.js';\n\n/** OpenAPI generation options. */\nexport interface ChartOpenAPIOptions {\n  title?: string;\n  version?: string;\n  description?: string;\n  path?: string;\n}\n\n/** MCP tool description. */\nexport interface MCPToolDescription {\n  name: string;\n  description: string;\n  inputSchema?: unknown;\n}\n\n/** FlowChart with d3-style methods: run, recorder, redact, toOpenAPI, toMCPTool. */\nexport interface RunnableFlowChart<TOut = any, TScope = any> extends FlowChart<TOut, TScope> {\n  // ── Builder metadata (set by FlowChartBuilder.build()) ──────────────────\n  /** Always set by build() — narrows the optional field from FlowChart to required. */\n  buildTimeStructure: SerializedPipelineStructure;\n  /** Human-readable numbered step list. Empty string when no descriptions were provided. */\n  description: string;\n  /** Per-stage descriptions, keyed by stage name. */\n  stageDescriptions: Map<string, string>;\n  /** Output schema (Zod or JSON Schema) — declared via .contract(). */\n  outputSchema?: unknown;\n  /** Output mapper — extracts response from final scope. Declared via .contract(). */\n  outputMapper?: (finalScope: Record<string, unknown>) => unknown;\n  // ── Runtime methods ──────────────────────────────────────────────────────\n  /** Attach a recorder for the next run. Returns a chainable RunContext. */\n  recorder(r: Recorder | FlowRecorder): RunContext<TOut, TScope>;\n  /** Set redaction policy for the next run. Returns a chainable RunContext. */\n  redact(policy: RedactionPolicy): RunContext<TOut, TScope>;\n  /** Execute the chart directly (bare run, no recorders). */\n  run(options?: RunOptions): Promise<RunResult>;\n  /** Generate OpenAPI 3.1 spec from chart metadata + contract. Cached. */\n  toOpenAPI(options?: ChartOpenAPIOptions): object;\n  /** Generate MCP tool description from chart metadata. Cached. */\n  toMCPTool(): MCPToolDescription;\n}\n\n// Caches for describe outputs\nconst openAPICache = new WeakMap<FlowChart, object>();\nconst mcpCache = new WeakMap<FlowChart, MCPToolDescription>();\n\n/**\n * Enrich a FlowChart with run + describe methods.\n * Called by FlowChartBuilder.build().\n */\nexport function makeRunnable<TOut, TScope>(chart: FlowChart<TOut, TScope>): RunnableFlowChart<TOut, TScope> {\n  const runnable = chart as RunnableFlowChart<TOut, TScope>;\n\n  runnable.recorder = function (r: Recorder | FlowRecorder): RunContext<TOut, TScope> {\n    return new RunContext(chart).recorder(r);\n  };\n\n  runnable.redact = function (policy: RedactionPolicy): RunContext<TOut, TScope> {\n    return new RunContext(chart).redact(policy);\n  };\n\n  runnable.run = function (options?: RunOptions): Promise<RunResult> {\n    return new RunContext(chart).run(options);\n  };\n\n  runnable.toOpenAPI = function (options?: ChartOpenAPIOptions): object {\n    const cached = openAPICache.get(chart);\n    if (cached) return cached;\n\n    const builderChart = chart as any;\n    const title = options?.title ?? builderChart.description?.split('\\n')[0] ?? 'API';\n    const version = options?.version ?? '1.0.0';\n    const path = options?.path ?? `/${(builderChart.root?.name ?? 'execute').toLowerCase().replace(/\\s+/g, '-')}`;\n\n    const spec: Record<string, unknown> = {\n      openapi: '3.1.0',\n      info: { title, version, description: options?.description ?? builderChart.description },\n      paths: {\n        [path]: {\n          post: {\n            summary: title,\n            description: builderChart.description,\n            ...(builderChart.inputSchema\n              ? {\n                  requestBody: {\n                    content: { 'application/json': { schema: normalizeSchema(builderChart.inputSchema) } },\n                  },\n                }\n              : {}),\n            responses: {\n              '200': {\n                description: 'Success',\n                ...(builderChart.outputSchema\n                  ? { content: { 'application/json': { schema: normalizeSchema(builderChart.outputSchema) } } }\n                  : {}),\n              },\n            },\n          },\n        },\n      },\n    };\n\n    openAPICache.set(chart, spec);\n    return spec;\n  };\n\n  runnable.toMCPTool = function (): MCPToolDescription {\n    const cached = mcpCache.get(chart);\n    if (cached) return cached;\n\n    const builderChart = chart as any;\n    const name = (builderChart.root?.name ?? 'execute').toLowerCase().replace(/\\s+/g, '_');\n    const description = builderChart.description || `Execute the ${name} flowchart`;\n\n    const tool: MCPToolDescription = {\n      name,\n      description,\n      ...(builderChart.inputSchema ? { inputSchema: normalizeSchema(builderChart.inputSchema) } : {}),\n    };\n\n    mcpCache.set(chart, tool);\n    return tool;\n  };\n\n  return runnable;\n}\n\n/** Normalize a Zod schema or plain JSON Schema to JSON Schema object. */\nfunction normalizeSchema(schema: unknown): unknown {\n  if (!schema) return schema;\n  // If it's a Zod schema with ._def, convert to JSON Schema\n  if (\n    typeof schema === 'object' &&\n    schema !== null &&\n    typeof (schema as Record<string, unknown>)._def !== 'undefined'\n  ) {\n    try {\n      return zodToJsonSchema(schema as Record<string, unknown>);\n    } catch {\n      // If conversion fails (e.g. unsupported Zod type), return as-is\n      return schema;\n    }\n  }\n  return schema;\n}\n"]}
103
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RunnableChart.js","sourceRoot":"","sources":["../../../../src/lib/runner/RunnableChart.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * RunnableChart -- Adds .recorder(), .redact(), .run(), .toOpenAPI(), .toMCPTool()\n * to a FlowChart object.\n *\n * Called by FlowChartBuilder.build() to enrich the compiled chart with\n * d3-style chainable run methods and self-describing outputs.\n */\n\nimport type { FlowChart } from '../builder/types.js';\nimport { zodToJsonSchema } from '../contract/schema.js';\nimport type { FlowRecorder } from '../engine/narrative/types.js';\nimport type { RunOptions } from '../engine/types.js';\nimport type { Recorder, RedactionPolicy } from '../scope/types.js';\nimport { type RunResult, RunContext } from './RunContext.js';\n\n/** OpenAPI generation options. */\nexport interface ChartOpenAPIOptions {\n  title?: string;\n  version?: string;\n  description?: string;\n  path?: string;\n}\n\n/** MCP tool description. */\nexport interface MCPToolDescription {\n  name: string;\n  description: string;\n  inputSchema?: unknown;\n}\n\n/**\n * FlowChart enriched with d3-style run methods and self-describing outputs.\n *\n * Extends builder.FlowChart (which already carries buildTimeStructure, description,\n * stageDescriptions, inputSchema, outputSchema, outputMapper) and adds the runtime\n * methods attached by makeRunnable().\n */\nexport interface RunnableFlowChart<TOut = any, TScope = any> extends FlowChart<TOut, TScope> {\n  /** Attach a recorder for the next run. Returns a chainable RunContext. */\n  recorder(r: Recorder | FlowRecorder): RunContext<TOut, TScope>;\n  /** Set redaction policy for the next run. Returns a chainable RunContext. */\n  redact(policy: RedactionPolicy): RunContext<TOut, TScope>;\n  /** Execute the chart directly (bare run, no recorders). */\n  run(options?: RunOptions): Promise<RunResult>;\n  /** Generate OpenAPI 3.1 spec from chart metadata + contract. Cached. */\n  toOpenAPI(options?: ChartOpenAPIOptions): object;\n  /** Generate MCP tool description from chart metadata. Cached. */\n  toMCPTool(): MCPToolDescription;\n}\n\n// Caches for describe outputs\nconst openAPICache = new WeakMap<FlowChart, object>();\nconst mcpCache = new WeakMap<FlowChart, MCPToolDescription>();\n\n/**\n * Enrich a FlowChart with run + describe methods.\n * Called by FlowChartBuilder.build().\n */\nexport function makeRunnable<TOut, TScope>(chart: FlowChart<TOut, TScope>): RunnableFlowChart<TOut, TScope> {\n  const runnable = chart as RunnableFlowChart<TOut, TScope>;\n\n  runnable.recorder = function (r: Recorder | FlowRecorder): RunContext<TOut, TScope> {\n    return new RunContext(chart).recorder(r);\n  };\n\n  runnable.redact = function (policy: RedactionPolicy): RunContext<TOut, TScope> {\n    return new RunContext(chart).redact(policy);\n  };\n\n  runnable.run = function (options?: RunOptions): Promise<RunResult> {\n    return new RunContext(chart).run(options);\n  };\n\n  runnable.toOpenAPI = function (options?: ChartOpenAPIOptions): object {\n    const cached = openAPICache.get(chart);\n    if (cached) return cached;\n\n    const builderChart = chart as any;\n    const title = options?.title ?? builderChart.description?.split('\\n')[0] ?? 'API';\n    const version = options?.version ?? '1.0.0';\n    const path = options?.path ?? `/${(builderChart.root?.name ?? 'execute').toLowerCase().replace(/\\s+/g, '-')}`;\n\n    const spec: Record<string, unknown> = {\n      openapi: '3.1.0',\n      info: { title, version, description: options?.description ?? builderChart.description },\n      paths: {\n        [path]: {\n          post: {\n            summary: title,\n            description: builderChart.description,\n            ...(builderChart.inputSchema\n              ? {\n                  requestBody: {\n                    content: { 'application/json': { schema: normalizeSchema(builderChart.inputSchema) } },\n                  },\n                }\n              : {}),\n            responses: {\n              '200': {\n                description: 'Success',\n                ...(builderChart.outputSchema\n                  ? { content: { 'application/json': { schema: normalizeSchema(builderChart.outputSchema) } } }\n                  : {}),\n              },\n            },\n          },\n        },\n      },\n    };\n\n    openAPICache.set(chart, spec);\n    return spec;\n  };\n\n  runnable.toMCPTool = function (): MCPToolDescription {\n    const cached = mcpCache.get(chart);\n    if (cached) return cached;\n\n    const builderChart = chart as any;\n    const name = (builderChart.root?.name ?? 'execute').toLowerCase().replace(/\\s+/g, '_');\n    const description = builderChart.description || `Execute the ${name} flowchart`;\n\n    const tool: MCPToolDescription = {\n      name,\n      description,\n      ...(builderChart.inputSchema ? { inputSchema: normalizeSchema(builderChart.inputSchema) } : {}),\n    };\n\n    mcpCache.set(chart, tool);\n    return tool;\n  };\n\n  return runnable;\n}\n\n/** Normalize a Zod schema or plain JSON Schema to JSON Schema object. */\nfunction normalizeSchema(schema: unknown): unknown {\n  if (!schema) return schema;\n  // If it's a Zod schema with ._def, convert to JSON Schema\n  if (\n    typeof schema === 'object' &&\n    schema !== null &&\n    typeof (schema as Record<string, unknown>)._def !== 'undefined'\n  ) {\n    try {\n      return zodToJsonSchema(schema as Record<string, unknown>);\n    } catch {\n      // If conversion fails (e.g. unsupported Zod type), return as-is\n      return schema;\n    }\n  }\n  return schema;\n}\n"]}
@@ -1,3 +1,20 @@
1
+ /**
2
+ * footprintjs/recorders — Factory functions for built-in recorders.
3
+ *
4
+ * Prefer these factory functions over constructing recorder classes directly.
5
+ * Each factory returns the recorder instance enriched with short convenience methods.
6
+ *
7
+ * ```ts
8
+ * import { narrative, metrics, debug, manifest } from 'footprintjs/recorders';
9
+ *
10
+ * const result = await chart
11
+ * .recorder(narrative())
12
+ * .recorder(metrics())
13
+ * .run();
14
+ * ```
15
+ *
16
+ * @module recorders
17
+ */
1
18
  /**
2
19
  * footprintjs/recorders -- Factory functions for built-in recorders.
3
20
  *
@@ -66,4 +83,4 @@ export function milestone() {
66
83
  export function windowed(maxEntries) {
67
84
  return new WindowedNarrativeFlowRecorder(maxEntries);
68
85
  }
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkZXJzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3JlY29yZGVycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7OztHQU9HO0FBR0gsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0scURBQXFELENBQUM7QUFDaEcsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sbUVBQW1FLENBQUM7QUFFbEgsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMERBQTBELENBQUM7QUFDaEcsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sb0VBQW9FLENBQUM7QUFDcEgsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sbUVBQW1FLENBQUM7QUFFbEgsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBRXZFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQVN6RSxNQUFNLFVBQVUsU0FBUztJQUN2QixNQUFNLEdBQUcsR0FBRyxJQUFJLHlCQUF5QixFQUF1QixDQUFDO0lBQ2pFLEdBQUcsQ0FBQyxLQUFLLEdBQUc7UUFDVixPQUFPLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUM3QixDQUFDLENBQUM7SUFDRixHQUFHLENBQUMsVUFBVSxHQUFHO1FBQ2YsT0FBTyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDM0IsQ0FBQyxDQUFDO0lBQ0YsT0FBTyxHQUFHLENBQUM7QUFDYixDQUFDO0FBWUQsTUFBTSxVQUFVLE9BQU87SUFDckIsTUFBTSxHQUFHLEdBQUcsSUFBSSxjQUFjLEVBQXFCLENBQUM7SUFDcEQsR0FBRyxDQUFDLEtBQUssR0FBRztRQUNWLE9BQU8sSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDLFVBQVUsQ0FBQztJQUN0QyxDQUFDLENBQUM7SUFDRixHQUFHLENBQUMsTUFBTSxHQUFHO1FBQ1gsT0FBTyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUMsV0FBVyxDQUFDO0lBQ3ZDLENBQUMsQ0FBQztJQUNGLEdBQUcsQ0FBQyxPQUFPLEdBQUc7UUFDWixPQUFPLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQyxZQUFZLENBQUM7SUFDeEMsQ0FBQyxDQUFDO0lBQ0YsR0FBRyxDQUFDLEtBQUssR0FBRyxVQUFnQyxJQUFZO1FBQ3RELE9BQU8sSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNwQyxDQUFDLENBQUM7SUFDRixHQUFHLENBQUMsR0FBRyxHQUFHO1FBQ1IsT0FBTyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDM0IsQ0FBQyxDQUFDO0lBQ0YsT0FBTyxHQUFHLENBQUM7QUFDYixDQUFDO0FBUUQsTUFBTSxVQUFVLEtBQUssQ0FBQyxPQUE4QjtJQUNsRCxNQUFNLEdBQUcsR0FBRyxJQUFJLGFBQWEsQ0FBQyxPQUFPLENBQWtCLENBQUM7SUFDeEQsR0FBRyxDQUFDLElBQUksR0FBRztRQUNULE9BQU8sSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQzNCLENBQUMsQ0FBQztJQUNGLE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQztBQVFELE1BQU0sVUFBVSxRQUFRO0lBQ3RCLE1BQU0sR0FBRyxHQUFHLElBQUksb0JBQW9CLEVBQXNCLENBQUM7SUFDM0QsR0FBRyxDQUFDLE9BQU8sR0FBRztRQUNaLE9BQU8sSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQzVCLENBQUMsQ0FBQztJQUNGLE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQztBQUVELHFDQUFxQztBQUVyQyxNQUFNLFVBQVUsUUFBUTtJQUN0QixPQUFPLElBQUksNkJBQTZCLEVBQUUsQ0FBQztBQUM3QyxDQUFDO0FBQ0QsTUFBTSxVQUFVLFNBQVM7SUFDdkIsT0FBTyxJQUFJLDhCQUE4QixFQUFFLENBQUM7QUFDOUMsQ0FBQztBQUNELE1BQU0sVUFBVSxRQUFRLENBQUMsVUFBbUI7SUFDMUMsT0FBTyxJQUFJLDZCQUE2QixDQUFDLFVBQVUsQ0FBQyxDQUFDO0FBQ3ZELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIGZvb3RwcmludGpzL3JlY29yZGVycyAtLSBGYWN0b3J5IGZ1bmN0aW9ucyBmb3IgYnVpbHQtaW4gcmVjb3JkZXJzLlxuICpcbiAqIEltcG9ydDogaW1wb3J0IHsgbmFycmF0aXZlLCBtZXRyaWNzLCBkZWJ1ZywgbWFuaWZlc3QgfSBmcm9tICdmb290cHJpbnRqcy9yZWNvcmRlcnMnO1xuICpcbiAqIEVhY2ggZmFjdG9yeSByZXR1cm5zIHRoZSByYXcgcmVjb3JkZXIgaW5zdGFuY2Ugd2l0aCBhZGRlZCBzaG9ydCBjb252ZW5pZW5jZSBtZXRob2RzLlxuICogUGFzcyBkaXJlY3RseSB0byBjaGFydC5yZWNvcmRlcigpLiBObyB3cmFwcGluZywgbm8gcHJveHlpbmcgLS0ganVzdCB0aGUgY2xhc3MgKyBzaG9ydGN1dHMuXG4gKi9cblxuaW1wb3J0IHR5cGUgeyBDb21iaW5lZE5hcnJhdGl2ZUVudHJ5IH0gZnJvbSAnLi9saWIvZW5naW5lL25hcnJhdGl2ZS9Db21iaW5lZE5hcnJhdGl2ZUJ1aWxkZXIuanMnO1xuaW1wb3J0IHsgQ29tYmluZWROYXJyYXRpdmVSZWNvcmRlciB9IGZyb20gJy4vbGliL2VuZ2luZS9uYXJyYXRpdmUvQ29tYmluZWROYXJyYXRpdmVSZWNvcmRlci5qcyc7XG5pbXBvcnQgeyBBZGFwdGl2ZU5hcnJhdGl2ZUZsb3dSZWNvcmRlciB9IGZyb20gJy4vbGliL2VuZ2luZS9uYXJyYXRpdmUvcmVjb3JkZXJzL0FkYXB0aXZlTmFycmF0aXZlRmxvd1JlY29yZGVyLmpzJztcbmltcG9ydCB0eXBlIHsgTWFuaWZlc3RFbnRyeSB9IGZyb20gJy4vbGliL2VuZ2luZS9uYXJyYXRpdmUvcmVjb3JkZXJzL01hbmlmZXN0Rmxvd1JlY29yZGVyLmpzJztcbmltcG9ydCB7IE1hbmlmZXN0Rmxvd1JlY29yZGVyIH0gZnJvbSAnLi9saWIvZW5naW5lL25hcnJhdGl2ZS9yZWNvcmRlcnMvTWFuaWZlc3RGbG93UmVjb3JkZXIuanMnO1xuaW1wb3J0IHsgTWlsZXN0b25lTmFycmF0aXZlRmxvd1JlY29yZGVyIH0gZnJvbSAnLi9saWIvZW5naW5lL25hcnJhdGl2ZS9yZWNvcmRlcnMvTWlsZXN0b25lTmFycmF0aXZlRmxvd1JlY29yZGVyLmpzJztcbmltcG9ydCB7IFdpbmRvd2VkTmFycmF0aXZlRmxvd1JlY29yZGVyIH0gZnJvbSAnLi9saWIvZW5naW5lL25hcnJhdGl2ZS9yZWNvcmRlcnMvV2luZG93ZWROYXJyYXRpdmVGbG93UmVjb3JkZXIuanMnO1xuaW1wb3J0IHR5cGUgeyBEZWJ1Z0VudHJ5LCBEZWJ1Z1JlY29yZGVyT3B0aW9ucyB9IGZyb20gJy4vbGliL3Njb3BlL3JlY29yZGVycy9EZWJ1Z1JlY29yZGVyLmpzJztcbmltcG9ydCB7IERlYnVnUmVjb3JkZXIgfSBmcm9tICcuL2xpYi9zY29wZS9yZWNvcmRlcnMvRGVidWdSZWNvcmRlci5qcyc7XG5pbXBvcnQgdHlwZSB7IEFnZ3JlZ2F0ZWRNZXRyaWNzLCBTdGFnZU1ldHJpY3MgfSBmcm9tICcuL2xpYi9zY29wZS9yZWNvcmRlcnMvTWV0cmljUmVjb3JkZXIuanMnO1xuaW1wb3J0IHsgTWV0cmljUmVjb3JkZXIgfSBmcm9tICcuL2xpYi9zY29wZS9yZWNvcmRlcnMvTWV0cmljUmVjb3JkZXIuanMnO1xuXG4vLyAtLS0tIE5hcnJhdGl2ZSAtLS0tXG5cbmV4cG9ydCB0eXBlIE5hcnJhdGl2ZUluc3RhbmNlID0gQ29tYmluZWROYXJyYXRpdmVSZWNvcmRlciAmIHtcbiAgbGluZXMoKTogc3RyaW5nW107XG4gIHN0cnVjdHVyZWQoKTogQ29tYmluZWROYXJyYXRpdmVFbnRyeVtdO1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIG5hcnJhdGl2ZSgpOiBOYXJyYXRpdmVJbnN0YW5jZSB7XG4gIGNvbnN0IHJlYyA9IG5ldyBDb21iaW5lZE5hcnJhdGl2ZVJlY29yZGVyKCkgYXMgTmFycmF0aXZlSW5zdGFuY2U7XG4gIHJlYy5saW5lcyA9IGZ1bmN0aW9uICh0aGlzOiBDb21iaW5lZE5hcnJhdGl2ZVJlY29yZGVyKSB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0TmFycmF0aXZlKCk7XG4gIH07XG4gIHJlYy5zdHJ1Y3R1cmVkID0gZnVuY3Rpb24gKHRoaXM6IENvbWJpbmVkTmFycmF0aXZlUmVjb3JkZXIpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRFbnRyaWVzKCk7XG4gIH07XG4gIHJldHVybiByZWM7XG59XG5cbi8vIC0tLS0gTWV0cmljcyAtLS0tXG5cbmV4cG9ydCB0eXBlIE1ldHJpY3NJbnN0YW5jZSA9IE1ldHJpY1JlY29yZGVyICYge1xuICByZWFkcygpOiBudW1iZXI7XG4gIHdyaXRlcygpOiBudW1iZXI7XG4gIGNvbW1pdHMoKTogbnVtYmVyO1xuICBzdGFnZShuYW1lOiBzdHJpbmcpOiBTdGFnZU1ldHJpY3MgfCB1bmRlZmluZWQ7XG4gIGFsbCgpOiBBZ2dyZWdhdGVkTWV0cmljcztcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBtZXRyaWNzKCk6IE1ldHJpY3NJbnN0YW5jZSB7XG4gIGNvbnN0IHJlYyA9IG5ldyBNZXRyaWNSZWNvcmRlcigpIGFzIE1ldHJpY3NJbnN0YW5jZTtcbiAgcmVjLnJlYWRzID0gZnVuY3Rpb24gKHRoaXM6IE1ldHJpY1JlY29yZGVyKSB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0TWV0cmljcygpLnRvdGFsUmVhZHM7XG4gIH07XG4gIHJlYy53cml0ZXMgPSBmdW5jdGlvbiAodGhpczogTWV0cmljUmVjb3JkZXIpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRNZXRyaWNzKCkudG90YWxXcml0ZXM7XG4gIH07XG4gIHJlYy5jb21taXRzID0gZnVuY3Rpb24gKHRoaXM6IE1ldHJpY1JlY29yZGVyKSB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0TWV0cmljcygpLnRvdGFsQ29tbWl0cztcbiAgfTtcbiAgcmVjLnN0YWdlID0gZnVuY3Rpb24gKHRoaXM6IE1ldHJpY1JlY29yZGVyLCBuYW1lOiBzdHJpbmcpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRTdGFnZU1ldHJpY3MobmFtZSk7XG4gIH07XG4gIHJlYy5hbGwgPSBmdW5jdGlvbiAodGhpczogTWV0cmljUmVjb3JkZXIpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRNZXRyaWNzKCk7XG4gIH07XG4gIHJldHVybiByZWM7XG59XG5cbi8vIC0tLS0gRGVidWcgLS0tLVxuXG5leHBvcnQgdHlwZSBEZWJ1Z0luc3RhbmNlID0gRGVidWdSZWNvcmRlciAmIHtcbiAgbG9ncygpOiBEZWJ1Z0VudHJ5W107XG59O1xuXG5leHBvcnQgZnVuY3Rpb24gZGVidWcob3B0aW9ucz86IERlYnVnUmVjb3JkZXJPcHRpb25zKTogRGVidWdJbnN0YW5jZSB7XG4gIGNvbnN0IHJlYyA9IG5ldyBEZWJ1Z1JlY29yZGVyKG9wdGlvbnMpIGFzIERlYnVnSW5zdGFuY2U7XG4gIHJlYy5sb2dzID0gZnVuY3Rpb24gKHRoaXM6IERlYnVnUmVjb3JkZXIpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRFbnRyaWVzKCk7XG4gIH07XG4gIHJldHVybiByZWM7XG59XG5cbi8vIC0tLS0gTWFuaWZlc3QgLS0tLVxuXG5leHBvcnQgdHlwZSBNYW5pZmVzdEluc3RhbmNlID0gTWFuaWZlc3RGbG93UmVjb3JkZXIgJiB7XG4gIGVudHJpZXMoKTogTWFuaWZlc3RFbnRyeVtdO1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIG1hbmlmZXN0KCk6IE1hbmlmZXN0SW5zdGFuY2Uge1xuICBjb25zdCByZWMgPSBuZXcgTWFuaWZlc3RGbG93UmVjb3JkZXIoKSBhcyBNYW5pZmVzdEluc3RhbmNlO1xuICByZWMuZW50cmllcyA9IGZ1bmN0aW9uICh0aGlzOiBNYW5pZmVzdEZsb3dSZWNvcmRlcikge1xuICAgIHJldHVybiB0aGlzLmdldE1hbmlmZXN0KCk7XG4gIH07XG4gIHJldHVybiByZWM7XG59XG5cbi8vIC0tLS0gRmxvdyByZWNvcmRlciBzdHJhdGVnaWVzIC0tLS1cblxuZXhwb3J0IGZ1bmN0aW9uIGFkYXB0aXZlKCkge1xuICByZXR1cm4gbmV3IEFkYXB0aXZlTmFycmF0aXZlRmxvd1JlY29yZGVyKCk7XG59XG5leHBvcnQgZnVuY3Rpb24gbWlsZXN0b25lKCkge1xuICByZXR1cm4gbmV3IE1pbGVzdG9uZU5hcnJhdGl2ZUZsb3dSZWNvcmRlcigpO1xufVxuZXhwb3J0IGZ1bmN0aW9uIHdpbmRvd2VkKG1heEVudHJpZXM/OiBudW1iZXIpIHtcbiAgcmV0dXJuIG5ldyBXaW5kb3dlZE5hcnJhdGl2ZUZsb3dSZWNvcmRlcihtYXhFbnRyaWVzKTtcbn1cbiJdfQ==
86
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recorders.js","sourceRoot":"","sources":["../../src/recorders.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;GAgBG;AACH;;;;;;;GAOG;AAGH,OAAO,EAAE,yBAAyB,EAAE,MAAM,qDAAqD,CAAC;AAChG,OAAO,EAAE,6BAA6B,EAAE,MAAM,mEAAmE,CAAC;AAElH,OAAO,EAAE,oBAAoB,EAAE,MAAM,0DAA0D,CAAC;AAChG,OAAO,EAAE,8BAA8B,EAAE,MAAM,oEAAoE,CAAC;AACpH,OAAO,EAAE,6BAA6B,EAAE,MAAM,mEAAmE,CAAC;AAElH,OAAO,EAAE,aAAa,EAAE,MAAM,wCAAwC,CAAC;AAEvE,OAAO,EAAE,cAAc,EAAE,MAAM,yCAAyC,CAAC;AASzE,MAAM,UAAU,SAAS;IACvB,MAAM,GAAG,GAAG,IAAI,yBAAyB,EAAuB,CAAC;IACjE,GAAG,CAAC,KAAK,GAAG;QACV,OAAO,IAAI,CAAC,YAAY,EAAE,CAAC;IAC7B,CAAC,CAAC;IACF,GAAG,CAAC,UAAU,GAAG;QACf,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC;IAC3B,CAAC,CAAC;IACF,OAAO,GAAG,CAAC;AACb,CAAC;AAYD,MAAM,UAAU,OAAO;IACrB,MAAM,GAAG,GAAG,IAAI,cAAc,EAAqB,CAAC;IACpD,GAAG,CAAC,KAAK,GAAG;QACV,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC,UAAU,CAAC;IACtC,CAAC,CAAC;IACF,GAAG,CAAC,MAAM,GAAG;QACX,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC,WAAW,CAAC;IACvC,CAAC,CAAC;IACF,GAAG,CAAC,OAAO,GAAG;QACZ,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC,YAAY,CAAC;IACxC,CAAC,CAAC;IACF,GAAG,CAAC,KAAK,GAAG,UAAgC,IAAY;QACtD,OAAO,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC,CAAC;IACF,GAAG,CAAC,GAAG,GAAG;QACR,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC;IAC3B,CAAC,CAAC;IACF,OAAO,GAAG,CAAC;AACb,CAAC;AAQD,MAAM,UAAU,KAAK,CAAC,OAA8B;IAClD,MAAM,GAAG,GAAG,IAAI,aAAa,CAAC,OAAO,CAAkB,CAAC;IACxD,GAAG,CAAC,IAAI,GAAG;QACT,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC;IAC3B,CAAC,CAAC;IACF,OAAO,GAAG,CAAC;AACb,CAAC;AAQD,MAAM,UAAU,QAAQ;IACtB,MAAM,GAAG,GAAG,IAAI,oBAAoB,EAAsB,CAAC;IAC3D,GAAG,CAAC,OAAO,GAAG;QACZ,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC;IAC5B,CAAC,CAAC;IACF,OAAO,GAAG,CAAC;AACb,CAAC;AAED,qCAAqC;AAErC,MAAM,UAAU,QAAQ;IACtB,OAAO,IAAI,6BAA6B,EAAE,CAAC;AAC7C,CAAC;AACD,MAAM,UAAU,SAAS;IACvB,OAAO,IAAI,8BAA8B,EAAE,CAAC;AAC9C,CAAC;AACD,MAAM,UAAU,QAAQ,CAAC,UAAmB;IAC1C,OAAO,IAAI,6BAA6B,CAAC,UAAU,CAAC,CAAC;AACvD,CAAC","sourcesContent":["/**\n * footprintjs/recorders — Factory functions for built-in recorders.\n *\n * Prefer these factory functions over constructing recorder classes directly.\n * Each factory returns the recorder instance enriched with short convenience methods.\n *\n * ```ts\n * import { narrative, metrics, debug, manifest } from 'footprintjs/recorders';\n *\n * const result = await chart\n *   .recorder(narrative())\n *   .recorder(metrics())\n *   .run();\n * ```\n *\n * @module recorders\n */\n/**\n * footprintjs/recorders -- Factory functions for built-in recorders.\n *\n * Import: import { narrative, metrics, debug, manifest } from 'footprintjs/recorders';\n *\n * Each factory returns the raw recorder instance with added short convenience methods.\n * Pass directly to chart.recorder(). No wrapping, no proxying -- just the class + shortcuts.\n */\n\nimport type { CombinedNarrativeEntry } from './lib/engine/narrative/CombinedNarrativeBuilder.js';\nimport { CombinedNarrativeRecorder } from './lib/engine/narrative/CombinedNarrativeRecorder.js';\nimport { AdaptiveNarrativeFlowRecorder } from './lib/engine/narrative/recorders/AdaptiveNarrativeFlowRecorder.js';\nimport type { ManifestEntry } from './lib/engine/narrative/recorders/ManifestFlowRecorder.js';\nimport { ManifestFlowRecorder } from './lib/engine/narrative/recorders/ManifestFlowRecorder.js';\nimport { MilestoneNarrativeFlowRecorder } from './lib/engine/narrative/recorders/MilestoneNarrativeFlowRecorder.js';\nimport { WindowedNarrativeFlowRecorder } from './lib/engine/narrative/recorders/WindowedNarrativeFlowRecorder.js';\nimport type { DebugEntry, DebugRecorderOptions } from './lib/scope/recorders/DebugRecorder.js';\nimport { DebugRecorder } from './lib/scope/recorders/DebugRecorder.js';\nimport type { AggregatedMetrics, StageMetrics } from './lib/scope/recorders/MetricRecorder.js';\nimport { MetricRecorder } from './lib/scope/recorders/MetricRecorder.js';\n\n// ---- Narrative ----\n\nexport type NarrativeInstance = CombinedNarrativeRecorder & {\n  lines(): string[];\n  structured(): CombinedNarrativeEntry[];\n};\n\nexport function narrative(): NarrativeInstance {\n  const rec = new CombinedNarrativeRecorder() as NarrativeInstance;\n  rec.lines = function (this: CombinedNarrativeRecorder) {\n    return this.getNarrative();\n  };\n  rec.structured = function (this: CombinedNarrativeRecorder) {\n    return this.getEntries();\n  };\n  return rec;\n}\n\n// ---- Metrics ----\n\nexport type MetricsInstance = MetricRecorder & {\n  reads(): number;\n  writes(): number;\n  commits(): number;\n  stage(name: string): StageMetrics | undefined;\n  all(): AggregatedMetrics;\n};\n\nexport function metrics(): MetricsInstance {\n  const rec = new MetricRecorder() as MetricsInstance;\n  rec.reads = function (this: MetricRecorder) {\n    return this.getMetrics().totalReads;\n  };\n  rec.writes = function (this: MetricRecorder) {\n    return this.getMetrics().totalWrites;\n  };\n  rec.commits = function (this: MetricRecorder) {\n    return this.getMetrics().totalCommits;\n  };\n  rec.stage = function (this: MetricRecorder, name: string) {\n    return this.getStageMetrics(name);\n  };\n  rec.all = function (this: MetricRecorder) {\n    return this.getMetrics();\n  };\n  return rec;\n}\n\n// ---- Debug ----\n\nexport type DebugInstance = DebugRecorder & {\n  logs(): DebugEntry[];\n};\n\nexport function debug(options?: DebugRecorderOptions): DebugInstance {\n  const rec = new DebugRecorder(options) as DebugInstance;\n  rec.logs = function (this: DebugRecorder) {\n    return this.getEntries();\n  };\n  return rec;\n}\n\n// ---- Manifest ----\n\nexport type ManifestInstance = ManifestFlowRecorder & {\n  entries(): ManifestEntry[];\n};\n\nexport function manifest(): ManifestInstance {\n  const rec = new ManifestFlowRecorder() as ManifestInstance;\n  rec.entries = function (this: ManifestFlowRecorder) {\n    return this.getManifest();\n  };\n  return rec;\n}\n\n// ---- Flow recorder strategies ----\n\nexport function adaptive() {\n  return new AdaptiveNarrativeFlowRecorder();\n}\nexport function milestone() {\n  return new MilestoneNarrativeFlowRecorder();\n}\nexport function windowed(maxEntries?: number) {\n  return new WindowedNarrativeFlowRecorder(maxEntries);\n}\n"]}
package/dist/index.js CHANGED
@@ -1,74 +1,100 @@
1
1
  "use strict";
2
2
  /**
3
- * FootPrint — Public API (v2.0)
3
+ * FootPrint — Public API (v3)
4
4
  *
5
5
  * The flowchart pattern for backend code.
6
- * Build → DescribeRun.
6
+ * Build → RunObserve.
7
7
  *
8
- * For advanced/internal APIs, import from 'footprintjs/advanced'.
9
- * For recorder factories, import from 'footprintjs/recorders'.
8
+ * **Three import paths:**
9
+ * ```ts
10
+ * import { flowChart, decide, narrative } from 'footprintjs'; // main — start here
11
+ * import { metrics, debug, manifest } from 'footprintjs/recorders'; // recorder factories
12
+ * import { SharedMemory, StageContext } from 'footprintjs/advanced'; // internals
13
+ * ```
14
+ *
15
+ * @module
10
16
  */
11
17
  Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.validateOrThrow = exports.validateAgainstSchema = exports.InputValidationError = exports.isZod = exports.isValidatable = exports.detectSchema = exports.WindowedNarrativeFlowRecorder = exports.SilentNarrativeFlowRecorder = exports.SeparateNarrativeFlowRecorder = exports.RLENarrativeFlowRecorder = exports.ProgressiveNarrativeFlowRecorder = exports.MilestoneNarrativeFlowRecorder = exports.AdaptiveNarrativeFlowRecorder = exports.ManifestFlowRecorder = exports.formatErrorInfo = exports.extractErrorInfo = exports.NarrativeFlowRecorder = exports.defineScopeFromZod = exports.DebugRecorder = exports.MetricRecorder = exports.enableDevMode = exports.disableDevMode = exports.ScopeFacade = exports.listSubflowPaths = exports.getSubtreeSnapshot = exports.narrative = exports.RunContext = exports.FlowChartExecutor = exports.select = exports.decide = exports.FlowChartBuilder = exports.flowChart = void 0;
18
+ exports.ScopeFacade = exports.defineScopeFromZod = exports.enableDevMode = exports.disableDevMode = exports.formatErrorInfo = exports.extractErrorInfo = exports.validateOrThrow = exports.validateAgainstSchema = exports.InputValidationError = exports.isZod = exports.isValidatable = exports.detectSchema = exports.listSubflowPaths = exports.getSubtreeSnapshot = exports.WindowedNarrativeFlowRecorder = exports.SilentNarrativeFlowRecorder = exports.SeparateNarrativeFlowRecorder = exports.RLENarrativeFlowRecorder = exports.ProgressiveNarrativeFlowRecorder = exports.MilestoneNarrativeFlowRecorder = exports.AdaptiveNarrativeFlowRecorder = exports.ManifestFlowRecorder = exports.NarrativeFlowRecorder = exports.DebugRecorder = exports.MetricRecorder = exports.RunContext = exports.FlowChartExecutor = exports.select = exports.decide = exports.narrative = exports.FlowChartBuilder = exports.flowChart = void 0;
19
+ /** @category Quick Start */
13
20
  var index_js_1 = require("./lib/builder/index.js");
14
21
  Object.defineProperty(exports, "flowChart", { enumerable: true, get: function () { return index_js_1.flowChart; } });
15
22
  Object.defineProperty(exports, "FlowChartBuilder", { enumerable: true, get: function () { return index_js_1.FlowChartBuilder; } });
23
+ /** @category Quick Start */
24
+ var recorders_js_1 = require("./recorders.js");
25
+ Object.defineProperty(exports, "narrative", { enumerable: true, get: function () { return recorders_js_1.narrative; } });
26
+ /** @category Decision Branching */
16
27
  var index_js_2 = require("./lib/decide/index.js");
17
28
  Object.defineProperty(exports, "decide", { enumerable: true, get: function () { return index_js_2.decide; } });
18
29
  Object.defineProperty(exports, "select", { enumerable: true, get: function () { return index_js_2.select; } });
30
+ /** @category Run */
19
31
  var index_js_3 = require("./lib/runner/index.js");
20
32
  Object.defineProperty(exports, "FlowChartExecutor", { enumerable: true, get: function () { return index_js_3.FlowChartExecutor; } });
33
+ /** @category Run */
21
34
  var index_js_4 = require("./lib/runner/index.js");
22
35
  Object.defineProperty(exports, "RunContext", { enumerable: true, get: function () { return index_js_4.RunContext; } });
23
- var recorders_js_1 = require("./recorders.js");
24
- Object.defineProperty(exports, "narrative", { enumerable: true, get: function () { return recorders_js_1.narrative; } });
25
- var index_js_5 = require("./lib/runner/index.js");
26
- Object.defineProperty(exports, "getSubtreeSnapshot", { enumerable: true, get: function () { return index_js_5.getSubtreeSnapshot; } });
27
- Object.defineProperty(exports, "listSubflowPaths", { enumerable: true, get: function () { return index_js_5.listSubflowPaths; } });
28
- // ============================================================================
29
- // Scope — Per-stage facades and recorders
30
- // ============================================================================
36
+ /** @category Observe — Data */
37
+ var index_js_5 = require("./lib/scope/index.js");
38
+ Object.defineProperty(exports, "MetricRecorder", { enumerable: true, get: function () { return index_js_5.MetricRecorder; } });
39
+ /** @category Observe Data */
31
40
  var index_js_6 = require("./lib/scope/index.js");
32
- Object.defineProperty(exports, "ScopeFacade", { enumerable: true, get: function () { return index_js_6.ScopeFacade; } });
33
- // Dev-mode diagnostics
34
- var detectCircular_js_1 = require("./lib/scope/detectCircular.js");
35
- Object.defineProperty(exports, "disableDevMode", { enumerable: true, get: function () { return detectCircular_js_1.disableDevMode; } });
36
- Object.defineProperty(exports, "enableDevMode", { enumerable: true, get: function () { return detectCircular_js_1.enableDevMode; } });
37
- // Recorders (class exports — prefer factory functions from footprintjs/recorders)
38
- var index_js_7 = require("./lib/scope/index.js");
39
- Object.defineProperty(exports, "MetricRecorder", { enumerable: true, get: function () { return index_js_7.MetricRecorder; } });
40
- var index_js_8 = require("./lib/scope/index.js");
41
- Object.defineProperty(exports, "DebugRecorder", { enumerable: true, get: function () { return index_js_8.DebugRecorder; } });
42
- // Zod-based scope definitions
43
- var index_js_9 = require("./lib/scope/index.js");
44
- Object.defineProperty(exports, "defineScopeFromZod", { enumerable: true, get: function () { return index_js_9.defineScopeFromZod; } });
41
+ Object.defineProperty(exports, "DebugRecorder", { enumerable: true, get: function () { return index_js_6.DebugRecorder; } });
42
+ /** @category Observe — Flow */
43
+ var index_js_7 = require("./lib/engine/index.js");
44
+ Object.defineProperty(exports, "NarrativeFlowRecorder", { enumerable: true, get: function () { return index_js_7.NarrativeFlowRecorder; } });
45
+ /** @category Observe Flow */
46
+ var index_js_8 = require("./lib/engine/index.js");
47
+ Object.defineProperty(exports, "ManifestFlowRecorder", { enumerable: true, get: function () { return index_js_8.ManifestFlowRecorder; } });
48
+ /** @category Observe Flow */
49
+ var index_js_9 = require("./lib/engine/index.js");
50
+ Object.defineProperty(exports, "AdaptiveNarrativeFlowRecorder", { enumerable: true, get: function () { return index_js_9.AdaptiveNarrativeFlowRecorder; } });
51
+ /** @category Observe — Flow */
45
52
  var index_js_10 = require("./lib/engine/index.js");
46
- Object.defineProperty(exports, "NarrativeFlowRecorder", { enumerable: true, get: function () { return index_js_10.NarrativeFlowRecorder; } });
53
+ Object.defineProperty(exports, "MilestoneNarrativeFlowRecorder", { enumerable: true, get: function () { return index_js_10.MilestoneNarrativeFlowRecorder; } });
54
+ /** @category Observe — Flow */
47
55
  var index_js_11 = require("./lib/engine/index.js");
48
- Object.defineProperty(exports, "extractErrorInfo", { enumerable: true, get: function () { return index_js_11.extractErrorInfo; } });
49
- Object.defineProperty(exports, "formatErrorInfo", { enumerable: true, get: function () { return index_js_11.formatErrorInfo; } });
56
+ Object.defineProperty(exports, "ProgressiveNarrativeFlowRecorder", { enumerable: true, get: function () { return index_js_11.ProgressiveNarrativeFlowRecorder; } });
57
+ /** @category Observe Flow */
50
58
  var index_js_12 = require("./lib/engine/index.js");
51
- Object.defineProperty(exports, "ManifestFlowRecorder", { enumerable: true, get: function () { return index_js_12.ManifestFlowRecorder; } });
59
+ Object.defineProperty(exports, "RLENarrativeFlowRecorder", { enumerable: true, get: function () { return index_js_12.RLENarrativeFlowRecorder; } });
60
+ /** @category Observe — Flow */
52
61
  var index_js_13 = require("./lib/engine/index.js");
53
- Object.defineProperty(exports, "AdaptiveNarrativeFlowRecorder", { enumerable: true, get: function () { return index_js_13.AdaptiveNarrativeFlowRecorder; } });
62
+ Object.defineProperty(exports, "SeparateNarrativeFlowRecorder", { enumerable: true, get: function () { return index_js_13.SeparateNarrativeFlowRecorder; } });
63
+ /** @category Observe — Flow */
54
64
  var index_js_14 = require("./lib/engine/index.js");
55
- Object.defineProperty(exports, "MilestoneNarrativeFlowRecorder", { enumerable: true, get: function () { return index_js_14.MilestoneNarrativeFlowRecorder; } });
65
+ Object.defineProperty(exports, "SilentNarrativeFlowRecorder", { enumerable: true, get: function () { return index_js_14.SilentNarrativeFlowRecorder; } });
66
+ /** @category Observe — Flow */
56
67
  var index_js_15 = require("./lib/engine/index.js");
57
- Object.defineProperty(exports, "ProgressiveNarrativeFlowRecorder", { enumerable: true, get: function () { return index_js_15.ProgressiveNarrativeFlowRecorder; } });
58
- var index_js_16 = require("./lib/engine/index.js");
59
- Object.defineProperty(exports, "RLENarrativeFlowRecorder", { enumerable: true, get: function () { return index_js_16.RLENarrativeFlowRecorder; } });
60
- var index_js_17 = require("./lib/engine/index.js");
61
- Object.defineProperty(exports, "SeparateNarrativeFlowRecorder", { enumerable: true, get: function () { return index_js_17.SeparateNarrativeFlowRecorder; } });
62
- var index_js_18 = require("./lib/engine/index.js");
63
- Object.defineProperty(exports, "SilentNarrativeFlowRecorder", { enumerable: true, get: function () { return index_js_18.SilentNarrativeFlowRecorder; } });
68
+ Object.defineProperty(exports, "WindowedNarrativeFlowRecorder", { enumerable: true, get: function () { return index_js_15.WindowedNarrativeFlowRecorder; } });
69
+ /** @category Snapshot & Composition */
70
+ var index_js_16 = require("./lib/runner/index.js");
71
+ Object.defineProperty(exports, "getSubtreeSnapshot", { enumerable: true, get: function () { return index_js_16.getSubtreeSnapshot; } });
72
+ Object.defineProperty(exports, "listSubflowPaths", { enumerable: true, get: function () { return index_js_16.listSubflowPaths; } });
73
+ /** @category Contract & Validation */
74
+ var index_js_17 = require("./lib/schema/index.js");
75
+ Object.defineProperty(exports, "detectSchema", { enumerable: true, get: function () { return index_js_17.detectSchema; } });
76
+ Object.defineProperty(exports, "isValidatable", { enumerable: true, get: function () { return index_js_17.isValidatable; } });
77
+ Object.defineProperty(exports, "isZod", { enumerable: true, get: function () { return index_js_17.isZod; } });
78
+ /** @category Contract & Validation */
79
+ var index_js_18 = require("./lib/schema/index.js");
80
+ Object.defineProperty(exports, "InputValidationError", { enumerable: true, get: function () { return index_js_18.InputValidationError; } });
81
+ Object.defineProperty(exports, "validateAgainstSchema", { enumerable: true, get: function () { return index_js_18.validateAgainstSchema; } });
82
+ Object.defineProperty(exports, "validateOrThrow", { enumerable: true, get: function () { return index_js_18.validateOrThrow; } });
83
+ /** @category Error Utilities */
64
84
  var index_js_19 = require("./lib/engine/index.js");
65
- Object.defineProperty(exports, "WindowedNarrativeFlowRecorder", { enumerable: true, get: function () { return index_js_19.WindowedNarrativeFlowRecorder; } });
66
- var index_js_20 = require("./lib/schema/index.js");
67
- Object.defineProperty(exports, "detectSchema", { enumerable: true, get: function () { return index_js_20.detectSchema; } });
68
- Object.defineProperty(exports, "isValidatable", { enumerable: true, get: function () { return index_js_20.isValidatable; } });
69
- Object.defineProperty(exports, "isZod", { enumerable: true, get: function () { return index_js_20.isZod; } });
70
- var index_js_21 = require("./lib/schema/index.js");
71
- Object.defineProperty(exports, "InputValidationError", { enumerable: true, get: function () { return index_js_21.InputValidationError; } });
72
- Object.defineProperty(exports, "validateAgainstSchema", { enumerable: true, get: function () { return index_js_21.validateAgainstSchema; } });
73
- Object.defineProperty(exports, "validateOrThrow", { enumerable: true, get: function () { return index_js_21.validateOrThrow; } });
74
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AAAA;;;;;;;;GAQG;;;AAOH,mDAAqE;AAA5D,qGAAA,SAAS,OAAA;AAAE,4GAAA,gBAAgB,OAAA;AAepC,kDAAuD;AAA9C,kGAAA,MAAM,OAAA;AAAE,kGAAA,MAAM,OAAA;AAUvB,kDAA0D;AAAjD,6GAAA,iBAAiB,OAAA;AAC1B,kDAAmD;AAA1C,sGAAA,UAAU,OAAA;AAEnB,+CAA2C;AAAlC,yGAAA,SAAS,OAAA;AAOlB,kDAA6E;AAApE,8GAAA,kBAAkB,OAAA;AAAE,4GAAA,gBAAgB,OAAA;AAE7C,+EAA+E;AAC/E,0CAA0C;AAC1C,+EAA+E;AAE/E,iDAAmD;AAA1C,uGAAA,WAAW,OAAA;AAEpB,uBAAuB;AACvB,mEAA8E;AAArE,mHAAA,cAAc,OAAA;AAAE,kHAAA,aAAa,OAAA;AAEtC,kFAAkF;AAClF,iDAAsD;AAA7C,0GAAA,cAAc,OAAA;AACvB,iDAAqD;AAA5C,yGAAA,aAAa,OAAA;AAatB,8BAA8B;AAC9B,iDAA0D;AAAjD,8GAAA,kBAAkB,OAAA;AAuB3B,mDAA8D;AAArD,kHAAA,qBAAqB,OAAA;AAI9B,mDAA0E;AAAjE,6GAAA,gBAAgB,OAAA;AAAE,4GAAA,eAAe,OAAA;AAI1C,mDAA6D;AAApD,iHAAA,oBAAoB,OAAA;AAC7B,mDAAsE;AAA7D,0HAAA,6BAA6B,OAAA;AACtC,mDAAuE;AAA9D,2HAAA,8BAA8B,OAAA;AACvC,mDAAyE;AAAhE,6HAAA,gCAAgC,OAAA;AACzC,mDAAiE;AAAxD,qHAAA,wBAAwB,OAAA;AACjC,mDAAsE;AAA7D,0HAAA,6BAA6B,OAAA;AACtC,mDAAoE;AAA3D,wHAAA,2BAA2B,OAAA;AACpC,mDAAsE;AAA7D,0HAAA,6BAA6B,OAAA;AA0BtC,mDAA2E;AAAlE,yGAAA,YAAY,OAAA;AAAE,0GAAA,aAAa,OAAA;AAAE,kGAAA,KAAK,OAAA;AAC3C,mDAAqG;AAA5F,iHAAA,oBAAoB,OAAA;AAAE,kHAAA,qBAAqB,OAAA;AAAE,4GAAA,eAAe,OAAA","sourcesContent":["/**\n * FootPrint — Public API (v2.0)\n *\n * The flowchart pattern for backend code.\n * Build → Describe → Run.\n *\n * For advanced/internal APIs, import from 'footprintjs/advanced'.\n * For recorder factories, import from 'footprintjs/recorders'.\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 type { ScopeMethods, TypedScope } 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 — v2 API: chart.recorder().run()\n// ============================================================================\n\n// narrative() — core recorder factory, exported here for the common case:\n//   import { flowChart, decide, narrative } from 'footprintjs';\n//   const result = await chart.recorder(narrative()).run();\nexport type { RunResult } from './lib/runner/index.js';\nexport { FlowChartExecutor } from './lib/runner/index.js';\nexport { RunContext } from './lib/runner/index.js';\nexport type { ChartOpenAPIOptions, MCPToolDescription, RunnableFlowChart } from './lib/runner/RunnableChart.js';\nexport { narrative } from './recorders.js';\n\n// ComposableRunner — interface for subflow composition\nexport type { ComposableRunner } from './lib/runner/index.js';\n\n// Snapshot navigation\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 (class exports — prefer factory functions from footprintjs/recorders)\nexport { MetricRecorder } from './lib/scope/index.js';\nexport { DebugRecorder } from './lib/scope/index.js';\n\n// Recorder interface and event types (for custom recorders)\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 types\n// ============================================================================\n\nexport type { CombinedNarrativeEntry } from './lib/engine/index.js';\n\n// FlowRecorder — Pluggable observer for control flow events\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 errors\nexport type { StructuredErrorInfo } from './lib/engine/index.js';\nexport { extractErrorInfo, formatErrorInfo } from './lib/engine/index.js';\n\n// Built-in FlowRecorder strategies (prefer factory functions from footprintjs/recorders)\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// Engine types\n// ============================================================================\n\nexport type { ExecutionEnv, RunOptions } from './lib/engine/index.js';\nexport type { ScopeFactory } from './lib/engine/index.js';\n\n// ============================================================================\n// Contract types (use .contract() on builder + chart.toOpenAPI() instead)\n// ============================================================================\n\nexport type {\n  FlowChartContract,\n  FlowChartContractOptions,\n  JsonSchema,\n  OpenAPIOptions,\n  OpenAPISpec,\n} from './lib/contract/index.js';\n\n// ============================================================================\n// Schema — Validation\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"]}
85
+ Object.defineProperty(exports, "extractErrorInfo", { enumerable: true, get: function () { return index_js_19.extractErrorInfo; } });
86
+ Object.defineProperty(exports, "formatErrorInfo", { enumerable: true, get: function () { return index_js_19.formatErrorInfo; } });
87
+ // ============================================================================
88
+ // Dev Tools Mode flags and Zod scope utilities
89
+ // ============================================================================
90
+ /** @category Dev Tools */
91
+ var detectCircular_js_1 = require("./lib/scope/detectCircular.js");
92
+ Object.defineProperty(exports, "disableDevMode", { enumerable: true, get: function () { return detectCircular_js_1.disableDevMode; } });
93
+ Object.defineProperty(exports, "enableDevMode", { enumerable: true, get: function () { return detectCircular_js_1.enableDevMode; } });
94
+ /** @category Dev Tools */
95
+ var index_js_20 = require("./lib/scope/index.js");
96
+ Object.defineProperty(exports, "defineScopeFromZod", { enumerable: true, get: function () { return index_js_20.defineScopeFromZod; } });
97
+ /** @category Dev Tools */
98
+ var index_js_21 = require("./lib/scope/index.js");
99
+ Object.defineProperty(exports, "ScopeFacade", { enumerable: true, get: function () { return index_js_21.ScopeFacade; } });
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;GAcG;;;AASH,4BAA4B;AAC5B,mDAAqE;AAA5D,qGAAA,SAAS,OAAA;AAAE,4GAAA,gBAAgB,OAAA;AAQpC,4BAA4B;AAC5B,+CAA2C;AAAlC,yGAAA,SAAS,OAAA;AAmBlB,mCAAmC;AACnC,kDAAuD;AAA9C,kGAAA,MAAM,OAAA;AAAE,kGAAA,MAAM,OAAA;AASvB,oBAAoB;AACpB,kDAA0D;AAAjD,6GAAA,iBAAiB,OAAA;AAE1B,oBAAoB;AACpB,kDAAmD;AAA1C,sGAAA,UAAU,OAAA;AAoBnB,+BAA+B;AAC/B,iDAAsD;AAA7C,0GAAA,cAAc,OAAA;AAEvB,+BAA+B;AAC/B,iDAAqD;AAA5C,yGAAA,aAAa,OAAA;AAyBtB,+BAA+B;AAC/B,kDAA8D;AAArD,iHAAA,qBAAqB,OAAA;AAK9B,+BAA+B;AAC/B,kDAA6D;AAApD,gHAAA,oBAAoB,OAAA;AAE7B,+BAA+B;AAC/B,kDAAsE;AAA7D,yHAAA,6BAA6B,OAAA;AAEtC,+BAA+B;AAC/B,mDAAuE;AAA9D,2HAAA,8BAA8B,OAAA;AAEvC,+BAA+B;AAC/B,mDAAyE;AAAhE,6HAAA,gCAAgC,OAAA;AAEzC,+BAA+B;AAC/B,mDAAiE;AAAxD,qHAAA,wBAAwB,OAAA;AAEjC,+BAA+B;AAC/B,mDAAsE;AAA7D,0HAAA,6BAA6B,OAAA;AAEtC,+BAA+B;AAC/B,mDAAoE;AAA3D,wHAAA,2BAA2B,OAAA;AAEpC,+BAA+B;AAC/B,mDAAsE;AAA7D,0HAAA,6BAA6B,OAAA;AAyBtC,uCAAuC;AACvC,mDAA6E;AAApE,+GAAA,kBAAkB,OAAA;AAAE,6GAAA,gBAAgB,OAAA;AAmB7C,sCAAsC;AACtC,mDAA2E;AAAlE,yGAAA,YAAY,OAAA;AAAE,0GAAA,aAAa,OAAA;AAAE,kGAAA,KAAK,OAAA;AAE3C,sCAAsC;AACtC,mDAAqG;AAA5F,iHAAA,oBAAoB,OAAA;AAAE,kHAAA,qBAAqB,OAAA;AAAE,4GAAA,eAAe,OAAA;AASrE,gCAAgC;AAChC,mDAA0E;AAAjE,6GAAA,gBAAgB,OAAA;AAAE,4GAAA,eAAe,OAAA;AAE1C,+EAA+E;AAC/E,iDAAiD;AACjD,+EAA+E;AAE/E,0BAA0B;AAC1B,mEAA8E;AAArE,mHAAA,cAAc,OAAA;AAAE,kHAAA,aAAa,OAAA;AAEtC,0BAA0B;AAC1B,kDAA0D;AAAjD,+GAAA,kBAAkB,OAAA;AAE3B,0BAA0B;AAC1B,kDAAmD;AAA1C,wGAAA,WAAW,OAAA","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 { 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\n/** @category Dev Tools */\nexport { ScopeFacade } from './lib/scope/index.js';\n"]}
@@ -104,4 +104,4 @@ function normalizeSchema(schema) {
104
104
  }
105
105
  return schema;
106
106
  }
107
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RunnableChart.js","sourceRoot":"","sources":["../../../src/lib/runner/RunnableChart.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * RunnableChart -- Adds .recorder(), .redact(), .run(), .toOpenAPI(), .toMCPTool()\n * to a FlowChart object.\n *\n * Called by FlowChartBuilder.build() to enrich the compiled chart with\n * d3-style chainable run methods and self-describing outputs.\n */\n\nimport { zodToJsonSchema } from '../contract/schema.js';\nimport type { FlowRecorder } from '../engine/narrative/types.js';\nimport type { FlowChart, RunOptions, SerializedPipelineStructure } from '../engine/types.js';\nimport type { Recorder, RedactionPolicy } from '../scope/types.js';\nimport { type RunResult, RunContext } from './RunContext.js';\n\n/** OpenAPI generation options. */\nexport interface ChartOpenAPIOptions {\n  title?: string;\n  version?: string;\n  description?: string;\n  path?: string;\n}\n\n/** MCP tool description. */\nexport interface MCPToolDescription {\n  name: string;\n  description: string;\n  inputSchema?: unknown;\n}\n\n/** FlowChart with d3-style methods: run, recorder, redact, toOpenAPI, toMCPTool. */\nexport interface RunnableFlowChart<TOut = any, TScope = any> extends FlowChart<TOut, TScope> {\n  // ── Builder metadata (set by FlowChartBuilder.build()) ──────────────────\n  /** Always set by build() — narrows the optional field from FlowChart to required. */\n  buildTimeStructure: SerializedPipelineStructure;\n  /** Human-readable numbered step list. Empty string when no descriptions were provided. */\n  description: string;\n  /** Per-stage descriptions, keyed by stage name. */\n  stageDescriptions: Map<string, string>;\n  /** Output schema (Zod or JSON Schema) — declared via .contract(). */\n  outputSchema?: unknown;\n  /** Output mapper — extracts response from final scope. Declared via .contract(). */\n  outputMapper?: (finalScope: Record<string, unknown>) => unknown;\n  // ── Runtime methods ──────────────────────────────────────────────────────\n  /** Attach a recorder for the next run. Returns a chainable RunContext. */\n  recorder(r: Recorder | FlowRecorder): RunContext<TOut, TScope>;\n  /** Set redaction policy for the next run. Returns a chainable RunContext. */\n  redact(policy: RedactionPolicy): RunContext<TOut, TScope>;\n  /** Execute the chart directly (bare run, no recorders). */\n  run(options?: RunOptions): Promise<RunResult>;\n  /** Generate OpenAPI 3.1 spec from chart metadata + contract. Cached. */\n  toOpenAPI(options?: ChartOpenAPIOptions): object;\n  /** Generate MCP tool description from chart metadata. Cached. */\n  toMCPTool(): MCPToolDescription;\n}\n\n// Caches for describe outputs\nconst openAPICache = new WeakMap<FlowChart, object>();\nconst mcpCache = new WeakMap<FlowChart, MCPToolDescription>();\n\n/**\n * Enrich a FlowChart with run + describe methods.\n * Called by FlowChartBuilder.build().\n */\nexport function makeRunnable<TOut, TScope>(chart: FlowChart<TOut, TScope>): RunnableFlowChart<TOut, TScope> {\n  const runnable = chart as RunnableFlowChart<TOut, TScope>;\n\n  runnable.recorder = function (r: Recorder | FlowRecorder): RunContext<TOut, TScope> {\n    return new RunContext(chart).recorder(r);\n  };\n\n  runnable.redact = function (policy: RedactionPolicy): RunContext<TOut, TScope> {\n    return new RunContext(chart).redact(policy);\n  };\n\n  runnable.run = function (options?: RunOptions): Promise<RunResult> {\n    return new RunContext(chart).run(options);\n  };\n\n  runnable.toOpenAPI = function (options?: ChartOpenAPIOptions): object {\n    const cached = openAPICache.get(chart);\n    if (cached) return cached;\n\n    const builderChart = chart as any;\n    const title = options?.title ?? builderChart.description?.split('\\n')[0] ?? 'API';\n    const version = options?.version ?? '1.0.0';\n    const path = options?.path ?? `/${(builderChart.root?.name ?? 'execute').toLowerCase().replace(/\\s+/g, '-')}`;\n\n    const spec: Record<string, unknown> = {\n      openapi: '3.1.0',\n      info: { title, version, description: options?.description ?? builderChart.description },\n      paths: {\n        [path]: {\n          post: {\n            summary: title,\n            description: builderChart.description,\n            ...(builderChart.inputSchema\n              ? {\n                  requestBody: {\n                    content: { 'application/json': { schema: normalizeSchema(builderChart.inputSchema) } },\n                  },\n                }\n              : {}),\n            responses: {\n              '200': {\n                description: 'Success',\n                ...(builderChart.outputSchema\n                  ? { content: { 'application/json': { schema: normalizeSchema(builderChart.outputSchema) } } }\n                  : {}),\n              },\n            },\n          },\n        },\n      },\n    };\n\n    openAPICache.set(chart, spec);\n    return spec;\n  };\n\n  runnable.toMCPTool = function (): MCPToolDescription {\n    const cached = mcpCache.get(chart);\n    if (cached) return cached;\n\n    const builderChart = chart as any;\n    const name = (builderChart.root?.name ?? 'execute').toLowerCase().replace(/\\s+/g, '_');\n    const description = builderChart.description || `Execute the ${name} flowchart`;\n\n    const tool: MCPToolDescription = {\n      name,\n      description,\n      ...(builderChart.inputSchema ? { inputSchema: normalizeSchema(builderChart.inputSchema) } : {}),\n    };\n\n    mcpCache.set(chart, tool);\n    return tool;\n  };\n\n  return runnable;\n}\n\n/** Normalize a Zod schema or plain JSON Schema to JSON Schema object. */\nfunction normalizeSchema(schema: unknown): unknown {\n  if (!schema) return schema;\n  // If it's a Zod schema with ._def, convert to JSON Schema\n  if (\n    typeof schema === 'object' &&\n    schema !== null &&\n    typeof (schema as Record<string, unknown>)._def !== 'undefined'\n  ) {\n    try {\n      return zodToJsonSchema(schema as Record<string, unknown>);\n    } catch {\n      // If conversion fails (e.g. unsupported Zod type), return as-is\n      return schema;\n    }\n  }\n  return schema;\n}\n"]}
107
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RunnableChart.js","sourceRoot":"","sources":["../../../src/lib/runner/RunnableChart.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * RunnableChart -- Adds .recorder(), .redact(), .run(), .toOpenAPI(), .toMCPTool()\n * to a FlowChart object.\n *\n * Called by FlowChartBuilder.build() to enrich the compiled chart with\n * d3-style chainable run methods and self-describing outputs.\n */\n\nimport type { FlowChart } from '../builder/types.js';\nimport { zodToJsonSchema } from '../contract/schema.js';\nimport type { FlowRecorder } from '../engine/narrative/types.js';\nimport type { RunOptions } from '../engine/types.js';\nimport type { Recorder, RedactionPolicy } from '../scope/types.js';\nimport { type RunResult, RunContext } from './RunContext.js';\n\n/** OpenAPI generation options. */\nexport interface ChartOpenAPIOptions {\n  title?: string;\n  version?: string;\n  description?: string;\n  path?: string;\n}\n\n/** MCP tool description. */\nexport interface MCPToolDescription {\n  name: string;\n  description: string;\n  inputSchema?: unknown;\n}\n\n/**\n * FlowChart enriched with d3-style run methods and self-describing outputs.\n *\n * Extends builder.FlowChart (which already carries buildTimeStructure, description,\n * stageDescriptions, inputSchema, outputSchema, outputMapper) and adds the runtime\n * methods attached by makeRunnable().\n */\nexport interface RunnableFlowChart<TOut = any, TScope = any> extends FlowChart<TOut, TScope> {\n  /** Attach a recorder for the next run. Returns a chainable RunContext. */\n  recorder(r: Recorder | FlowRecorder): RunContext<TOut, TScope>;\n  /** Set redaction policy for the next run. Returns a chainable RunContext. */\n  redact(policy: RedactionPolicy): RunContext<TOut, TScope>;\n  /** Execute the chart directly (bare run, no recorders). */\n  run(options?: RunOptions): Promise<RunResult>;\n  /** Generate OpenAPI 3.1 spec from chart metadata + contract. Cached. */\n  toOpenAPI(options?: ChartOpenAPIOptions): object;\n  /** Generate MCP tool description from chart metadata. Cached. */\n  toMCPTool(): MCPToolDescription;\n}\n\n// Caches for describe outputs\nconst openAPICache = new WeakMap<FlowChart, object>();\nconst mcpCache = new WeakMap<FlowChart, MCPToolDescription>();\n\n/**\n * Enrich a FlowChart with run + describe methods.\n * Called by FlowChartBuilder.build().\n */\nexport function makeRunnable<TOut, TScope>(chart: FlowChart<TOut, TScope>): RunnableFlowChart<TOut, TScope> {\n  const runnable = chart as RunnableFlowChart<TOut, TScope>;\n\n  runnable.recorder = function (r: Recorder | FlowRecorder): RunContext<TOut, TScope> {\n    return new RunContext(chart).recorder(r);\n  };\n\n  runnable.redact = function (policy: RedactionPolicy): RunContext<TOut, TScope> {\n    return new RunContext(chart).redact(policy);\n  };\n\n  runnable.run = function (options?: RunOptions): Promise<RunResult> {\n    return new RunContext(chart).run(options);\n  };\n\n  runnable.toOpenAPI = function (options?: ChartOpenAPIOptions): object {\n    const cached = openAPICache.get(chart);\n    if (cached) return cached;\n\n    const builderChart = chart as any;\n    const title = options?.title ?? builderChart.description?.split('\\n')[0] ?? 'API';\n    const version = options?.version ?? '1.0.0';\n    const path = options?.path ?? `/${(builderChart.root?.name ?? 'execute').toLowerCase().replace(/\\s+/g, '-')}`;\n\n    const spec: Record<string, unknown> = {\n      openapi: '3.1.0',\n      info: { title, version, description: options?.description ?? builderChart.description },\n      paths: {\n        [path]: {\n          post: {\n            summary: title,\n            description: builderChart.description,\n            ...(builderChart.inputSchema\n              ? {\n                  requestBody: {\n                    content: { 'application/json': { schema: normalizeSchema(builderChart.inputSchema) } },\n                  },\n                }\n              : {}),\n            responses: {\n              '200': {\n                description: 'Success',\n                ...(builderChart.outputSchema\n                  ? { content: { 'application/json': { schema: normalizeSchema(builderChart.outputSchema) } } }\n                  : {}),\n              },\n            },\n          },\n        },\n      },\n    };\n\n    openAPICache.set(chart, spec);\n    return spec;\n  };\n\n  runnable.toMCPTool = function (): MCPToolDescription {\n    const cached = mcpCache.get(chart);\n    if (cached) return cached;\n\n    const builderChart = chart as any;\n    const name = (builderChart.root?.name ?? 'execute').toLowerCase().replace(/\\s+/g, '_');\n    const description = builderChart.description || `Execute the ${name} flowchart`;\n\n    const tool: MCPToolDescription = {\n      name,\n      description,\n      ...(builderChart.inputSchema ? { inputSchema: normalizeSchema(builderChart.inputSchema) } : {}),\n    };\n\n    mcpCache.set(chart, tool);\n    return tool;\n  };\n\n  return runnable;\n}\n\n/** Normalize a Zod schema or plain JSON Schema to JSON Schema object. */\nfunction normalizeSchema(schema: unknown): unknown {\n  if (!schema) return schema;\n  // If it's a Zod schema with ._def, convert to JSON Schema\n  if (\n    typeof schema === 'object' &&\n    schema !== null &&\n    typeof (schema as Record<string, unknown>)._def !== 'undefined'\n  ) {\n    try {\n      return zodToJsonSchema(schema as Record<string, unknown>);\n    } catch {\n      // If conversion fails (e.g. unsupported Zod type), return as-is\n      return schema;\n    }\n  }\n  return schema;\n}\n"]}
package/dist/recorders.js CHANGED
@@ -1,4 +1,21 @@
1
1
  "use strict";
2
+ /**
3
+ * footprintjs/recorders — Factory functions for built-in recorders.
4
+ *
5
+ * Prefer these factory functions over constructing recorder classes directly.
6
+ * Each factory returns the recorder instance enriched with short convenience methods.
7
+ *
8
+ * ```ts
9
+ * import { narrative, metrics, debug, manifest } from 'footprintjs/recorders';
10
+ *
11
+ * const result = await chart
12
+ * .recorder(narrative())
13
+ * .recorder(metrics())
14
+ * .run();
15
+ * ```
16
+ *
17
+ * @module recorders
18
+ */
2
19
  /**
3
20
  * footprintjs/recorders -- Factory functions for built-in recorders.
4
21
  *
@@ -76,4 +93,4 @@ function windowed(maxEntries) {
76
93
  return new WindowedNarrativeFlowRecorder_js_1.WindowedNarrativeFlowRecorder(maxEntries);
77
94
  }
78
95
  exports.windowed = windowed;
79
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkZXJzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3JlY29yZGVycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7R0FPRzs7O0FBR0gsc0dBQWdHO0FBQ2hHLHdIQUFrSDtBQUVsSCxzR0FBZ0c7QUFDaEcsMEhBQW9IO0FBQ3BILHdIQUFrSDtBQUVsSCw2RUFBdUU7QUFFdkUsK0VBQXlFO0FBU3pFLFNBQWdCLFNBQVM7SUFDdkIsTUFBTSxHQUFHLEdBQUcsSUFBSSx3REFBeUIsRUFBdUIsQ0FBQztJQUNqRSxHQUFHLENBQUMsS0FBSyxHQUFHO1FBQ1YsT0FBTyxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDN0IsQ0FBQyxDQUFDO0lBQ0YsR0FBRyxDQUFDLFVBQVUsR0FBRztRQUNmLE9BQU8sSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQzNCLENBQUMsQ0FBQztJQUNGLE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQztBQVRELDhCQVNDO0FBWUQsU0FBZ0IsT0FBTztJQUNyQixNQUFNLEdBQUcsR0FBRyxJQUFJLGtDQUFjLEVBQXFCLENBQUM7SUFDcEQsR0FBRyxDQUFDLEtBQUssR0FBRztRQUNWLE9BQU8sSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDLFVBQVUsQ0FBQztJQUN0QyxDQUFDLENBQUM7SUFDRixHQUFHLENBQUMsTUFBTSxHQUFHO1FBQ1gsT0FBTyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUMsV0FBVyxDQUFDO0lBQ3ZDLENBQUMsQ0FBQztJQUNGLEdBQUcsQ0FBQyxPQUFPLEdBQUc7UUFDWixPQUFPLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQyxZQUFZLENBQUM7SUFDeEMsQ0FBQyxDQUFDO0lBQ0YsR0FBRyxDQUFDLEtBQUssR0FBRyxVQUFnQyxJQUFZO1FBQ3RELE9BQU8sSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNwQyxDQUFDLENBQUM7SUFDRixHQUFHLENBQUMsR0FBRyxHQUFHO1FBQ1IsT0FBTyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDM0IsQ0FBQyxDQUFDO0lBQ0YsT0FBTyxHQUFHLENBQUM7QUFDYixDQUFDO0FBbEJELDBCQWtCQztBQVFELFNBQWdCLEtBQUssQ0FBQyxPQUE4QjtJQUNsRCxNQUFNLEdBQUcsR0FBRyxJQUFJLGdDQUFhLENBQUMsT0FBTyxDQUFrQixDQUFDO0lBQ3hELEdBQUcsQ0FBQyxJQUFJLEdBQUc7UUFDVCxPQUFPLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUMzQixDQUFDLENBQUM7SUFDRixPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUM7QUFORCxzQkFNQztBQVFELFNBQWdCLFFBQVE7SUFDdEIsTUFBTSxHQUFHLEdBQUcsSUFBSSw4Q0FBb0IsRUFBc0IsQ0FBQztJQUMzRCxHQUFHLENBQUMsT0FBTyxHQUFHO1FBQ1osT0FBTyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDNUIsQ0FBQyxDQUFDO0lBQ0YsT0FBTyxHQUFHLENBQUM7QUFDYixDQUFDO0FBTkQsNEJBTUM7QUFFRCxxQ0FBcUM7QUFFckMsU0FBZ0IsUUFBUTtJQUN0QixPQUFPLElBQUksZ0VBQTZCLEVBQUUsQ0FBQztBQUM3QyxDQUFDO0FBRkQsNEJBRUM7QUFDRCxTQUFnQixTQUFTO0lBQ3ZCLE9BQU8sSUFBSSxrRUFBOEIsRUFBRSxDQUFDO0FBQzlDLENBQUM7QUFGRCw4QkFFQztBQUNELFNBQWdCLFFBQVEsQ0FBQyxVQUFtQjtJQUMxQyxPQUFPLElBQUksZ0VBQTZCLENBQUMsVUFBVSxDQUFDLENBQUM7QUFDdkQsQ0FBQztBQUZELDRCQUVDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBmb290cHJpbnRqcy9yZWNvcmRlcnMgLS0gRmFjdG9yeSBmdW5jdGlvbnMgZm9yIGJ1aWx0LWluIHJlY29yZGVycy5cbiAqXG4gKiBJbXBvcnQ6IGltcG9ydCB7IG5hcnJhdGl2ZSwgbWV0cmljcywgZGVidWcsIG1hbmlmZXN0IH0gZnJvbSAnZm9vdHByaW50anMvcmVjb3JkZXJzJztcbiAqXG4gKiBFYWNoIGZhY3RvcnkgcmV0dXJucyB0aGUgcmF3IHJlY29yZGVyIGluc3RhbmNlIHdpdGggYWRkZWQgc2hvcnQgY29udmVuaWVuY2UgbWV0aG9kcy5cbiAqIFBhc3MgZGlyZWN0bHkgdG8gY2hhcnQucmVjb3JkZXIoKS4gTm8gd3JhcHBpbmcsIG5vIHByb3h5aW5nIC0tIGp1c3QgdGhlIGNsYXNzICsgc2hvcnRjdXRzLlxuICovXG5cbmltcG9ydCB0eXBlIHsgQ29tYmluZWROYXJyYXRpdmVFbnRyeSB9IGZyb20gJy4vbGliL2VuZ2luZS9uYXJyYXRpdmUvQ29tYmluZWROYXJyYXRpdmVCdWlsZGVyLmpzJztcbmltcG9ydCB7IENvbWJpbmVkTmFycmF0aXZlUmVjb3JkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUvbmFycmF0aXZlL0NvbWJpbmVkTmFycmF0aXZlUmVjb3JkZXIuanMnO1xuaW1wb3J0IHsgQWRhcHRpdmVOYXJyYXRpdmVGbG93UmVjb3JkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUvbmFycmF0aXZlL3JlY29yZGVycy9BZGFwdGl2ZU5hcnJhdGl2ZUZsb3dSZWNvcmRlci5qcyc7XG5pbXBvcnQgdHlwZSB7IE1hbmlmZXN0RW50cnkgfSBmcm9tICcuL2xpYi9lbmdpbmUvbmFycmF0aXZlL3JlY29yZGVycy9NYW5pZmVzdEZsb3dSZWNvcmRlci5qcyc7XG5pbXBvcnQgeyBNYW5pZmVzdEZsb3dSZWNvcmRlciB9IGZyb20gJy4vbGliL2VuZ2luZS9uYXJyYXRpdmUvcmVjb3JkZXJzL01hbmlmZXN0Rmxvd1JlY29yZGVyLmpzJztcbmltcG9ydCB7IE1pbGVzdG9uZU5hcnJhdGl2ZUZsb3dSZWNvcmRlciB9IGZyb20gJy4vbGliL2VuZ2luZS9uYXJyYXRpdmUvcmVjb3JkZXJzL01pbGVzdG9uZU5hcnJhdGl2ZUZsb3dSZWNvcmRlci5qcyc7XG5pbXBvcnQgeyBXaW5kb3dlZE5hcnJhdGl2ZUZsb3dSZWNvcmRlciB9IGZyb20gJy4vbGliL2VuZ2luZS9uYXJyYXRpdmUvcmVjb3JkZXJzL1dpbmRvd2VkTmFycmF0aXZlRmxvd1JlY29yZGVyLmpzJztcbmltcG9ydCB0eXBlIHsgRGVidWdFbnRyeSwgRGVidWdSZWNvcmRlck9wdGlvbnMgfSBmcm9tICcuL2xpYi9zY29wZS9yZWNvcmRlcnMvRGVidWdSZWNvcmRlci5qcyc7XG5pbXBvcnQgeyBEZWJ1Z1JlY29yZGVyIH0gZnJvbSAnLi9saWIvc2NvcGUvcmVjb3JkZXJzL0RlYnVnUmVjb3JkZXIuanMnO1xuaW1wb3J0IHR5cGUgeyBBZ2dyZWdhdGVkTWV0cmljcywgU3RhZ2VNZXRyaWNzIH0gZnJvbSAnLi9saWIvc2NvcGUvcmVjb3JkZXJzL01ldHJpY1JlY29yZGVyLmpzJztcbmltcG9ydCB7IE1ldHJpY1JlY29yZGVyIH0gZnJvbSAnLi9saWIvc2NvcGUvcmVjb3JkZXJzL01ldHJpY1JlY29yZGVyLmpzJztcblxuLy8gLS0tLSBOYXJyYXRpdmUgLS0tLVxuXG5leHBvcnQgdHlwZSBOYXJyYXRpdmVJbnN0YW5jZSA9IENvbWJpbmVkTmFycmF0aXZlUmVjb3JkZXIgJiB7XG4gIGxpbmVzKCk6IHN0cmluZ1tdO1xuICBzdHJ1Y3R1cmVkKCk6IENvbWJpbmVkTmFycmF0aXZlRW50cnlbXTtcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBuYXJyYXRpdmUoKTogTmFycmF0aXZlSW5zdGFuY2Uge1xuICBjb25zdCByZWMgPSBuZXcgQ29tYmluZWROYXJyYXRpdmVSZWNvcmRlcigpIGFzIE5hcnJhdGl2ZUluc3RhbmNlO1xuICByZWMubGluZXMgPSBmdW5jdGlvbiAodGhpczogQ29tYmluZWROYXJyYXRpdmVSZWNvcmRlcikge1xuICAgIHJldHVybiB0aGlzLmdldE5hcnJhdGl2ZSgpO1xuICB9O1xuICByZWMuc3RydWN0dXJlZCA9IGZ1bmN0aW9uICh0aGlzOiBDb21iaW5lZE5hcnJhdGl2ZVJlY29yZGVyKSB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0RW50cmllcygpO1xuICB9O1xuICByZXR1cm4gcmVjO1xufVxuXG4vLyAtLS0tIE1ldHJpY3MgLS0tLVxuXG5leHBvcnQgdHlwZSBNZXRyaWNzSW5zdGFuY2UgPSBNZXRyaWNSZWNvcmRlciAmIHtcbiAgcmVhZHMoKTogbnVtYmVyO1xuICB3cml0ZXMoKTogbnVtYmVyO1xuICBjb21taXRzKCk6IG51bWJlcjtcbiAgc3RhZ2UobmFtZTogc3RyaW5nKTogU3RhZ2VNZXRyaWNzIHwgdW5kZWZpbmVkO1xuICBhbGwoKTogQWdncmVnYXRlZE1ldHJpY3M7XG59O1xuXG5leHBvcnQgZnVuY3Rpb24gbWV0cmljcygpOiBNZXRyaWNzSW5zdGFuY2Uge1xuICBjb25zdCByZWMgPSBuZXcgTWV0cmljUmVjb3JkZXIoKSBhcyBNZXRyaWNzSW5zdGFuY2U7XG4gIHJlYy5yZWFkcyA9IGZ1bmN0aW9uICh0aGlzOiBNZXRyaWNSZWNvcmRlcikge1xuICAgIHJldHVybiB0aGlzLmdldE1ldHJpY3MoKS50b3RhbFJlYWRzO1xuICB9O1xuICByZWMud3JpdGVzID0gZnVuY3Rpb24gKHRoaXM6IE1ldHJpY1JlY29yZGVyKSB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0TWV0cmljcygpLnRvdGFsV3JpdGVzO1xuICB9O1xuICByZWMuY29tbWl0cyA9IGZ1bmN0aW9uICh0aGlzOiBNZXRyaWNSZWNvcmRlcikge1xuICAgIHJldHVybiB0aGlzLmdldE1ldHJpY3MoKS50b3RhbENvbW1pdHM7XG4gIH07XG4gIHJlYy5zdGFnZSA9IGZ1bmN0aW9uICh0aGlzOiBNZXRyaWNSZWNvcmRlciwgbmFtZTogc3RyaW5nKSB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0U3RhZ2VNZXRyaWNzKG5hbWUpO1xuICB9O1xuICByZWMuYWxsID0gZnVuY3Rpb24gKHRoaXM6IE1ldHJpY1JlY29yZGVyKSB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0TWV0cmljcygpO1xuICB9O1xuICByZXR1cm4gcmVjO1xufVxuXG4vLyAtLS0tIERlYnVnIC0tLS1cblxuZXhwb3J0IHR5cGUgRGVidWdJbnN0YW5jZSA9IERlYnVnUmVjb3JkZXIgJiB7XG4gIGxvZ3MoKTogRGVidWdFbnRyeVtdO1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIGRlYnVnKG9wdGlvbnM/OiBEZWJ1Z1JlY29yZGVyT3B0aW9ucyk6IERlYnVnSW5zdGFuY2Uge1xuICBjb25zdCByZWMgPSBuZXcgRGVidWdSZWNvcmRlcihvcHRpb25zKSBhcyBEZWJ1Z0luc3RhbmNlO1xuICByZWMubG9ncyA9IGZ1bmN0aW9uICh0aGlzOiBEZWJ1Z1JlY29yZGVyKSB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0RW50cmllcygpO1xuICB9O1xuICByZXR1cm4gcmVjO1xufVxuXG4vLyAtLS0tIE1hbmlmZXN0IC0tLS1cblxuZXhwb3J0IHR5cGUgTWFuaWZlc3RJbnN0YW5jZSA9IE1hbmlmZXN0Rmxvd1JlY29yZGVyICYge1xuICBlbnRyaWVzKCk6IE1hbmlmZXN0RW50cnlbXTtcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBtYW5pZmVzdCgpOiBNYW5pZmVzdEluc3RhbmNlIHtcbiAgY29uc3QgcmVjID0gbmV3IE1hbmlmZXN0Rmxvd1JlY29yZGVyKCkgYXMgTWFuaWZlc3RJbnN0YW5jZTtcbiAgcmVjLmVudHJpZXMgPSBmdW5jdGlvbiAodGhpczogTWFuaWZlc3RGbG93UmVjb3JkZXIpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRNYW5pZmVzdCgpO1xuICB9O1xuICByZXR1cm4gcmVjO1xufVxuXG4vLyAtLS0tIEZsb3cgcmVjb3JkZXIgc3RyYXRlZ2llcyAtLS0tXG5cbmV4cG9ydCBmdW5jdGlvbiBhZGFwdGl2ZSgpIHtcbiAgcmV0dXJuIG5ldyBBZGFwdGl2ZU5hcnJhdGl2ZUZsb3dSZWNvcmRlcigpO1xufVxuZXhwb3J0IGZ1bmN0aW9uIG1pbGVzdG9uZSgpIHtcbiAgcmV0dXJuIG5ldyBNaWxlc3RvbmVOYXJyYXRpdmVGbG93UmVjb3JkZXIoKTtcbn1cbmV4cG9ydCBmdW5jdGlvbiB3aW5kb3dlZChtYXhFbnRyaWVzPzogbnVtYmVyKSB7XG4gIHJldHVybiBuZXcgV2luZG93ZWROYXJyYXRpdmVGbG93UmVjb3JkZXIobWF4RW50cmllcyk7XG59XG4iXX0=
96
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkZXJzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3JlY29yZGVycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7R0FnQkc7QUFDSDs7Ozs7OztHQU9HOzs7QUFHSCxzR0FBZ0c7QUFDaEcsd0hBQWtIO0FBRWxILHNHQUFnRztBQUNoRywwSEFBb0g7QUFDcEgsd0hBQWtIO0FBRWxILDZFQUF1RTtBQUV2RSwrRUFBeUU7QUFTekUsU0FBZ0IsU0FBUztJQUN2QixNQUFNLEdBQUcsR0FBRyxJQUFJLHdEQUF5QixFQUF1QixDQUFDO0lBQ2pFLEdBQUcsQ0FBQyxLQUFLLEdBQUc7UUFDVixPQUFPLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUM3QixDQUFDLENBQUM7SUFDRixHQUFHLENBQUMsVUFBVSxHQUFHO1FBQ2YsT0FBTyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDM0IsQ0FBQyxDQUFDO0lBQ0YsT0FBTyxHQUFHLENBQUM7QUFDYixDQUFDO0FBVEQsOEJBU0M7QUFZRCxTQUFnQixPQUFPO0lBQ3JCLE1BQU0sR0FBRyxHQUFHLElBQUksa0NBQWMsRUFBcUIsQ0FBQztJQUNwRCxHQUFHLENBQUMsS0FBSyxHQUFHO1FBQ1YsT0FBTyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUMsVUFBVSxDQUFDO0lBQ3RDLENBQUMsQ0FBQztJQUNGLEdBQUcsQ0FBQyxNQUFNLEdBQUc7UUFDWCxPQUFPLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQyxXQUFXLENBQUM7SUFDdkMsQ0FBQyxDQUFDO0lBQ0YsR0FBRyxDQUFDLE9BQU8sR0FBRztRQUNaLE9BQU8sSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDLFlBQVksQ0FBQztJQUN4QyxDQUFDLENBQUM7SUFDRixHQUFHLENBQUMsS0FBSyxHQUFHLFVBQWdDLElBQVk7UUFDdEQsT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3BDLENBQUMsQ0FBQztJQUNGLEdBQUcsQ0FBQyxHQUFHLEdBQUc7UUFDUixPQUFPLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUMzQixDQUFDLENBQUM7SUFDRixPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUM7QUFsQkQsMEJBa0JDO0FBUUQsU0FBZ0IsS0FBSyxDQUFDLE9BQThCO0lBQ2xELE1BQU0sR0FBRyxHQUFHLElBQUksZ0NBQWEsQ0FBQyxPQUFPLENBQWtCLENBQUM7SUFDeEQsR0FBRyxDQUFDLElBQUksR0FBRztRQUNULE9BQU8sSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQzNCLENBQUMsQ0FBQztJQUNGLE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQztBQU5ELHNCQU1DO0FBUUQsU0FBZ0IsUUFBUTtJQUN0QixNQUFNLEdBQUcsR0FBRyxJQUFJLDhDQUFvQixFQUFzQixDQUFDO0lBQzNELEdBQUcsQ0FBQyxPQUFPLEdBQUc7UUFDWixPQUFPLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUM1QixDQUFDLENBQUM7SUFDRixPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUM7QUFORCw0QkFNQztBQUVELHFDQUFxQztBQUVyQyxTQUFnQixRQUFRO0lBQ3RCLE9BQU8sSUFBSSxnRUFBNkIsRUFBRSxDQUFDO0FBQzdDLENBQUM7QUFGRCw0QkFFQztBQUNELFNBQWdCLFNBQVM7SUFDdkIsT0FBTyxJQUFJLGtFQUE4QixFQUFFLENBQUM7QUFDOUMsQ0FBQztBQUZELDhCQUVDO0FBQ0QsU0FBZ0IsUUFBUSxDQUFDLFVBQW1CO0lBQzFDLE9BQU8sSUFBSSxnRUFBNkIsQ0FBQyxVQUFVLENBQUMsQ0FBQztBQUN2RCxDQUFDO0FBRkQsNEJBRUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIGZvb3RwcmludGpzL3JlY29yZGVycyDigJQgRmFjdG9yeSBmdW5jdGlvbnMgZm9yIGJ1aWx0LWluIHJlY29yZGVycy5cbiAqXG4gKiBQcmVmZXIgdGhlc2UgZmFjdG9yeSBmdW5jdGlvbnMgb3ZlciBjb25zdHJ1Y3RpbmcgcmVjb3JkZXIgY2xhc3NlcyBkaXJlY3RseS5cbiAqIEVhY2ggZmFjdG9yeSByZXR1cm5zIHRoZSByZWNvcmRlciBpbnN0YW5jZSBlbnJpY2hlZCB3aXRoIHNob3J0IGNvbnZlbmllbmNlIG1ldGhvZHMuXG4gKlxuICogYGBgdHNcbiAqIGltcG9ydCB7IG5hcnJhdGl2ZSwgbWV0cmljcywgZGVidWcsIG1hbmlmZXN0IH0gZnJvbSAnZm9vdHByaW50anMvcmVjb3JkZXJzJztcbiAqXG4gKiBjb25zdCByZXN1bHQgPSBhd2FpdCBjaGFydFxuICogICAucmVjb3JkZXIobmFycmF0aXZlKCkpXG4gKiAgIC5yZWNvcmRlcihtZXRyaWNzKCkpXG4gKiAgIC5ydW4oKTtcbiAqIGBgYFxuICpcbiAqIEBtb2R1bGUgcmVjb3JkZXJzXG4gKi9cbi8qKlxuICogZm9vdHByaW50anMvcmVjb3JkZXJzIC0tIEZhY3RvcnkgZnVuY3Rpb25zIGZvciBidWlsdC1pbiByZWNvcmRlcnMuXG4gKlxuICogSW1wb3J0OiBpbXBvcnQgeyBuYXJyYXRpdmUsIG1ldHJpY3MsIGRlYnVnLCBtYW5pZmVzdCB9IGZyb20gJ2Zvb3RwcmludGpzL3JlY29yZGVycyc7XG4gKlxuICogRWFjaCBmYWN0b3J5IHJldHVybnMgdGhlIHJhdyByZWNvcmRlciBpbnN0YW5jZSB3aXRoIGFkZGVkIHNob3J0IGNvbnZlbmllbmNlIG1ldGhvZHMuXG4gKiBQYXNzIGRpcmVjdGx5IHRvIGNoYXJ0LnJlY29yZGVyKCkuIE5vIHdyYXBwaW5nLCBubyBwcm94eWluZyAtLSBqdXN0IHRoZSBjbGFzcyArIHNob3J0Y3V0cy5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7IENvbWJpbmVkTmFycmF0aXZlRW50cnkgfSBmcm9tICcuL2xpYi9lbmdpbmUvbmFycmF0aXZlL0NvbWJpbmVkTmFycmF0aXZlQnVpbGRlci5qcyc7XG5pbXBvcnQgeyBDb21iaW5lZE5hcnJhdGl2ZVJlY29yZGVyIH0gZnJvbSAnLi9saWIvZW5naW5lL25hcnJhdGl2ZS9Db21iaW5lZE5hcnJhdGl2ZVJlY29yZGVyLmpzJztcbmltcG9ydCB7IEFkYXB0aXZlTmFycmF0aXZlRmxvd1JlY29yZGVyIH0gZnJvbSAnLi9saWIvZW5naW5lL25hcnJhdGl2ZS9yZWNvcmRlcnMvQWRhcHRpdmVOYXJyYXRpdmVGbG93UmVjb3JkZXIuanMnO1xuaW1wb3J0IHR5cGUgeyBNYW5pZmVzdEVudHJ5IH0gZnJvbSAnLi9saWIvZW5naW5lL25hcnJhdGl2ZS9yZWNvcmRlcnMvTWFuaWZlc3RGbG93UmVjb3JkZXIuanMnO1xuaW1wb3J0IHsgTWFuaWZlc3RGbG93UmVjb3JkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUvbmFycmF0aXZlL3JlY29yZGVycy9NYW5pZmVzdEZsb3dSZWNvcmRlci5qcyc7XG5pbXBvcnQgeyBNaWxlc3RvbmVOYXJyYXRpdmVGbG93UmVjb3JkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUvbmFycmF0aXZlL3JlY29yZGVycy9NaWxlc3RvbmVOYXJyYXRpdmVGbG93UmVjb3JkZXIuanMnO1xuaW1wb3J0IHsgV2luZG93ZWROYXJyYXRpdmVGbG93UmVjb3JkZXIgfSBmcm9tICcuL2xpYi9lbmdpbmUvbmFycmF0aXZlL3JlY29yZGVycy9XaW5kb3dlZE5hcnJhdGl2ZUZsb3dSZWNvcmRlci5qcyc7XG5pbXBvcnQgdHlwZSB7IERlYnVnRW50cnksIERlYnVnUmVjb3JkZXJPcHRpb25zIH0gZnJvbSAnLi9saWIvc2NvcGUvcmVjb3JkZXJzL0RlYnVnUmVjb3JkZXIuanMnO1xuaW1wb3J0IHsgRGVidWdSZWNvcmRlciB9IGZyb20gJy4vbGliL3Njb3BlL3JlY29yZGVycy9EZWJ1Z1JlY29yZGVyLmpzJztcbmltcG9ydCB0eXBlIHsgQWdncmVnYXRlZE1ldHJpY3MsIFN0YWdlTWV0cmljcyB9IGZyb20gJy4vbGliL3Njb3BlL3JlY29yZGVycy9NZXRyaWNSZWNvcmRlci5qcyc7XG5pbXBvcnQgeyBNZXRyaWNSZWNvcmRlciB9IGZyb20gJy4vbGliL3Njb3BlL3JlY29yZGVycy9NZXRyaWNSZWNvcmRlci5qcyc7XG5cbi8vIC0tLS0gTmFycmF0aXZlIC0tLS1cblxuZXhwb3J0IHR5cGUgTmFycmF0aXZlSW5zdGFuY2UgPSBDb21iaW5lZE5hcnJhdGl2ZVJlY29yZGVyICYge1xuICBsaW5lcygpOiBzdHJpbmdbXTtcbiAgc3RydWN0dXJlZCgpOiBDb21iaW5lZE5hcnJhdGl2ZUVudHJ5W107XG59O1xuXG5leHBvcnQgZnVuY3Rpb24gbmFycmF0aXZlKCk6IE5hcnJhdGl2ZUluc3RhbmNlIHtcbiAgY29uc3QgcmVjID0gbmV3IENvbWJpbmVkTmFycmF0aXZlUmVjb3JkZXIoKSBhcyBOYXJyYXRpdmVJbnN0YW5jZTtcbiAgcmVjLmxpbmVzID0gZnVuY3Rpb24gKHRoaXM6IENvbWJpbmVkTmFycmF0aXZlUmVjb3JkZXIpIHtcbiAgICByZXR1cm4gdGhpcy5nZXROYXJyYXRpdmUoKTtcbiAgfTtcbiAgcmVjLnN0cnVjdHVyZWQgPSBmdW5jdGlvbiAodGhpczogQ29tYmluZWROYXJyYXRpdmVSZWNvcmRlcikge1xuICAgIHJldHVybiB0aGlzLmdldEVudHJpZXMoKTtcbiAgfTtcbiAgcmV0dXJuIHJlYztcbn1cblxuLy8gLS0tLSBNZXRyaWNzIC0tLS1cblxuZXhwb3J0IHR5cGUgTWV0cmljc0luc3RhbmNlID0gTWV0cmljUmVjb3JkZXIgJiB7XG4gIHJlYWRzKCk6IG51bWJlcjtcbiAgd3JpdGVzKCk6IG51bWJlcjtcbiAgY29tbWl0cygpOiBudW1iZXI7XG4gIHN0YWdlKG5hbWU6IHN0cmluZyk6IFN0YWdlTWV0cmljcyB8IHVuZGVmaW5lZDtcbiAgYWxsKCk6IEFnZ3JlZ2F0ZWRNZXRyaWNzO1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIG1ldHJpY3MoKTogTWV0cmljc0luc3RhbmNlIHtcbiAgY29uc3QgcmVjID0gbmV3IE1ldHJpY1JlY29yZGVyKCkgYXMgTWV0cmljc0luc3RhbmNlO1xuICByZWMucmVhZHMgPSBmdW5jdGlvbiAodGhpczogTWV0cmljUmVjb3JkZXIpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRNZXRyaWNzKCkudG90YWxSZWFkcztcbiAgfTtcbiAgcmVjLndyaXRlcyA9IGZ1bmN0aW9uICh0aGlzOiBNZXRyaWNSZWNvcmRlcikge1xuICAgIHJldHVybiB0aGlzLmdldE1ldHJpY3MoKS50b3RhbFdyaXRlcztcbiAgfTtcbiAgcmVjLmNvbW1pdHMgPSBmdW5jdGlvbiAodGhpczogTWV0cmljUmVjb3JkZXIpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRNZXRyaWNzKCkudG90YWxDb21taXRzO1xuICB9O1xuICByZWMuc3RhZ2UgPSBmdW5jdGlvbiAodGhpczogTWV0cmljUmVjb3JkZXIsIG5hbWU6IHN0cmluZykge1xuICAgIHJldHVybiB0aGlzLmdldFN0YWdlTWV0cmljcyhuYW1lKTtcbiAgfTtcbiAgcmVjLmFsbCA9IGZ1bmN0aW9uICh0aGlzOiBNZXRyaWNSZWNvcmRlcikge1xuICAgIHJldHVybiB0aGlzLmdldE1ldHJpY3MoKTtcbiAgfTtcbiAgcmV0dXJuIHJlYztcbn1cblxuLy8gLS0tLSBEZWJ1ZyAtLS0tXG5cbmV4cG9ydCB0eXBlIERlYnVnSW5zdGFuY2UgPSBEZWJ1Z1JlY29yZGVyICYge1xuICBsb2dzKCk6IERlYnVnRW50cnlbXTtcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBkZWJ1ZyhvcHRpb25zPzogRGVidWdSZWNvcmRlck9wdGlvbnMpOiBEZWJ1Z0luc3RhbmNlIHtcbiAgY29uc3QgcmVjID0gbmV3IERlYnVnUmVjb3JkZXIob3B0aW9ucykgYXMgRGVidWdJbnN0YW5jZTtcbiAgcmVjLmxvZ3MgPSBmdW5jdGlvbiAodGhpczogRGVidWdSZWNvcmRlcikge1xuICAgIHJldHVybiB0aGlzLmdldEVudHJpZXMoKTtcbiAgfTtcbiAgcmV0dXJuIHJlYztcbn1cblxuLy8gLS0tLSBNYW5pZmVzdCAtLS0tXG5cbmV4cG9ydCB0eXBlIE1hbmlmZXN0SW5zdGFuY2UgPSBNYW5pZmVzdEZsb3dSZWNvcmRlciAmIHtcbiAgZW50cmllcygpOiBNYW5pZmVzdEVudHJ5W107XG59O1xuXG5leHBvcnQgZnVuY3Rpb24gbWFuaWZlc3QoKTogTWFuaWZlc3RJbnN0YW5jZSB7XG4gIGNvbnN0IHJlYyA9IG5ldyBNYW5pZmVzdEZsb3dSZWNvcmRlcigpIGFzIE1hbmlmZXN0SW5zdGFuY2U7XG4gIHJlYy5lbnRyaWVzID0gZnVuY3Rpb24gKHRoaXM6IE1hbmlmZXN0Rmxvd1JlY29yZGVyKSB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0TWFuaWZlc3QoKTtcbiAgfTtcbiAgcmV0dXJuIHJlYztcbn1cblxuLy8gLS0tLSBGbG93IHJlY29yZGVyIHN0cmF0ZWdpZXMgLS0tLVxuXG5leHBvcnQgZnVuY3Rpb24gYWRhcHRpdmUoKSB7XG4gIHJldHVybiBuZXcgQWRhcHRpdmVOYXJyYXRpdmVGbG93UmVjb3JkZXIoKTtcbn1cbmV4cG9ydCBmdW5jdGlvbiBtaWxlc3RvbmUoKSB7XG4gIHJldHVybiBuZXcgTWlsZXN0b25lTmFycmF0aXZlRmxvd1JlY29yZGVyKCk7XG59XG5leHBvcnQgZnVuY3Rpb24gd2luZG93ZWQobWF4RW50cmllcz86IG51bWJlcikge1xuICByZXR1cm4gbmV3IFdpbmRvd2VkTmFycmF0aXZlRmxvd1JlY29yZGVyKG1heEVudHJpZXMpO1xufVxuIl19
@@ -1,3 +1,16 @@
1
+ /**
2
+ * footprintjs/advanced — Low-level internals for custom execution engines and testing.
3
+ *
4
+ * Most users never need this. Use `footprintjs` (main) instead.
5
+ * This entry point exposes `SharedMemory`, `StageContext`, `FlowchartTraverser`,
6
+ * and other primitives that power the engine.
7
+ *
8
+ * ```ts
9
+ * import { SharedMemory, StageContext } from 'footprintjs/advanced';
10
+ * ```
11
+ *
12
+ * @module advanced
13
+ */
1
14
  /**
2
15
  * FootPrint — Advanced / Internal API
3
16
  *
@@ -1,49 +1,95 @@
1
1
  /**
2
- * FootPrint — Public API (v2.0)
2
+ * FootPrint — Public API (v3)
3
3
  *
4
4
  * The flowchart pattern for backend code.
5
- * Build → DescribeRun.
5
+ * Build → RunObserve.
6
6
  *
7
- * For advanced/internal APIs, import from 'footprintjs/advanced'.
8
- * For recorder factories, import from 'footprintjs/recorders'.
7
+ * **Three import paths:**
8
+ * ```ts
9
+ * import { flowChart, decide, narrative } from 'footprintjs'; // main — start here
10
+ * import { metrics, debug, manifest } from 'footprintjs/recorders'; // recorder factories
11
+ * import { SharedMemory, StageContext } from 'footprintjs/advanced'; // internals
12
+ * ```
13
+ *
14
+ * @module
9
15
  */
16
+ /** @category Quick Start */
10
17
  export type { FlowChart, StageFunction as StageHandler, StreamHandlers } from './lib/builder/index.js';
18
+ /** @category Quick Start */
11
19
  export { flowChart, FlowChartBuilder } from './lib/builder/index.js';
20
+ /** @category Quick Start */
12
21
  export type { TypedStageFunction } from './lib/builder/typedFlowChart.js';
22
+ /** @category Quick Start */
13
23
  export type { ScopeMethods, TypedScope } from './lib/reactive/index.js';
14
- export type { DecideRule, DecisionEvidence, DecisionResult, FilterOps, SelectionResult, WhereFilter, } from './lib/decide/index.js';
24
+ /** @category Quick Start */
25
+ export { narrative } from './recorders.js';
26
+ /** @category Decision Branching */
27
+ export type { DecideRule, DecisionEvidence, DecisionResult, FilterOps, RuleEvidence, SelectionEvidence, SelectionResult, WhenClause, WhereFilter, } from './lib/decide/index.js';
28
+ /** @category Decision Branching */
15
29
  export { decide, select } from './lib/decide/index.js';
30
+ /** @category Run */
16
31
  export type { RunResult } from './lib/runner/index.js';
32
+ /** @category Run */
17
33
  export { FlowChartExecutor } from './lib/runner/index.js';
34
+ /** @category Run */
18
35
  export { RunContext } from './lib/runner/index.js';
36
+ /** @category Run */
19
37
  export type { ChartOpenAPIOptions, MCPToolDescription, RunnableFlowChart } from './lib/runner/RunnableChart.js';
20
- export { narrative } from './recorders.js';
21
- export type { ComposableRunner } from './lib/runner/index.js';
22
- export type { RecorderSnapshot, RuntimeSnapshot, SubtreeSnapshot } from './lib/runner/index.js';
23
- export { getSubtreeSnapshot, listSubflowPaths } from './lib/runner/index.js';
24
- export { ScopeFacade } from './lib/scope/index.js';
25
- export { disableDevMode, enableDevMode } from './lib/scope/detectCircular.js';
38
+ /** @category Observe Data */
39
+ export type { CommitEvent, ErrorEvent, ReadEvent, Recorder, RedactionPolicy, RedactionReport, WriteEvent, } from './lib/scope/index.js';
40
+ /** @category Observe Data */
26
41
  export { MetricRecorder } from './lib/scope/index.js';
42
+ /** @category Observe — Data */
27
43
  export { DebugRecorder } from './lib/scope/index.js';
28
- export type { CommitEvent, ErrorEvent, ReadEvent, Recorder, RedactionPolicy, RedactionReport, WriteEvent, } from './lib/scope/index.js';
29
- export { defineScopeFromZod } from './lib/scope/index.js';
30
- export type { CombinedNarrativeEntry } from './lib/engine/index.js';
44
+ /** @category Observe Flow */
31
45
  export type { FlowBreakEvent, FlowDecisionEvent, FlowErrorEvent, FlowForkEvent, FlowLoopEvent, FlowNextEvent, FlowRecorder, FlowSelectedEvent, FlowStageEvent, FlowSubflowEvent, FlowSubflowRegisteredEvent, TraversalContext, } from './lib/engine/index.js';
46
+ /** @category Observe — Flow */
47
+ export type { CombinedNarrativeEntry } from './lib/engine/index.js';
48
+ /** @category Observe — Flow */
32
49
  export { NarrativeFlowRecorder } from './lib/engine/index.js';
33
- export type { StructuredErrorInfo } from './lib/engine/index.js';
34
- export { extractErrorInfo, formatErrorInfo } from './lib/engine/index.js';
50
+ /** @category Observe Flow */
35
51
  export type { ManifestEntry } from './lib/engine/index.js';
52
+ /** @category Observe — Flow */
36
53
  export { ManifestFlowRecorder } from './lib/engine/index.js';
54
+ /** @category Observe — Flow */
37
55
  export { AdaptiveNarrativeFlowRecorder } from './lib/engine/index.js';
56
+ /** @category Observe — Flow */
38
57
  export { MilestoneNarrativeFlowRecorder } from './lib/engine/index.js';
58
+ /** @category Observe — Flow */
39
59
  export { ProgressiveNarrativeFlowRecorder } from './lib/engine/index.js';
60
+ /** @category Observe — Flow */
40
61
  export { RLENarrativeFlowRecorder } from './lib/engine/index.js';
62
+ /** @category Observe — Flow */
41
63
  export { SeparateNarrativeFlowRecorder } from './lib/engine/index.js';
64
+ /** @category Observe — Flow */
42
65
  export { SilentNarrativeFlowRecorder } from './lib/engine/index.js';
66
+ /** @category Observe — Flow */
43
67
  export { WindowedNarrativeFlowRecorder } from './lib/engine/index.js';
68
+ /** @category Self-Describing */
69
+ export type { FlowChartContract, FlowChartContractOptions, JsonSchema, OpenAPIOptions, OpenAPISpec, } from './lib/contract/index.js';
70
+ /** @category Snapshot & Composition */
71
+ export type { ComposableRunner } from './lib/runner/index.js';
72
+ /** @category Snapshot & Composition */
73
+ export type { RecorderSnapshot, RuntimeSnapshot, SubtreeSnapshot } from './lib/runner/index.js';
74
+ /** @category Snapshot & Composition */
75
+ export { getSubtreeSnapshot, listSubflowPaths } from './lib/runner/index.js';
76
+ /** @category Configuration */
44
77
  export type { ExecutionEnv, RunOptions } from './lib/engine/index.js';
78
+ /** @category Configuration */
45
79
  export type { ScopeFactory } from './lib/engine/index.js';
46
- export type { FlowChartContract, FlowChartContractOptions, JsonSchema, OpenAPIOptions, OpenAPISpec, } from './lib/contract/index.js';
80
+ /** @category Contract & Validation */
47
81
  export type { SchemaKind, ValidationIssue, ValidationResult } from './lib/schema/index.js';
82
+ /** @category Contract & Validation */
48
83
  export { detectSchema, isValidatable, isZod } from './lib/schema/index.js';
84
+ /** @category Contract & Validation */
49
85
  export { InputValidationError, validateAgainstSchema, validateOrThrow } from './lib/schema/index.js';
86
+ /** @category Error Utilities */
87
+ export type { StructuredErrorInfo } from './lib/engine/index.js';
88
+ /** @category Error Utilities */
89
+ export { extractErrorInfo, formatErrorInfo } from './lib/engine/index.js';
90
+ /** @category Dev Tools */
91
+ export { disableDevMode, enableDevMode } from './lib/scope/detectCircular.js';
92
+ /** @category Dev Tools */
93
+ export { defineScopeFromZod } from './lib/scope/index.js';
94
+ /** @category Dev Tools */
95
+ export { ScopeFacade } from './lib/scope/index.js';
@@ -5,8 +5,9 @@
5
5
  * Called by FlowChartBuilder.build() to enrich the compiled chart with
6
6
  * d3-style chainable run methods and self-describing outputs.
7
7
  */
8
+ import type { FlowChart } from '../builder/types.js';
8
9
  import type { FlowRecorder } from '../engine/narrative/types.js';
9
- import type { FlowChart, RunOptions, SerializedPipelineStructure } from '../engine/types.js';
10
+ import type { RunOptions } from '../engine/types.js';
10
11
  import type { Recorder, RedactionPolicy } from '../scope/types.js';
11
12
  import { type RunResult, RunContext } from './RunContext.js';
12
13
  /** OpenAPI generation options. */
@@ -22,18 +23,14 @@ export interface MCPToolDescription {
22
23
  description: string;
23
24
  inputSchema?: unknown;
24
25
  }
25
- /** FlowChart with d3-style methods: run, recorder, redact, toOpenAPI, toMCPTool. */
26
+ /**
27
+ * FlowChart enriched with d3-style run methods and self-describing outputs.
28
+ *
29
+ * Extends builder.FlowChart (which already carries buildTimeStructure, description,
30
+ * stageDescriptions, inputSchema, outputSchema, outputMapper) and adds the runtime
31
+ * methods attached by makeRunnable().
32
+ */
26
33
  export interface RunnableFlowChart<TOut = any, TScope = any> extends FlowChart<TOut, TScope> {
27
- /** Always set by build() — narrows the optional field from FlowChart to required. */
28
- buildTimeStructure: SerializedPipelineStructure;
29
- /** Human-readable numbered step list. Empty string when no descriptions were provided. */
30
- description: string;
31
- /** Per-stage descriptions, keyed by stage name. */
32
- stageDescriptions: Map<string, string>;
33
- /** Output schema (Zod or JSON Schema) — declared via .contract(). */
34
- outputSchema?: unknown;
35
- /** Output mapper — extracts response from final scope. Declared via .contract(). */
36
- outputMapper?: (finalScope: Record<string, unknown>) => unknown;
37
34
  /** Attach a recorder for the next run. Returns a chainable RunContext. */
38
35
  recorder(r: Recorder | FlowRecorder): RunContext<TOut, TScope>;
39
36
  /** Set redaction policy for the next run. Returns a chainable RunContext. */
@@ -1,3 +1,20 @@
1
+ /**
2
+ * footprintjs/recorders — Factory functions for built-in recorders.
3
+ *
4
+ * Prefer these factory functions over constructing recorder classes directly.
5
+ * Each factory returns the recorder instance enriched with short convenience methods.
6
+ *
7
+ * ```ts
8
+ * import { narrative, metrics, debug, manifest } from 'footprintjs/recorders';
9
+ *
10
+ * const result = await chart
11
+ * .recorder(narrative())
12
+ * .recorder(metrics())
13
+ * .run();
14
+ * ```
15
+ *
16
+ * @module recorders
17
+ */
1
18
  /**
2
19
  * footprintjs/recorders -- Factory functions for built-in recorders.
3
20
  *
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "footprintjs",
3
- "version": "3.0.13",
3
+ "version": "3.0.14",
4
4
  "description": "Turn your whiteboard flowchart into running code — with automatic causal traces for LLM reasoning",
5
5
  "license": "MIT",
6
6
  "author": "Sanjay Krishna Anbalagan",