footprintjs 0.15.0 → 0.15.2

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.
@@ -71,8 +71,8 @@ export class DeciderHandler {
71
71
  rationale: rationale || `returned branchId: ${branchId}`,
72
72
  });
73
73
  this.deps.narrativeGenerator.onDecision(node.name, chosen.name, rationale, node.description);
74
- const nextStageContext = context.createNext(branchPath, chosen.name, chosen.id);
75
- return executeNode(chosen, nextStageContext, breakFlag, branchPath);
74
+ const branchContext = context.createChild(branchPath, chosen.id, chosen.name, chosen.id);
75
+ return executeNode(chosen, branchContext, breakFlag, branchPath);
76
76
  }
77
77
  }
78
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DeciderHandler.js","sourceRoot":"","sources":["../../../../../src/lib/engine/handlers/DeciderHandler.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * DeciderHandler — Single-choice conditional branching.\n *\n * Handles scope-based deciders (stage IS the decider, returns branch ID).\n * Logs flow control decisions and narrative sentences.\n */\n\nimport type { StageContext } from '../../memory/StageContext.js';\nimport type { StageNode } from '../graph/StageNode.js';\nimport type { HandlerDeps, StageFunction } from '../types.js';\n\n/** Callback for running a stage with commit + extractor. Avoids circular dep with traverser. */\nexport type RunStageFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  stageFunc: StageFunction<TOut, TScope>,\n  context: StageContext,\n  breakFn: () => void,\n) => Promise<TOut>;\n\n/** Callback for recursive node execution. Avoids circular dep with traverser. */\nexport type ExecuteNodeFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  context: StageContext,\n  breakFlag: { shouldBreak: boolean },\n  branchPath?: string,\n) => Promise<any>;\n\n/** Callback for calling the extractor after stage execution. */\nexport type CallExtractorFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  context: StageContext,\n  stagePath: string,\n  stageOutput?: unknown,\n  errorInfo?: { type: string; message: string },\n) => void;\n\n/** Callback for computing the stage path for extractor. */\nexport type GetStagePathFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  branchPath?: string,\n  contextStageName?: string,\n) => string;\n\nexport class DeciderHandler<TOut = any, TScope = any> {\n  constructor(private readonly deps: HandlerDeps<TOut, TScope>) {}\n\n  /**\n   * Handle a scope-based decider (created via addDeciderFunction).\n   * The stage function IS the decider — its return value is the branch ID.\n   * Execution order: runStage(fn) → commit → resolve child → log → executeNode(child).\n   */\n  async handleScopeBased(\n    node: StageNode<TOut, TScope>,\n    stageFunc: StageFunction<TOut, TScope>,\n    context: StageContext,\n    breakFlag: { shouldBreak: boolean },\n    branchPath: string | undefined,\n    runStage: RunStageFn<TOut, TScope>,\n    executeNode: ExecuteNodeFn<TOut, TScope>,\n    callExtractor: CallExtractorFn<TOut, TScope>,\n    getStagePath: GetStagePathFn<TOut, TScope>,\n  ): Promise<any> {\n    const breakFn = () => (breakFlag.shouldBreak = true);\n\n    let branchId: string;\n    try {\n      const stageOutput = await runStage(node, stageFunc, context, breakFn);\n      branchId = String(stageOutput);\n    } catch (error: any) {\n      context.commit();\n      callExtractor(node, context, getStagePath(node, branchPath, context.stageName), undefined, {\n        type: 'stageExecutionError',\n        message: error.toString(),\n      });\n      this.deps.logger.error(`Error in pipeline (${branchPath}) stage [${node.name}]:`, { error });\n      context.addError('stageExecutionError', error.toString());\n      this.deps.narrativeGenerator.onError(node.name, error.toString(), error);\n      throw error;\n    }\n\n    context.commit();\n    callExtractor(node, context, getStagePath(node, branchPath, context.stageName), branchId);\n\n    if (breakFlag.shouldBreak) {\n      this.deps.logger.info(`Execution stopped in pipeline (${branchPath}) after ${node.name} due to break condition.`);\n      return branchId;\n    }\n\n    // Resolve child by matching branch ID against node.children\n    const children = node.children as StageNode<TOut, TScope>[];\n    let chosen = children.find((child) => child.id === branchId);\n\n    // Fall back to default branch\n    if (!chosen) {\n      const defaultChild = children.find((child) => child.id === 'default');\n      if (defaultChild) {\n        chosen = defaultChild;\n      } else {\n        const errorMessage = `Scope-based decider '${node.name}' returned branch ID '${branchId}' which doesn't match any child and no default branch is set`;\n        context.addError('deciderError', errorMessage);\n        throw new Error(errorMessage);\n      }\n    }\n\n    const chosenName = chosen.name;\n    const wasDefault = chosen.id !== branchId;\n    const rationale = context.debug?.logContext?.deciderRationale as string | undefined;\n    let branchReason: string;\n    if (wasDefault) {\n      branchReason = `Returned '${branchId}' (no match), fell back to default → ${chosenName} path.`;\n    } else if (rationale) {\n      branchReason = `Based on: ${rationale} → chose ${chosenName} path.`;\n    } else {\n      branchReason = `Evaluated scope and returned '${branchId}' → chose ${chosenName} path.`;\n    }\n    context.addFlowDebugMessage('branch', branchReason, {\n      targetStage: chosen.name,\n      rationale: rationale || `returned branchId: ${branchId}`,\n    });\n\n    this.deps.narrativeGenerator.onDecision(node.name, chosen.name, rationale, node.description);\n\n    const nextStageContext = context.createNext(branchPath as string, chosen.name, chosen.id);\n    return executeNode(chosen, nextStageContext, breakFlag, branchPath);\n  }\n}\n"]}
78
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DeciderHandler.js","sourceRoot":"","sources":["../../../../../src/lib/engine/handlers/DeciderHandler.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * DeciderHandler — Single-choice conditional branching.\n *\n * Handles scope-based deciders (stage IS the decider, returns branch ID).\n * Logs flow control decisions and narrative sentences.\n */\n\nimport type { StageContext } from '../../memory/StageContext.js';\nimport type { StageNode } from '../graph/StageNode.js';\nimport type { HandlerDeps, StageFunction } from '../types.js';\n\n/** Callback for running a stage with commit + extractor. Avoids circular dep with traverser. */\nexport type RunStageFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  stageFunc: StageFunction<TOut, TScope>,\n  context: StageContext,\n  breakFn: () => void,\n) => Promise<TOut>;\n\n/** Callback for recursive node execution. Avoids circular dep with traverser. */\nexport type ExecuteNodeFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  context: StageContext,\n  breakFlag: { shouldBreak: boolean },\n  branchPath?: string,\n) => Promise<any>;\n\n/** Callback for calling the extractor after stage execution. */\nexport type CallExtractorFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  context: StageContext,\n  stagePath: string,\n  stageOutput?: unknown,\n  errorInfo?: { type: string; message: string },\n) => void;\n\n/** Callback for computing the stage path for extractor. */\nexport type GetStagePathFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  branchPath?: string,\n  contextStageName?: string,\n) => string;\n\nexport class DeciderHandler<TOut = any, TScope = any> {\n  constructor(private readonly deps: HandlerDeps<TOut, TScope>) {}\n\n  /**\n   * Handle a scope-based decider (created via addDeciderFunction).\n   * The stage function IS the decider — its return value is the branch ID.\n   * Execution order: runStage(fn) → commit → resolve child → log → executeNode(child).\n   */\n  async handleScopeBased(\n    node: StageNode<TOut, TScope>,\n    stageFunc: StageFunction<TOut, TScope>,\n    context: StageContext,\n    breakFlag: { shouldBreak: boolean },\n    branchPath: string | undefined,\n    runStage: RunStageFn<TOut, TScope>,\n    executeNode: ExecuteNodeFn<TOut, TScope>,\n    callExtractor: CallExtractorFn<TOut, TScope>,\n    getStagePath: GetStagePathFn<TOut, TScope>,\n  ): Promise<any> {\n    const breakFn = () => (breakFlag.shouldBreak = true);\n\n    let branchId: string;\n    try {\n      const stageOutput = await runStage(node, stageFunc, context, breakFn);\n      branchId = String(stageOutput);\n    } catch (error: any) {\n      context.commit();\n      callExtractor(node, context, getStagePath(node, branchPath, context.stageName), undefined, {\n        type: 'stageExecutionError',\n        message: error.toString(),\n      });\n      this.deps.logger.error(`Error in pipeline (${branchPath}) stage [${node.name}]:`, { error });\n      context.addError('stageExecutionError', error.toString());\n      this.deps.narrativeGenerator.onError(node.name, error.toString(), error);\n      throw error;\n    }\n\n    context.commit();\n    callExtractor(node, context, getStagePath(node, branchPath, context.stageName), branchId);\n\n    if (breakFlag.shouldBreak) {\n      this.deps.logger.info(`Execution stopped in pipeline (${branchPath}) after ${node.name} due to break condition.`);\n      return branchId;\n    }\n\n    // Resolve child by matching branch ID against node.children\n    const children = node.children as StageNode<TOut, TScope>[];\n    let chosen = children.find((child) => child.id === branchId);\n\n    // Fall back to default branch\n    if (!chosen) {\n      const defaultChild = children.find((child) => child.id === 'default');\n      if (defaultChild) {\n        chosen = defaultChild;\n      } else {\n        const errorMessage = `Scope-based decider '${node.name}' returned branch ID '${branchId}' which doesn't match any child and no default branch is set`;\n        context.addError('deciderError', errorMessage);\n        throw new Error(errorMessage);\n      }\n    }\n\n    const chosenName = chosen.name;\n    const wasDefault = chosen.id !== branchId;\n    const rationale = context.debug?.logContext?.deciderRationale as string | undefined;\n    let branchReason: string;\n    if (wasDefault) {\n      branchReason = `Returned '${branchId}' (no match), fell back to default → ${chosenName} path.`;\n    } else if (rationale) {\n      branchReason = `Based on: ${rationale} → chose ${chosenName} path.`;\n    } else {\n      branchReason = `Evaluated scope and returned '${branchId}' → chose ${chosenName} path.`;\n    }\n    context.addFlowDebugMessage('branch', branchReason, {\n      targetStage: chosen.name,\n      rationale: rationale || `returned branchId: ${branchId}`,\n    });\n\n    this.deps.narrativeGenerator.onDecision(node.name, chosen.name, rationale, node.description);\n\n    const branchContext = context.createChild(branchPath as string, chosen.id, chosen.name, chosen.id);\n    return executeNode(chosen, branchContext, breakFlag, branchPath);\n  }\n}\n"]}
@@ -57,15 +57,17 @@ export class NodeResolver {
57
57
  this.deps.logger.info(`Subflow not found in dictionary for node '${node.name}' (tried keys: ${keysToTry.join(', ')})`);
58
58
  return node;
59
59
  }
60
- // Merge reference metadata with actual structure
60
+ // Merge reference metadata with actual structure.
61
+ // id comes from the inner root (the actual stage identity for trace matching),
62
+ // not the mount node (which is the subflow entry point in the parent).
61
63
  return {
62
64
  ...subflowDef.root,
63
65
  isSubflowRoot: node.isSubflowRoot,
64
66
  subflowId: node.subflowId,
65
67
  subflowName: node.subflowName,
66
- id: node.id || subflowDef.root.id,
68
+ id: subflowDef.root.id || node.id,
67
69
  subflowMountOptions: node.subflowMountOptions || subflowDef.root.subflowMountOptions,
68
70
  };
69
71
  }
70
72
  }
