footprintjs 3.0.8 → 3.0.10

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/README.md CHANGED
@@ -73,14 +73,16 @@ That answer came from the trace — not from the LLM's imagination.
73
73
  ## Quick Start
74
74
 
75
75
  ```typescript
76
- import { flowChart, FlowChartExecutor, decide } from 'footprintjs';
76
+ import { flowChart, decide, narrative } from 'footprintjs';
77
77
 
78
+ // 1. Define your state
78
79
  interface State {
79
80
  user: { name: string; tier: string };
80
81
  discount: number;
81
82
  lane: string;
82
83
  }
83
84
 
85
+ // 2. Build the flowchart
84
86
  const chart = flowChart<State>('FetchUser', async (scope) => {
85
87
  scope.user = { name: 'Alice', tier: 'premium' };
86
88
  }, 'fetch-user')
@@ -102,20 +104,23 @@ const chart = flowChart<State>('FetchUser', async (scope) => {
102
104
  .end()
103
105
  .build();
104
106
 
105
- const executor = new FlowChartExecutor(chart);
106
- await executor.run();
107
-
108
- console.log(executor.getNarrative());
109
- // Stage 1: The process began with FetchUser.
110
- // Step 1: Write user = {name, tier}
111
- // Stage 2: Next, it moved on to ApplyDiscount.
112
- // Step 1: Read user = {name, tier}
113
- // Step 2: Write discount = 0.2
114
- // Stage 3: Next step: Route by discount tier.
115
- // Step 1: Read discount = 0.2
116
- // [Condition]: It evaluated "High discount": discount 0.2 gt 0.1 ✓, and chose VIPCheckout.
117
- // Stage 4: Next, it moved on to VIPCheckout.
118
- // Step 1: Write lane = "VIP express"
107
+ // 3. Run state + self-generated trace included
108
+ const result = await chart.recorder(narrative()).run();
109
+
110
+ console.log(result.state.lane); // "VIP express"
111
+ console.log(result.narrative);
112
+ // [
113
+ // "Stage 1: The process began with FetchUser.",
114
+ // " Step 1: Write user = {name, tier}",
115
+ // "Stage 2: Next, it moved on to ApplyDiscount.",
116
+ // " Step 1: Read user = {name, tier}",
117
+ // " Step 2: Write discount = 0.2",
118
+ // "Stage 3: Next step: Route by discount tier.",
119
+ // " Step 1: Read discount = 0.2",
120
+ // "[Condition]: It evaluated Rule 0 \"High discount\": discount 0.2 gt 0.1 ✓, and chose VIPCheckout.",
121
+ // "Stage 4: Next, it moved on to VIPCheckout.",
122
+ // " Step 1: Write lane = \"VIP express\"",
123
+ // ]
119
124
  ```
120
125
 
121
126
  > **[Try it in the browser](https://footprintjs.github.io/footprint-playground/)** &mdash; no install needed
package/dist/esm/index.js CHANGED
@@ -11,6 +11,7 @@ export { flowChart, FlowChartBuilder } from './lib/builder/index.js';
11
11
  export { decide, select } from './lib/decide/index.js';
12
12
  export { FlowChartExecutor } from './lib/runner/index.js';
13
13
  export { RunContext } from './lib/runner/index.js';
14
+ export { narrative } from './recorders.js';
14
15
  export { getSubtreeSnapshot, listSubflowPaths } from './lib/runner/index.js';
15
16
  // ============================================================================
16
17
  // Scope — Per-stage facades and recorders
@@ -35,4 +36,4 @@ export { SilentNarrativeFlowRecorder } from './lib/engine/index.js';
35
36
  export { WindowedNarrativeFlowRecorder } from './lib/engine/index.js';
36
37
  export { detectSchema, isValidatable, isZod } from './lib/schema/index.js';
37
38
  export { InputValidationError, validateAgainstSchema, validateOrThrow } from './lib/schema/index.js';
38
- //# 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;AAOvD,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAYnD,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\nexport type { RunResult } from './lib/runner/index.js';\nexport { FlowChartExecutor } from './lib/runner/index.js';\nexport { RunContext } from './lib/runner/index.js';\nexport type {\n  OpenAPIOptions as ChartOpenAPIOptions,\n  MCPToolDescription,\n  RunnableFlowChart,\n} from './lib/runner/RunnableChart.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/memory/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"]}
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;AAMnD,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 {\n  OpenAPIOptions as ChartOpenAPIOptions,\n  MCPToolDescription,\n  RunnableFlowChart,\n} 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/memory/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"]}
@@ -9,4 +9,4 @@
9
9
  * The builder remains standalone at runtime.
10
10
  */
11
11
  export {};
12
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/lib/builder/types.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG","sourcesContent":["/**\n * builder/types.ts — All types used by the builder library.\n *\n * Shared types (StageNode, StageFunction, etc.) are imported from the engine.\n * Builder-specific types (FlowChartSpec, FlowChart, SerializedPipelineStructure)\n * are defined locally — they carry builder-only fields (description, outputMapper, etc.).\n *\n * NOTE: All engine imports are `import type` — zero runtime dependency.\n * The builder remains standalone at runtime.\n */\n\nimport type { StageNode } from '../engine/graph/StageNode.js';\nimport type { ILogger, ScopeFactory, StageFunction } from '../engine/types.js';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Re-exports from engine (canonical definitions)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type { StageNode } from '../engine/graph/StageNode.js';\nexport type {\n  ILogger,\n  StageFunction,\n  StreamCallback,\n  StreamHandlers,\n  StreamLifecycleHandler,\n  StreamTokenHandler,\n  SubflowMountOptions,\n} from '../engine/types.js';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Aliases\n// ─────────────────────────────────────────────────────────────────────────────\n\n/** Relaxed-generic alias for builder ergonomics. */\nexport type StageFn = StageFunction<any, any>;\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Scope Protection\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type ScopeProtectionMode = 'error' | 'warn' | 'off';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Serialized Pipeline Structure (JSON-safe, for visualization)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface SerializedPipelineStructure {\n  name: string;\n  id?: string;\n  type: 'stage' | 'decider' | 'fork' | 'streaming';\n  /** Semantic icon hint for visualization (e.g., \"llm\", \"tool\", \"rag\", \"agent\", \"start\") */\n  icon?: string;\n  description?: string;\n  children?: SerializedPipelineStructure[];\n  next?: SerializedPipelineStructure;\n  hasDecider?: boolean;\n  hasSelector?: boolean;\n  branchIds?: string[];\n  loopTarget?: string;\n  isStreaming?: boolean;\n  streamId?: string;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n  subflowStructure?: SerializedPipelineStructure;\n  iterationCount?: number;\n  /** True when this subflow uses lazy resolution (deferred until execution). */\n  isLazy?: boolean;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// FlowChartSpec (pure JSON, no functions — for FE→BE transport)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface FlowChartSpec {\n  name: string;\n  id?: string;\n  /** Semantic icon hint for visualization (e.g., \"llm\", \"tool\", \"rag\", \"agent\", \"start\") */\n  icon?: string;\n  description?: string;\n  children?: FlowChartSpec[];\n  next?: FlowChartSpec;\n  hasDecider?: boolean;\n  hasSelector?: boolean;\n  branchIds?: string[];\n  loopTarget?: string;\n  isStreaming?: boolean;\n  streamId?: string;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Build-Time Extractor\n// ─────────────────────────────────────────────────────────────────────────────\n\n/** Metadata provided to the build-time extractor for each node. */\nexport type BuildTimeNodeMetadata = FlowChartSpec;\n\nexport type BuildTimeExtractor<TResult = FlowChartSpec> = (metadata: BuildTimeNodeMetadata) => TResult;\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Traversal Extractor (runtime)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type TraversalExtractor<TResult = unknown> = (snapshot: unknown) => TResult | undefined | null;\n\n// ─────────────────────────────────────────────────────────────────────────────\n// FlowChart — compiled output of build()\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type FlowChart<TOut = any, TScope = any> = {\n  root: StageNode<TOut, TScope>;\n  stageMap: Map<string, StageFunction<TOut, TScope>>;\n  extractor?: TraversalExtractor;\n  subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  buildTimeStructure: SerializedPipelineStructure;\n  enableNarrative?: boolean;\n  logger?: ILogger;\n  description: string;\n  stageDescriptions: Map<string, string>;\n  /** Input schema (Zod or JSON Schema) — declared via setInputSchema() or .contract(). */\n  inputSchema?: unknown;\n  /** Output schema (Zod or JSON Schema) — declared via setOutputSchema() or .contract(). */\n  outputSchema?: unknown;\n  /** Output mapper — extracts response from final scope. */\n  outputMapper?: (finalScope: Record<string, unknown>) => unknown;\n  /** Scope factory — auto-embedded by flowChart<T>(). Executor reads this if no factory param. */\n  scopeFactory?: ScopeFactory<TScope>;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Simplified Parallel Spec (for addListOfFunction)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type SimplifiedParallelSpec<TOut = any, TScope = any> = {\n  id: string;\n  name: string;\n  fn?: StageFunction<TOut, TScope>;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// ExecOptions (for execute() convenience — used by runner layer)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type ExecOptions = {\n  defaults?: unknown;\n  initial?: unknown;\n  readOnly?: unknown;\n  throttlingErrorChecker?: (e: unknown) => boolean;\n  scopeProtectionMode?: ScopeProtectionMode;\n  enableNarrative?: boolean;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// SubflowRef\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface SubflowRef {\n  $ref: string;\n  mountId: string;\n}\n"]}
12
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/lib/builder/types.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG","sourcesContent":["/**\n * builder/types.ts — All types used by the builder library.\n *\n * Shared types (StageNode, StageFunction, etc.) are imported from the engine.\n * Builder-specific types (FlowChartSpec, FlowChart, SerializedPipelineStructure)\n * are defined locally — they carry builder-only fields (description, outputMapper, etc.).\n *\n * NOTE: All engine imports are `import type` — zero runtime dependency.\n * The builder remains standalone at runtime.\n */\n\nimport type { StageNode } from '../engine/graph/StageNode.js';\nimport type { ILogger, ScopeFactory, StageFunction, TraversalExtractor } from '../engine/types.js';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Re-exports from engine (canonical definitions)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type { StageNode } from '../engine/graph/StageNode.js';\nexport type {\n  ILogger,\n  StageFunction,\n  StreamCallback,\n  StreamHandlers,\n  StreamLifecycleHandler,\n  StreamTokenHandler,\n  SubflowMountOptions,\n} from '../engine/types.js';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Aliases\n// ─────────────────────────────────────────────────────────────────────────────\n\n/** Relaxed-generic alias for builder ergonomics. */\nexport type StageFn = StageFunction<any, any>;\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Scope Protection\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type ScopeProtectionMode = 'error' | 'warn' | 'off';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Serialized Pipeline Structure (JSON-safe, for visualization)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface SerializedPipelineStructure {\n  name: string;\n  id?: string;\n  type: 'stage' | 'decider' | 'fork' | 'streaming';\n  /** Semantic icon hint for visualization (e.g., \"llm\", \"tool\", \"rag\", \"agent\", \"start\") */\n  icon?: string;\n  description?: string;\n  children?: SerializedPipelineStructure[];\n  next?: SerializedPipelineStructure;\n  hasDecider?: boolean;\n  hasSelector?: boolean;\n  branchIds?: string[];\n  loopTarget?: string;\n  isStreaming?: boolean;\n  streamId?: string;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n  subflowStructure?: SerializedPipelineStructure;\n  iterationCount?: number;\n  /** True when this subflow uses lazy resolution (deferred until execution). */\n  isLazy?: boolean;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// FlowChartSpec (pure JSON, no functions — for FE→BE transport)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface FlowChartSpec {\n  name: string;\n  id?: string;\n  /** Semantic icon hint for visualization (e.g., \"llm\", \"tool\", \"rag\", \"agent\", \"start\") */\n  icon?: string;\n  description?: string;\n  children?: FlowChartSpec[];\n  next?: FlowChartSpec;\n  hasDecider?: boolean;\n  hasSelector?: boolean;\n  branchIds?: string[];\n  loopTarget?: string;\n  isStreaming?: boolean;\n  streamId?: string;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Build-Time Extractor\n// ─────────────────────────────────────────────────────────────────────────────\n\n/** Metadata provided to the build-time extractor for each node. */\nexport type BuildTimeNodeMetadata = FlowChartSpec;\n\nexport type BuildTimeExtractor<TResult = FlowChartSpec> = (metadata: BuildTimeNodeMetadata) => TResult;\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Traversal Extractor (runtime) — canonical definition lives in engine/types.\n// Re-exported here so callers don't need two import paths.\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type { TraversalExtractor } from '../engine/types.js';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// FlowChart — compiled output of build()\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type FlowChart<TOut = any, TScope = any> = {\n  root: StageNode<TOut, TScope>;\n  stageMap: Map<string, StageFunction<TOut, TScope>>;\n  extractor?: TraversalExtractor;\n  subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  buildTimeStructure: SerializedPipelineStructure;\n  enableNarrative?: boolean;\n  logger?: ILogger;\n  description: string;\n  stageDescriptions: Map<string, string>;\n  /** Input schema (Zod or JSON Schema) — declared via setInputSchema() or .contract(). */\n  inputSchema?: unknown;\n  /** Output schema (Zod or JSON Schema) — declared via setOutputSchema() or .contract(). */\n  outputSchema?: unknown;\n  /** Output mapper — extracts response from final scope. */\n  outputMapper?: (finalScope: Record<string, unknown>) => unknown;\n  /** Scope factory — auto-embedded by flowChart<T>(). Executor reads this if no factory param. */\n  scopeFactory?: ScopeFactory<TScope>;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Simplified Parallel Spec (for addListOfFunction)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type SimplifiedParallelSpec<TOut = any, TScope = any> = {\n  id: string;\n  name: string;\n  fn?: StageFunction<TOut, TScope>;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// ExecOptions (for execute() convenience — used by runner layer)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type ExecOptions = {\n  defaults?: unknown;\n  initial?: unknown;\n  readOnly?: unknown;\n  throttlingErrorChecker?: (e: unknown) => boolean;\n  scopeProtectionMode?: ScopeProtectionMode;\n  enableNarrative?: boolean;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// SubflowRef\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface SubflowRef {\n  $ref: string;\n  mountId: string;\n}\n"]}
@@ -101,4 +101,4 @@ function normalizeSchema(schema) {
101
101
  }
102
102
  return schema;
103
103
  }