71
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTm9kZVJlc29sdmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9lbmdpbmUvaGFuZGxlcnMvTm9kZVJlc29sdmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7O0dBT0c7QUFNSCxNQUFNLE9BQU8sWUFBWTtJQUN2QixZQUFvQixJQUErQjtRQUEvQixTQUFJLEdBQUosSUFBSSxDQUEyQjtJQUFHLENBQUM7SUFFdkQ7OztPQUdHO0lBQ0gsWUFBWSxDQUFDLE1BQWMsRUFBRSxTQUFtQztRQUM5RCxNQUFNLElBQUksR0FBRyxTQUFTLGFBQVQsU0FBUyxjQUFULFNBQVMsR0FBSSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQztRQUV6QyxJQUFJLElBQUksQ0FBQyxFQUFFLEtBQUssTUFBTTtZQUFFLE9BQU8sSUFBSSxDQUFDO1FBRXBDLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ2xCLEtBQUssTUFBTSxLQUFLLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO2dCQUNsQyxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsQ0FBQztnQkFDL0MsSUFBSSxLQUFLO29CQUFFLE9BQU8sS0FBSyxDQUFDO1lBQzFCLENBQUM7UUFDSCxDQUFDO1FBRUQsSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDZCxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDbkQsSUFBSSxLQUFLO2dCQUFFLE9BQU8sS0FBSyxDQUFDO1FBQzFCLENBQUM7UUFFRCxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCx1QkFBdUIsQ0FBQyxJQUE2QjtRQUNuRCwwQ0FBMEM7UUFDMUMsSUFBSSxJQUFJLENBQUMsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7WUFBRSxPQUFPLElBQUksQ0FBQztRQUV4RSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRO1lBQUUsT0FBTyxJQUFJLENBQUM7UUFFckMsMkNBQTJDO1FBQzNDLE1BQU0sU0FBUyxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsV0FBVyxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFhLENBQUM7UUFDNUYsSUFBSSxVQUF5RCxDQUFDO1FBRTlELEtBQUssTUFBTSxHQUFHLElBQUksU0FBUyxFQUFFLENBQUM7WUFDNUIsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO2dCQUM1QixVQUFVLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUM7Z0JBQ3JDLE1BQU07WUFDUixDQUFDO1FBQ0gsQ0FBQztRQUVELElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQ25CLDZDQUE2QyxJQUFJLENBQUMsSUFBSSxrQkFBa0IsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUNoRyxDQUFDO1lBQ0YsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDO1FBRUQsaURBQWlEO1FBQ2pELE9BQU87WUFDTCxHQUFHLFVBQVUsQ0FBQyxJQUFJO1lBQ2xCLGFBQWEsRUFBRSxJQUFJLENBQUMsYUFBYTtZQUNqQyxTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVM7WUFDekIsV0FBVyxFQUFFLElBQUksQ0FBQyxXQUFXO1lBQzdCLEVBQUUsRUFBRSxJQUFJLENBQUMsRUFBRSxJQUFJLFVBQVUsQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUNqQyxtQkFBbUIsRUFBRSxJQUFJLENBQUMsbUJBQW1CLElBQUksVUFBVSxDQUFDLElBQUksQ0FBQyxtQkFBbUI7U0FDckYsQ0FBQztJQUNKLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogTm9kZVJlc29sdmVyIOKAlCBERlMgbm9kZSBsb29rdXAgKyBzdWJmbG93IHJlZmVyZW5jZSByZXNvbHV0aW9uLlxuICpcbiAqIFJlc3BvbnNpYmlsaXRpZXM6XG4gKiAtIEZpbmQgbm9kZXMgYnkgSUQgdmlhIHJlY3Vyc2l2ZSBkZXB0aC1maXJzdCBzZWFyY2ggKGZvciBiYWNrLWVkZ2UvbG9vcCBzdXBwb3J0KVxuICogLSBSZXNvbHZlIHN1YmZsb3cgcmVmZXJlbmNlIG5vZGVzIHRvIGFjdHVhbCBzdWJmbG93IHN0cnVjdHVyZXNcbiAqIC0gRXZhbHVhdGUgZGVjaWRlcnMgdG8gZGV0ZXJtaW5lIG5leHQgbm9kZSBpbiBicmFuY2hpbmcgc2NlbmFyaW9zXG4gKi9cblxuaW1wb3J0IHR5cGUgeyBTdGFnZUNvbnRleHQgfSBmcm9tICcuLi8uLi9tZW1vcnkvU3RhZ2VDb250ZXh0LmpzJztcbmltcG9ydCB0eXBlIHsgU3RhZ2VOb2RlIH0gZnJvbSAnLi4vZ3JhcGgvU3RhZ2VOb2RlLmpzJztcbmltcG9ydCB0eXBlIHsgSGFuZGxlckRlcHMgfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbmV4cG9ydCBjbGFzcyBOb2RlUmVzb2x2ZXI8VE91dCA9IGFueSwgVFNjb3BlID0gYW55PiB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZGVwczogSGFuZGxlckRlcHM8VE91dCwgVFNjb3BlPikge31cblxuICAvKipcbiAgICogREZTIHNlYXJjaCBmb3IgYSBub2RlIGJ5IElELlxuICAgKiBDaGVja3M6IGN1cnJlbnQg4oaSIGNoaWxkcmVuIChkZXB0aC1maXJzdCkg4oaSIG5leHQgKGxpbmVhciBjb250aW51YXRpb24pLlxuICAgKi9cbiAgZmluZE5vZGVCeUlkKG5vZGVJZDogc3RyaW5nLCBzdGFydE5vZGU/OiBTdGFnZU5vZGU8VE91dCwgVFNjb3BlPik6IFN0YWdlTm9kZTxUT3V0LCBUU2NvcGU+IHwgdW5kZWZpbmVkIHtcbiAgICBjb25zdCBub2RlID0gc3RhcnROb2RlID8/IHRoaXMuZGVwcy5yb290O1xuXG4gICAgaWYgKG5vZGUuaWQgPT09IG5vZGVJZCkgcmV0dXJuIG5vZGU7XG5cbiAgICBpZiAobm9kZS5jaGlsZHJlbikge1xuICAgICAgZm9yIChjb25zdCBjaGlsZCBvZiBub2RlLmNoaWxkcmVuKSB7XG4gICAgICAgIGNvbnN0IGZvdW5kID0gdGhpcy5maW5kTm9kZUJ5SWQobm9kZUlkLCBjaGlsZCk7XG4gICAgICAgIGlmIChmb3VuZCkgcmV0dXJuIGZvdW5kO1xuICAgICAgfVxuICAgIH1cblxuICAgIGlmIChub2RlLm5leHQpIHtcbiAgICAgIGNvbnN0IGZvdW5kID0gdGhpcy5maW5kTm9kZUJ5SWQobm9kZUlkLCBub2RlLm5leHQpO1xuICAgICAgaWYgKGZvdW5kKSByZXR1cm4gZm91bmQ7XG4gICAgfVxuXG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXNvbHZlIGEgc3ViZmxvdyByZWZlcmVuY2Ugbm9kZSB0byBpdHMgYWN0dWFsIHN0cnVjdHVyZS5cbiAgICpcbiAgICogUmVmZXJlbmNlIG5vZGVzIGFyZSBsaWdodHdlaWdodCBwbGFjZWhvbGRlcnMgKGlzU3ViZmxvd1Jvb3QgYnV0IG5vIGZuL2NoaWxkcmVuKS5cbiAgICogVGhlIGFjdHVhbCBzdHJ1Y3R1cmUgbGl2ZXMgaW4gdGhlIHN1YmZsb3dzIGRpY3Rpb25hcnkuXG4gICAqL1xuICByZXNvbHZlU3ViZmxvd1JlZmVyZW5jZShub2RlOiBTdGFnZU5vZGU8VE91dCwgVFNjb3BlPik6IFN0YWdlTm9kZTxUT3V0LCBUU2NvcGU+IHtcbiAgICAvLyBBbHJlYWR5IGhhcyBzdHJ1Y3R1cmUg4oCUIG5vdCBhIHJlZmVyZW5jZVxuICAgIGlmIChub2RlLmZuIHx8IChub2RlLmNoaWxkcmVuICYmIG5vZGUuY2hpbGRyZW4ubGVuZ3RoID4gMCkpIHJldHVybiBub2RlO1xuXG4gICAgaWYgKCF0aGlzLmRlcHMuc3ViZmxvd3MpIHJldHVybiBub2RlO1xuXG4gICAgLy8gVHJ5IG11bHRpcGxlIGtleXMgaW4gb3JkZXIgb2YgcHJlZmVyZW5jZVxuICAgIGNvbnN0IGtleXNUb1RyeSA9IFtub2RlLnN1YmZsb3dJZCwgbm9kZS5zdWJmbG93TmFtZSwgbm9kZS5uYW1lXS5maWx0ZXIoQm9vbGVhbikgYXMgc3RyaW5nW107XG4gICAgbGV0IHN1YmZsb3dEZWY6IHsgcm9vdDogU3RhZ2VOb2RlPFRPdXQsIFRTY29wZT4gfSB8IHVuZGVmaW5lZDtcblxuICAgIGZvciAoY29uc3Qga2V5IG9mIGtleXNUb1RyeSkge1xuICAgICAgaWYgKHRoaXMuZGVwcy5zdWJmbG93c1trZXldKSB7XG4gICAgICAgIHN1YmZsb3dEZWYgPSB0aGlzLmRlcHMuc3ViZmxvd3Nba2V5XTtcbiAgICAgICAgYnJlYWs7XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKCFzdWJmbG93RGVmKSB7XG4gICAgICB0aGlzLmRlcHMubG9nZ2VyLmluZm8oXG4gICAgICAgIGBTdWJmbG93IG5vdCBmb3VuZCBpbiBkaWN0aW9uYXJ5IGZvciBub2RlICcke25vZGUubmFtZX0nICh0cmllZCBrZXlzOiAke2tleXNUb1RyeS5qb2luKCcsICcpfSlgLFxuICAgICAgKTtcbiAgICAgIHJldHVybiBub2RlO1xuICAgIH1cblxuICAgIC8vIE1lcmdlIHJlZmVyZW5jZSBtZXRhZGF0YSB3aXRoIGFjdHVhbCBzdHJ1Y3R1cmVcbiAgICByZXR1cm4ge1xuICAgICAgLi4uc3ViZmxvd0RlZi5yb290LFxuICAgICAgaXNTdWJmbG93Um9vdDogbm9kZS5pc1N1YmZsb3dSb290LFxuICAgICAgc3ViZmxvd0lkOiBub2RlLnN1YmZsb3dJZCxcbiAgICAgIHN1YmZsb3dOYW1lOiBub2RlLnN1YmZsb3dOYW1lLFxuICAgICAgaWQ6IG5vZGUuaWQgfHwgc3ViZmxvd0RlZi5yb290LmlkLFxuICAgICAgc3ViZmxvd01vdW50T3B0aW9uczogbm9kZS5zdWJmbG93TW91bnRPcHRpb25zIHx8IHN1YmZsb3dEZWYucm9vdC5zdWJmbG93TW91bnRPcHRpb25zLFxuICAgIH07XG4gIH1cbn1cbiJdfQ==
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTm9kZVJlc29sdmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9lbmdpbmUvaGFuZGxlcnMvTm9kZVJlc29sdmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7O0dBT0c7QUFNSCxNQUFNLE9BQU8sWUFBWTtJQUN2QixZQUFvQixJQUErQjtRQUEvQixTQUFJLEdBQUosSUFBSSxDQUEyQjtJQUFHLENBQUM7SUFFdkQ7OztPQUdHO0lBQ0gsWUFBWSxDQUFDLE1BQWMsRUFBRSxTQUFtQztRQUM5RCxNQUFNLElBQUksR0FBRyxTQUFTLGFBQVQsU0FBUyxjQUFULFNBQVMsR0FBSSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQztRQUV6QyxJQUFJLElBQUksQ0FBQyxFQUFFLEtBQUssTUFBTTtZQUFFLE9BQU8sSUFBSSxDQUFDO1FBRXBDLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ2xCLEtBQUssTUFBTSxLQUFLLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO2dCQUNsQyxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsQ0FBQztnQkFDL0MsSUFBSSxLQUFLO29CQUFFLE9BQU8sS0FBSyxDQUFDO1lBQzFCLENBQUM7UUFDSCxDQUFDO1FBRUQsSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDZCxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDbkQsSUFBSSxLQUFLO2dCQUFFLE9BQU8sS0FBSyxDQUFDO1FBQzFCLENBQUM7UUFFRCxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCx1QkFBdUIsQ0FBQyxJQUE2QjtRQUNuRCwwQ0FBMEM7UUFDMUMsSUFBSSxJQUFJLENBQUMsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7WUFBRSxPQUFPLElBQUksQ0FBQztRQUV4RSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRO1lBQUUsT0FBTyxJQUFJLENBQUM7UUFFckMsMkNBQTJDO1FBQzNDLE1BQU0sU0FBUyxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsV0FBVyxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFhLENBQUM7UUFDNUYsSUFBSSxVQUF5RCxDQUFDO1FBRTlELEtBQUssTUFBTSxHQUFHLElBQUksU0FBUyxFQUFFLENBQUM7WUFDNUIsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO2dCQUM1QixVQUFVLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUM7Z0JBQ3JDLE1BQU07WUFDUixDQUFDO1FBQ0gsQ0FBQztRQUVELElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQ25CLDZDQUE2QyxJQUFJLENBQUMsSUFBSSxrQkFBa0IsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUNoRyxDQUFDO1lBQ0YsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDO1FBRUQsa0RBQWtEO1FBQ2xELCtFQUErRTtRQUMvRSx1RUFBdUU7UUFDdkUsT0FBTztZQUNMLEdBQUcsVUFBVSxDQUFDLElBQUk7WUFDbEIsYUFBYSxFQUFFLElBQUksQ0FBQyxhQUFhO1lBQ2pDLFNBQVMsRUFBRSxJQUFJLENBQUMsU0FBUztZQUN6QixXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVc7WUFDN0IsRUFBRSxFQUFFLFVBQVUsQ0FBQyxJQUFJLENBQUMsRUFBRSxJQUFJLElBQUksQ0FBQyxFQUFFO1lBQ2pDLG1CQUFtQixFQUFFLElBQUksQ0FBQyxtQkFBbUIsSUFBSSxVQUFVLENBQUMsSUFBSSxDQUFDLG1CQUFtQjtTQUNyRixDQUFDO0lBQ0osQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBOb2RlUmVzb2x2ZXIg4oCUIERGUyBub2RlIGxvb2t1cCArIHN1YmZsb3cgcmVmZXJlbmNlIHJlc29sdXRpb24uXG4gKlxuICogUmVzcG9uc2liaWxpdGllczpcbiAqIC0gRmluZCBub2RlcyBieSBJRCB2aWEgcmVjdXJzaXZlIGRlcHRoLWZpcnN0IHNlYXJjaCAoZm9yIGJhY2stZWRnZS9sb29wIHN1cHBvcnQpXG4gKiAtIFJlc29sdmUgc3ViZmxvdyByZWZlcmVuY2Ugbm9kZXMgdG8gYWN0dWFsIHN1YmZsb3cgc3RydWN0dXJlc1xuICogLSBFdmFsdWF0ZSBkZWNpZGVycyB0byBkZXRlcm1pbmUgbmV4dCBub2RlIGluIGJyYW5jaGluZyBzY2VuYXJpb3NcbiAqL1xuXG5pbXBvcnQgdHlwZSB7IFN0YWdlQ29udGV4dCB9IGZyb20gJy4uLy4uL21lbW9yeS9TdGFnZUNvbnRleHQuanMnO1xuaW1wb3J0IHR5cGUgeyBTdGFnZU5vZGUgfSBmcm9tICcuLi9ncmFwaC9TdGFnZU5vZGUuanMnO1xuaW1wb3J0IHR5cGUgeyBIYW5kbGVyRGVwcyB9IGZyb20gJy4uL3R5cGVzLmpzJztcblxuZXhwb3J0IGNsYXNzIE5vZGVSZXNvbHZlcjxUT3V0ID0gYW55LCBUU2NvcGUgPSBhbnk+IHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBkZXBzOiBIYW5kbGVyRGVwczxUT3V0LCBUU2NvcGU+KSB7fVxuXG4gIC8qKlxuICAgKiBERlMgc2VhcmNoIGZvciBhIG5vZGUgYnkgSUQuXG4gICAqIENoZWNrczogY3VycmVudCDihpIgY2hpbGRyZW4gKGRlcHRoLWZpcnN0KSDihpIgbmV4dCAobGluZWFyIGNvbnRpbnVhdGlvbikuXG4gICAqL1xuICBmaW5kTm9kZUJ5SWQobm9kZUlkOiBzdHJpbmcsIHN0YXJ0Tm9kZT86IFN0YWdlTm9kZTxUT3V0LCBUU2NvcGU+KTogU3RhZ2VOb2RlPFRPdXQsIFRTY29wZT4gfCB1bmRlZmluZWQge1xuICAgIGNvbnN0IG5vZGUgPSBzdGFydE5vZGUgPz8gdGhpcy5kZXBzLnJvb3Q7XG5cbiAgICBpZiAobm9kZS5pZCA9PT0gbm9kZUlkKSByZXR1cm4gbm9kZTtcblxuICAgIGlmIChub2RlLmNoaWxkcmVuKSB7XG4gICAgICBmb3IgKGNvbnN0IGNoaWxkIG9mIG5vZGUuY2hpbGRyZW4pIHtcbiAgICAgICAgY29uc3QgZm91bmQgPSB0aGlzLmZpbmROb2RlQnlJZChub2RlSWQsIGNoaWxkKTtcbiAgICAgICAgaWYgKGZvdW5kKSByZXR1cm4gZm91bmQ7XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKG5vZGUubmV4dCkge1xuICAgICAgY29uc3QgZm91bmQgPSB0aGlzLmZpbmROb2RlQnlJZChub2RlSWQsIG5vZGUubmV4dCk7XG4gICAgICBpZiAoZm91bmQpIHJldHVybiBmb3VuZDtcbiAgICB9XG5cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgLyoqXG4gICAqIFJlc29sdmUgYSBzdWJmbG93IHJlZmVyZW5jZSBub2RlIHRvIGl0cyBhY3R1YWwgc3RydWN0dXJlLlxuICAgKlxuICAgKiBSZWZlcmVuY2Ugbm9kZXMgYXJlIGxpZ2h0d2VpZ2h0IHBsYWNlaG9sZGVycyAoaXNTdWJmbG93Um9vdCBidXQgbm8gZm4vY2hpbGRyZW4pLlxuICAgKiBUaGUgYWN0dWFsIHN0cnVjdHVyZSBsaXZlcyBpbiB0aGUgc3ViZmxvd3MgZGljdGlvbmFyeS5cbiAgICovXG4gIHJlc29sdmVTdWJmbG93UmVmZXJlbmNlKG5vZGU6IFN0YWdlTm9kZTxUT3V0LCBUU2NvcGU+KTogU3RhZ2VOb2RlPFRPdXQsIFRTY29wZT4ge1xuICAgIC8vIEFscmVhZHkgaGFzIHN0cnVjdHVyZSDigJQgbm90IGEgcmVmZXJlbmNlXG4gICAgaWYgKG5vZGUuZm4gfHwgKG5vZGUuY2hpbGRyZW4gJiYgbm9kZS5jaGlsZHJlbi5sZW5ndGggPiAwKSkgcmV0dXJuIG5vZGU7XG5cbiAgICBpZiAoIXRoaXMuZGVwcy5zdWJmbG93cykgcmV0dXJuIG5vZGU7XG5cbiAgICAvLyBUcnkgbXVsdGlwbGUga2V5cyBpbiBvcmRlciBvZiBwcmVmZXJlbmNlXG4gICAgY29uc3Qga2V5c1RvVHJ5ID0gW25vZGUuc3ViZmxvd0lkLCBub2RlLnN1YmZsb3dOYW1lLCBub2RlLm5hbWVdLmZpbHRlcihCb29sZWFuKSBhcyBzdHJpbmdbXTtcbiAgICBsZXQgc3ViZmxvd0RlZjogeyByb290OiBTdGFnZU5vZGU8VE91dCwgVFNjb3BlPiB9IHwgdW5kZWZpbmVkO1xuXG4gICAgZm9yIChjb25zdCBrZXkgb2Yga2V5c1RvVHJ5KSB7XG4gICAgICBpZiAodGhpcy5kZXBzLnN1YmZsb3dzW2tleV0pIHtcbiAgICAgICAgc3ViZmxvd0RlZiA9IHRoaXMuZGVwcy5zdWJmbG93c1trZXldO1xuICAgICAgICBicmVhaztcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAoIXN1YmZsb3dEZWYpIHtcbiAgICAgIHRoaXMuZGVwcy5sb2dnZXIuaW5mbyhcbiAgICAgICAgYFN1YmZsb3cgbm90IGZvdW5kIGluIGRpY3Rpb25hcnkgZm9yIG5vZGUgJyR7bm9kZS5uYW1lfScgKHRyaWVkIGtleXM6ICR7a2V5c1RvVHJ5LmpvaW4oJywgJyl9KWAsXG4gICAgICApO1xuICAgICAgcmV0dXJuIG5vZGU7XG4gICAgfVxuXG4gICAgLy8gTWVyZ2UgcmVmZXJlbmNlIG1ldGFkYXRhIHdpdGggYWN0dWFsIHN0cnVjdHVyZS5cbiAgICAvLyBpZCBjb21lcyBmcm9tIHRoZSBpbm5lciByb290ICh0aGUgYWN0dWFsIHN0YWdlIGlkZW50aXR5IGZvciB0cmFjZSBtYXRjaGluZyksXG4gICAgLy8gbm90IHRoZSBtb3VudCBub2RlICh3aGljaCBpcyB0aGUgc3ViZmxvdyBlbnRyeSBwb2ludCBpbiB0aGUgcGFyZW50KS5cbiAgICByZXR1cm4ge1xuICAgICAgLi4uc3ViZmxvd0RlZi5yb290LFxuICAgICAgaXNTdWJmbG93Um9vdDogbm9kZS5pc1N1YmZsb3dSb290LFxuICAgICAgc3ViZmxvd0lkOiBub2RlLnN1YmZsb3dJZCxcbiAgICAgIHN1YmZsb3dOYW1lOiBub2RlLnN1YmZsb3dOYW1lLFxuICAgICAgaWQ6IHN1YmZsb3dEZWYucm9vdC5pZCB8fCBub2RlLmlkLFxuICAgICAgc3ViZmxvd01vdW50T3B0aW9uczogbm9kZS5zdWJmbG93TW91bnRPcHRpb25zIHx8IHN1YmZsb3dEZWYucm9vdC5zdWJmbG93TW91bnRPcHRpb25zLFxuICAgIH07XG4gIH1cbn1cbiJdfQ==
@@ -74,9 +74,9 @@ class DeciderHandler {
74
74
  rationale: rationale || `returned branchId: ${branchId}`,
75
75
  });
76
76
  this.deps.narrativeGenerator.onDecision(node.name, chosen.name, rationale, node.description);
77
- const nextStageContext = context.createNext(branchPath, chosen.name, chosen.id);
78
- return executeNode(chosen, nextStageContext, breakFlag, branchPath);
77
+ const branchContext = context.createChild(branchPath, chosen.id, chosen.name, chosen.id);
78
+ return executeNode(chosen, branchContext, breakFlag, branchPath);
79
79
  }
80
80
  }
81
81
  exports.DeciderHandler = DeciderHandler;
82
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DeciderHandler.js","sourceRoot":"","sources":["../../../../src/lib/engine/handlers/DeciderHandler.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * DeciderHandler — Single-choice conditional branching.\n *\n * Handles scope-based deciders (stage IS the decider, returns branch ID).\n * Logs flow control decisions and narrative sentences.\n */\n\nimport type { StageContext } from '../../memory/StageContext.js';\nimport type { StageNode } from '../graph/StageNode.js';\nimport type { HandlerDeps, StageFunction } from '../types.js';\n\n/** Callback for running a stage with commit + extractor. Avoids circular dep with traverser. */\nexport type RunStageFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  stageFunc: StageFunction<TOut, TScope>,\n  context: StageContext,\n  breakFn: () => void,\n) => Promise<TOut>;\n\n/** Callback for recursive node execution. Avoids circular dep with traverser. */\nexport type ExecuteNodeFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  context: StageContext,\n  breakFlag: { shouldBreak: boolean },\n  branchPath?: string,\n) => Promise<any>;\n\n/** Callback for calling the extractor after stage execution. */\nexport type CallExtractorFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  context: StageContext,\n  stagePath: string,\n  stageOutput?: unknown,\n  errorInfo?: { type: string; message: string },\n) => void;\n\n/** Callback for computing the stage path for extractor. */\nexport type GetStagePathFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  branchPath?: string,\n  contextStageName?: string,\n) => string;\n\nexport class DeciderHandler<TOut = any, TScope = any> {\n  constructor(private readonly deps: HandlerDeps<TOut, TScope>) {}\n\n  /**\n   * Handle a scope-based decider (created via addDeciderFunction).\n   * The stage function IS the decider — its return value is the branch ID.\n   * Execution order: runStage(fn) → commit → resolve child → log → executeNode(child).\n   */\n  async handleScopeBased(\n    node: StageNode<TOut, TScope>,\n    stageFunc: StageFunction<TOut, TScope>,\n    context: StageContext,\n    breakFlag: { shouldBreak: boolean },\n    branchPath: string | undefined,\n    runStage: RunStageFn<TOut, TScope>,\n    executeNode: ExecuteNodeFn<TOut, TScope>,\n    callExtractor: CallExtractorFn<TOut, TScope>,\n    getStagePath: GetStagePathFn<TOut, TScope>,\n  ): Promise<any> {\n    const breakFn = () => (breakFlag.shouldBreak = true);\n\n    let branchId: string;\n    try {\n      const stageOutput = await runStage(node, stageFunc, context, breakFn);\n      branchId = String(stageOutput);\n    } catch (error: any) {\n      context.commit();\n      callExtractor(node, context, getStagePath(node, branchPath, context.stageName), undefined, {\n        type: 'stageExecutionError',\n        message: error.toString(),\n      });\n      this.deps.logger.error(`Error in pipeline (${branchPath}) stage [${node.name}]:`, { error });\n      context.addError('stageExecutionError', error.toString());\n      this.deps.narrativeGenerator.onError(node.name, error.toString(), error);\n      throw error;\n    }\n\n    context.commit();\n    callExtractor(node, context, getStagePath(node, branchPath, context.stageName), branchId);\n\n    if (breakFlag.shouldBreak) {\n      this.deps.logger.info(`Execution stopped in pipeline (${branchPath}) after ${node.name} due to break condition.`);\n      return branchId;\n    }\n\n    // Resolve child by matching branch ID against node.children\n    const children = node.children as StageNode<TOut, TScope>[];\n    let chosen = children.find((child) => child.id === branchId);\n\n    // Fall back to default branch\n    if (!chosen) {\n      const defaultChild = children.find((child) => child.id === 'default');\n      if (defaultChild) {\n        chosen = defaultChild;\n      } else {\n        const errorMessage = `Scope-based decider '${node.name}' returned branch ID '${branchId}' which doesn't match any child and no default branch is set`;\n        context.addError('deciderError', errorMessage);\n        throw new Error(errorMessage);\n      }\n    }\n\n    const chosenName = chosen.name;\n    const wasDefault = chosen.id !== branchId;\n    const rationale = context.debug?.logContext?.deciderRationale as string | undefined;\n    let branchReason: string;\n    if (wasDefault) {\n      branchReason = `Returned '${branchId}' (no match), fell back to default → ${chosenName} path.`;\n    } else if (rationale) {\n      branchReason = `Based on: ${rationale} → chose ${chosenName} path.`;\n    } else {\n      branchReason = `Evaluated scope and returned '${branchId}' → chose ${chosenName} path.`;\n    }\n    context.addFlowDebugMessage('branch', branchReason, {\n      targetStage: chosen.name,\n      rationale: rationale || `returned branchId: ${branchId}`,\n    });\n\n    this.deps.narrativeGenerator.onDecision(node.name, chosen.name, rationale, node.description);\n\n    const nextStageContext = context.createNext(branchPath as string, chosen.name, chosen.id);\n    return executeNode(chosen, nextStageContext, breakFlag, branchPath);\n  }\n}\n"]}
82
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DeciderHandler.js","sourceRoot":"","sources":["../../../../src/lib/engine/handlers/DeciderHandler.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * DeciderHandler — Single-choice conditional branching.\n *\n * Handles scope-based deciders (stage IS the decider, returns branch ID).\n * Logs flow control decisions and narrative sentences.\n */\n\nimport type { StageContext } from '../../memory/StageContext.js';\nimport type { StageNode } from '../graph/StageNode.js';\nimport type { HandlerDeps, StageFunction } from '../types.js';\n\n/** Callback for running a stage with commit + extractor. Avoids circular dep with traverser. */\nexport type RunStageFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  stageFunc: StageFunction<TOut, TScope>,\n  context: StageContext,\n  breakFn: () => void,\n) => Promise<TOut>;\n\n/** Callback for recursive node execution. Avoids circular dep with traverser. */\nexport type ExecuteNodeFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  context: StageContext,\n  breakFlag: { shouldBreak: boolean },\n  branchPath?: string,\n) => Promise<any>;\n\n/** Callback for calling the extractor after stage execution. */\nexport type CallExtractorFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  context: StageContext,\n  stagePath: string,\n  stageOutput?: unknown,\n  errorInfo?: { type: string; message: string },\n) => void;\n\n/** Callback for computing the stage path for extractor. */\nexport type GetStagePathFn<TOut = any, TScope = any> = (\n  node: StageNode<TOut, TScope>,\n  branchPath?: string,\n  contextStageName?: string,\n) => string;\n\nexport class DeciderHandler<TOut = any, TScope = any> {\n  constructor(private readonly deps: HandlerDeps<TOut, TScope>) {}\n\n  /**\n   * Handle a scope-based decider (created via addDeciderFunction).\n   * The stage function IS the decider — its return value is the branch ID.\n   * Execution order: runStage(fn) → commit → resolve child → log → executeNode(child).\n   */\n  async handleScopeBased(\n    node: StageNode<TOut, TScope>,\n    stageFunc: StageFunction<TOut, TScope>,\n    context: StageContext,\n    breakFlag: { shouldBreak: boolean },\n    branchPath: string | undefined,\n    runStage: RunStageFn<TOut, TScope>,\n    executeNode: ExecuteNodeFn<TOut, TScope>,\n    callExtractor: CallExtractorFn<TOut, TScope>,\n    getStagePath: GetStagePathFn<TOut, TScope>,\n  ): Promise<any> {\n    const breakFn = () => (breakFlag.shouldBreak = true);\n\n    let branchId: string;\n    try {\n      const stageOutput = await runStage(node, stageFunc, context, breakFn);\n      branchId = String(stageOutput);\n    } catch (error: any) {\n      context.commit();\n      callExtractor(node, context, getStagePath(node, branchPath, context.stageName), undefined, {\n        type: 'stageExecutionError',\n        message: error.toString(),\n      });\n      this.deps.logger.error(`Error in pipeline (${branchPath}) stage [${node.name}]:`, { error });\n      context.addError('stageExecutionError', error.toString());\n      this.deps.narrativeGenerator.onError(node.name, error.toString(), error);\n      throw error;\n    }\n\n    context.commit();\n    callExtractor(node, context, getStagePath(node, branchPath, context.stageName), branchId);\n\n    if (breakFlag.shouldBreak) {\n      this.deps.logger.info(`Execution stopped in pipeline (${branchPath}) after ${node.name} due to break condition.`);\n      return branchId;\n    }\n\n    // Resolve child by matching branch ID against node.children\n    const children = node.children as StageNode<TOut, TScope>[];\n    let chosen = children.find((child) => child.id === branchId);\n\n    // Fall back to default branch\n    if (!chosen) {\n      const defaultChild = children.find((child) => child.id === 'default');\n      if (defaultChild) {\n        chosen = defaultChild;\n      } else {\n        const errorMessage = `Scope-based decider '${node.name}' returned branch ID '${branchId}' which doesn't match any child and no default branch is set`;\n        context.addError('deciderError', errorMessage);\n        throw new Error(errorMessage);\n      }\n    }\n\n    const chosenName = chosen.name;\n    const wasDefault = chosen.id !== branchId;\n    const rationale = context.debug?.logContext?.deciderRationale as string | undefined;\n    let branchReason: string;\n    if (wasDefault) {\n      branchReason = `Returned '${branchId}' (no match), fell back to default → ${chosenName} path.`;\n    } else if (rationale) {\n      branchReason = `Based on: ${rationale} → chose ${chosenName} path.`;\n    } else {\n      branchReason = `Evaluated scope and returned '${branchId}' → chose ${chosenName} path.`;\n    }\n    context.addFlowDebugMessage('branch', branchReason, {\n      targetStage: chosen.name,\n      rationale: rationale || `returned branchId: ${branchId}`,\n    });\n\n    this.deps.narrativeGenerator.onDecision(node.name, chosen.name, rationale, node.description);\n\n    const branchContext = context.createChild(branchPath as string, chosen.id, chosen.name, chosen.id);\n    return executeNode(chosen, branchContext, breakFlag, branchPath);\n  }\n}\n"]}
@@ -60,16 +60,18 @@ class NodeResolver {
60
60
  this.deps.logger.info(`Subflow not found in dictionary for node '${node.name}' (tried keys: ${keysToTry.join(', ')})`);
61
61
  return node;
62
62
  }
63
- // Merge reference metadata with actual structure
63
+ // Merge reference metadata with actual structure.
64
+ // id comes from the inner root (the actual stage identity for trace matching),
65
+ // not the mount node (which is the subflow entry point in the parent).
64
66
  return {
65
67
  ...subflowDef.root,
66
68
  isSubflowRoot: node.isSubflowRoot,
67
69
  subflowId: node.subflowId,
68
70
  subflowName: node.subflowName,
69
- id: node.id || subflowDef.root.id,
71
+ id: subflowDef.root.id || node.id,
70
72
  subflowMountOptions: node.subflowMountOptions || subflowDef.root.subflowMountOptions,
71
73
  };
72
74
  }
73
75
  }