104
- //# 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 { FlowRecorder } from '../engine/narrative/types.js';\nimport type { FlowChart, 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 OpenAPIOptions {\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  /** 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?: OpenAPIOptions): 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?: OpenAPIOptions): 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, try to convert\n  if (\n    typeof schema === 'object' &&\n    schema !== null &&\n    typeof (schema as Record<string, unknown>)._def !== 'undefined'\n  ) {\n    try {\n      // Attempt Zod-to-JSON-Schema conversion via the library's existing converter\n      const { zodToJsonSchema } = require('../contract/zodToJsonSchema.js');\n      return zodToJsonSchema(schema);\n    } catch {\n      // If conversion fails, return as-is\n      return schema;\n    }\n  }\n  return schema;\n}\n"]}
104
+ //# 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 { 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 OpenAPIOptions {\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?: OpenAPIOptions): 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?: OpenAPIOptions): 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, try to convert\n  if (\n    typeof schema === 'object' &&\n    schema !== null &&\n    typeof (schema as Record<string, unknown>)._def !== 'undefined'\n  ) {\n    try {\n      // Attempt Zod-to-JSON-Schema conversion via the library's existing converter\n      const { zodToJsonSchema } = require('../contract/zodToJsonSchema.js');\n      return zodToJsonSchema(schema);\n    } catch {\n      // If conversion fails, return as-is\n      return schema;\n    }\n  }\n  return schema;\n}\n"]}
package/dist/index.js CHANGED
@@ -9,7 +9,7 @@
9
9
  * For recorder factories, import from 'footprintjs/recorders'.
10
10
  */
11
11
  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.RunContext = exports.FlowChartExecutor = exports.select = exports.decide = exports.FlowChartBuilder = exports.flowChart = void 0;
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;
13
13
  var index_js_1 = require("./lib/builder/index.js");
14
14
  Object.defineProperty(exports, "flowChart", { enumerable: true, get: function () { return index_js_1.flowChart; } });
15
15
  Object.defineProperty(exports, "FlowChartBuilder", { enumerable: true, get: function () { return index_js_1.FlowChartBuilder; } });
@@ -20,6 +20,8 @@ var index_js_3 = require("./lib/runner/index.js");
20
20
  Object.defineProperty(exports, "FlowChartExecutor", { enumerable: true, get: function () { return index_js_3.FlowChartExecutor; } });
21
21
  var index_js_4 = require("./lib/runner/index.js");
22
22
  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; } });
23
25
  var index_js_5 = require("./lib/runner/index.js");
24
26
  Object.defineProperty(exports, "getSubtreeSnapshot", { enumerable: true, get: function () { return index_js_5.getSubtreeSnapshot; } });
25
27
  Object.defineProperty(exports, "listSubflowPaths", { enumerable: true, get: function () { return index_js_5.listSubflowPaths; } });
@@ -69,4 +71,4 @@ var index_js_21 = require("./lib/schema/index.js");
69
71
  Object.defineProperty(exports, "InputValidationError", { enumerable: true, get: function () { return index_js_21.InputValidationError; } });
70
72
  Object.defineProperty(exports, "validateAgainstSchema", { enumerable: true, get: function () { return index_js_21.validateAgainstSchema; } });
71
73
  Object.defineProperty(exports, "validateOrThrow", { enumerable: true, get: function () { return index_js_21.validateOrThrow; } });
72
- //# 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;AAOvB,kDAA0D;AAAjD,6GAAA,iBAAiB,OAAA;AAC1B,kDAAmD;AAA1C,sGAAA,UAAU,OAAA;AAYnB,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\nexport type { RunResult } from './lib/runner/index.js';\nexport { FlowChartExecutor } from './lib/runner/index.js';\nexport { RunContext } from './lib/runner/index.js';\nexport type {\n  OpenAPIOptions as ChartOpenAPIOptions,\n  MCPToolDescription,\n  RunnableFlowChart,\n} from './lib/runner/RunnableChart.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/memory/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"]}
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;AAMnB,+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 {\n  OpenAPIOptions as ChartOpenAPIOptions,\n  MCPToolDescription,\n  RunnableFlowChart,\n} 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/memory/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"]}
@@ -10,4 +10,4 @@
10
10
  * The builder remains standalone at runtime.
11
11
  */
12
12
  Object.defineProperty(exports, "__esModule", { value: true });