74
76
  exports.NodeResolver = NodeResolver;
75
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTm9kZVJlc29sdmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9lbmdpbmUvaGFuZGxlcnMvTm9kZVJlc29sdmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7OztHQU9HOzs7QUFNSCxNQUFhLFlBQVk7SUFDdkIsWUFBb0IsSUFBK0I7UUFBL0IsU0FBSSxHQUFKLElBQUksQ0FBMkI7SUFBRyxDQUFDO0lBRXZEOzs7T0FHRztJQUNILFlBQVksQ0FBQyxNQUFjLEVBQUUsU0FBbUM7UUFDOUQsTUFBTSxJQUFJLEdBQUcsU0FBUyxhQUFULFNBQVMsY0FBVCxTQUFTLEdBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUM7UUFFekMsSUFBSSxJQUFJLENBQUMsRUFBRSxLQUFLLE1BQU07WUFBRSxPQUFPLElBQUksQ0FBQztRQUVwQyxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUNsQixLQUFLLE1BQU0sS0FBSyxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztnQkFDbEMsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLENBQUM7Z0JBQy9DLElBQUksS0FBSztvQkFBRSxPQUFPLEtBQUssQ0FBQztZQUMxQixDQUFDO1FBQ0gsQ0FBQztRQUVELElBQUksSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ2QsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQ25ELElBQUksS0FBSztnQkFBRSxPQUFPLEtBQUssQ0FBQztRQUMxQixDQUFDO1FBRUQsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsdUJBQXVCLENBQUMsSUFBNkI7UUFDbkQsMENBQTBDO1FBQzFDLElBQUksSUFBSSxDQUFDLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO1lBQUUsT0FBTyxJQUFJLENBQUM7UUFFeEUsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUTtZQUFFLE9BQU8sSUFBSSxDQUFDO1FBRXJDLDJDQUEyQztRQUMzQyxNQUFNLFNBQVMsR0FBRyxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBYSxDQUFDO1FBQzVGLElBQUksVUFBeUQsQ0FBQztRQUU5RCxLQUFLLE1BQU0sR0FBRyxJQUFJLFNBQVMsRUFBRSxDQUFDO1lBQzVCLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztnQkFDNUIsVUFBVSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDO2dCQUNyQyxNQUFNO1lBQ1IsQ0FBQztRQUNILENBQUM7UUFFRCxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDaEIsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUNuQiw2Q0FBNkMsSUFBSSxDQUFDLElBQUksa0JBQWtCLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FDaEcsQ0FBQztZQUNGLE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQztRQUVELGlEQUFpRDtRQUNqRCxPQUFPO1lBQ0wsR0FBRyxVQUFVLENBQUMsSUFBSTtZQUNsQixhQUFhLEVBQUUsSUFBSSxDQUFDLGFBQWE7WUFDakMsU0FBUyxFQUFFLElBQUksQ0FBQyxTQUFTO1lBQ3pCLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVztZQUM3QixFQUFFLEVBQUUsSUFBSSxDQUFDLEVBQUUsSUFBSSxVQUFVLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDakMsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLG1CQUFtQixJQUFJLFVBQVUsQ0FBQyxJQUFJLENBQUMsbUJBQW1CO1NBQ3JGLENBQUM7SUFDSixDQUFDO0NBQ0Y7QUFuRUQsb0NBbUVDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBOb2RlUmVzb2x2ZXIg4oCUIERGUyBub2RlIGxvb2t1cCArIHN1YmZsb3cgcmVmZXJlbmNlIHJlc29sdXRpb24uXG4gKlxuICogUmVzcG9uc2liaWxpdGllczpcbiAqIC0gRmluZCBub2RlcyBieSBJRCB2aWEgcmVjdXJzaXZlIGRlcHRoLWZpcnN0IHNlYXJjaCAoZm9yIGJhY2stZWRnZS9sb29wIHN1cHBvcnQpXG4gKiAtIFJlc29sdmUgc3ViZmxvdyByZWZlcmVuY2Ugbm9kZXMgdG8gYWN0dWFsIHN1YmZsb3cgc3RydWN0dXJlc1xuICogLSBFdmFsdWF0ZSBkZWNpZGVycyB0byBkZXRlcm1pbmUgbmV4dCBub2RlIGluIGJyYW5jaGluZyBzY2VuYXJpb3NcbiAqL1xuXG5pbXBvcnQgdHlwZSB7IFN0YWdlQ29udGV4dCB9IGZyb20gJy4uLy4uL21lbW9yeS9TdGFnZUNvbnRleHQuanMnO1xuaW1wb3J0IHR5cGUgeyBTdGFnZU5vZGUgfSBmcm9tICcuLi9ncmFwaC9TdGFnZU5vZGUuanMnO1xuaW1wb3J0IHR5cGUgeyBIYW5kbGVyRGVwcyB9IGZyb20gJy4uL3R5cGVzLmpzJztcblxuZXhwb3J0IGNsYXNzIE5vZGVSZXNvbHZlcjxUT3V0ID0gYW55LCBUU2NvcGUgPSBhbnk+IHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBkZXBzOiBIYW5kbGVyRGVwczxUT3V0LCBUU2NvcGU+KSB7fVxuXG4gIC8qKlxuICAgKiBERlMgc2VhcmNoIGZvciBhIG5vZGUgYnkgSUQuXG4gICAqIENoZWNrczogY3VycmVudCDihpIgY2hpbGRyZW4gKGRlcHRoLWZpcnN0KSDihpIgbmV4dCAobGluZWFyIGNvbnRpbnVhdGlvbikuXG4gICAqL1xuICBmaW5kTm9kZUJ5SWQobm9kZUlkOiBzdHJpbmcsIHN0YXJ0Tm9kZT86IFN0YWdlTm9kZTxUT3V0LCBUU2NvcGU+KTogU3RhZ2VOb2RlPFRPdXQsIFRTY29wZT4gfCB1bmRlZmluZWQge1xuICAgIGNvbnN0IG5vZGUgPSBzdGFydE5vZGUgPz8gdGhpcy5kZXBzLnJvb3Q7XG5cbiAgICBpZiAobm9kZS5pZCA9PT0gbm9kZUlkKSByZXR1cm4gbm9kZTtcblxuICAgIGlmIChub2RlLmNoaWxkcmVuKSB7XG4gICAgICBmb3IgKGNvbnN0IGNoaWxkIG9mIG5vZGUuY2hpbGRyZW4pIHtcbiAgICAgICAgY29uc3QgZm91bmQgPSB0aGlzLmZpbmROb2RlQnlJZChub2RlSWQsIGNoaWxkKTtcbiAgICAgICAgaWYgKGZvdW5kKSByZXR1cm4gZm91bmQ7XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKG5vZGUubmV4dCkge1xuICAgICAgY29uc3QgZm91bmQgPSB0aGlzLmZpbmROb2RlQnlJZChub2RlSWQsIG5vZGUubmV4dCk7XG4gICAgICBpZiAoZm91bmQpIHJldHVybiBmb3VuZDtcbiAgICB9XG5cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgLyoqXG4gICAqIFJlc29sdmUgYSBzdWJmbG93IHJlZmVyZW5jZSBub2RlIHRvIGl0cyBhY3R1YWwgc3RydWN0dXJlLlxuICAgKlxuICAgKiBSZWZlcmVuY2Ugbm9kZXMgYXJlIGxpZ2h0d2VpZ2h0IHBsYWNlaG9sZGVycyAoaXNTdWJmbG93Um9vdCBidXQgbm8gZm4vY2hpbGRyZW4pLlxuICAgKiBUaGUgYWN0dWFsIHN0cnVjdHVyZSBsaXZlcyBpbiB0aGUgc3ViZmxvd3MgZGljdGlvbmFyeS5cbiAgICovXG4gIHJlc29sdmVTdWJmbG93UmVmZXJlbmNlKG5vZGU6IFN0YWdlTm9kZTxUT3V0LCBUU2NvcGU+KTogU3RhZ2VOb2RlPFRPdXQsIFRTY29wZT4ge1xuICAgIC8vIEFscmVhZHkgaGFzIHN0cnVjdHVyZSDigJQgbm90IGEgcmVmZXJlbmNlXG4gICAgaWYgKG5vZGUuZm4gfHwgKG5vZGUuY2hpbGRyZW4gJiYgbm9kZS5jaGlsZHJlbi5sZW5ndGggPiAwKSkgcmV0dXJuIG5vZGU7XG5cbiAgICBpZiAoIXRoaXMuZGVwcy5zdWJmbG93cykgcmV0dXJuIG5vZGU7XG5cbiAgICAvLyBUcnkgbXVsdGlwbGUga2V5cyBpbiBvcmRlciBvZiBwcmVmZXJlbmNlXG4gICAgY29uc3Qga2V5c1RvVHJ5ID0gW25vZGUuc3ViZmxvd0lkLCBub2RlLnN1YmZsb3dOYW1lLCBub2RlLm5hbWVdLmZpbHRlcihCb29sZWFuKSBhcyBzdHJpbmdbXTtcbiAgICBsZXQgc3ViZmxvd0RlZjogeyByb290OiBTdGFnZU5vZGU8VE91dCwgVFNjb3BlPiB9IHwgdW5kZWZpbmVkO1xuXG4gICAgZm9yIChjb25zdCBrZXkgb2Yga2V5c1RvVHJ5KSB7XG4gICAgICBpZiAodGhpcy5kZXBzLnN1YmZsb3dzW2tleV0pIHtcbiAgICAgICAgc3ViZmxvd0RlZiA9IHRoaXMuZGVwcy5zdWJmbG93c1trZXldO1xuICAgICAgICBicmVhaztcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAoIXN1YmZsb3dEZWYpIHtcbiAgICAgIHRoaXMuZGVwcy5sb2dnZXIuaW5mbyhcbiAgICAgICAgYFN1YmZsb3cgbm90IGZvdW5kIGluIGRpY3Rpb25hcnkgZm9yIG5vZGUgJyR7bm9kZS5uYW1lfScgKHRyaWVkIGtleXM6ICR7a2V5c1RvVHJ5LmpvaW4oJywgJyl9KWAsXG4gICAgICApO1xuICAgICAgcmV0dXJuIG5vZGU7XG4gICAgfVxuXG4gICAgLy8gTWVyZ2UgcmVmZXJlbmNlIG1ldGFkYXRhIHdpdGggYWN0dWFsIHN0cnVjdHVyZVxuICAgIHJldHVybiB7XG4gICAgICAuLi5zdWJmbG93RGVmLnJvb3QsXG4gICAgICBpc1N1YmZsb3dSb290OiBub2RlLmlzU3ViZmxvd1Jvb3QsXG4gICAgICBzdWJmbG93SWQ6IG5vZGUuc3ViZmxvd0lkLFxuICAgICAgc3ViZmxvd05hbWU6IG5vZGUuc3ViZmxvd05hbWUsXG4gICAgICBpZDogbm9kZS5pZCB8fCBzdWJmbG93RGVmLnJvb3QuaWQsXG4gICAgICBzdWJmbG93TW91bnRPcHRpb25zOiBub2RlLnN1YmZsb3dNb3VudE9wdGlvbnMgfHwgc3ViZmxvd0RlZi5yb290LnN1YmZsb3dNb3VudE9wdGlvbnMsXG4gICAgfTtcbiAgfVxufVxuIl19
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTm9kZVJlc29sdmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9lbmdpbmUvaGFuZGxlcnMvTm9kZVJlc29sdmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7OztHQU9HOzs7QUFNSCxNQUFhLFlBQVk7SUFDdkIsWUFBb0IsSUFBK0I7UUFBL0IsU0FBSSxHQUFKLElBQUksQ0FBMkI7SUFBRyxDQUFDO0lBRXZEOzs7T0FHRztJQUNILFlBQVksQ0FBQyxNQUFjLEVBQUUsU0FBbUM7UUFDOUQsTUFBTSxJQUFJLEdBQUcsU0FBUyxhQUFULFNBQVMsY0FBVCxTQUFTLEdBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUM7UUFFekMsSUFBSSxJQUFJLENBQUMsRUFBRSxLQUFLLE1BQU07WUFBRSxPQUFPLElBQUksQ0FBQztRQUVwQyxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUNsQixLQUFLLE1BQU0sS0FBSyxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztnQkFDbEMsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLENBQUM7Z0JBQy9DLElBQUksS0FBSztvQkFBRSxPQUFPLEtBQUssQ0FBQztZQUMxQixDQUFDO1FBQ0gsQ0FBQztRQUVELElBQUksSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ2QsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQ25ELElBQUksS0FBSztnQkFBRSxPQUFPLEtBQUssQ0FBQztRQUMxQixDQUFDO1FBRUQsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsdUJBQXVCLENBQUMsSUFBNkI7UUFDbkQsMENBQTBDO1FBQzFDLElBQUksSUFBSSxDQUFDLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO1lBQUUsT0FBTyxJQUFJLENBQUM7UUFFeEUsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUTtZQUFFLE9BQU8sSUFBSSxDQUFDO1FBRXJDLDJDQUEyQztRQUMzQyxNQUFNLFNBQVMsR0FBRyxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBYSxDQUFDO1FBQzVGLElBQUksVUFBeUQsQ0FBQztRQUU5RCxLQUFLLE1BQU0sR0FBRyxJQUFJLFNBQVMsRUFBRSxDQUFDO1lBQzVCLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztnQkFDNUIsVUFBVSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDO2dCQUNyQyxNQUFNO1lBQ1IsQ0FBQztRQUNILENBQUM7UUFFRCxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDaEIsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUNuQiw2Q0FBNkMsSUFBSSxDQUFDLElBQUksa0JBQWtCLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FDaEcsQ0FBQztZQUNGLE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQztRQUVELGtEQUFrRDtRQUNsRCwrRUFBK0U7UUFDL0UsdUVBQXVFO1FBQ3ZFLE9BQU87WUFDTCxHQUFHLFVBQVUsQ0FBQyxJQUFJO1lBQ2xCLGFBQWEsRUFBRSxJQUFJLENBQUMsYUFBYTtZQUNqQyxTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVM7WUFDekIsV0FBVyxFQUFFLElBQUksQ0FBQyxXQUFXO1lBQzdCLEVBQUUsRUFBRSxVQUFVLENBQUMsSUFBSSxDQUFDLEVBQUUsSUFBSSxJQUFJLENBQUMsRUFBRTtZQUNqQyxtQkFBbUIsRUFBRSxJQUFJLENBQUMsbUJBQW1CLElBQUksVUFBVSxDQUFDLElBQUksQ0FBQyxtQkFBbUI7U0FDckYsQ0FBQztJQUNKLENBQUM7Q0FDRjtBQXJFRCxvQ0FxRUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIE5vZGVSZXNvbHZlciDigJQgREZTIG5vZGUgbG9va3VwICsgc3ViZmxvdyByZWZlcmVuY2UgcmVzb2x1dGlvbi5cbiAqXG4gKiBSZXNwb25zaWJpbGl0aWVzOlxuICogLSBGaW5kIG5vZGVzIGJ5IElEIHZpYSByZWN1cnNpdmUgZGVwdGgtZmlyc3Qgc2VhcmNoIChmb3IgYmFjay1lZGdlL2xvb3Agc3VwcG9ydClcbiAqIC0gUmVzb2x2ZSBzdWJmbG93IHJlZmVyZW5jZSBub2RlcyB0byBhY3R1YWwgc3ViZmxvdyBzdHJ1Y3R1cmVzXG4gKiAtIEV2YWx1YXRlIGRlY2lkZXJzIHRvIGRldGVybWluZSBuZXh0IG5vZGUgaW4gYnJhbmNoaW5nIHNjZW5hcmlvc1xuICovXG5cbmltcG9ydCB0eXBlIHsgU3RhZ2VDb250ZXh0IH0gZnJvbSAnLi4vLi4vbWVtb3J5L1N0YWdlQ29udGV4dC5qcyc7XG5pbXBvcnQgdHlwZSB7IFN0YWdlTm9kZSB9IGZyb20gJy4uL2dyYXBoL1N0YWdlTm9kZS5qcyc7XG5pbXBvcnQgdHlwZSB7IEhhbmRsZXJEZXBzIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgY2xhc3MgTm9kZVJlc29sdmVyPFRPdXQgPSBhbnksIFRTY29wZSA9IGFueT4ge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGRlcHM6IEhhbmRsZXJEZXBzPFRPdXQsIFRTY29wZT4pIHt9XG5cbiAgLyoqXG4gICAqIERGUyBzZWFyY2ggZm9yIGEgbm9kZSBieSBJRC5cbiAgICogQ2hlY2tzOiBjdXJyZW50IOKGkiBjaGlsZHJlbiAoZGVwdGgtZmlyc3QpIOKGkiBuZXh0IChsaW5lYXIgY29udGludWF0aW9uKS5cbiAgICovXG4gIGZpbmROb2RlQnlJZChub2RlSWQ6IHN0cmluZywgc3RhcnROb2RlPzogU3RhZ2VOb2RlPFRPdXQsIFRTY29wZT4pOiBTdGFnZU5vZGU8VE91dCwgVFNjb3BlPiB8IHVuZGVmaW5lZCB7XG4gICAgY29uc3Qgbm9kZSA9IHN0YXJ0Tm9kZSA/PyB0aGlzLmRlcHMucm9vdDtcblxuICAgIGlmIChub2RlLmlkID09PSBub2RlSWQpIHJldHVybiBub2RlO1xuXG4gICAgaWYgKG5vZGUuY2hpbGRyZW4pIHtcbiAgICAgIGZvciAoY29uc3QgY2hpbGQgb2Ygbm9kZS5jaGlsZHJlbikge1xuICAgICAgICBjb25zdCBmb3VuZCA9IHRoaXMuZmluZE5vZGVCeUlkKG5vZGVJZCwgY2hpbGQpO1xuICAgICAgICBpZiAoZm91bmQpIHJldHVybiBmb3VuZDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAobm9kZS5uZXh0KSB7XG4gICAgICBjb25zdCBmb3VuZCA9IHRoaXMuZmluZE5vZGVCeUlkKG5vZGVJZCwgbm9kZS5uZXh0KTtcbiAgICAgIGlmIChmb3VuZCkgcmV0dXJuIGZvdW5kO1xuICAgIH1cblxuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICAvKipcbiAgICogUmVzb2x2ZSBhIHN1YmZsb3cgcmVmZXJlbmNlIG5vZGUgdG8gaXRzIGFjdHVhbCBzdHJ1Y3R1cmUuXG4gICAqXG4gICAqIFJlZmVyZW5jZSBub2RlcyBhcmUgbGlnaHR3ZWlnaHQgcGxhY2Vob2xkZXJzIChpc1N1YmZsb3dSb290IGJ1dCBubyBmbi9jaGlsZHJlbikuXG4gICAqIFRoZSBhY3R1YWwgc3RydWN0dXJlIGxpdmVzIGluIHRoZSBzdWJmbG93cyBkaWN0aW9uYXJ5LlxuICAgKi9cbiAgcmVzb2x2ZVN1YmZsb3dSZWZlcmVuY2Uobm9kZTogU3RhZ2VOb2RlPFRPdXQsIFRTY29wZT4pOiBTdGFnZU5vZGU8VE91dCwgVFNjb3BlPiB7XG4gICAgLy8gQWxyZWFkeSBoYXMgc3RydWN0dXJlIOKAlCBub3QgYSByZWZlcmVuY2VcbiAgICBpZiAobm9kZS5mbiB8fCAobm9kZS5jaGlsZHJlbiAmJiBub2RlLmNoaWxkcmVuLmxlbmd0aCA+IDApKSByZXR1cm4gbm9kZTtcblxuICAgIGlmICghdGhpcy5kZXBzLnN1YmZsb3dzKSByZXR1cm4gbm9kZTtcblxuICAgIC8vIFRyeSBtdWx0aXBsZSBrZXlzIGluIG9yZGVyIG9mIHByZWZlcmVuY2VcbiAgICBjb25zdCBrZXlzVG9UcnkgPSBbbm9kZS5zdWJmbG93SWQsIG5vZGUuc3ViZmxvd05hbWUsIG5vZGUubmFtZV0uZmlsdGVyKEJvb2xlYW4pIGFzIHN0cmluZ1tdO1xuICAgIGxldCBzdWJmbG93RGVmOiB7IHJvb3Q6IFN0YWdlTm9kZTxUT3V0LCBUU2NvcGU+IH0gfCB1bmRlZmluZWQ7XG5cbiAgICBmb3IgKGNvbnN0IGtleSBvZiBrZXlzVG9UcnkpIHtcbiAgICAgIGlmICh0aGlzLmRlcHMuc3ViZmxvd3Nba2V5XSkge1xuICAgICAgICBzdWJmbG93RGVmID0gdGhpcy5kZXBzLnN1YmZsb3dzW2tleV07XG4gICAgICAgIGJyZWFrO1xuICAgICAgfVxuICAgIH1cblxuICAgIGlmICghc3ViZmxvd0RlZikge1xuICAgICAgdGhpcy5kZXBzLmxvZ2dlci5pbmZvKFxuICAgICAgICBgU3ViZmxvdyBub3QgZm91bmQgaW4gZGljdGlvbmFyeSBmb3Igbm9kZSAnJHtub2RlLm5hbWV9JyAodHJpZWQga2V5czogJHtrZXlzVG9Ucnkuam9pbignLCAnKX0pYCxcbiAgICAgICk7XG4gICAgICByZXR1cm4gbm9kZTtcbiAgICB9XG5cbiAgICAvLyBNZXJnZSByZWZlcmVuY2UgbWV0YWRhdGEgd2l0aCBhY3R1YWwgc3RydWN0dXJlLlxuICAgIC8vIGlkIGNvbWVzIGZyb20gdGhlIGlubmVyIHJvb3QgKHRoZSBhY3R1YWwgc3RhZ2UgaWRlbnRpdHkgZm9yIHRyYWNlIG1hdGNoaW5nKSxcbiAgICAvLyBub3QgdGhlIG1vdW50IG5vZGUgKHdoaWNoIGlzIHRoZSBzdWJmbG93IGVudHJ5IHBvaW50IGluIHRoZSBwYXJlbnQpLlxuICAgIHJldHVybiB7XG4gICAgICAuLi5zdWJmbG93RGVmLnJvb3QsXG4gICAgICBpc1N1YmZsb3dSb290OiBub2RlLmlzU3ViZmxvd1Jvb3QsXG4gICAgICBzdWJmbG93SWQ6IG5vZGUuc3ViZmxvd0lkLFxuICAgICAgc3ViZmxvd05hbWU6IG5vZGUuc3ViZmxvd05hbWUsXG4gICAgICBpZDogc3ViZmxvd0RlZi5yb290LmlkIHx8IG5vZGUuaWQsXG4gICAgICBzdWJmbG93TW91bnRPcHRpb25zOiBub2RlLnN1YmZsb3dNb3VudE9wdGlvbnMgfHwgc3ViZmxvd0RlZi5yb290LnN1YmZsb3dNb3VudE9wdGlvbnMsXG4gICAgfTtcbiAgfVxufVxuIl19
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "footprintjs",
3
- "version": "0.15.0",
3
+ "version": "0.15.2",
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",