13
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/lib/builder/types.ts"],"names":[],"mappings":";AAAA;;;;;;;;;GASG","sourcesContent":["/**\n * builder/types.ts — All types used by the builder library.\n *\n * Shared types (StageNode, StageFunction, etc.) are imported from the engine.\n * Builder-specific types (FlowChartSpec, FlowChart, SerializedPipelineStructure)\n * are defined locally — they carry builder-only fields (description, outputMapper, etc.).\n *\n * NOTE: All engine imports are `import type` — zero runtime dependency.\n * The builder remains standalone at runtime.\n */\n\nimport type { StageNode } from '../engine/graph/StageNode.js';\nimport type { ILogger, ScopeFactory, StageFunction } from '../engine/types.js';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Re-exports from engine (canonical definitions)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type { StageNode } from '../engine/graph/StageNode.js';\nexport type {\n  ILogger,\n  StageFunction,\n  StreamCallback,\n  StreamHandlers,\n  StreamLifecycleHandler,\n  StreamTokenHandler,\n  SubflowMountOptions,\n} from '../engine/types.js';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Aliases\n// ─────────────────────────────────────────────────────────────────────────────\n\n/** Relaxed-generic alias for builder ergonomics. */\nexport type StageFn = StageFunction<any, any>;\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Scope Protection\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type ScopeProtectionMode = 'error' | 'warn' | 'off';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Serialized Pipeline Structure (JSON-safe, for visualization)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface SerializedPipelineStructure {\n  name: string;\n  id?: string;\n  type: 'stage' | 'decider' | 'fork' | 'streaming';\n  /** Semantic icon hint for visualization (e.g., \"llm\", \"tool\", \"rag\", \"agent\", \"start\") */\n  icon?: string;\n  description?: string;\n  children?: SerializedPipelineStructure[];\n  next?: SerializedPipelineStructure;\n  hasDecider?: boolean;\n  hasSelector?: boolean;\n  branchIds?: string[];\n  loopTarget?: string;\n  isStreaming?: boolean;\n  streamId?: string;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n  subflowStructure?: SerializedPipelineStructure;\n  iterationCount?: number;\n  /** True when this subflow uses lazy resolution (deferred until execution). */\n  isLazy?: boolean;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// FlowChartSpec (pure JSON, no functions — for FE→BE transport)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface FlowChartSpec {\n  name: string;\n  id?: string;\n  /** Semantic icon hint for visualization (e.g., \"llm\", \"tool\", \"rag\", \"agent\", \"start\") */\n  icon?: string;\n  description?: string;\n  children?: FlowChartSpec[];\n  next?: FlowChartSpec;\n  hasDecider?: boolean;\n  hasSelector?: boolean;\n  branchIds?: string[];\n  loopTarget?: string;\n  isStreaming?: boolean;\n  streamId?: string;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Build-Time Extractor\n// ─────────────────────────────────────────────────────────────────────────────\n\n/** Metadata provided to the build-time extractor for each node. */\nexport type BuildTimeNodeMetadata = FlowChartSpec;\n\nexport type BuildTimeExtractor<TResult = FlowChartSpec> = (metadata: BuildTimeNodeMetadata) => TResult;\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Traversal Extractor (runtime)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type TraversalExtractor<TResult = unknown> = (snapshot: unknown) => TResult | undefined | null;\n\n// ─────────────────────────────────────────────────────────────────────────────\n// FlowChart — compiled output of build()\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type FlowChart<TOut = any, TScope = any> = {\n  root: StageNode<TOut, TScope>;\n  stageMap: Map<string, StageFunction<TOut, TScope>>;\n  extractor?: TraversalExtractor;\n  subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  buildTimeStructure: SerializedPipelineStructure;\n  enableNarrative?: boolean;\n  logger?: ILogger;\n  description: string;\n  stageDescriptions: Map<string, string>;\n  /** Input schema (Zod or JSON Schema) — declared via setInputSchema() or .contract(). */\n  inputSchema?: unknown;\n  /** Output schema (Zod or JSON Schema) — declared via setOutputSchema() or .contract(). */\n  outputSchema?: unknown;\n  /** Output mapper — extracts response from final scope. */\n  outputMapper?: (finalScope: Record<string, unknown>) => unknown;\n  /** Scope factory — auto-embedded by flowChart<T>(). Executor reads this if no factory param. */\n  scopeFactory?: ScopeFactory<TScope>;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Simplified Parallel Spec (for addListOfFunction)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type SimplifiedParallelSpec<TOut = any, TScope = any> = {\n  id: string;\n  name: string;\n  fn?: StageFunction<TOut, TScope>;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// ExecOptions (for execute() convenience — used by runner layer)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type ExecOptions = {\n  defaults?: unknown;\n  initial?: unknown;\n  readOnly?: unknown;\n  throttlingErrorChecker?: (e: unknown) => boolean;\n  scopeProtectionMode?: ScopeProtectionMode;\n  enableNarrative?: boolean;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// SubflowRef\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface SubflowRef {\n  $ref: string;\n  mountId: string;\n}\n"]}
13
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/lib/builder/types.ts"],"names":[],"mappings":";AAAA;;;;;;;;;GASG","sourcesContent":["/**\n * builder/types.ts — All types used by the builder library.\n *\n * Shared types (StageNode, StageFunction, etc.) are imported from the engine.\n * Builder-specific types (FlowChartSpec, FlowChart, SerializedPipelineStructure)\n * are defined locally — they carry builder-only fields (description, outputMapper, etc.).\n *\n * NOTE: All engine imports are `import type` — zero runtime dependency.\n * The builder remains standalone at runtime.\n */\n\nimport type { StageNode } from '../engine/graph/StageNode.js';\nimport type { ILogger, ScopeFactory, StageFunction, TraversalExtractor } from '../engine/types.js';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Re-exports from engine (canonical definitions)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type { StageNode } from '../engine/graph/StageNode.js';\nexport type {\n  ILogger,\n  StageFunction,\n  StreamCallback,\n  StreamHandlers,\n  StreamLifecycleHandler,\n  StreamTokenHandler,\n  SubflowMountOptions,\n} from '../engine/types.js';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Aliases\n// ─────────────────────────────────────────────────────────────────────────────\n\n/** Relaxed-generic alias for builder ergonomics. */\nexport type StageFn = StageFunction<any, any>;\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Scope Protection\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type ScopeProtectionMode = 'error' | 'warn' | 'off';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Serialized Pipeline Structure (JSON-safe, for visualization)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface SerializedPipelineStructure {\n  name: string;\n  id?: string;\n  type: 'stage' | 'decider' | 'fork' | 'streaming';\n  /** Semantic icon hint for visualization (e.g., \"llm\", \"tool\", \"rag\", \"agent\", \"start\") */\n  icon?: string;\n  description?: string;\n  children?: SerializedPipelineStructure[];\n  next?: SerializedPipelineStructure;\n  hasDecider?: boolean;\n  hasSelector?: boolean;\n  branchIds?: string[];\n  loopTarget?: string;\n  isStreaming?: boolean;\n  streamId?: string;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n  subflowStructure?: SerializedPipelineStructure;\n  iterationCount?: number;\n  /** True when this subflow uses lazy resolution (deferred until execution). */\n  isLazy?: boolean;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// FlowChartSpec (pure JSON, no functions — for FE→BE transport)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface FlowChartSpec {\n  name: string;\n  id?: string;\n  /** Semantic icon hint for visualization (e.g., \"llm\", \"tool\", \"rag\", \"agent\", \"start\") */\n  icon?: string;\n  description?: string;\n  children?: FlowChartSpec[];\n  next?: FlowChartSpec;\n  hasDecider?: boolean;\n  hasSelector?: boolean;\n  branchIds?: string[];\n  loopTarget?: string;\n  isStreaming?: boolean;\n  streamId?: string;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Build-Time Extractor\n// ─────────────────────────────────────────────────────────────────────────────\n\n/** Metadata provided to the build-time extractor for each node. */\nexport type BuildTimeNodeMetadata = FlowChartSpec;\n\nexport type BuildTimeExtractor<TResult = FlowChartSpec> = (metadata: BuildTimeNodeMetadata) => TResult;\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Traversal Extractor (runtime) — canonical definition lives in engine/types.\n// Re-exported here so callers don't need two import paths.\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type { TraversalExtractor } from '../engine/types.js';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// FlowChart — compiled output of build()\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type FlowChart<TOut = any, TScope = any> = {\n  root: StageNode<TOut, TScope>;\n  stageMap: Map<string, StageFunction<TOut, TScope>>;\n  extractor?: TraversalExtractor;\n  subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  buildTimeStructure: SerializedPipelineStructure;\n  enableNarrative?: boolean;\n  logger?: ILogger;\n  description: string;\n  stageDescriptions: Map<string, string>;\n  /** Input schema (Zod or JSON Schema) — declared via setInputSchema() or .contract(). */\n  inputSchema?: unknown;\n  /** Output schema (Zod or JSON Schema) — declared via setOutputSchema() or .contract(). */\n  outputSchema?: unknown;\n  /** Output mapper — extracts response from final scope. */\n  outputMapper?: (finalScope: Record<string, unknown>) => unknown;\n  /** Scope factory — auto-embedded by flowChart<T>(). Executor reads this if no factory param. */\n  scopeFactory?: ScopeFactory<TScope>;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Simplified Parallel Spec (for addListOfFunction)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type SimplifiedParallelSpec<TOut = any, TScope = any> = {\n  id: string;\n  name: string;\n  fn?: StageFunction<TOut, TScope>;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// ExecOptions (for execute() convenience — used by runner layer)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type ExecOptions = {\n  defaults?: unknown;\n  initial?: unknown;\n  readOnly?: unknown;\n  throttlingErrorChecker?: (e: unknown) => boolean;\n  scopeProtectionMode?: ScopeProtectionMode;\n  enableNarrative?: boolean;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// SubflowRef\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface SubflowRef {\n  $ref: string;\n  mountId: string;\n}\n"]}
@@ -105,4 +105,4 @@ function normalizeSchema(schema) {
105
105
  }
106
106
  return schema;
107
107
  }
108
- //# 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 { FlowRecorder } from '../engine/narrative/types.js';\nimport type { FlowChart, 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 OpenAPIOptions {\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  /** 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?: OpenAPIOptions): 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?: OpenAPIOptions): 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, try to convert\n  if (\n    typeof schema === 'object' &&\n    schema !== null &&\n    typeof (schema as Record<string, unknown>)._def !== 'undefined'\n  ) {\n    try {\n      // Attempt Zod-to-JSON-Schema conversion via the library's existing converter\n      const { zodToJsonSchema } = require('../contract/zodToJsonSchema.js');\n      return zodToJsonSchema(schema);\n    } catch {\n      // If conversion fails, return as-is\n      return schema;\n    }\n  }\n  return schema;\n}\n"]}
108
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RunnableChart.js","sourceRoot":"","sources":["../../../src/lib/runner/RunnableChart.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;AAKH,mDAA6D;AA2C7D,8BAA8B;AAC9B,MAAM,YAAY,GAAG,IAAI,OAAO,EAAqB,CAAC;AACtD,MAAM,QAAQ,GAAG,IAAI,OAAO,EAAiC,CAAC;AAE9D;;;GAGG;AACH,SAAgB,YAAY,CAAe,KAA8B;IACvE,MAAM,QAAQ,GAAG,KAAwC,CAAC;IAE1D,QAAQ,CAAC,QAAQ,GAAG,UAAU,CAA0B;QACtD,OAAO,IAAI,0BAAU,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;IAC3C,CAAC,CAAC;IAEF,QAAQ,CAAC,MAAM,GAAG,UAAU,MAAuB;QACjD,OAAO,IAAI,0BAAU,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAC9C,CAAC,CAAC;IAEF,QAAQ,CAAC,GAAG,GAAG,UAAU,OAAoB;QAC3C,OAAO,IAAI,0BAAU,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAC5C,CAAC,CAAC;IAEF,QAAQ,CAAC,SAAS,GAAG,UAAU,OAAwB;;QACrD,MAAM,MAAM,GAAG,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACvC,IAAI,MAAM;YAAE,OAAO,MAAM,CAAC;QAE1B,MAAM,YAAY,GAAG,KAAY,CAAC;QAClC,MAAM,KAAK,GAAG,MAAA,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,mCAAI,MAAA,YAAY,CAAC,WAAW,0CAAE,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC,mCAAI,KAAK,CAAC;QAClF,MAAM,OAAO,GAAG,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,OAAO,mCAAI,OAAO,CAAC;QAC5C,MAAM,IAAI,GAAG,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,IAAI,mCAAI,IAAI,CAAC,MAAA,MAAA,YAAY,CAAC,IAAI,0CAAE,IAAI,mCAAI,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,CAAC;QAE9G,MAAM,IAAI,GAA4B;YACpC,OAAO,EAAE,OAAO;YAChB,IAAI,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,WAAW,mCAAI,YAAY,CAAC,WAAW,EAAE;YACvF,KAAK,EAAE;gBACL,CAAC,IAAI,CAAC,EAAE;oBACN,IAAI,EAAE;wBACJ,OAAO,EAAE,KAAK;wBACd,WAAW,EAAE,YAAY,CAAC,WAAW;wBACrC,GAAG,CAAC,YAAY,CAAC,WAAW;4BAC1B,CAAC,CAAC;gCACE,WAAW,EAAE;oCACX,OAAO,EAAE,EAAE,kBAAkB,EAAE,EAAE,MAAM,EAAE,eAAe,CAAC,YAAY,CAAC,WAAW,CAAC,EAAE,EAAE;iCACvF;6BACF;4BACH,CAAC,CAAC,EAAE,CAAC;wBACP,SAAS,EAAE;4BACT,KAAK,EAAE;gCACL,WAAW,EAAE,SAAS;gCACtB,GAAG,CAAC,YAAY,CAAC,YAAY;oCAC3B,CAAC,CAAC,EAAE,OAAO,EAAE,EAAE,kBAAkB,EAAE,EAAE,MAAM,EAAE,eAAe,CAAC,YAAY,CAAC,YAAY,CAAC,EAAE,EAAE,EAAE;oCAC7F,CAAC,CAAC,EAAE,CAAC;6BACR;yBACF;qBACF;iBACF;aACF;SACF,CAAC;QAEF,YAAY,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QAC9B,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;IAEF,QAAQ,CAAC,SAAS,GAAG;;QACnB,MAAM,MAAM,GAAG,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACnC,IAAI,MAAM;YAAE,OAAO,MAAM,CAAC;QAE1B,MAAM,YAAY,GAAG,KAAY,CAAC;QAClC,MAAM,IAAI,GAAG,CAAC,MAAA,MAAA,YAAY,CAAC,IAAI,0CAAE,IAAI,mCAAI,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QACvF,MAAM,WAAW,GAAG,YAAY,CAAC,WAAW,IAAI,eAAe,IAAI,YAAY,CAAC;QAEhF,MAAM,IAAI,GAAuB;YAC/B,IAAI;YACJ,WAAW;YACX,GAAG,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,eAAe,CAAC,YAAY,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SAChG,CAAC;QAEF,QAAQ,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QAC1B,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;IAEF,OAAO,QAAQ,CAAC;AAClB,CAAC;AA3ED,oCA2EC;AAED,yEAAyE;AACzE,SAAS,eAAe,CAAC,MAAe;IACtC,IAAI,CAAC,MAAM;QAAE,OAAO,MAAM,CAAC;IAC3B,kDAAkD;IAClD,IACE,OAAO,MAAM,KAAK,QAAQ;QAC1B,MAAM,KAAK,IAAI;QACf,OAAQ,MAAkC,CAAC,IAAI,KAAK,WAAW,EAC/D,CAAC;QACD,IAAI,CAAC;YACH,6EAA6E;YAC7E,MAAM,EAAE,eAAe,EAAE,GAAG,OAAO,CAAC,gCAAgC,CAAC,CAAC;YACtE,OAAO,eAAe,CAAC,MAAM,CAAC,CAAC;QACjC,CAAC;QAAC,WAAM,CAAC;YACP,oCAAoC;YACpC,OAAO,MAAM,CAAC;QAChB,CAAC;IACH,CAAC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC","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 { 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 OpenAPIOptions {\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?: OpenAPIOptions): 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?: OpenAPIOptions): 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, try to convert\n  if (\n    typeof schema === 'object' &&\n    schema !== null &&\n    typeof (schema as Record<string, unknown>)._def !== 'undefined'\n  ) {\n    try {\n      // Attempt Zod-to-JSON-Schema conversion via the library's existing converter\n      const { zodToJsonSchema } = require('../contract/zodToJsonSchema.js');\n      return zodToJsonSchema(schema);\n    } catch {\n      // If conversion fails, return as-is\n      return schema;\n    }\n  }\n  return schema;\n}\n"]}
@@ -17,6 +17,7 @@ export type { RunResult } from './lib/runner/index.js';
17
17
  export { FlowChartExecutor } from './lib/runner/index.js';
18
18
  export { RunContext } from './lib/runner/index.js';
19
19
  export type { OpenAPIOptions as ChartOpenAPIOptions, MCPToolDescription, RunnableFlowChart, } from './lib/runner/RunnableChart.js';
20
+ export { narrative } from './recorders.js';
20
21
  export type { ComposableRunner } from './lib/runner/index.js';
21
22
  export type { RecorderSnapshot, RuntimeSnapshot, SubtreeSnapshot } from './lib/runner/index.js';
22
23
  export { getSubtreeSnapshot, listSubflowPaths } from './lib/runner/index.js';
@@ -9,7 +9,7 @@
9
9
  * The builder remains standalone at runtime.
10
10
  */
11
11
  import type { StageNode } from '../engine/graph/StageNode.js';
12
- import type { ILogger, ScopeFactory, StageFunction } from '../engine/types.js';
12
+ import type { ILogger, ScopeFactory, StageFunction, TraversalExtractor } from '../engine/types.js';
13
13
  export type { StageNode } from '../engine/graph/StageNode.js';
14
14
  export type { ILogger, StageFunction, StreamCallback, StreamHandlers, StreamLifecycleHandler, StreamTokenHandler, SubflowMountOptions, } from '../engine/types.js';
15
15
  /** Relaxed-generic alias for builder ergonomics. */
@@ -63,7 +63,7 @@ export interface FlowChartSpec {
63
63
  /** Metadata provided to the build-time extractor for each node. */
64
64
  export type BuildTimeNodeMetadata = FlowChartSpec;
65
65
  export type BuildTimeExtractor<TResult = FlowChartSpec> = (metadata: BuildTimeNodeMetadata) => TResult;
66
- export type TraversalExtractor<TResult = unknown> = (snapshot: unknown) => TResult | undefined | null;
66
+ export type { TraversalExtractor } from '../engine/types.js';
67
67
  export type FlowChart<TOut = any, TScope = any> = {
68
68
  root: StageNode<TOut, TScope>;
69
69
  stageMap: Map<string, StageFunction<TOut, TScope>>;
@@ -6,7 +6,7 @@
6
6
  * d3-style chainable run methods and self-describing outputs.
7
7
  */
8
8
  import type { FlowRecorder } from '../engine/narrative/types.js';
9
- import type { FlowChart, RunOptions } from '../engine/types.js';
9
+ import type { FlowChart, RunOptions, SerializedPipelineStructure } from '../engine/types.js';
10
10
  import type { Recorder, RedactionPolicy } from '../scope/types.js';
11
11
  import { type RunResult, RunContext } from './RunContext.js';
12
12
  /** OpenAPI generation options. */
@@ -24,6 +24,8 @@ export interface MCPToolDescription {
24
24
  }
25
25
  /** FlowChart with d3-style methods: run, recorder, redact, toOpenAPI, toMCPTool. */
26
26
  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;
27
29
  /** Human-readable numbered step list. Empty string when no descriptions were provided. */
28
30
  description: string;
29
31
  /** Per-stage descriptions, keyed by stage name. */
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "footprintjs",
3
- "version": "3.0.8",
3
+ "version": "3.0.10",
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",