@stackmemoryai/stackmemory 0.5.31 → 0.5.34

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (148) hide show
  1. package/dist/agents/core/agent-task-manager.js.map +1 -1
  2. package/dist/cli/claude-sm.js +199 -16
  3. package/dist/cli/claude-sm.js.map +2 -2
  4. package/dist/cli/commands/clear.js +1 -1
  5. package/dist/cli/commands/clear.js.map +1 -1
  6. package/dist/cli/commands/context.js +1 -12
  7. package/dist/cli/commands/context.js.map +2 -2
  8. package/dist/cli/commands/dashboard.js.map +1 -1
  9. package/dist/cli/commands/discovery.js +1 -1
  10. package/dist/cli/commands/discovery.js.map +1 -1
  11. package/dist/cli/commands/handoff.js +1 -1
  12. package/dist/cli/commands/handoff.js.map +1 -1
  13. package/dist/cli/commands/linear.js +1 -14
  14. package/dist/cli/commands/linear.js.map +2 -2
  15. package/dist/cli/commands/login.js +32 -10
  16. package/dist/cli/commands/login.js.map +2 -2
  17. package/dist/cli/commands/migrate.js +80 -22
  18. package/dist/cli/commands/migrate.js.map +2 -2
  19. package/dist/cli/commands/model.js +533 -0
  20. package/dist/cli/commands/model.js.map +7 -0
  21. package/dist/cli/commands/monitor.js +1 -1
  22. package/dist/cli/commands/monitor.js.map +1 -1
  23. package/dist/cli/commands/quality.js +1 -1
  24. package/dist/cli/commands/quality.js.map +1 -1
  25. package/dist/cli/commands/ralph.js +93 -28
  26. package/dist/cli/commands/ralph.js.map +2 -2
  27. package/dist/cli/commands/service.js +10 -3
  28. package/dist/cli/commands/service.js.map +2 -2
  29. package/dist/cli/commands/skills.js +61 -11
  30. package/dist/cli/commands/skills.js.map +2 -2
  31. package/dist/cli/commands/sms-notify.js +342 -22
  32. package/dist/cli/commands/sms-notify.js.map +3 -3
  33. package/dist/cli/commands/workflow.js +1 -1
  34. package/dist/cli/commands/workflow.js.map +1 -1
  35. package/dist/cli/commands/worktree.js +1 -1
  36. package/dist/cli/commands/worktree.js.map +1 -1
  37. package/dist/cli/index.js +3 -1
  38. package/dist/cli/index.js.map +2 -2
  39. package/dist/core/context/auto-context.js.map +1 -1
  40. package/dist/core/context/compaction-handler.js.map +2 -2
  41. package/dist/core/context/context-bridge.js.map +2 -2
  42. package/dist/core/context/dual-stack-manager.js +24 -8
  43. package/dist/core/context/dual-stack-manager.js.map +2 -2
  44. package/dist/core/context/enhanced-rehydration.js.map +1 -1
  45. package/dist/core/context/frame-database.js +41 -5
  46. package/dist/core/context/frame-database.js.map +2 -2
  47. package/dist/core/context/frame-digest.js +6 -1
  48. package/dist/core/context/frame-digest.js.map +2 -2
  49. package/dist/core/context/frame-handoff-manager.js.map +1 -1
  50. package/dist/core/context/frame-lifecycle-hooks.js +119 -0
  51. package/dist/core/context/frame-lifecycle-hooks.js.map +7 -0
  52. package/dist/core/context/frame-manager.js +56 -9
  53. package/dist/core/context/frame-manager.js.map +2 -2
  54. package/dist/core/context/frame-stack.js +29 -0
  55. package/dist/core/context/frame-stack.js.map +2 -2
  56. package/dist/core/context/incremental-gc.js.map +2 -2
  57. package/dist/core/context/index.js +4 -22
  58. package/dist/core/context/index.js.map +2 -2
  59. package/dist/core/context/permission-manager.js +0 -11
  60. package/dist/core/context/permission-manager.js.map +2 -2
  61. package/dist/core/context/recursive-context-manager.js +15 -9
  62. package/dist/core/context/recursive-context-manager.js.map +2 -2
  63. package/dist/core/context/refactored-frame-manager.js +140 -34
  64. package/dist/core/context/refactored-frame-manager.js.map +3 -3
  65. package/dist/core/context/shared-context-layer.js +0 -11
  66. package/dist/core/context/shared-context-layer.js.map +2 -2
  67. package/dist/core/context/stack-merge-resolver.js.map +1 -1
  68. package/dist/core/context/validation.js +6 -1
  69. package/dist/core/context/validation.js.map +2 -2
  70. package/dist/core/database/database-adapter.js.map +1 -1
  71. package/dist/core/database/paradedb-adapter.js.map +1 -1
  72. package/dist/core/database/query-router.js.map +1 -1
  73. package/dist/core/database/sqlite-adapter.js.map +1 -1
  74. package/dist/core/digest/frame-digest-integration.js.map +1 -1
  75. package/dist/core/digest/hybrid-digest-generator.js.map +1 -1
  76. package/dist/core/digest/types.js.map +1 -1
  77. package/dist/core/errors/index.js +249 -0
  78. package/dist/core/errors/index.js.map +2 -2
  79. package/dist/core/frame/workflow-templates.js.map +2 -2
  80. package/dist/core/merge/conflict-detector.js.map +1 -1
  81. package/dist/core/merge/resolution-engine.js.map +1 -1
  82. package/dist/core/merge/stack-diff.js.map +1 -1
  83. package/dist/core/models/fallback-monitor.js +229 -0
  84. package/dist/core/models/fallback-monitor.js.map +7 -0
  85. package/dist/core/models/model-router.js +340 -0
  86. package/dist/core/models/model-router.js.map +7 -0
  87. package/dist/core/monitoring/error-handler.js +37 -270
  88. package/dist/core/monitoring/error-handler.js.map +3 -3
  89. package/dist/core/monitoring/session-monitor.js.map +1 -1
  90. package/dist/core/performance/lazy-context-loader.js.map +1 -1
  91. package/dist/core/performance/optimized-frame-context.js.map +1 -1
  92. package/dist/core/retrieval/context-retriever.js.map +1 -1
  93. package/dist/core/retrieval/graph-retrieval.js.map +1 -1
  94. package/dist/core/retrieval/hierarchical-retrieval.js.map +1 -1
  95. package/dist/core/retrieval/llm-context-retrieval.js.map +1 -1
  96. package/dist/core/retrieval/retrieval-benchmarks.js.map +1 -1
  97. package/dist/core/retrieval/summary-generator.js.map +1 -1
  98. package/dist/core/retrieval/types.js.map +1 -1
  99. package/dist/core/storage/chromadb-adapter.js.map +1 -1
  100. package/dist/core/storage/infinite-storage.js.map +1 -1
  101. package/dist/core/storage/two-tier-storage.js.map +1 -1
  102. package/dist/features/tasks/task-aware-context.js.map +1 -1
  103. package/dist/features/web/server/index.js +1 -1
  104. package/dist/features/web/server/index.js.map +1 -1
  105. package/dist/hooks/claude-code-whatsapp-hook.js +197 -0
  106. package/dist/hooks/claude-code-whatsapp-hook.js.map +7 -0
  107. package/dist/hooks/linear-task-picker.js +1 -1
  108. package/dist/hooks/linear-task-picker.js.map +2 -2
  109. package/dist/hooks/schemas.js +105 -1
  110. package/dist/hooks/schemas.js.map +2 -2
  111. package/dist/hooks/session-summary.js +5 -1
  112. package/dist/hooks/session-summary.js.map +2 -2
  113. package/dist/hooks/sms-action-runner.js +16 -1
  114. package/dist/hooks/sms-action-runner.js.map +2 -2
  115. package/dist/hooks/sms-notify.js +4 -2
  116. package/dist/hooks/sms-notify.js.map +2 -2
  117. package/dist/hooks/sms-webhook.js +23 -2
  118. package/dist/hooks/sms-webhook.js.map +2 -2
  119. package/dist/hooks/whatsapp-commands.js +516 -0
  120. package/dist/hooks/whatsapp-commands.js.map +7 -0
  121. package/dist/hooks/whatsapp-scheduler.js +317 -0
  122. package/dist/hooks/whatsapp-scheduler.js.map +7 -0
  123. package/dist/hooks/whatsapp-sync.js +409 -0
  124. package/dist/hooks/whatsapp-sync.js.map +7 -0
  125. package/dist/index.js +1 -1
  126. package/dist/index.js.map +1 -1
  127. package/dist/integrations/mcp/handlers/context-handlers.js.map +1 -1
  128. package/dist/integrations/mcp/handlers/discovery-handlers.js.map +1 -1
  129. package/dist/integrations/mcp/server.js +1 -1
  130. package/dist/integrations/mcp/server.js.map +1 -1
  131. package/dist/integrations/ralph/bridge/ralph-stackmemory-bridge.js +1 -1
  132. package/dist/integrations/ralph/bridge/ralph-stackmemory-bridge.js.map +1 -1
  133. package/dist/integrations/ralph/context/stackmemory-context-loader.js +1 -1
  134. package/dist/integrations/ralph/context/stackmemory-context-loader.js.map +1 -1
  135. package/dist/integrations/ralph/learning/pattern-learner.js +1 -1
  136. package/dist/integrations/ralph/learning/pattern-learner.js.map +1 -1
  137. package/dist/integrations/ralph/orchestration/multi-loop-orchestrator.js +1 -1
  138. package/dist/integrations/ralph/orchestration/multi-loop-orchestrator.js.map +1 -1
  139. package/dist/integrations/ralph/swarm/swarm-coordinator.js +1 -1
  140. package/dist/integrations/ralph/swarm/swarm-coordinator.js.map +1 -1
  141. package/dist/integrations/ralph/visualization/ralph-debugger.js +1 -1
  142. package/dist/integrations/ralph/visualization/ralph-debugger.js.map +1 -1
  143. package/dist/mcp/stackmemory-mcp-server.js +1 -1
  144. package/dist/mcp/stackmemory-mcp-server.js.map +1 -1
  145. package/dist/skills/claude-skills.js.map +1 -1
  146. package/dist/skills/recursive-agent-orchestrator.js.map +1 -1
  147. package/dist/skills/unified-rlm-orchestrator.js.map +1 -1
  148. package/package.json +2 -3
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../src/integrations/ralph/bridge/ralph-stackmemory-bridge.ts"],
4
- "sourcesContent": ["/**\n * Ralph-StackMemory Bridge\n * Main integration point connecting Ralph Wiggum loops with StackMemory persistence\n */\n\nimport { v4 as uuidv4 } from 'uuid';\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\nimport { execSync } from 'child_process';\nimport { logger } from '../../../core/monitoring/logger.js';\nimport { FrameManager } from '../../../core/context/frame-manager.js';\nimport { SessionManager } from '../../../core/session/session-manager.js';\nimport { SQLiteAdapter } from '../../../core/database/sqlite-adapter.js';\nimport { ContextBudgetManager } from '../context/context-budget-manager.js';\nimport { StateReconciler } from '../state/state-reconciler.js';\nimport {\n IterationLifecycle,\n LifecycleHooks,\n} from '../lifecycle/iteration-lifecycle.js';\nimport { PerformanceOptimizer } from '../performance/performance-optimizer.js';\nimport {\n RalphLoopState,\n RalphIteration,\n BridgeState,\n BridgeOptions,\n RalphStackMemoryConfig,\n IterationContext,\n Frame,\n FrameType,\n RecoveryState,\n Checkpoint,\n StateSource,\n} from '../types.js';\n\nexport class RalphStackMemoryBridge {\n private state: BridgeState;\n private config: RalphStackMemoryConfig;\n private frameManager?: FrameManager;\n private sessionManager: SessionManager;\n private recoveryState?: RecoveryState;\n private readonly ralphDir = '.ralph';\n private readonly requiresDatabase: boolean;\n\n constructor(options?: BridgeOptions & { useStackMemory?: boolean }) {\n // Initialize configuration\n this.config = this.mergeConfig(options?.config);\n\n // Check if database/StackMemory features are required\n this.requiresDatabase = options?.useStackMemory !== false;\n\n // Initialize managers\n this.state = {\n initialized: false,\n contextManager: new ContextBudgetManager(this.config.contextBudget),\n stateReconciler: new StateReconciler(this.config.stateReconciliation),\n performanceOptimizer: new PerformanceOptimizer(this.config.performance),\n };\n\n this.sessionManager = SessionManager.getInstance();\n\n // Setup lifecycle hooks\n this.setupLifecycleHooks(options);\n\n logger.info('Ralph-StackMemory Bridge initialized', {\n config: {\n maxTokens: this.config.contextBudget.maxTokens,\n asyncSaves: this.config.performance.asyncSaves,\n checkpoints: this.config.lifecycle.checkpoints.enabled,\n },\n });\n }\n\n /**\n * Initialize bridge with session\n */\n async initialize(options?: {\n sessionId?: string;\n loopId?: string;\n task?: string;\n criteria?: string;\n }): Promise<void> {\n logger.info('Initializing bridge', options);\n\n try {\n // Initialize session manager\n await this.sessionManager.initialize();\n\n // Get or create session\n const session = await this.sessionManager.getOrCreateSession({\n sessionId: options?.sessionId,\n });\n\n this.state.currentSession = session;\n\n // Initialize frame manager with database\n const dbAdapter = await this.getDatabaseAdapter();\n await dbAdapter.connect();\n const db = (dbAdapter as any).db; // Get the actual Database instance\n const projectId = path.basename(this.ralphDir);\n this.frameManager = new FrameManager(db, projectId, { skipContextBridge: true });\n // Initialize frame manager with session database if required\n if (this.requiresDatabase) {\n if (session.database && session.projectId) {\n this.frameManager = new FrameManager(\n session.database,\n session.projectId,\n {\n skipContextBridge: true,\n }\n );\n } else {\n throw new Error(\n 'Session database not available for FrameManager initialization. ' +\n 'If StackMemory features are not needed, set useStackMemory: false in options'\n );\n }\n } else {\n // Database not required, skip frame manager initialization\n logger.info(\n 'Running without StackMemory database (useStackMemory: false)'\n );\n }\n\n // Check for existing loop or create new\n if (options?.loopId) {\n await this.resumeLoop(options.loopId);\n } else if (options?.task && options?.criteria) {\n await this.createNewLoop(options.task, options.criteria);\n } else {\n // Try to recover from crash\n await this.attemptRecovery();\n }\n\n this.state.initialized = true;\n logger.info('Bridge initialized successfully');\n } catch (error: any) {\n logger.error('Bridge initialization failed', { error: error.message });\n throw error;\n }\n }\n\n /**\n * Create new Ralph loop with StackMemory integration\n */\n async createNewLoop(task: string, criteria: string): Promise<RalphLoopState> {\n logger.info('Creating new Ralph loop', { task: task.substring(0, 100) });\n\n const loopId = uuidv4();\n const startTime = Date.now();\n\n // Create Ralph loop state\n const loopState: RalphLoopState = {\n loopId,\n task,\n criteria,\n iteration: 0,\n status: 'initialized',\n startTime,\n lastUpdateTime: startTime,\n startCommit: await this.getCurrentGitCommit(),\n };\n\n // Initialize Ralph directory structure\n await this.initializeRalphDirectory(loopState);\n\n // Create root frame in StackMemory\n const rootFrame = await this.createRootFrame(loopState);\n\n // Save initial state\n await this.saveLoopState(loopState);\n\n this.state.activeLoop = loopState;\n\n logger.info('Ralph loop created', {\n loopId,\n frameId: rootFrame.frame_id,\n });\n\n return loopState;\n }\n\n /**\n * Resume existing loop\n */\n async resumeLoop(loopId: string): Promise<RalphLoopState> {\n logger.info('Resuming loop', { loopId });\n\n // Get state from all sources\n const sources = await this.gatherStateSources(loopId);\n\n // Reconcile state\n const reconciledState =\n await this.state.stateReconciler!.reconcile(sources);\n\n // Validate consistency\n if (this.config.stateReconciliation.validateConsistency) {\n const validation =\n await this.state.stateReconciler!.validateConsistency(reconciledState);\n\n if (validation.errors.length > 0) {\n logger.error('State validation failed', { errors: validation.errors });\n throw new Error(`Invalid state: ${validation.errors.join(', ')}`);\n }\n }\n\n this.state.activeLoop = reconciledState;\n\n // Load context from StackMemory\n const context = await this.loadIterationContext(reconciledState);\n\n logger.info('Loop resumed', {\n loopId,\n iteration: reconciledState.iteration,\n status: reconciledState.status,\n });\n\n return reconciledState;\n }\n\n /**\n * Run worker iteration\n */\n async runWorkerIteration(): Promise<RalphIteration> {\n if (!this.state.activeLoop) {\n throw new Error('No active loop');\n }\n\n const iterationNumber = this.state.activeLoop.iteration + 1;\n logger.info('Starting worker iteration', { iteration: iterationNumber });\n\n // Load and prepare context\n let context = await this.loadIterationContext(this.state.activeLoop);\n\n // Apply context budget management\n context = this.state.contextManager!.allocateBudget(context);\n\n if (this.config.contextBudget.compressionEnabled) {\n context = this.state.contextManager!.compressContext(context);\n }\n\n // Start iteration with lifecycle\n const lifecycle = this.getLifecycle();\n context = await lifecycle.startIteration(iterationNumber, context);\n\n // Execute iteration work\n const iteration = await this.executeWorkerIteration(context);\n\n // Save iteration results\n await this.saveIterationResults(iteration);\n\n // Complete iteration with lifecycle\n await lifecycle.completeIteration(iteration);\n\n // Update loop state\n this.state.activeLoop.iteration = iterationNumber;\n this.state.activeLoop.lastUpdateTime = Date.now();\n await this.saveLoopState(this.state.activeLoop);\n\n logger.info('Worker iteration completed', {\n iteration: iterationNumber,\n changes: iteration.changes.length,\n success: iteration.validation.testsPass,\n });\n\n return iteration;\n }\n\n /**\n * Run reviewer iteration\n */\n async runReviewerIteration(): Promise<{\n complete: boolean;\n feedback?: string;\n }> {\n if (!this.state.activeLoop) {\n throw new Error('No active loop');\n }\n\n logger.info('Starting reviewer iteration', {\n iteration: this.state.activeLoop.iteration,\n });\n\n // Evaluate against criteria\n const evaluation = await this.evaluateCompletion();\n\n if (evaluation.complete) {\n // Mark as complete\n this.state.activeLoop.status = 'completed';\n this.state.activeLoop.completionData = evaluation;\n await this.saveLoopState(this.state.activeLoop);\n\n // Handle completion\n const lifecycle = this.getLifecycle();\n await lifecycle.handleCompletion(this.state.activeLoop);\n\n logger.info('Task completed successfully');\n return { complete: true };\n }\n\n // Generate feedback for next iteration\n const feedback = this.generateFeedback(evaluation);\n this.state.activeLoop.feedback = feedback;\n\n await this.saveLoopState(this.state.activeLoop);\n\n logger.info('Reviewer iteration completed', {\n complete: false,\n feedbackLength: feedback.length,\n });\n\n return { complete: false, feedback };\n }\n\n /**\n * Rehydrate session from StackMemory\n */\n async rehydrateSession(sessionId: string): Promise<IterationContext> {\n logger.info('Rehydrating session', { sessionId });\n\n // Get session from StackMemory\n const session = await this.sessionManager.getSession(sessionId);\n\n if (!session) {\n throw new Error(`Session not found: ${sessionId}`);\n }\n\n // Load frames from session\n const frames = await this.loadSessionFrames(sessionId);\n\n // Extract Ralph loop information\n const ralphFrames = frames.filter(\n (f) => f.type === 'task' && f.name.startsWith('ralph-')\n );\n\n if (ralphFrames.length === 0) {\n throw new Error('No Ralph loops found in session');\n }\n\n // Get most recent Ralph loop\n const latestLoop = ralphFrames[ralphFrames.length - 1];\n\n // Reconstruct loop state\n const loopState = await this.reconstructLoopState(latestLoop);\n\n // Build context from frames\n const context = await this.buildContextFromFrames(frames, loopState);\n\n this.state.activeLoop = loopState;\n\n logger.info('Session rehydrated', {\n loopId: loopState.loopId,\n iteration: loopState.iteration,\n frameCount: frames.length,\n });\n\n return context;\n }\n\n /**\n * Create checkpoint\n */\n async createCheckpoint(): Promise<Checkpoint> {\n if (!this.state.activeLoop) {\n throw new Error('No active loop');\n }\n\n const lifecycle = this.getLifecycle();\n\n // Create dummy iteration for checkpoint\n const iteration: RalphIteration = {\n number: this.state.activeLoop.iteration,\n timestamp: Date.now(),\n analysis: {\n filesCount: 0,\n testsPass: true,\n testsFail: 0,\n lastChange: await this.getCurrentGitCommit(),\n },\n plan: {\n summary: 'Checkpoint',\n steps: [],\n priority: 'low',\n },\n changes: [],\n validation: {\n testsPass: true,\n lintClean: true,\n buildSuccess: true,\n errors: [],\n warnings: [],\n },\n };\n\n const checkpoint = await lifecycle.createCheckpoint(iteration);\n\n logger.info('Checkpoint created', {\n id: checkpoint.id,\n iteration: checkpoint.iteration,\n });\n\n return checkpoint;\n }\n\n /**\n * Restore from checkpoint\n */\n async restoreFromCheckpoint(checkpointId: string): Promise<void> {\n const lifecycle = this.getLifecycle();\n await lifecycle.restoreFromCheckpoint(checkpointId);\n\n // Reload loop state\n const sources = await this.gatherStateSources(\n this.state.activeLoop?.loopId || ''\n );\n const reconciledState =\n await this.state.stateReconciler!.reconcile(sources);\n\n this.state.activeLoop = reconciledState;\n\n logger.info('Restored from checkpoint', {\n checkpointId,\n iteration: reconciledState.iteration,\n });\n }\n\n /**\n * Get performance metrics\n */\n getPerformanceMetrics() {\n return this.state.performanceOptimizer!.getMetrics();\n }\n\n /**\n * Start a new Ralph loop\n */\n async startLoop(options: {\n task: string;\n criteria: string;\n }): Promise<string> {\n const state = await this.createNewLoop(options.task, options.criteria);\n return state.loopId;\n }\n\n /**\n * Stop the active loop\n */\n async stopLoop(): Promise<void> {\n if (!this.state.activeLoop) {\n logger.warn('No active loop to stop');\n return;\n }\n\n this.state.activeLoop.status = 'completed';\n this.state.activeLoop.lastUpdateTime = Date.now();\n await this.saveLoopState(this.state.activeLoop);\n\n // Handle completion lifecycle\n const lifecycle = this.getLifecycle();\n await lifecycle.handleCompletion(this.state.activeLoop);\n\n logger.info('Ralph loop stopped', { loopId: this.state.activeLoop.loopId });\n this.state.activeLoop = undefined;\n }\n\n /**\n * Cleanup resources\n */\n async cleanup(): Promise<void> {\n logger.info('Cleaning up bridge resources');\n\n // Flush any pending saves\n await this.state.performanceOptimizer!.flushBatch();\n\n // Clean up lifecycle\n this.getLifecycle().cleanup();\n\n // Clean up optimizer\n this.state.performanceOptimizer!.cleanup();\n\n logger.info('Bridge cleanup completed');\n }\n\n /**\n * Merge configuration with defaults\n */\n private mergeConfig(\n config?: Partial<RalphStackMemoryConfig>\n ): RalphStackMemoryConfig {\n return {\n contextBudget: {\n maxTokens: 4000,\n priorityWeights: {\n task: 0.3,\n recentWork: 0.25,\n feedback: 0.2,\n gitHistory: 0.15,\n dependencies: 0.1,\n },\n compressionEnabled: true,\n adaptiveBudgeting: true,\n ...config?.contextBudget,\n },\n stateReconciliation: {\n precedence: ['git', 'files', 'memory'],\n conflictResolution: 'automatic',\n syncInterval: 5000,\n validateConsistency: true,\n ...config?.stateReconciliation,\n },\n lifecycle: {\n hooks: {\n preIteration: true,\n postIteration: true,\n onStateChange: true,\n onError: true,\n onComplete: true,\n },\n checkpoints: {\n enabled: true,\n frequency: 5,\n retentionDays: 7,\n },\n ...config?.lifecycle,\n },\n performance: {\n asyncSaves: true,\n batchSize: 10,\n compressionLevel: 2,\n cacheEnabled: true,\n parallelOperations: true,\n ...config?.performance,\n },\n };\n }\n\n /**\n * Setup lifecycle hooks\n */\n private setupLifecycleHooks(options?: BridgeOptions): void {\n const hooks: LifecycleHooks = {\n preIteration: async (context) => {\n logger.debug('Pre-iteration hook', {\n iteration: context.task.currentIteration,\n });\n return context;\n },\n postIteration: async (iteration) => {\n // Save to StackMemory\n await this.saveIterationFrame(iteration);\n },\n onStateChange: async (oldState, newState) => {\n // Update StackMemory with state change\n await this.updateStateFrame(oldState, newState);\n },\n onError: async (error, context) => {\n logger.error('Iteration error', { error: error.message, context });\n // Save error frame\n await this.saveErrorFrame(error, context);\n },\n onComplete: async (state) => {\n // Close root frame\n await this.closeRootFrame(state);\n },\n };\n\n const lifecycle = new IterationLifecycle(this.config.lifecycle, hooks);\n (this.state as any).lifecycle = lifecycle;\n }\n\n /**\n * Get lifecycle instance\n */\n private getLifecycle(): IterationLifecycle {\n return (this.state as any).lifecycle;\n }\n\n /**\n * Initialize Ralph directory structure\n */\n private async initializeRalphDirectory(state: RalphLoopState): Promise<void> {\n await fs.mkdir(this.ralphDir, { recursive: true });\n await fs.mkdir(path.join(this.ralphDir, 'history'), { recursive: true });\n\n // Write initial files\n await fs.writeFile(path.join(this.ralphDir, 'task.md'), state.task);\n await fs.writeFile(\n path.join(this.ralphDir, 'completion-criteria.md'),\n state.criteria\n );\n await fs.writeFile(path.join(this.ralphDir, 'iteration.txt'), '0');\n await fs.writeFile(path.join(this.ralphDir, 'feedback.txt'), '');\n await fs.writeFile(\n path.join(this.ralphDir, 'state.json'),\n JSON.stringify(state, null, 2)\n );\n }\n\n /**\n * Create root frame for Ralph loop\n */\n private async createRootFrame(state: RalphLoopState): Promise<Frame> {\n if (!this.requiresDatabase) {\n // Return a mock frame when database is not required\n return {\n frame_id: `mock-${state.loopId}`,\n type: 'task' as FrameType,\n name: `ralph-${state.loopId}`,\n inputs: {\n task: state.task,\n criteria: state.criteria,\n loopId: state.loopId,\n },\n created_at: Date.now(),\n } as Frame;\n }\n\n if (!this.frameManager) {\n throw new Error('Frame manager not initialized');\n }\n\n const frame: Partial<Frame> = {\n type: 'task' as FrameType,\n name: `ralph-${state.loopId}`,\n inputs: {\n task: state.task,\n criteria: state.criteria,\n loopId: state.loopId,\n },\n digest_json: {\n type: 'ralph_loop',\n status: 'started',\n },\n };\n\n return await this.frameManager.createFrame({\n name: frame.name,\n type: frame.type,\n content: frame.content || '',\n metadata: frame.metadata\n });\n }\n\n /**\n * Load iteration context from StackMemory\n */\n private async loadIterationContext(\n state: RalphLoopState\n ): Promise<IterationContext> {\n const frames = await this.loadRelevantFrames(state.loopId);\n\n return {\n task: {\n description: state.task,\n criteria: state.criteria.split('\\n').filter(Boolean),\n currentIteration: state.iteration,\n feedback: state.feedback,\n priority: 'medium',\n },\n history: {\n recentIterations: await this.loadRecentIterations(state.loopId),\n gitCommits: await this.loadGitCommits(),\n changedFiles: await this.loadChangedFiles(),\n testResults: [],\n },\n environment: {\n projectPath: process.cwd(),\n branch: await this.getCurrentBranch(),\n dependencies: {},\n configuration: {},\n },\n memory: {\n relevantFrames: frames,\n decisions: [],\n patterns: [],\n blockers: [],\n },\n tokenCount: 0,\n };\n }\n\n /**\n * Execute worker iteration\n */\n private async executeWorkerIteration(\n context: IterationContext\n ): Promise<RalphIteration> {\n const iterationNumber = context.task.currentIteration + 1;\n\n try {\n // Analyze current codebase state\n const analysis = await this.analyzeCodebaseState();\n\n // Generate iteration plan based on context and analysis\n const plan = await this.generateIterationPlan(context, analysis);\n\n // Execute the planned changes\n const changes = await this.executeIterationChanges(plan, context);\n\n // Validate the changes\n const validation = await this.validateIterationResults(changes);\n\n logger.info('Iteration execution completed', {\n iteration: iterationNumber,\n changesCount: changes.length,\n testsPass: validation.testsPass,\n });\n\n return {\n number: iterationNumber,\n timestamp: Date.now(),\n analysis,\n plan,\n changes,\n validation,\n };\n } catch (error: unknown) {\n logger.error('Iteration execution failed', error as Error);\n\n // Return a minimal iteration with error state\n return {\n number: iterationNumber,\n timestamp: Date.now(),\n analysis: {\n filesCount: 0,\n testsPass: false,\n testsFail: 1,\n lastChange: `Error: ${(error as Error).message}`,\n },\n plan: {\n summary: 'Iteration failed due to error',\n steps: ['Investigate error', 'Fix underlying issue'],\n priority: 'high',\n },\n changes: [],\n validation: {\n testsPass: false,\n lintClean: false,\n buildSuccess: false,\n errors: [(error as Error).message],\n warnings: [],\n },\n };\n }\n }\n\n /**\n * Analyze current codebase state\n */\n private async analyzeCodebaseState(): Promise<any> {\n try {\n const stats = {\n filesCount: 0,\n testsPass: true,\n testsFail: 0,\n lastChange: 'No recent changes',\n };\n\n // Count files in the project (excluding node_modules, .git, etc.)\n try {\n const { execSync } = await import('child_process');\n const output = execSync(\n 'find . -type f -name \"*.ts\" -o -name \"*.js\" -o -name \"*.json\" | grep -v node_modules | grep -v .git | wc -l',\n { encoding: 'utf8', cwd: process.cwd() }\n );\n stats.filesCount = parseInt(output.trim()) || 0;\n } catch {\n stats.filesCount = 0;\n }\n\n // Check git status for recent changes\n try {\n const { execSync } = await import('child_process');\n const gitLog = execSync('git log -1 --oneline', {\n encoding: 'utf8',\n cwd: process.cwd(),\n });\n stats.lastChange = gitLog.trim() || 'No git history';\n } catch {\n stats.lastChange = 'No git repository';\n }\n\n // Run basic tests if available\n try {\n const { existsSync } = await import('fs');\n if (existsSync('package.json')) {\n const packageJson = JSON.parse(\n await fs.readFile('package.json', 'utf8')\n );\n if (packageJson.scripts?.test) {\n const { execSync } = await import('child_process');\n execSync('npm test', { stdio: 'pipe', timeout: 30000 });\n stats.testsPass = true;\n stats.testsFail = 0;\n }\n }\n } catch {\n stats.testsPass = false;\n stats.testsFail = 1;\n }\n\n return stats;\n } catch (error: unknown) {\n return {\n filesCount: 0,\n testsPass: false,\n testsFail: 1,\n lastChange: `Analysis failed: ${(error as Error).message}`,\n };\n }\n }\n\n /**\n * Generate iteration plan based on context and analysis\n */\n private async generateIterationPlan(\n context: IterationContext,\n analysis: any\n ): Promise<any> {\n // Extract task information\n const task = context.task.task || 'Complete assigned work';\n const criteria = context.task.criteria || 'Meet completion criteria';\n\n // Generate basic plan based on analysis\n const steps = [];\n\n if (!analysis.testsPass) {\n steps.push('Fix failing tests');\n }\n\n if (analysis.filesCount === 0) {\n steps.push('Initialize project structure');\n }\n\n // Add task-specific steps\n if (task.toLowerCase().includes('implement')) {\n steps.push('Implement required functionality');\n steps.push('Add appropriate tests');\n } else if (task.toLowerCase().includes('fix')) {\n steps.push('Identify root cause');\n steps.push('Implement fix');\n steps.push('Verify fix works');\n } else {\n steps.push('Analyze requirements');\n steps.push('Plan implementation approach');\n steps.push('Execute planned work');\n }\n\n steps.push('Validate changes');\n\n return {\n summary: `Iteration plan for: ${task}`,\n steps,\n priority: analysis.testsPass ? 'medium' : 'high',\n };\n }\n\n /**\n * Execute planned changes\n */\n private async executeIterationChanges(\n plan: any,\n context: IterationContext\n ): Promise<any[]> {\n const changes = [];\n\n // This would integrate with actual Ralph implementation\n // For now, we'll simulate basic changes based on the plan\n\n for (let i = 0; i < plan.steps.length; i++) {\n const step = plan.steps[i];\n\n changes.push({\n type: 'step_execution',\n description: step,\n timestamp: Date.now(),\n files_affected: [],\n success: true,\n });\n\n // Small delay to simulate work\n await new Promise((resolve) => setTimeout(resolve, 100));\n }\n\n logger.debug('Executed iteration changes', {\n stepsCount: plan.steps.length,\n changesCount: changes.length,\n });\n\n return changes;\n }\n\n /**\n * Validate iteration results\n */\n private async validateIterationResults(changes: any[]): Promise<any> {\n const validation = {\n testsPass: true,\n lintClean: true,\n buildSuccess: true,\n errors: [],\n warnings: [],\n };\n\n // Run validation checks if available\n try {\n const { existsSync } = await import('fs');\n\n // Check if linting is available\n if (existsSync('package.json')) {\n const packageJson = JSON.parse(\n await fs.readFile('package.json', 'utf8')\n );\n\n if (packageJson.scripts?.lint) {\n try {\n const { execSync } = await import('child_process');\n execSync('npm run lint', { stdio: 'pipe', timeout: 30000 });\n validation.lintClean = true;\n } catch (error: any) {\n validation.lintClean = false;\n validation.warnings.push('Lint warnings detected');\n }\n }\n\n if (packageJson.scripts?.build) {\n try {\n const { execSync } = await import('child_process');\n execSync('npm run build', { stdio: 'pipe', timeout: 60000 });\n validation.buildSuccess = true;\n } catch (error: any) {\n validation.buildSuccess = false;\n validation.errors.push('Build failed');\n }\n }\n }\n } catch (error: unknown) {\n validation.errors.push(`Validation error: ${(error as Error).message}`);\n }\n\n return validation;\n }\n\n /**\n * Save iteration results\n */\n private async saveIterationResults(iteration: RalphIteration): Promise<void> {\n // Save with performance optimization\n await this.state.performanceOptimizer!.saveIteration(iteration);\n\n // Save iteration artifacts to Ralph directory\n const iterDir = path.join(\n this.ralphDir,\n 'history',\n `iteration-${String(iteration.number).padStart(3, '0')}`\n );\n\n await fs.mkdir(iterDir, { recursive: true });\n await fs.writeFile(\n path.join(iterDir, 'artifacts.json'),\n JSON.stringify(iteration, null, 2)\n );\n }\n\n /**\n * Save iteration frame to StackMemory\n */\n private async saveIterationFrame(iteration: RalphIteration): Promise<void> {\n if (!this.requiresDatabase || !this.frameManager || !this.state.activeLoop)\n return;\n\n const frame: Partial<Frame> = {\n type: 'subtask' as FrameType,\n name: `iteration-${iteration.number}`,\n inputs: {\n iterationNumber: iteration.number,\n loopId: this.state.activeLoop.loopId,\n },\n outputs: {\n changes: iteration.changes.length,\n success: iteration.validation.testsPass,\n },\n digest_json: iteration,\n };\n\n await this.state.performanceOptimizer!.saveFrame(frame as Frame);\n }\n\n /**\n * Get database adapter for FrameManager\n */\n private async getDatabaseAdapter(): Promise<SQLiteAdapter> {\n const dbPath = path.join(this.ralphDir, 'stackmemory.db');\n const projectId = path.basename(this.ralphDir);\n return new SQLiteAdapter(projectId, { dbPath });\n }\n\n /**\n * Additional helper methods\n */\n private async getCurrentGitCommit(): Promise<string> {\n try {\n // execSync already imported at top\n return execSync('git rev-parse HEAD', { encoding: 'utf8' }).trim();\n } catch {\n return '';\n }\n }\n\n private async getCurrentBranch(): Promise<string> {\n try {\n // execSync already imported at top\n return execSync('git branch --show-current', { encoding: 'utf8' }).trim();\n } catch {\n return 'main';\n }\n }\n\n private async saveLoopState(state: RalphLoopState): Promise<void> {\n // Save state.json\n await fs.writeFile(\n path.join(this.ralphDir, 'state.json'),\n JSON.stringify(state, null, 2)\n );\n\n // Synchronize iteration.txt with current iteration\n await fs.writeFile(\n path.join(this.ralphDir, 'iteration.txt'),\n state.iteration.toString()\n );\n\n logger.debug('Saved loop state', {\n iteration: state.iteration,\n status: state.status,\n });\n }\n\n private async gatherStateSources(loopId: string): Promise<StateSource[]> {\n const sources: StateSource[] = [];\n\n // Get git state\n sources.push(await this.state.stateReconciler!.getGitState());\n\n // Get file state\n sources.push(await this.state.stateReconciler!.getFileState());\n\n // Get memory state\n sources.push(await this.state.stateReconciler!.getMemoryState(loopId));\n\n return sources;\n }\n\n private async attemptRecovery(): Promise<void> {\n logger.info('Attempting crash recovery');\n\n try {\n // Check for incomplete loops in file system\n const stateFile = path.join(this.ralphDir, 'state.json');\n const exists = await fs\n .stat(stateFile)\n .then(() => true)\n .catch(() => false);\n\n if (exists) {\n const stateData = await fs.readFile(stateFile, 'utf8');\n const state = JSON.parse(stateData) as RalphLoopState;\n\n if (state.status !== 'completed') {\n logger.info('Found incomplete loop', { loopId: state.loopId });\n await this.resumeLoop(state.loopId);\n }\n }\n } catch (error: any) {\n logger.error('Recovery failed', { error: error.message });\n }\n }\n\n private async evaluateCompletion(): Promise<any> {\n // This would evaluate completion criteria\n // Placeholder implementation\n return {\n complete: false,\n criteria: {},\n unmet: ['criteria1', 'criteria2'],\n };\n }\n\n private generateFeedback(evaluation: any): string {\n if (evaluation.unmet.length === 0) {\n return 'All criteria met';\n }\n return `Still need to address:\\n${evaluation.unmet.map((c: string) => `- ${c}`).join('\\n')}`;\n }\n\n private async loadRelevantFrames(loopId: string): Promise<Frame[]> {\n // This would load frames from StackMemory\n // Placeholder implementation\n return [];\n }\n\n private async loadRecentIterations(loopId: string): Promise<any[]> {\n // Load recent iteration summaries\n return [];\n }\n\n private async loadGitCommits(): Promise<any[]> {\n // Load recent git commits\n return [];\n }\n\n private async loadChangedFiles(): Promise<string[]> {\n // Load recently changed files\n return [];\n }\n\n private async loadSessionFrames(sessionId: string): Promise<Frame[]> {\n // Load frames from session\n return [];\n }\n\n private async reconstructLoopState(frame: Frame): Promise<RalphLoopState> {\n // Reconstruct loop state from frame\n return {\n loopId: frame.inputs.loopId || '',\n task: frame.inputs.task || '',\n criteria: frame.inputs.criteria || '',\n iteration: 0,\n status: 'running',\n startTime: frame.created_at,\n lastUpdateTime: Date.now(),\n };\n }\n\n private async buildContextFromFrames(\n frames: Frame[],\n state: RalphLoopState\n ): Promise<IterationContext> {\n // Build context from frames\n return await this.loadIterationContext(state);\n }\n\n private async updateStateFrame(\n oldState: RalphLoopState,\n newState: RalphLoopState\n ): Promise<void> {\n // Update state in StackMemory\n logger.debug('State frame updated');\n }\n\n private async saveErrorFrame(error: Error, context: any): Promise<void> {\n // Save error as frame\n logger.debug('Error frame saved');\n }\n\n private async closeRootFrame(state: RalphLoopState): Promise<void> {\n // Close the root frame\n logger.debug('Root frame closed');\n }\n}\n"],
4
+ "sourcesContent": ["/**\n * Ralph-StackMemory Bridge\n * Main integration point connecting Ralph Wiggum loops with StackMemory persistence\n */\n\nimport { v4 as uuidv4 } from 'uuid';\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\nimport { execSync } from 'child_process';\nimport { logger } from '../../../core/monitoring/logger.js';\nimport { FrameManager } from '../../../core/context/index.js';\nimport { SessionManager } from '../../../core/session/session-manager.js';\nimport { SQLiteAdapter } from '../../../core/database/sqlite-adapter.js';\nimport { ContextBudgetManager } from '../context/context-budget-manager.js';\nimport { StateReconciler } from '../state/state-reconciler.js';\nimport {\n IterationLifecycle,\n LifecycleHooks,\n} from '../lifecycle/iteration-lifecycle.js';\nimport { PerformanceOptimizer } from '../performance/performance-optimizer.js';\nimport {\n RalphLoopState,\n RalphIteration,\n BridgeState,\n BridgeOptions,\n RalphStackMemoryConfig,\n IterationContext,\n Frame,\n FrameType,\n RecoveryState,\n Checkpoint,\n StateSource,\n} from '../types.js';\n\nexport class RalphStackMemoryBridge {\n private state: BridgeState;\n private config: RalphStackMemoryConfig;\n private frameManager?: FrameManager;\n private sessionManager: SessionManager;\n private recoveryState?: RecoveryState;\n private readonly ralphDir = '.ralph';\n private readonly requiresDatabase: boolean;\n\n constructor(options?: BridgeOptions & { useStackMemory?: boolean }) {\n // Initialize configuration\n this.config = this.mergeConfig(options?.config);\n\n // Check if database/StackMemory features are required\n this.requiresDatabase = options?.useStackMemory !== false;\n\n // Initialize managers\n this.state = {\n initialized: false,\n contextManager: new ContextBudgetManager(this.config.contextBudget),\n stateReconciler: new StateReconciler(this.config.stateReconciliation),\n performanceOptimizer: new PerformanceOptimizer(this.config.performance),\n };\n\n this.sessionManager = SessionManager.getInstance();\n\n // Setup lifecycle hooks\n this.setupLifecycleHooks(options);\n\n logger.info('Ralph-StackMemory Bridge initialized', {\n config: {\n maxTokens: this.config.contextBudget.maxTokens,\n asyncSaves: this.config.performance.asyncSaves,\n checkpoints: this.config.lifecycle.checkpoints.enabled,\n },\n });\n }\n\n /**\n * Initialize bridge with session\n */\n async initialize(options?: {\n sessionId?: string;\n loopId?: string;\n task?: string;\n criteria?: string;\n }): Promise<void> {\n logger.info('Initializing bridge', options);\n\n try {\n // Initialize session manager\n await this.sessionManager.initialize();\n\n // Get or create session\n const session = await this.sessionManager.getOrCreateSession({\n sessionId: options?.sessionId,\n });\n\n this.state.currentSession = session;\n\n // Initialize frame manager with database\n const dbAdapter = await this.getDatabaseAdapter();\n await dbAdapter.connect();\n const db = (dbAdapter as any).db; // Get the actual Database instance\n const projectId = path.basename(this.ralphDir);\n this.frameManager = new FrameManager(db, projectId, { skipContextBridge: true });\n // Initialize frame manager with session database if required\n if (this.requiresDatabase) {\n if (session.database && session.projectId) {\n this.frameManager = new FrameManager(\n session.database,\n session.projectId,\n {\n skipContextBridge: true,\n }\n );\n } else {\n throw new Error(\n 'Session database not available for FrameManager initialization. ' +\n 'If StackMemory features are not needed, set useStackMemory: false in options'\n );\n }\n } else {\n // Database not required, skip frame manager initialization\n logger.info(\n 'Running without StackMemory database (useStackMemory: false)'\n );\n }\n\n // Check for existing loop or create new\n if (options?.loopId) {\n await this.resumeLoop(options.loopId);\n } else if (options?.task && options?.criteria) {\n await this.createNewLoop(options.task, options.criteria);\n } else {\n // Try to recover from crash\n await this.attemptRecovery();\n }\n\n this.state.initialized = true;\n logger.info('Bridge initialized successfully');\n } catch (error: any) {\n logger.error('Bridge initialization failed', { error: error.message });\n throw error;\n }\n }\n\n /**\n * Create new Ralph loop with StackMemory integration\n */\n async createNewLoop(task: string, criteria: string): Promise<RalphLoopState> {\n logger.info('Creating new Ralph loop', { task: task.substring(0, 100) });\n\n const loopId = uuidv4();\n const startTime = Date.now();\n\n // Create Ralph loop state\n const loopState: RalphLoopState = {\n loopId,\n task,\n criteria,\n iteration: 0,\n status: 'initialized',\n startTime,\n lastUpdateTime: startTime,\n startCommit: await this.getCurrentGitCommit(),\n };\n\n // Initialize Ralph directory structure\n await this.initializeRalphDirectory(loopState);\n\n // Create root frame in StackMemory\n const rootFrame = await this.createRootFrame(loopState);\n\n // Save initial state\n await this.saveLoopState(loopState);\n\n this.state.activeLoop = loopState;\n\n logger.info('Ralph loop created', {\n loopId,\n frameId: rootFrame.frame_id,\n });\n\n return loopState;\n }\n\n /**\n * Resume existing loop\n */\n async resumeLoop(loopId: string): Promise<RalphLoopState> {\n logger.info('Resuming loop', { loopId });\n\n // Get state from all sources\n const sources = await this.gatherStateSources(loopId);\n\n // Reconcile state\n const reconciledState =\n await this.state.stateReconciler!.reconcile(sources);\n\n // Validate consistency\n if (this.config.stateReconciliation.validateConsistency) {\n const validation =\n await this.state.stateReconciler!.validateConsistency(reconciledState);\n\n if (validation.errors.length > 0) {\n logger.error('State validation failed', { errors: validation.errors });\n throw new Error(`Invalid state: ${validation.errors.join(', ')}`);\n }\n }\n\n this.state.activeLoop = reconciledState;\n\n // Load context from StackMemory\n const context = await this.loadIterationContext(reconciledState);\n\n logger.info('Loop resumed', {\n loopId,\n iteration: reconciledState.iteration,\n status: reconciledState.status,\n });\n\n return reconciledState;\n }\n\n /**\n * Run worker iteration\n */\n async runWorkerIteration(): Promise<RalphIteration> {\n if (!this.state.activeLoop) {\n throw new Error('No active loop');\n }\n\n const iterationNumber = this.state.activeLoop.iteration + 1;\n logger.info('Starting worker iteration', { iteration: iterationNumber });\n\n // Load and prepare context\n let context = await this.loadIterationContext(this.state.activeLoop);\n\n // Apply context budget management\n context = this.state.contextManager!.allocateBudget(context);\n\n if (this.config.contextBudget.compressionEnabled) {\n context = this.state.contextManager!.compressContext(context);\n }\n\n // Start iteration with lifecycle\n const lifecycle = this.getLifecycle();\n context = await lifecycle.startIteration(iterationNumber, context);\n\n // Execute iteration work\n const iteration = await this.executeWorkerIteration(context);\n\n // Save iteration results\n await this.saveIterationResults(iteration);\n\n // Complete iteration with lifecycle\n await lifecycle.completeIteration(iteration);\n\n // Update loop state\n this.state.activeLoop.iteration = iterationNumber;\n this.state.activeLoop.lastUpdateTime = Date.now();\n await this.saveLoopState(this.state.activeLoop);\n\n logger.info('Worker iteration completed', {\n iteration: iterationNumber,\n changes: iteration.changes.length,\n success: iteration.validation.testsPass,\n });\n\n return iteration;\n }\n\n /**\n * Run reviewer iteration\n */\n async runReviewerIteration(): Promise<{\n complete: boolean;\n feedback?: string;\n }> {\n if (!this.state.activeLoop) {\n throw new Error('No active loop');\n }\n\n logger.info('Starting reviewer iteration', {\n iteration: this.state.activeLoop.iteration,\n });\n\n // Evaluate against criteria\n const evaluation = await this.evaluateCompletion();\n\n if (evaluation.complete) {\n // Mark as complete\n this.state.activeLoop.status = 'completed';\n this.state.activeLoop.completionData = evaluation;\n await this.saveLoopState(this.state.activeLoop);\n\n // Handle completion\n const lifecycle = this.getLifecycle();\n await lifecycle.handleCompletion(this.state.activeLoop);\n\n logger.info('Task completed successfully');\n return { complete: true };\n }\n\n // Generate feedback for next iteration\n const feedback = this.generateFeedback(evaluation);\n this.state.activeLoop.feedback = feedback;\n\n await this.saveLoopState(this.state.activeLoop);\n\n logger.info('Reviewer iteration completed', {\n complete: false,\n feedbackLength: feedback.length,\n });\n\n return { complete: false, feedback };\n }\n\n /**\n * Rehydrate session from StackMemory\n */\n async rehydrateSession(sessionId: string): Promise<IterationContext> {\n logger.info('Rehydrating session', { sessionId });\n\n // Get session from StackMemory\n const session = await this.sessionManager.getSession(sessionId);\n\n if (!session) {\n throw new Error(`Session not found: ${sessionId}`);\n }\n\n // Load frames from session\n const frames = await this.loadSessionFrames(sessionId);\n\n // Extract Ralph loop information\n const ralphFrames = frames.filter(\n (f) => f.type === 'task' && f.name.startsWith('ralph-')\n );\n\n if (ralphFrames.length === 0) {\n throw new Error('No Ralph loops found in session');\n }\n\n // Get most recent Ralph loop\n const latestLoop = ralphFrames[ralphFrames.length - 1];\n\n // Reconstruct loop state\n const loopState = await this.reconstructLoopState(latestLoop);\n\n // Build context from frames\n const context = await this.buildContextFromFrames(frames, loopState);\n\n this.state.activeLoop = loopState;\n\n logger.info('Session rehydrated', {\n loopId: loopState.loopId,\n iteration: loopState.iteration,\n frameCount: frames.length,\n });\n\n return context;\n }\n\n /**\n * Create checkpoint\n */\n async createCheckpoint(): Promise<Checkpoint> {\n if (!this.state.activeLoop) {\n throw new Error('No active loop');\n }\n\n const lifecycle = this.getLifecycle();\n\n // Create dummy iteration for checkpoint\n const iteration: RalphIteration = {\n number: this.state.activeLoop.iteration,\n timestamp: Date.now(),\n analysis: {\n filesCount: 0,\n testsPass: true,\n testsFail: 0,\n lastChange: await this.getCurrentGitCommit(),\n },\n plan: {\n summary: 'Checkpoint',\n steps: [],\n priority: 'low',\n },\n changes: [],\n validation: {\n testsPass: true,\n lintClean: true,\n buildSuccess: true,\n errors: [],\n warnings: [],\n },\n };\n\n const checkpoint = await lifecycle.createCheckpoint(iteration);\n\n logger.info('Checkpoint created', {\n id: checkpoint.id,\n iteration: checkpoint.iteration,\n });\n\n return checkpoint;\n }\n\n /**\n * Restore from checkpoint\n */\n async restoreFromCheckpoint(checkpointId: string): Promise<void> {\n const lifecycle = this.getLifecycle();\n await lifecycle.restoreFromCheckpoint(checkpointId);\n\n // Reload loop state\n const sources = await this.gatherStateSources(\n this.state.activeLoop?.loopId || ''\n );\n const reconciledState =\n await this.state.stateReconciler!.reconcile(sources);\n\n this.state.activeLoop = reconciledState;\n\n logger.info('Restored from checkpoint', {\n checkpointId,\n iteration: reconciledState.iteration,\n });\n }\n\n /**\n * Get performance metrics\n */\n getPerformanceMetrics() {\n return this.state.performanceOptimizer!.getMetrics();\n }\n\n /**\n * Start a new Ralph loop\n */\n async startLoop(options: {\n task: string;\n criteria: string;\n }): Promise<string> {\n const state = await this.createNewLoop(options.task, options.criteria);\n return state.loopId;\n }\n\n /**\n * Stop the active loop\n */\n async stopLoop(): Promise<void> {\n if (!this.state.activeLoop) {\n logger.warn('No active loop to stop');\n return;\n }\n\n this.state.activeLoop.status = 'completed';\n this.state.activeLoop.lastUpdateTime = Date.now();\n await this.saveLoopState(this.state.activeLoop);\n\n // Handle completion lifecycle\n const lifecycle = this.getLifecycle();\n await lifecycle.handleCompletion(this.state.activeLoop);\n\n logger.info('Ralph loop stopped', { loopId: this.state.activeLoop.loopId });\n this.state.activeLoop = undefined;\n }\n\n /**\n * Cleanup resources\n */\n async cleanup(): Promise<void> {\n logger.info('Cleaning up bridge resources');\n\n // Flush any pending saves\n await this.state.performanceOptimizer!.flushBatch();\n\n // Clean up lifecycle\n this.getLifecycle().cleanup();\n\n // Clean up optimizer\n this.state.performanceOptimizer!.cleanup();\n\n logger.info('Bridge cleanup completed');\n }\n\n /**\n * Merge configuration with defaults\n */\n private mergeConfig(\n config?: Partial<RalphStackMemoryConfig>\n ): RalphStackMemoryConfig {\n return {\n contextBudget: {\n maxTokens: 4000,\n priorityWeights: {\n task: 0.3,\n recentWork: 0.25,\n feedback: 0.2,\n gitHistory: 0.15,\n dependencies: 0.1,\n },\n compressionEnabled: true,\n adaptiveBudgeting: true,\n ...config?.contextBudget,\n },\n stateReconciliation: {\n precedence: ['git', 'files', 'memory'],\n conflictResolution: 'automatic',\n syncInterval: 5000,\n validateConsistency: true,\n ...config?.stateReconciliation,\n },\n lifecycle: {\n hooks: {\n preIteration: true,\n postIteration: true,\n onStateChange: true,\n onError: true,\n onComplete: true,\n },\n checkpoints: {\n enabled: true,\n frequency: 5,\n retentionDays: 7,\n },\n ...config?.lifecycle,\n },\n performance: {\n asyncSaves: true,\n batchSize: 10,\n compressionLevel: 2,\n cacheEnabled: true,\n parallelOperations: true,\n ...config?.performance,\n },\n };\n }\n\n /**\n * Setup lifecycle hooks\n */\n private setupLifecycleHooks(options?: BridgeOptions): void {\n const hooks: LifecycleHooks = {\n preIteration: async (context) => {\n logger.debug('Pre-iteration hook', {\n iteration: context.task.currentIteration,\n });\n return context;\n },\n postIteration: async (iteration) => {\n // Save to StackMemory\n await this.saveIterationFrame(iteration);\n },\n onStateChange: async (oldState, newState) => {\n // Update StackMemory with state change\n await this.updateStateFrame(oldState, newState);\n },\n onError: async (error, context) => {\n logger.error('Iteration error', { error: error.message, context });\n // Save error frame\n await this.saveErrorFrame(error, context);\n },\n onComplete: async (state) => {\n // Close root frame\n await this.closeRootFrame(state);\n },\n };\n\n const lifecycle = new IterationLifecycle(this.config.lifecycle, hooks);\n (this.state as any).lifecycle = lifecycle;\n }\n\n /**\n * Get lifecycle instance\n */\n private getLifecycle(): IterationLifecycle {\n return (this.state as any).lifecycle;\n }\n\n /**\n * Initialize Ralph directory structure\n */\n private async initializeRalphDirectory(state: RalphLoopState): Promise<void> {\n await fs.mkdir(this.ralphDir, { recursive: true });\n await fs.mkdir(path.join(this.ralphDir, 'history'), { recursive: true });\n\n // Write initial files\n await fs.writeFile(path.join(this.ralphDir, 'task.md'), state.task);\n await fs.writeFile(\n path.join(this.ralphDir, 'completion-criteria.md'),\n state.criteria\n );\n await fs.writeFile(path.join(this.ralphDir, 'iteration.txt'), '0');\n await fs.writeFile(path.join(this.ralphDir, 'feedback.txt'), '');\n await fs.writeFile(\n path.join(this.ralphDir, 'state.json'),\n JSON.stringify(state, null, 2)\n );\n }\n\n /**\n * Create root frame for Ralph loop\n */\n private async createRootFrame(state: RalphLoopState): Promise<Frame> {\n if (!this.requiresDatabase) {\n // Return a mock frame when database is not required\n return {\n frame_id: `mock-${state.loopId}`,\n type: 'task' as FrameType,\n name: `ralph-${state.loopId}`,\n inputs: {\n task: state.task,\n criteria: state.criteria,\n loopId: state.loopId,\n },\n created_at: Date.now(),\n } as Frame;\n }\n\n if (!this.frameManager) {\n throw new Error('Frame manager not initialized');\n }\n\n const frame: Partial<Frame> = {\n type: 'task' as FrameType,\n name: `ralph-${state.loopId}`,\n inputs: {\n task: state.task,\n criteria: state.criteria,\n loopId: state.loopId,\n },\n digest_json: {\n type: 'ralph_loop',\n status: 'started',\n },\n };\n\n return await this.frameManager.createFrame({\n name: frame.name,\n type: frame.type,\n content: frame.content || '',\n metadata: frame.metadata\n });\n }\n\n /**\n * Load iteration context from StackMemory\n */\n private async loadIterationContext(\n state: RalphLoopState\n ): Promise<IterationContext> {\n const frames = await this.loadRelevantFrames(state.loopId);\n\n return {\n task: {\n description: state.task,\n criteria: state.criteria.split('\\n').filter(Boolean),\n currentIteration: state.iteration,\n feedback: state.feedback,\n priority: 'medium',\n },\n history: {\n recentIterations: await this.loadRecentIterations(state.loopId),\n gitCommits: await this.loadGitCommits(),\n changedFiles: await this.loadChangedFiles(),\n testResults: [],\n },\n environment: {\n projectPath: process.cwd(),\n branch: await this.getCurrentBranch(),\n dependencies: {},\n configuration: {},\n },\n memory: {\n relevantFrames: frames,\n decisions: [],\n patterns: [],\n blockers: [],\n },\n tokenCount: 0,\n };\n }\n\n /**\n * Execute worker iteration\n */\n private async executeWorkerIteration(\n context: IterationContext\n ): Promise<RalphIteration> {\n const iterationNumber = context.task.currentIteration + 1;\n\n try {\n // Analyze current codebase state\n const analysis = await this.analyzeCodebaseState();\n\n // Generate iteration plan based on context and analysis\n const plan = await this.generateIterationPlan(context, analysis);\n\n // Execute the planned changes\n const changes = await this.executeIterationChanges(plan, context);\n\n // Validate the changes\n const validation = await this.validateIterationResults(changes);\n\n logger.info('Iteration execution completed', {\n iteration: iterationNumber,\n changesCount: changes.length,\n testsPass: validation.testsPass,\n });\n\n return {\n number: iterationNumber,\n timestamp: Date.now(),\n analysis,\n plan,\n changes,\n validation,\n };\n } catch (error: unknown) {\n logger.error('Iteration execution failed', error as Error);\n\n // Return a minimal iteration with error state\n return {\n number: iterationNumber,\n timestamp: Date.now(),\n analysis: {\n filesCount: 0,\n testsPass: false,\n testsFail: 1,\n lastChange: `Error: ${(error as Error).message}`,\n },\n plan: {\n summary: 'Iteration failed due to error',\n steps: ['Investigate error', 'Fix underlying issue'],\n priority: 'high',\n },\n changes: [],\n validation: {\n testsPass: false,\n lintClean: false,\n buildSuccess: false,\n errors: [(error as Error).message],\n warnings: [],\n },\n };\n }\n }\n\n /**\n * Analyze current codebase state\n */\n private async analyzeCodebaseState(): Promise<any> {\n try {\n const stats = {\n filesCount: 0,\n testsPass: true,\n testsFail: 0,\n lastChange: 'No recent changes',\n };\n\n // Count files in the project (excluding node_modules, .git, etc.)\n try {\n const { execSync } = await import('child_process');\n const output = execSync(\n 'find . -type f -name \"*.ts\" -o -name \"*.js\" -o -name \"*.json\" | grep -v node_modules | grep -v .git | wc -l',\n { encoding: 'utf8', cwd: process.cwd() }\n );\n stats.filesCount = parseInt(output.trim()) || 0;\n } catch {\n stats.filesCount = 0;\n }\n\n // Check git status for recent changes\n try {\n const { execSync } = await import('child_process');\n const gitLog = execSync('git log -1 --oneline', {\n encoding: 'utf8',\n cwd: process.cwd(),\n });\n stats.lastChange = gitLog.trim() || 'No git history';\n } catch {\n stats.lastChange = 'No git repository';\n }\n\n // Run basic tests if available\n try {\n const { existsSync } = await import('fs');\n if (existsSync('package.json')) {\n const packageJson = JSON.parse(\n await fs.readFile('package.json', 'utf8')\n );\n if (packageJson.scripts?.test) {\n const { execSync } = await import('child_process');\n execSync('npm test', { stdio: 'pipe', timeout: 30000 });\n stats.testsPass = true;\n stats.testsFail = 0;\n }\n }\n } catch {\n stats.testsPass = false;\n stats.testsFail = 1;\n }\n\n return stats;\n } catch (error: unknown) {\n return {\n filesCount: 0,\n testsPass: false,\n testsFail: 1,\n lastChange: `Analysis failed: ${(error as Error).message}`,\n };\n }\n }\n\n /**\n * Generate iteration plan based on context and analysis\n */\n private async generateIterationPlan(\n context: IterationContext,\n analysis: any\n ): Promise<any> {\n // Extract task information\n const task = context.task.task || 'Complete assigned work';\n const criteria = context.task.criteria || 'Meet completion criteria';\n\n // Generate basic plan based on analysis\n const steps = [];\n\n if (!analysis.testsPass) {\n steps.push('Fix failing tests');\n }\n\n if (analysis.filesCount === 0) {\n steps.push('Initialize project structure');\n }\n\n // Add task-specific steps\n if (task.toLowerCase().includes('implement')) {\n steps.push('Implement required functionality');\n steps.push('Add appropriate tests');\n } else if (task.toLowerCase().includes('fix')) {\n steps.push('Identify root cause');\n steps.push('Implement fix');\n steps.push('Verify fix works');\n } else {\n steps.push('Analyze requirements');\n steps.push('Plan implementation approach');\n steps.push('Execute planned work');\n }\n\n steps.push('Validate changes');\n\n return {\n summary: `Iteration plan for: ${task}`,\n steps,\n priority: analysis.testsPass ? 'medium' : 'high',\n };\n }\n\n /**\n * Execute planned changes\n */\n private async executeIterationChanges(\n plan: any,\n context: IterationContext\n ): Promise<any[]> {\n const changes = [];\n\n // This would integrate with actual Ralph implementation\n // For now, we'll simulate basic changes based on the plan\n\n for (let i = 0; i < plan.steps.length; i++) {\n const step = plan.steps[i];\n\n changes.push({\n type: 'step_execution',\n description: step,\n timestamp: Date.now(),\n files_affected: [],\n success: true,\n });\n\n // Small delay to simulate work\n await new Promise((resolve) => setTimeout(resolve, 100));\n }\n\n logger.debug('Executed iteration changes', {\n stepsCount: plan.steps.length,\n changesCount: changes.length,\n });\n\n return changes;\n }\n\n /**\n * Validate iteration results\n */\n private async validateIterationResults(changes: any[]): Promise<any> {\n const validation = {\n testsPass: true,\n lintClean: true,\n buildSuccess: true,\n errors: [],\n warnings: [],\n };\n\n // Run validation checks if available\n try {\n const { existsSync } = await import('fs');\n\n // Check if linting is available\n if (existsSync('package.json')) {\n const packageJson = JSON.parse(\n await fs.readFile('package.json', 'utf8')\n );\n\n if (packageJson.scripts?.lint) {\n try {\n const { execSync } = await import('child_process');\n execSync('npm run lint', { stdio: 'pipe', timeout: 30000 });\n validation.lintClean = true;\n } catch (error: any) {\n validation.lintClean = false;\n validation.warnings.push('Lint warnings detected');\n }\n }\n\n if (packageJson.scripts?.build) {\n try {\n const { execSync } = await import('child_process');\n execSync('npm run build', { stdio: 'pipe', timeout: 60000 });\n validation.buildSuccess = true;\n } catch (error: any) {\n validation.buildSuccess = false;\n validation.errors.push('Build failed');\n }\n }\n }\n } catch (error: unknown) {\n validation.errors.push(`Validation error: ${(error as Error).message}`);\n }\n\n return validation;\n }\n\n /**\n * Save iteration results\n */\n private async saveIterationResults(iteration: RalphIteration): Promise<void> {\n // Save with performance optimization\n await this.state.performanceOptimizer!.saveIteration(iteration);\n\n // Save iteration artifacts to Ralph directory\n const iterDir = path.join(\n this.ralphDir,\n 'history',\n `iteration-${String(iteration.number).padStart(3, '0')}`\n );\n\n await fs.mkdir(iterDir, { recursive: true });\n await fs.writeFile(\n path.join(iterDir, 'artifacts.json'),\n JSON.stringify(iteration, null, 2)\n );\n }\n\n /**\n * Save iteration frame to StackMemory\n */\n private async saveIterationFrame(iteration: RalphIteration): Promise<void> {\n if (!this.requiresDatabase || !this.frameManager || !this.state.activeLoop)\n return;\n\n const frame: Partial<Frame> = {\n type: 'subtask' as FrameType,\n name: `iteration-${iteration.number}`,\n inputs: {\n iterationNumber: iteration.number,\n loopId: this.state.activeLoop.loopId,\n },\n outputs: {\n changes: iteration.changes.length,\n success: iteration.validation.testsPass,\n },\n digest_json: iteration,\n };\n\n await this.state.performanceOptimizer!.saveFrame(frame as Frame);\n }\n\n /**\n * Get database adapter for FrameManager\n */\n private async getDatabaseAdapter(): Promise<SQLiteAdapter> {\n const dbPath = path.join(this.ralphDir, 'stackmemory.db');\n const projectId = path.basename(this.ralphDir);\n return new SQLiteAdapter(projectId, { dbPath });\n }\n\n /**\n * Additional helper methods\n */\n private async getCurrentGitCommit(): Promise<string> {\n try {\n // execSync already imported at top\n return execSync('git rev-parse HEAD', { encoding: 'utf8' }).trim();\n } catch {\n return '';\n }\n }\n\n private async getCurrentBranch(): Promise<string> {\n try {\n // execSync already imported at top\n return execSync('git branch --show-current', { encoding: 'utf8' }).trim();\n } catch {\n return 'main';\n }\n }\n\n private async saveLoopState(state: RalphLoopState): Promise<void> {\n // Save state.json\n await fs.writeFile(\n path.join(this.ralphDir, 'state.json'),\n JSON.stringify(state, null, 2)\n );\n\n // Synchronize iteration.txt with current iteration\n await fs.writeFile(\n path.join(this.ralphDir, 'iteration.txt'),\n state.iteration.toString()\n );\n\n logger.debug('Saved loop state', {\n iteration: state.iteration,\n status: state.status,\n });\n }\n\n private async gatherStateSources(loopId: string): Promise<StateSource[]> {\n const sources: StateSource[] = [];\n\n // Get git state\n sources.push(await this.state.stateReconciler!.getGitState());\n\n // Get file state\n sources.push(await this.state.stateReconciler!.getFileState());\n\n // Get memory state\n sources.push(await this.state.stateReconciler!.getMemoryState(loopId));\n\n return sources;\n }\n\n private async attemptRecovery(): Promise<void> {\n logger.info('Attempting crash recovery');\n\n try {\n // Check for incomplete loops in file system\n const stateFile = path.join(this.ralphDir, 'state.json');\n const exists = await fs\n .stat(stateFile)\n .then(() => true)\n .catch(() => false);\n\n if (exists) {\n const stateData = await fs.readFile(stateFile, 'utf8');\n const state = JSON.parse(stateData) as RalphLoopState;\n\n if (state.status !== 'completed') {\n logger.info('Found incomplete loop', { loopId: state.loopId });\n await this.resumeLoop(state.loopId);\n }\n }\n } catch (error: any) {\n logger.error('Recovery failed', { error: error.message });\n }\n }\n\n private async evaluateCompletion(): Promise<any> {\n // This would evaluate completion criteria\n // Placeholder implementation\n return {\n complete: false,\n criteria: {},\n unmet: ['criteria1', 'criteria2'],\n };\n }\n\n private generateFeedback(evaluation: any): string {\n if (evaluation.unmet.length === 0) {\n return 'All criteria met';\n }\n return `Still need to address:\\n${evaluation.unmet.map((c: string) => `- ${c}`).join('\\n')}`;\n }\n\n private async loadRelevantFrames(loopId: string): Promise<Frame[]> {\n // This would load frames from StackMemory\n // Placeholder implementation\n return [];\n }\n\n private async loadRecentIterations(loopId: string): Promise<any[]> {\n // Load recent iteration summaries\n return [];\n }\n\n private async loadGitCommits(): Promise<any[]> {\n // Load recent git commits\n return [];\n }\n\n private async loadChangedFiles(): Promise<string[]> {\n // Load recently changed files\n return [];\n }\n\n private async loadSessionFrames(sessionId: string): Promise<Frame[]> {\n // Load frames from session\n return [];\n }\n\n private async reconstructLoopState(frame: Frame): Promise<RalphLoopState> {\n // Reconstruct loop state from frame\n return {\n loopId: frame.inputs.loopId || '',\n task: frame.inputs.task || '',\n criteria: frame.inputs.criteria || '',\n iteration: 0,\n status: 'running',\n startTime: frame.created_at,\n lastUpdateTime: Date.now(),\n };\n }\n\n private async buildContextFromFrames(\n frames: Frame[],\n state: RalphLoopState\n ): Promise<IterationContext> {\n // Build context from frames\n return await this.loadIterationContext(state);\n }\n\n private async updateStateFrame(\n oldState: RalphLoopState,\n newState: RalphLoopState\n ): Promise<void> {\n // Update state in StackMemory\n logger.debug('State frame updated');\n }\n\n private async saveErrorFrame(error: Error, context: any): Promise<void> {\n // Save error as frame\n logger.debug('Error frame saved');\n }\n\n private async closeRootFrame(state: RalphLoopState): Promise<void> {\n // Close the root frame\n logger.debug('Root frame closed');\n }\n}\n"],
5
5
  "mappings": "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",
6
6
  "names": ["execSync"]
7
7
  }
@@ -3,7 +3,7 @@ import { dirname as __pathDirname } from 'path';
3
3
  const __filename = __fileURLToPath(import.meta.url);
4
4
  const __dirname = __pathDirname(__filename);
5
5
  import { logger } from "../../../core/monitoring/logger.js";
6
- import { FrameManager } from "../../../core/context/frame-manager.js";
6
+ import { FrameManager } from "../../../core/context/index.js";
7
7
  import { sharedContextLayer } from "../../../core/context/shared-context-layer.js";
8
8
  import { ContextRetriever } from "../../../core/retrieval/context-retriever.js";
9
9
  import { sessionManager } from "../../../core/session/index.js";
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../src/integrations/ralph/context/stackmemory-context-loader.ts"],
4
- "sourcesContent": ["/**\n * StackMemory Context Loader for Ralph Loops\n * Provides intelligent context loading with historical pattern recognition\n */\n\nimport { logger } from '../../../core/monitoring/logger.js';\nimport { FrameManager } from '../../../core/context/frame-manager.js';\nimport { sharedContextLayer } from '../../../core/context/shared-context-layer.js';\nimport { ContextRetriever } from '../../../core/retrieval/context-retriever.js';\nimport { sessionManager } from '../../../core/session/index.js';\nimport { ContextBudgetManager } from './context-budget-manager.js';\nimport { \n RalphContextRequest, \n RalphContextResponse, \n HistoricalPattern,\n TaskSimilarity,\n ContextSource\n} from '../types.js';\n\nexport interface StackMemoryContextConfig {\n maxTokens: number;\n lookbackDays: number;\n similarityThreshold: number;\n patternDetectionEnabled: boolean;\n includeFailedAttempts: boolean;\n crossSessionSearch: boolean;\n}\n\nexport class StackMemoryContextLoader {\n private frameManager?: FrameManager;\n private contextRetriever?: ContextRetriever;\n private budgetManager: ContextBudgetManager;\n private config: StackMemoryContextConfig;\n\n constructor(config?: Partial<StackMemoryContextConfig>) {\n this.config = {\n maxTokens: 3200, // Leave room for task description\n lookbackDays: 30,\n similarityThreshold: 0.7,\n patternDetectionEnabled: true,\n includeFailedAttempts: true,\n crossSessionSearch: true,\n ...config\n };\n \n this.budgetManager = new ContextBudgetManager({\n maxTokens: this.config.maxTokens,\n priorityWeights: {\n task: 0.15,\n recentWork: 0.30,\n patterns: 0.25,\n decisions: 0.20,\n dependencies: 0.10\n }\n });\n\n logger.info('StackMemory context loader initialized', {\n maxTokens: this.config.maxTokens,\n lookbackDays: this.config.lookbackDays,\n patternDetection: this.config.patternDetectionEnabled\n });\n }\n\n async initialize(): Promise<void> {\n try {\n // Initialize StackMemory components\n await sessionManager.initialize();\n await sharedContextLayer.initialize();\n\n // Get current session\n const session = await sessionManager.getOrCreateSession({});\n \n if (session.database) {\n this.frameManager = new FrameManager(session.database, session.projectId);\n this.contextRetriever = new ContextRetriever(session.database);\n }\n\n logger.info('Context loader initialized successfully');\n } catch (error: unknown) {\n logger.error('Failed to initialize context loader', error as Error);\n throw error;\n }\n }\n\n /**\n * Load context for Ralph loop initialization\n */\n async loadInitialContext(request: RalphContextRequest): Promise<RalphContextResponse> {\n logger.info('Loading initial context for Ralph loop', {\n task: request.task.substring(0, 100),\n usePatterns: request.usePatterns,\n useSimilarTasks: request.useSimilarTasks\n });\n\n const sources: ContextSource[] = [];\n let totalTokens = 0;\n\n try {\n // 1. Find similar tasks if requested\n if (request.useSimilarTasks) {\n const similarTasks = await this.findSimilarTasks(request.task);\n if (similarTasks.length > 0) {\n const tasksContext = await this.extractTaskContext(similarTasks);\n sources.push({\n type: 'similar_tasks',\n weight: 0.3,\n content: tasksContext,\n tokens: this.budgetManager.estimateTokens(tasksContext)\n });\n totalTokens += sources[sources.length - 1].tokens;\n }\n }\n\n // 2. Extract relevant patterns if requested\n if (request.usePatterns) {\n const patterns = await this.extractRelevantPatterns(request.task);\n if (patterns.length > 0) {\n const patternsContext = await this.formatPatterns(patterns);\n sources.push({\n type: 'historical_patterns',\n weight: 0.25,\n content: patternsContext,\n tokens: this.budgetManager.estimateTokens(patternsContext)\n });\n totalTokens += sources[sources.length - 1].tokens;\n }\n }\n\n // 3. Load recent decisions and learnings\n const decisions = await this.loadRecentDecisions();\n if (decisions.length > 0) {\n const decisionsContext = this.formatDecisions(decisions);\n sources.push({\n type: 'recent_decisions',\n weight: 0.2,\n content: decisionsContext,\n tokens: this.budgetManager.estimateTokens(decisionsContext)\n });\n totalTokens += sources[sources.length - 1].tokens;\n }\n\n // 4. Load project-specific context\n const projectContext = await this.loadProjectContext(request.task);\n if (projectContext) {\n sources.push({\n type: 'project_context',\n weight: 0.15,\n content: projectContext,\n tokens: this.budgetManager.estimateTokens(projectContext)\n });\n totalTokens += sources[sources.length - 1].tokens;\n }\n\n // 5. Apply budget constraints and synthesize\n const budgetedSources = this.budgetManager.allocateBudget({ sources });\n const synthesizedContext = this.synthesizeContext(budgetedSources.sources);\n\n logger.info('Context loaded successfully', {\n totalSources: sources.length,\n totalTokens,\n budgetedTokens: budgetedSources.sources.reduce((sum, s) => sum + s.tokens, 0)\n });\n\n return {\n context: synthesizedContext,\n sources: budgetedSources.sources,\n metadata: {\n totalTokens: budgetedSources.sources.reduce((sum, s) => sum + s.tokens, 0),\n sourcesCount: budgetedSources.sources.length,\n patterns: request.usePatterns ? patterns : [],\n similarTasks: request.useSimilarTasks ? similarTasks : []\n }\n };\n\n } catch (error: unknown) {\n logger.error('Failed to load context', error as Error);\n throw error;\n }\n }\n\n /**\n * Find similar tasks from StackMemory history\n */\n private async findSimilarTasks(taskDescription: string): Promise<TaskSimilarity[]> {\n if (!this.frameManager || !this.contextRetriever) {\n return [];\n }\n\n try {\n // Search for similar task frames\n const searchResults = await this.contextRetriever.search(taskDescription, {\n maxResults: 10,\n types: ['task', 'subtask'],\n timeFilter: {\n days: this.config.lookbackDays\n }\n });\n\n const similarities: TaskSimilarity[] = [];\n\n for (const result of searchResults) {\n // Calculate similarity score\n const similarity = this.calculateTaskSimilarity(taskDescription, result.content);\n \n if (similarity >= this.config.similarityThreshold) {\n similarities.push({\n frameId: result.frameId,\n task: result.content,\n similarity,\n outcome: await this.determineTaskOutcome(result.frameId),\n createdAt: result.timestamp,\n sessionId: result.sessionId || 'unknown'\n });\n }\n }\n\n // Sort by similarity and recent success\n return similarities\n .sort((a, b) => {\n // Prioritize successful outcomes and higher similarity\n const aScore = a.similarity * (a.outcome === 'success' ? 1.2 : 1.0);\n const bScore = b.similarity * (b.outcome === 'success' ? 1.2 : 1.0);\n return bScore - aScore;\n })\n .slice(0, 5); // Top 5 most relevant\n\n } catch (error: unknown) {\n logger.error('Failed to find similar tasks', error as Error);\n return [];\n }\n }\n\n /**\n * Extract relevant patterns from historical data\n */\n private async extractRelevantPatterns(taskDescription: string): Promise<HistoricalPattern[]> {\n try {\n const context = await sharedContextLayer.getSharedContext();\n if (!context) return [];\n\n const relevantPatterns: HistoricalPattern[] = [];\n\n // Filter patterns by relevance to current task\n for (const pattern of context.globalPatterns) {\n const relevance = this.calculatePatternRelevance(taskDescription, pattern.pattern);\n \n if (relevance >= 0.5) {\n relevantPatterns.push({\n pattern: pattern.pattern,\n type: pattern.type,\n frequency: pattern.frequency,\n lastSeen: pattern.lastSeen,\n relevance,\n resolution: pattern.resolution,\n examples: await this.getPatternExamples(pattern.pattern)\n });\n }\n }\n\n // Sort by relevance and frequency\n return relevantPatterns\n .sort((a, b) => (b.relevance * Math.log(b.frequency + 1)) - (a.relevance * Math.log(a.frequency + 1)))\n .slice(0, 8); // Top 8 most relevant patterns\n\n } catch (error: unknown) {\n logger.error('Failed to extract patterns', error as Error);\n return [];\n }\n }\n\n /**\n * Load recent decisions that might be relevant\n */\n private async loadRecentDecisions(): Promise<any[]> {\n try {\n const context = await sharedContextLayer.getSharedContext();\n if (!context) return [];\n\n // Get recent successful decisions\n const cutoff = Date.now() - (7 * 24 * 60 * 60 * 1000); // Last 7 days\n \n return context.decisionLog\n .filter(d => d.timestamp >= cutoff && d.outcome === 'success')\n .sort((a, b) => b.timestamp - a.timestamp)\n .slice(0, 5);\n\n } catch (error: unknown) {\n logger.error('Failed to load recent decisions', error as Error);\n return [];\n }\n }\n\n /**\n * Load project-specific context\n */\n private async loadProjectContext(taskDescription: string): Promise<string | null> {\n try {\n if (!this.contextRetriever) return null;\n\n // Search for project-relevant information\n const projectInfo = await this.contextRetriever.search(taskDescription, {\n maxResults: 3,\n types: ['task'],\n projectSpecific: true\n });\n\n if (projectInfo.length === 0) return null;\n\n const contextParts: string[] = [];\n \n for (const info of projectInfo) {\n contextParts.push(`Project context: ${info.content}`);\n }\n\n return contextParts.join('\\n\\n');\n\n } catch (error: unknown) {\n logger.error('Failed to load project context', error as Error);\n return null;\n }\n }\n\n /**\n * Calculate similarity between task descriptions\n */\n private calculateTaskSimilarity(task1: string, task2: string): number {\n // Simple similarity calculation - in production would use embeddings\n const words1 = new Set(task1.toLowerCase().split(/\\s+/));\n const words2 = new Set(task2.toLowerCase().split(/\\s+/));\n \n const intersection = new Set([...words1].filter(x => words2.has(x)));\n const union = new Set([...words1, ...words2]);\n \n return intersection.size / union.size;\n }\n\n /**\n * Calculate pattern relevance to current task\n */\n private calculatePatternRelevance(taskDescription: string, pattern: string): number {\n // Simple keyword matching - in production would use semantic analysis\n const taskWords = taskDescription.toLowerCase().split(/\\s+/);\n const patternWords = pattern.toLowerCase().split(/\\s+/);\n \n let matches = 0;\n for (const word of taskWords) {\n if (patternWords.some(p => p.includes(word) || word.includes(p))) {\n matches++;\n }\n }\n \n return matches / taskWords.length;\n }\n\n /**\n * Extract context from similar tasks\n */\n private async extractTaskContext(similarities: TaskSimilarity[]): Promise<string> {\n const contextParts: string[] = [];\n \n contextParts.push('Similar tasks from history:');\n \n for (const sim of similarities) {\n contextParts.push(`\nTask: ${sim.task}\nOutcome: ${sim.outcome}\nSimilarity: ${Math.round(sim.similarity * 100)}%\n${sim.outcome === 'success' ? '\u2705 Successfully completed' : '\u274C Had issues'}\n `.trim());\n }\n \n return contextParts.join('\\n\\n');\n }\n\n /**\n * Format patterns for context inclusion\n */\n private async formatPatterns(patterns: HistoricalPattern[]): Promise<string> {\n const contextParts: string[] = [];\n \n contextParts.push('Relevant patterns from experience:');\n \n for (const pattern of patterns) {\n contextParts.push(`\nPattern: ${pattern.pattern}\nType: ${pattern.type}\nFrequency: ${pattern.frequency} occurrences\n${pattern.resolution ? `Resolution: ${pattern.resolution}` : ''}\nRelevance: ${Math.round(pattern.relevance * 100)}%\n `.trim());\n }\n \n return contextParts.join('\\n\\n');\n }\n\n /**\n * Format decisions for context inclusion\n */\n private formatDecisions(decisions: any[]): string {\n const contextParts: string[] = [];\n \n contextParts.push('Recent successful decisions:');\n \n for (const decision of decisions) {\n contextParts.push(`\nDecision: ${decision.decision}\nReasoning: ${decision.reasoning}\nDate: ${new Date(decision.timestamp).toLocaleDateString()}\n `.trim());\n }\n \n return contextParts.join('\\n\\n');\n }\n\n /**\n * Synthesize all context sources into coherent input\n */\n private synthesizeContext(sources: ContextSource[]): string {\n if (sources.length === 0) {\n return 'No relevant historical context found.';\n }\n\n const contextParts: string[] = [];\n \n contextParts.push('Context from StackMemory:');\n \n // Sort by weight (importance)\n const sortedSources = sources.sort((a, b) => b.weight - a.weight);\n \n for (const source of sortedSources) {\n contextParts.push(`\\n--- ${source.type.replace('_', ' ').toUpperCase()} ---`);\n contextParts.push(source.content);\n }\n \n contextParts.push('\\nUse this context to inform your approach to the current task.');\n \n return contextParts.join('\\n');\n }\n\n /**\n * Determine task outcome from frame history\n */\n private async determineTaskOutcome(frameId: string): Promise<'success' | 'failure' | 'unknown'> {\n try {\n if (!this.frameManager) return 'unknown';\n \n const frame = await this.frameManager.getFrame(frameId);\n if (!frame) return 'unknown';\n \n // Simple heuristic - check if frame was properly closed\n if (frame.state === 'closed' && frame.outputs) {\n return 'success';\n }\n \n return frame.state === 'closed' ? 'failure' : 'unknown';\n \n } catch {\n return 'unknown';\n }\n }\n\n /**\n * Get examples of a specific pattern\n */\n private async getPatternExamples(pattern: string): Promise<string[]> {\n // Would search for concrete examples of this pattern\n // For now, return empty array\n return [];\n }\n}\n\n// Export default instance\nexport const stackMemoryContextLoader = new StackMemoryContextLoader();"],
4
+ "sourcesContent": ["/**\n * StackMemory Context Loader for Ralph Loops\n * Provides intelligent context loading with historical pattern recognition\n */\n\nimport { logger } from '../../../core/monitoring/logger.js';\nimport { FrameManager } from '../../../core/context/index.js';\nimport { sharedContextLayer } from '../../../core/context/shared-context-layer.js';\nimport { ContextRetriever } from '../../../core/retrieval/context-retriever.js';\nimport { sessionManager } from '../../../core/session/index.js';\nimport { ContextBudgetManager } from './context-budget-manager.js';\nimport { \n RalphContextRequest, \n RalphContextResponse, \n HistoricalPattern,\n TaskSimilarity,\n ContextSource\n} from '../types.js';\n\nexport interface StackMemoryContextConfig {\n maxTokens: number;\n lookbackDays: number;\n similarityThreshold: number;\n patternDetectionEnabled: boolean;\n includeFailedAttempts: boolean;\n crossSessionSearch: boolean;\n}\n\nexport class StackMemoryContextLoader {\n private frameManager?: FrameManager;\n private contextRetriever?: ContextRetriever;\n private budgetManager: ContextBudgetManager;\n private config: StackMemoryContextConfig;\n\n constructor(config?: Partial<StackMemoryContextConfig>) {\n this.config = {\n maxTokens: 3200, // Leave room for task description\n lookbackDays: 30,\n similarityThreshold: 0.7,\n patternDetectionEnabled: true,\n includeFailedAttempts: true,\n crossSessionSearch: true,\n ...config\n };\n \n this.budgetManager = new ContextBudgetManager({\n maxTokens: this.config.maxTokens,\n priorityWeights: {\n task: 0.15,\n recentWork: 0.30,\n patterns: 0.25,\n decisions: 0.20,\n dependencies: 0.10\n }\n });\n\n logger.info('StackMemory context loader initialized', {\n maxTokens: this.config.maxTokens,\n lookbackDays: this.config.lookbackDays,\n patternDetection: this.config.patternDetectionEnabled\n });\n }\n\n async initialize(): Promise<void> {\n try {\n // Initialize StackMemory components\n await sessionManager.initialize();\n await sharedContextLayer.initialize();\n\n // Get current session\n const session = await sessionManager.getOrCreateSession({});\n \n if (session.database) {\n this.frameManager = new FrameManager(session.database, session.projectId);\n this.contextRetriever = new ContextRetriever(session.database);\n }\n\n logger.info('Context loader initialized successfully');\n } catch (error: unknown) {\n logger.error('Failed to initialize context loader', error as Error);\n throw error;\n }\n }\n\n /**\n * Load context for Ralph loop initialization\n */\n async loadInitialContext(request: RalphContextRequest): Promise<RalphContextResponse> {\n logger.info('Loading initial context for Ralph loop', {\n task: request.task.substring(0, 100),\n usePatterns: request.usePatterns,\n useSimilarTasks: request.useSimilarTasks\n });\n\n const sources: ContextSource[] = [];\n let totalTokens = 0;\n\n try {\n // 1. Find similar tasks if requested\n if (request.useSimilarTasks) {\n const similarTasks = await this.findSimilarTasks(request.task);\n if (similarTasks.length > 0) {\n const tasksContext = await this.extractTaskContext(similarTasks);\n sources.push({\n type: 'similar_tasks',\n weight: 0.3,\n content: tasksContext,\n tokens: this.budgetManager.estimateTokens(tasksContext)\n });\n totalTokens += sources[sources.length - 1].tokens;\n }\n }\n\n // 2. Extract relevant patterns if requested\n if (request.usePatterns) {\n const patterns = await this.extractRelevantPatterns(request.task);\n if (patterns.length > 0) {\n const patternsContext = await this.formatPatterns(patterns);\n sources.push({\n type: 'historical_patterns',\n weight: 0.25,\n content: patternsContext,\n tokens: this.budgetManager.estimateTokens(patternsContext)\n });\n totalTokens += sources[sources.length - 1].tokens;\n }\n }\n\n // 3. Load recent decisions and learnings\n const decisions = await this.loadRecentDecisions();\n if (decisions.length > 0) {\n const decisionsContext = this.formatDecisions(decisions);\n sources.push({\n type: 'recent_decisions',\n weight: 0.2,\n content: decisionsContext,\n tokens: this.budgetManager.estimateTokens(decisionsContext)\n });\n totalTokens += sources[sources.length - 1].tokens;\n }\n\n // 4. Load project-specific context\n const projectContext = await this.loadProjectContext(request.task);\n if (projectContext) {\n sources.push({\n type: 'project_context',\n weight: 0.15,\n content: projectContext,\n tokens: this.budgetManager.estimateTokens(projectContext)\n });\n totalTokens += sources[sources.length - 1].tokens;\n }\n\n // 5. Apply budget constraints and synthesize\n const budgetedSources = this.budgetManager.allocateBudget({ sources });\n const synthesizedContext = this.synthesizeContext(budgetedSources.sources);\n\n logger.info('Context loaded successfully', {\n totalSources: sources.length,\n totalTokens,\n budgetedTokens: budgetedSources.sources.reduce((sum, s) => sum + s.tokens, 0)\n });\n\n return {\n context: synthesizedContext,\n sources: budgetedSources.sources,\n metadata: {\n totalTokens: budgetedSources.sources.reduce((sum, s) => sum + s.tokens, 0),\n sourcesCount: budgetedSources.sources.length,\n patterns: request.usePatterns ? patterns : [],\n similarTasks: request.useSimilarTasks ? similarTasks : []\n }\n };\n\n } catch (error: unknown) {\n logger.error('Failed to load context', error as Error);\n throw error;\n }\n }\n\n /**\n * Find similar tasks from StackMemory history\n */\n private async findSimilarTasks(taskDescription: string): Promise<TaskSimilarity[]> {\n if (!this.frameManager || !this.contextRetriever) {\n return [];\n }\n\n try {\n // Search for similar task frames\n const searchResults = await this.contextRetriever.search(taskDescription, {\n maxResults: 10,\n types: ['task', 'subtask'],\n timeFilter: {\n days: this.config.lookbackDays\n }\n });\n\n const similarities: TaskSimilarity[] = [];\n\n for (const result of searchResults) {\n // Calculate similarity score\n const similarity = this.calculateTaskSimilarity(taskDescription, result.content);\n \n if (similarity >= this.config.similarityThreshold) {\n similarities.push({\n frameId: result.frameId,\n task: result.content,\n similarity,\n outcome: await this.determineTaskOutcome(result.frameId),\n createdAt: result.timestamp,\n sessionId: result.sessionId || 'unknown'\n });\n }\n }\n\n // Sort by similarity and recent success\n return similarities\n .sort((a, b) => {\n // Prioritize successful outcomes and higher similarity\n const aScore = a.similarity * (a.outcome === 'success' ? 1.2 : 1.0);\n const bScore = b.similarity * (b.outcome === 'success' ? 1.2 : 1.0);\n return bScore - aScore;\n })\n .slice(0, 5); // Top 5 most relevant\n\n } catch (error: unknown) {\n logger.error('Failed to find similar tasks', error as Error);\n return [];\n }\n }\n\n /**\n * Extract relevant patterns from historical data\n */\n private async extractRelevantPatterns(taskDescription: string): Promise<HistoricalPattern[]> {\n try {\n const context = await sharedContextLayer.getSharedContext();\n if (!context) return [];\n\n const relevantPatterns: HistoricalPattern[] = [];\n\n // Filter patterns by relevance to current task\n for (const pattern of context.globalPatterns) {\n const relevance = this.calculatePatternRelevance(taskDescription, pattern.pattern);\n \n if (relevance >= 0.5) {\n relevantPatterns.push({\n pattern: pattern.pattern,\n type: pattern.type,\n frequency: pattern.frequency,\n lastSeen: pattern.lastSeen,\n relevance,\n resolution: pattern.resolution,\n examples: await this.getPatternExamples(pattern.pattern)\n });\n }\n }\n\n // Sort by relevance and frequency\n return relevantPatterns\n .sort((a, b) => (b.relevance * Math.log(b.frequency + 1)) - (a.relevance * Math.log(a.frequency + 1)))\n .slice(0, 8); // Top 8 most relevant patterns\n\n } catch (error: unknown) {\n logger.error('Failed to extract patterns', error as Error);\n return [];\n }\n }\n\n /**\n * Load recent decisions that might be relevant\n */\n private async loadRecentDecisions(): Promise<any[]> {\n try {\n const context = await sharedContextLayer.getSharedContext();\n if (!context) return [];\n\n // Get recent successful decisions\n const cutoff = Date.now() - (7 * 24 * 60 * 60 * 1000); // Last 7 days\n \n return context.decisionLog\n .filter(d => d.timestamp >= cutoff && d.outcome === 'success')\n .sort((a, b) => b.timestamp - a.timestamp)\n .slice(0, 5);\n\n } catch (error: unknown) {\n logger.error('Failed to load recent decisions', error as Error);\n return [];\n }\n }\n\n /**\n * Load project-specific context\n */\n private async loadProjectContext(taskDescription: string): Promise<string | null> {\n try {\n if (!this.contextRetriever) return null;\n\n // Search for project-relevant information\n const projectInfo = await this.contextRetriever.search(taskDescription, {\n maxResults: 3,\n types: ['task'],\n projectSpecific: true\n });\n\n if (projectInfo.length === 0) return null;\n\n const contextParts: string[] = [];\n \n for (const info of projectInfo) {\n contextParts.push(`Project context: ${info.content}`);\n }\n\n return contextParts.join('\\n\\n');\n\n } catch (error: unknown) {\n logger.error('Failed to load project context', error as Error);\n return null;\n }\n }\n\n /**\n * Calculate similarity between task descriptions\n */\n private calculateTaskSimilarity(task1: string, task2: string): number {\n // Simple similarity calculation - in production would use embeddings\n const words1 = new Set(task1.toLowerCase().split(/\\s+/));\n const words2 = new Set(task2.toLowerCase().split(/\\s+/));\n \n const intersection = new Set([...words1].filter(x => words2.has(x)));\n const union = new Set([...words1, ...words2]);\n \n return intersection.size / union.size;\n }\n\n /**\n * Calculate pattern relevance to current task\n */\n private calculatePatternRelevance(taskDescription: string, pattern: string): number {\n // Simple keyword matching - in production would use semantic analysis\n const taskWords = taskDescription.toLowerCase().split(/\\s+/);\n const patternWords = pattern.toLowerCase().split(/\\s+/);\n \n let matches = 0;\n for (const word of taskWords) {\n if (patternWords.some(p => p.includes(word) || word.includes(p))) {\n matches++;\n }\n }\n \n return matches / taskWords.length;\n }\n\n /**\n * Extract context from similar tasks\n */\n private async extractTaskContext(similarities: TaskSimilarity[]): Promise<string> {\n const contextParts: string[] = [];\n \n contextParts.push('Similar tasks from history:');\n \n for (const sim of similarities) {\n contextParts.push(`\nTask: ${sim.task}\nOutcome: ${sim.outcome}\nSimilarity: ${Math.round(sim.similarity * 100)}%\n${sim.outcome === 'success' ? '\u2705 Successfully completed' : '\u274C Had issues'}\n `.trim());\n }\n \n return contextParts.join('\\n\\n');\n }\n\n /**\n * Format patterns for context inclusion\n */\n private async formatPatterns(patterns: HistoricalPattern[]): Promise<string> {\n const contextParts: string[] = [];\n \n contextParts.push('Relevant patterns from experience:');\n \n for (const pattern of patterns) {\n contextParts.push(`\nPattern: ${pattern.pattern}\nType: ${pattern.type}\nFrequency: ${pattern.frequency} occurrences\n${pattern.resolution ? `Resolution: ${pattern.resolution}` : ''}\nRelevance: ${Math.round(pattern.relevance * 100)}%\n `.trim());\n }\n \n return contextParts.join('\\n\\n');\n }\n\n /**\n * Format decisions for context inclusion\n */\n private formatDecisions(decisions: any[]): string {\n const contextParts: string[] = [];\n \n contextParts.push('Recent successful decisions:');\n \n for (const decision of decisions) {\n contextParts.push(`\nDecision: ${decision.decision}\nReasoning: ${decision.reasoning}\nDate: ${new Date(decision.timestamp).toLocaleDateString()}\n `.trim());\n }\n \n return contextParts.join('\\n\\n');\n }\n\n /**\n * Synthesize all context sources into coherent input\n */\n private synthesizeContext(sources: ContextSource[]): string {\n if (sources.length === 0) {\n return 'No relevant historical context found.';\n }\n\n const contextParts: string[] = [];\n \n contextParts.push('Context from StackMemory:');\n \n // Sort by weight (importance)\n const sortedSources = sources.sort((a, b) => b.weight - a.weight);\n \n for (const source of sortedSources) {\n contextParts.push(`\\n--- ${source.type.replace('_', ' ').toUpperCase()} ---`);\n contextParts.push(source.content);\n }\n \n contextParts.push('\\nUse this context to inform your approach to the current task.');\n \n return contextParts.join('\\n');\n }\n\n /**\n * Determine task outcome from frame history\n */\n private async determineTaskOutcome(frameId: string): Promise<'success' | 'failure' | 'unknown'> {\n try {\n if (!this.frameManager) return 'unknown';\n \n const frame = await this.frameManager.getFrame(frameId);\n if (!frame) return 'unknown';\n \n // Simple heuristic - check if frame was properly closed\n if (frame.state === 'closed' && frame.outputs) {\n return 'success';\n }\n \n return frame.state === 'closed' ? 'failure' : 'unknown';\n \n } catch {\n return 'unknown';\n }\n }\n\n /**\n * Get examples of a specific pattern\n */\n private async getPatternExamples(pattern: string): Promise<string[]> {\n // Would search for concrete examples of this pattern\n // For now, return empty array\n return [];\n }\n}\n\n// Export default instance\nexport const stackMemoryContextLoader = new StackMemoryContextLoader();"],
5
5
  "mappings": "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",
6
6
  "names": ["similarTasks", "patterns"]
7
7
  }
@@ -3,7 +3,7 @@ import { dirname as __pathDirname } from 'path';
3
3
  const __filename = __fileURLToPath(import.meta.url);
4
4
  const __dirname = __pathDirname(__filename);
5
5
  import { logger } from "../../../core/monitoring/logger.js";
6
- import { FrameManager } from "../../../core/context/frame-manager.js";
6
+ import { FrameManager } from "../../../core/context/index.js";
7
7
  import { sharedContextLayer } from "../../../core/context/shared-context-layer.js";
8
8
  import { sessionManager } from "../../../core/session/index.js";
9
9
  class PatternLearner {
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../src/integrations/ralph/learning/pattern-learner.ts"],
4
- "sourcesContent": ["/**\n * Pattern Learning Engine for Ralph Loops\n * Analyzes completed loops to extract reusable patterns and strategies\n */\n\nimport { logger } from '../../../core/monitoring/logger.js';\nimport { FrameManager } from '../../../core/context/frame-manager.js';\nimport { sharedContextLayer } from '../../../core/context/shared-context-layer.js';\nimport { sessionManager } from '../../../core/session/index.js';\nimport {\n LearnedPattern,\n LoopAnalysis,\n PatternType,\n SuccessMetrics,\n FailureAnalysis,\n RalphLoopState\n} from '../types.js';\n\nexport interface PatternLearningConfig {\n minLoopCountForPattern: number;\n confidenceThreshold: number;\n maxPatternsPerType: number;\n analysisDepth: 'shallow' | 'deep' | 'comprehensive';\n}\n\nexport class PatternLearner {\n private frameManager?: FrameManager;\n private config: PatternLearningConfig;\n\n constructor(config?: Partial<PatternLearningConfig>) {\n this.config = {\n minLoopCountForPattern: 3,\n confidenceThreshold: 0.7,\n maxPatternsPerType: 10,\n analysisDepth: 'deep',\n ...config\n };\n\n logger.info('Pattern learner initialized', this.config);\n }\n\n async initialize(): Promise<void> {\n try {\n await sessionManager.initialize();\n await sharedContextLayer.initialize();\n\n const session = await sessionManager.getOrCreateSession({});\n if (session.database) {\n this.frameManager = new FrameManager(session.database, session.projectId);\n }\n\n logger.info('Pattern learner initialized successfully');\n } catch (error: unknown) {\n logger.error('Failed to initialize pattern learner', error as Error);\n throw error;\n }\n }\n\n /**\n * Learn patterns from all completed Ralph loops\n */\n async learnFromCompletedLoops(): Promise<LearnedPattern[]> {\n logger.info('Starting pattern learning from completed loops');\n\n try {\n const completedLoops = await this.getCompletedRalphLoops();\n logger.info(`Found ${completedLoops.length} completed loops for analysis`);\n\n if (completedLoops.length < this.config.minLoopCountForPattern) {\n logger.info('Not enough loops for pattern extraction');\n return [];\n }\n\n const patterns: LearnedPattern[] = [];\n\n // Learn success patterns\n const successPatterns = await this.extractSuccessPatterns(completedLoops);\n patterns.push(...successPatterns);\n\n // Learn failure patterns (to avoid)\n const failurePatterns = await this.extractFailurePatterns(completedLoops);\n patterns.push(...failurePatterns);\n\n // Learn iteration patterns\n const iterationPatterns = await this.extractIterationPatterns(completedLoops);\n patterns.push(...iterationPatterns);\n\n // Learn task-specific patterns\n const taskPatterns = await this.extractTaskPatterns(completedLoops);\n patterns.push(...taskPatterns);\n\n // Save patterns to shared context\n await this.saveLearnedPatterns(patterns);\n\n logger.info(`Learned ${patterns.length} patterns from ${completedLoops.length} loops`);\n return patterns;\n\n } catch (error: unknown) {\n logger.error('Failed to learn patterns', error as Error);\n throw error;\n }\n }\n\n /**\n * Learn patterns specific to a task type\n */\n async learnForTaskType(taskType: string): Promise<LearnedPattern[]> {\n logger.info(`Learning patterns for task type: ${taskType}`);\n\n const completedLoops = await this.getCompletedRalphLoops();\n const relevantLoops = completedLoops.filter(loop => \n this.classifyTaskType(loop.task) === taskType\n );\n\n if (relevantLoops.length < this.config.minLoopCountForPattern) {\n return [];\n }\n\n return this.extractSpecializedPatterns(relevantLoops, taskType);\n }\n\n /**\n * Get all completed Ralph loops from StackMemory\n */\n private async getCompletedRalphLoops(): Promise<LoopAnalysis[]> {\n if (!this.frameManager) {\n throw new Error('Frame manager not initialized');\n }\n\n try {\n // Get all Ralph loop frames\n const ralphFrames = await this.frameManager.searchFrames({\n type: 'task',\n namePattern: 'ralph-*',\n state: 'closed'\n });\n\n const analyses: LoopAnalysis[] = [];\n\n for (const frame of ralphFrames) {\n try {\n const analysis = await this.analyzeCompletedLoop(frame);\n if (analysis) {\n analyses.push(analysis);\n }\n } catch (error: unknown) {\n logger.warn(`Failed to analyze loop ${frame.frame_id}`, error as Error);\n }\n }\n\n return analyses;\n\n } catch (error: unknown) {\n logger.error('Failed to get completed loops', error as Error);\n return [];\n }\n }\n\n /**\n * Analyze a completed loop for patterns\n */\n private async analyzeCompletedLoop(ralphFrame: any): Promise<LoopAnalysis | null> {\n if (!this.frameManager) return null;\n\n try {\n // Get loop state from frame inputs\n const loopState = ralphFrame.inputs as RalphLoopState;\n \n // Get all iteration frames for this loop\n const iterationFrames = await this.frameManager.searchFrames({\n type: 'subtask',\n namePattern: 'iteration-*',\n parentId: ralphFrame.frame_id\n });\n\n // Calculate success metrics\n const successMetrics = this.calculateSuccessMetrics(iterationFrames);\n \n // Analyze iteration patterns\n const iterationAnalysis = this.analyzeIterations(iterationFrames);\n \n // Determine outcome\n const outcome = this.determineLoopOutcome(ralphFrame, iterationFrames);\n\n return {\n loopId: loopState.loopId,\n task: loopState.task,\n criteria: loopState.criteria,\n taskType: this.classifyTaskType(loopState.task),\n iterationCount: iterationFrames.length,\n outcome,\n successMetrics,\n iterationAnalysis,\n duration: ralphFrame.updated_at - ralphFrame.created_at,\n startTime: ralphFrame.created_at,\n endTime: ralphFrame.updated_at\n };\n\n } catch (error: unknown) {\n logger.error('Failed to analyze loop', error as Error);\n return null;\n }\n }\n\n /**\n * Extract patterns from successful loops\n */\n private async extractSuccessPatterns(loops: LoopAnalysis[]): Promise<LearnedPattern[]> {\n const successfulLoops = loops.filter(l => l.outcome === 'success');\n \n if (successfulLoops.length < this.config.minLoopCountForPattern) {\n return [];\n }\n\n const patterns: LearnedPattern[] = [];\n\n // Pattern: Optimal iteration count\n const avgIterations = successfulLoops.reduce((sum, l) => sum + l.iterationCount, 0) / successfulLoops.length;\n patterns.push({\n id: 'optimal-iterations',\n type: 'iteration_strategy',\n pattern: `Successful tasks typically complete in ${Math.round(avgIterations)} iterations`,\n confidence: this.calculateConfidence(successfulLoops.length),\n frequency: successfulLoops.length,\n strategy: `Target ${Math.round(avgIterations)} iterations for similar tasks`,\n examples: successfulLoops.slice(0, 3).map(l => l.task),\n metadata: {\n avgIterations,\n minIterations: Math.min(...successfulLoops.map(l => l.iterationCount)),\n maxIterations: Math.max(...successfulLoops.map(l => l.iterationCount))\n }\n });\n\n // Pattern: Task completion criteria\n const criteriaPatterns = this.extractCriteriaPatterns(successfulLoops);\n patterns.push(...criteriaPatterns);\n\n // Pattern: Common success factors\n const successFactors = this.extractSuccessFactors(successfulLoops);\n patterns.push(...successFactors);\n\n return patterns.filter(p => p.confidence >= this.config.confidenceThreshold);\n }\n\n /**\n * Extract patterns from failed loops to avoid\n */\n private async extractFailurePatterns(loops: LoopAnalysis[]): Promise<LearnedPattern[]> {\n const failedLoops = loops.filter(l => l.outcome === 'failure');\n \n if (failedLoops.length < this.config.minLoopCountForPattern) {\n return [];\n }\n\n const patterns: LearnedPattern[] = [];\n\n // Pattern: Common failure points\n const commonFailures = this.analyzeFailurePoints(failedLoops);\n for (const failure of commonFailures) {\n patterns.push({\n id: `avoid-${failure.type}`,\n type: 'failure_avoidance',\n pattern: `Avoid: ${failure.pattern}`,\n confidence: this.calculateConfidence(failure.frequency),\n frequency: failure.frequency,\n strategy: failure.avoidanceStrategy,\n examples: failure.examples,\n metadata: { failureType: failure.type }\n });\n }\n\n return patterns.filter(p => p.confidence >= this.config.confidenceThreshold);\n }\n\n /**\n * Extract iteration-specific patterns\n */\n private async extractIterationPatterns(loops: LoopAnalysis[]): Promise<LearnedPattern[]> {\n const patterns: LearnedPattern[] = [];\n\n // Analyze iteration sequences\n const iterationSequences = this.analyzeIterationSequences(loops);\n \n for (const sequence of iterationSequences) {\n if (sequence.frequency >= this.config.minLoopCountForPattern) {\n patterns.push({\n id: `iteration-sequence-${sequence.id}`,\n type: 'iteration_sequence',\n pattern: sequence.description,\n confidence: this.calculateConfidence(sequence.frequency),\n frequency: sequence.frequency,\n strategy: sequence.strategy,\n examples: sequence.examples,\n metadata: { sequenceType: sequence.type }\n });\n }\n }\n\n return patterns;\n }\n\n /**\n * Extract task-specific patterns\n */\n private async extractTaskPatterns(loops: LoopAnalysis[]): Promise<LearnedPattern[]> {\n const taskGroups = this.groupByTaskType(loops);\n const patterns: LearnedPattern[] = [];\n\n for (const [taskType, taskLoops] of Object.entries(taskGroups)) {\n if (taskLoops.length >= this.config.minLoopCountForPattern) {\n const taskSpecificPatterns = await this.extractSpecializedPatterns(taskLoops, taskType);\n patterns.push(...taskSpecificPatterns);\n }\n }\n\n return patterns;\n }\n\n /**\n * Extract specialized patterns for specific task types\n */\n private async extractSpecializedPatterns(loops: LoopAnalysis[], taskType: string): Promise<LearnedPattern[]> {\n const patterns: LearnedPattern[] = [];\n const successful = loops.filter(l => l.outcome === 'success');\n\n if (successful.length === 0) return patterns;\n\n // Task-specific success pattern\n patterns.push({\n id: `${taskType}-success-pattern`,\n type: 'task_specific',\n pattern: `${taskType} tasks: ${this.summarizeSuccessPattern(successful)}`,\n confidence: this.calculateConfidence(successful.length),\n frequency: successful.length,\n strategy: this.generateTaskStrategy(successful),\n examples: successful.slice(0, 2).map(l => l.task),\n metadata: { taskType, totalAttempts: loops.length }\n });\n\n return patterns;\n }\n\n /**\n * Calculate success metrics for iterations\n */\n private calculateSuccessMetrics(iterations: any[]): SuccessMetrics {\n const total = iterations.length;\n const successful = iterations.filter(i => i.outputs?.success).length;\n \n return {\n iterationCount: total,\n successRate: total > 0 ? successful / total : 0,\n averageProgress: this.calculateAverageProgress(iterations),\n timeToCompletion: total > 0 ? iterations[total - 1].updated_at - iterations[0].created_at : 0\n };\n }\n\n /**\n * Classify task type based on description\n */\n private classifyTaskType(task: string): string {\n const taskLower = task.toLowerCase();\n \n if (taskLower.includes('test') || taskLower.includes('unit')) return 'testing';\n if (taskLower.includes('fix') || taskLower.includes('bug')) return 'bugfix';\n if (taskLower.includes('refactor')) return 'refactoring';\n if (taskLower.includes('add') || taskLower.includes('implement')) return 'feature';\n if (taskLower.includes('document')) return 'documentation';\n if (taskLower.includes('optimize') || taskLower.includes('performance')) return 'optimization';\n \n return 'general';\n }\n\n /**\n * Determine loop outcome\n */\n private determineLoopOutcome(ralphFrame: any, iterations: any[]): 'success' | 'failure' | 'unknown' {\n if (ralphFrame.digest_json?.status === 'completed') return 'success';\n if (iterations.length === 0) return 'unknown';\n \n const lastIteration = iterations[iterations.length - 1];\n if (lastIteration.outputs?.success) return 'success';\n \n return 'failure';\n }\n\n /**\n * Calculate confidence based on frequency\n */\n private calculateConfidence(frequency: number): number {\n // Simple confidence calculation based on sample size\n return Math.min(0.95, Math.log(frequency + 1) / Math.log(10));\n }\n\n /**\n * Save learned patterns to shared context\n */\n private async saveLearnedPatterns(patterns: LearnedPattern[]): Promise<void> {\n try {\n const context = await sharedContextLayer.getSharedContext();\n if (!context) return;\n\n // Convert to shared context format\n const contextPatterns = patterns.map(p => ({\n pattern: p.pattern,\n type: this.mapPatternType(p.type),\n frequency: p.frequency,\n lastSeen: Date.now(),\n resolution: p.strategy\n }));\n\n // Add to global patterns\n context.globalPatterns.push(...contextPatterns);\n\n // Keep only the most relevant patterns\n context.globalPatterns.sort((a, b) => b.frequency - a.frequency);\n context.globalPatterns = context.globalPatterns.slice(0, 100);\n\n await sharedContextLayer.updateSharedContext(context);\n \n logger.info(`Saved ${patterns.length} patterns to shared context`);\n\n } catch (error: unknown) {\n logger.error('Failed to save patterns', error as Error);\n }\n }\n\n /**\n * Map pattern types to shared context types\n */\n private mapPatternType(patternType: PatternType): 'error' | 'success' | 'decision' | 'learning' {\n switch (patternType) {\n case 'failure_avoidance': return 'error';\n case 'success_strategy': return 'success';\n case 'task_specific': return 'learning';\n default: return 'learning';\n }\n }\n\n // Additional helper methods for pattern analysis\n private analyzeIterations(iterations: any[]): any {\n return {\n avgDuration: iterations.length > 0 ? \n iterations.reduce((sum, i) => sum + (i.updated_at - i.created_at), 0) / iterations.length : 0,\n progressPattern: this.extractProgressPattern(iterations),\n commonIssues: this.extractCommonIssues(iterations)\n };\n }\n\n private extractProgressPattern(iterations: any[]): string {\n // Analyze how progress typically unfolds\n const progressSteps = iterations.map((_, i) => {\n const progress = i / iterations.length;\n return Math.round(progress * 100);\n });\n \n return progressSteps.join(' \u2192 ') + '%';\n }\n\n private extractCommonIssues(iterations: any[]): string[] {\n // Extract common error patterns from iteration outputs\n return iterations\n .filter(i => i.outputs?.errors?.length > 0)\n .flatMap(i => i.outputs.errors)\n .slice(0, 3);\n }\n\n private extractCriteriaPatterns(loops: LoopAnalysis[]): LearnedPattern[] {\n // Analyze common successful completion criteria\n const criteriaWords = loops.flatMap(l => l.criteria.toLowerCase().split(/\\s+/));\n const wordCounts = criteriaWords.reduce((acc, word) => {\n acc[word] = (acc[word] || 0) + 1;\n return acc;\n }, {} as Record<string, number>);\n\n const commonCriteria = Object.entries(wordCounts)\n .filter(([_, count]) => count >= this.config.minLoopCountForPattern)\n .sort((a, b) => b[1] - a[1])\n .slice(0, 3);\n\n return commonCriteria.map(([word, count]) => ({\n id: `criteria-${word}`,\n type: 'success_strategy' as PatternType,\n pattern: `Successful tasks often include \"${word}\" in completion criteria`,\n confidence: this.calculateConfidence(count),\n frequency: count,\n strategy: `Consider including \"${word}\" in task completion criteria`,\n examples: loops.filter(l => l.criteria.toLowerCase().includes(word)).slice(0, 2).map(l => l.task),\n metadata: { criteriaWord: word }\n }));\n }\n\n private extractSuccessFactors(loops: LoopAnalysis[]): LearnedPattern[] {\n // Placeholder for success factor analysis\n return [];\n }\n\n private analyzeFailurePoints(loops: LoopAnalysis[]): FailureAnalysis[] {\n // Placeholder for failure analysis\n return [];\n }\n\n private analyzeIterationSequences(loops: LoopAnalysis[]): any[] {\n // Placeholder for iteration sequence analysis\n return [];\n }\n\n private groupByTaskType(loops: LoopAnalysis[]): Record<string, LoopAnalysis[]> {\n return loops.reduce((acc, loop) => {\n const type = loop.taskType;\n if (!acc[type]) acc[type] = [];\n acc[type].push(loop);\n return acc;\n }, {} as Record<string, LoopAnalysis[]>);\n }\n\n private summarizeSuccessPattern(loops: LoopAnalysis[]): string {\n const avgIterations = loops.reduce((sum, l) => sum + l.iterationCount, 0) / loops.length;\n return `typically complete in ${Math.round(avgIterations)} iterations with ${Math.round(loops[0]?.successMetrics?.successRate * 100 || 0)}% success rate`;\n }\n\n private generateTaskStrategy(loops: LoopAnalysis[]): string {\n const avgIterations = loops.reduce((sum, l) => sum + l.iterationCount, 0) / loops.length;\n return `Plan for approximately ${Math.round(avgIterations)} iterations and focus on iterative improvement`;\n }\n\n private calculateAverageProgress(iterations: any[]): number {\n // Simple progress calculation\n return iterations.length > 0 ? iterations.length / 10 : 0; // Assume 10 iterations is 100% progress\n }\n}\n\n// Export default instance\nexport const patternLearner = new PatternLearner();"],
4
+ "sourcesContent": ["/**\n * Pattern Learning Engine for Ralph Loops\n * Analyzes completed loops to extract reusable patterns and strategies\n */\n\nimport { logger } from '../../../core/monitoring/logger.js';\nimport { FrameManager } from '../../../core/context/index.js';\nimport { sharedContextLayer } from '../../../core/context/shared-context-layer.js';\nimport { sessionManager } from '../../../core/session/index.js';\nimport {\n LearnedPattern,\n LoopAnalysis,\n PatternType,\n SuccessMetrics,\n FailureAnalysis,\n RalphLoopState\n} from '../types.js';\n\nexport interface PatternLearningConfig {\n minLoopCountForPattern: number;\n confidenceThreshold: number;\n maxPatternsPerType: number;\n analysisDepth: 'shallow' | 'deep' | 'comprehensive';\n}\n\nexport class PatternLearner {\n private frameManager?: FrameManager;\n private config: PatternLearningConfig;\n\n constructor(config?: Partial<PatternLearningConfig>) {\n this.config = {\n minLoopCountForPattern: 3,\n confidenceThreshold: 0.7,\n maxPatternsPerType: 10,\n analysisDepth: 'deep',\n ...config\n };\n\n logger.info('Pattern learner initialized', this.config);\n }\n\n async initialize(): Promise<void> {\n try {\n await sessionManager.initialize();\n await sharedContextLayer.initialize();\n\n const session = await sessionManager.getOrCreateSession({});\n if (session.database) {\n this.frameManager = new FrameManager(session.database, session.projectId);\n }\n\n logger.info('Pattern learner initialized successfully');\n } catch (error: unknown) {\n logger.error('Failed to initialize pattern learner', error as Error);\n throw error;\n }\n }\n\n /**\n * Learn patterns from all completed Ralph loops\n */\n async learnFromCompletedLoops(): Promise<LearnedPattern[]> {\n logger.info('Starting pattern learning from completed loops');\n\n try {\n const completedLoops = await this.getCompletedRalphLoops();\n logger.info(`Found ${completedLoops.length} completed loops for analysis`);\n\n if (completedLoops.length < this.config.minLoopCountForPattern) {\n logger.info('Not enough loops for pattern extraction');\n return [];\n }\n\n const patterns: LearnedPattern[] = [];\n\n // Learn success patterns\n const successPatterns = await this.extractSuccessPatterns(completedLoops);\n patterns.push(...successPatterns);\n\n // Learn failure patterns (to avoid)\n const failurePatterns = await this.extractFailurePatterns(completedLoops);\n patterns.push(...failurePatterns);\n\n // Learn iteration patterns\n const iterationPatterns = await this.extractIterationPatterns(completedLoops);\n patterns.push(...iterationPatterns);\n\n // Learn task-specific patterns\n const taskPatterns = await this.extractTaskPatterns(completedLoops);\n patterns.push(...taskPatterns);\n\n // Save patterns to shared context\n await this.saveLearnedPatterns(patterns);\n\n logger.info(`Learned ${patterns.length} patterns from ${completedLoops.length} loops`);\n return patterns;\n\n } catch (error: unknown) {\n logger.error('Failed to learn patterns', error as Error);\n throw error;\n }\n }\n\n /**\n * Learn patterns specific to a task type\n */\n async learnForTaskType(taskType: string): Promise<LearnedPattern[]> {\n logger.info(`Learning patterns for task type: ${taskType}`);\n\n const completedLoops = await this.getCompletedRalphLoops();\n const relevantLoops = completedLoops.filter(loop => \n this.classifyTaskType(loop.task) === taskType\n );\n\n if (relevantLoops.length < this.config.minLoopCountForPattern) {\n return [];\n }\n\n return this.extractSpecializedPatterns(relevantLoops, taskType);\n }\n\n /**\n * Get all completed Ralph loops from StackMemory\n */\n private async getCompletedRalphLoops(): Promise<LoopAnalysis[]> {\n if (!this.frameManager) {\n throw new Error('Frame manager not initialized');\n }\n\n try {\n // Get all Ralph loop frames\n const ralphFrames = await this.frameManager.searchFrames({\n type: 'task',\n namePattern: 'ralph-*',\n state: 'closed'\n });\n\n const analyses: LoopAnalysis[] = [];\n\n for (const frame of ralphFrames) {\n try {\n const analysis = await this.analyzeCompletedLoop(frame);\n if (analysis) {\n analyses.push(analysis);\n }\n } catch (error: unknown) {\n logger.warn(`Failed to analyze loop ${frame.frame_id}`, error as Error);\n }\n }\n\n return analyses;\n\n } catch (error: unknown) {\n logger.error('Failed to get completed loops', error as Error);\n return [];\n }\n }\n\n /**\n * Analyze a completed loop for patterns\n */\n private async analyzeCompletedLoop(ralphFrame: any): Promise<LoopAnalysis | null> {\n if (!this.frameManager) return null;\n\n try {\n // Get loop state from frame inputs\n const loopState = ralphFrame.inputs as RalphLoopState;\n \n // Get all iteration frames for this loop\n const iterationFrames = await this.frameManager.searchFrames({\n type: 'subtask',\n namePattern: 'iteration-*',\n parentId: ralphFrame.frame_id\n });\n\n // Calculate success metrics\n const successMetrics = this.calculateSuccessMetrics(iterationFrames);\n \n // Analyze iteration patterns\n const iterationAnalysis = this.analyzeIterations(iterationFrames);\n \n // Determine outcome\n const outcome = this.determineLoopOutcome(ralphFrame, iterationFrames);\n\n return {\n loopId: loopState.loopId,\n task: loopState.task,\n criteria: loopState.criteria,\n taskType: this.classifyTaskType(loopState.task),\n iterationCount: iterationFrames.length,\n outcome,\n successMetrics,\n iterationAnalysis,\n duration: ralphFrame.updated_at - ralphFrame.created_at,\n startTime: ralphFrame.created_at,\n endTime: ralphFrame.updated_at\n };\n\n } catch (error: unknown) {\n logger.error('Failed to analyze loop', error as Error);\n return null;\n }\n }\n\n /**\n * Extract patterns from successful loops\n */\n private async extractSuccessPatterns(loops: LoopAnalysis[]): Promise<LearnedPattern[]> {\n const successfulLoops = loops.filter(l => l.outcome === 'success');\n \n if (successfulLoops.length < this.config.minLoopCountForPattern) {\n return [];\n }\n\n const patterns: LearnedPattern[] = [];\n\n // Pattern: Optimal iteration count\n const avgIterations = successfulLoops.reduce((sum, l) => sum + l.iterationCount, 0) / successfulLoops.length;\n patterns.push({\n id: 'optimal-iterations',\n type: 'iteration_strategy',\n pattern: `Successful tasks typically complete in ${Math.round(avgIterations)} iterations`,\n confidence: this.calculateConfidence(successfulLoops.length),\n frequency: successfulLoops.length,\n strategy: `Target ${Math.round(avgIterations)} iterations for similar tasks`,\n examples: successfulLoops.slice(0, 3).map(l => l.task),\n metadata: {\n avgIterations,\n minIterations: Math.min(...successfulLoops.map(l => l.iterationCount)),\n maxIterations: Math.max(...successfulLoops.map(l => l.iterationCount))\n }\n });\n\n // Pattern: Task completion criteria\n const criteriaPatterns = this.extractCriteriaPatterns(successfulLoops);\n patterns.push(...criteriaPatterns);\n\n // Pattern: Common success factors\n const successFactors = this.extractSuccessFactors(successfulLoops);\n patterns.push(...successFactors);\n\n return patterns.filter(p => p.confidence >= this.config.confidenceThreshold);\n }\n\n /**\n * Extract patterns from failed loops to avoid\n */\n private async extractFailurePatterns(loops: LoopAnalysis[]): Promise<LearnedPattern[]> {\n const failedLoops = loops.filter(l => l.outcome === 'failure');\n \n if (failedLoops.length < this.config.minLoopCountForPattern) {\n return [];\n }\n\n const patterns: LearnedPattern[] = [];\n\n // Pattern: Common failure points\n const commonFailures = this.analyzeFailurePoints(failedLoops);\n for (const failure of commonFailures) {\n patterns.push({\n id: `avoid-${failure.type}`,\n type: 'failure_avoidance',\n pattern: `Avoid: ${failure.pattern}`,\n confidence: this.calculateConfidence(failure.frequency),\n frequency: failure.frequency,\n strategy: failure.avoidanceStrategy,\n examples: failure.examples,\n metadata: { failureType: failure.type }\n });\n }\n\n return patterns.filter(p => p.confidence >= this.config.confidenceThreshold);\n }\n\n /**\n * Extract iteration-specific patterns\n */\n private async extractIterationPatterns(loops: LoopAnalysis[]): Promise<LearnedPattern[]> {\n const patterns: LearnedPattern[] = [];\n\n // Analyze iteration sequences\n const iterationSequences = this.analyzeIterationSequences(loops);\n \n for (const sequence of iterationSequences) {\n if (sequence.frequency >= this.config.minLoopCountForPattern) {\n patterns.push({\n id: `iteration-sequence-${sequence.id}`,\n type: 'iteration_sequence',\n pattern: sequence.description,\n confidence: this.calculateConfidence(sequence.frequency),\n frequency: sequence.frequency,\n strategy: sequence.strategy,\n examples: sequence.examples,\n metadata: { sequenceType: sequence.type }\n });\n }\n }\n\n return patterns;\n }\n\n /**\n * Extract task-specific patterns\n */\n private async extractTaskPatterns(loops: LoopAnalysis[]): Promise<LearnedPattern[]> {\n const taskGroups = this.groupByTaskType(loops);\n const patterns: LearnedPattern[] = [];\n\n for (const [taskType, taskLoops] of Object.entries(taskGroups)) {\n if (taskLoops.length >= this.config.minLoopCountForPattern) {\n const taskSpecificPatterns = await this.extractSpecializedPatterns(taskLoops, taskType);\n patterns.push(...taskSpecificPatterns);\n }\n }\n\n return patterns;\n }\n\n /**\n * Extract specialized patterns for specific task types\n */\n private async extractSpecializedPatterns(loops: LoopAnalysis[], taskType: string): Promise<LearnedPattern[]> {\n const patterns: LearnedPattern[] = [];\n const successful = loops.filter(l => l.outcome === 'success');\n\n if (successful.length === 0) return patterns;\n\n // Task-specific success pattern\n patterns.push({\n id: `${taskType}-success-pattern`,\n type: 'task_specific',\n pattern: `${taskType} tasks: ${this.summarizeSuccessPattern(successful)}`,\n confidence: this.calculateConfidence(successful.length),\n frequency: successful.length,\n strategy: this.generateTaskStrategy(successful),\n examples: successful.slice(0, 2).map(l => l.task),\n metadata: { taskType, totalAttempts: loops.length }\n });\n\n return patterns;\n }\n\n /**\n * Calculate success metrics for iterations\n */\n private calculateSuccessMetrics(iterations: any[]): SuccessMetrics {\n const total = iterations.length;\n const successful = iterations.filter(i => i.outputs?.success).length;\n \n return {\n iterationCount: total,\n successRate: total > 0 ? successful / total : 0,\n averageProgress: this.calculateAverageProgress(iterations),\n timeToCompletion: total > 0 ? iterations[total - 1].updated_at - iterations[0].created_at : 0\n };\n }\n\n /**\n * Classify task type based on description\n */\n private classifyTaskType(task: string): string {\n const taskLower = task.toLowerCase();\n \n if (taskLower.includes('test') || taskLower.includes('unit')) return 'testing';\n if (taskLower.includes('fix') || taskLower.includes('bug')) return 'bugfix';\n if (taskLower.includes('refactor')) return 'refactoring';\n if (taskLower.includes('add') || taskLower.includes('implement')) return 'feature';\n if (taskLower.includes('document')) return 'documentation';\n if (taskLower.includes('optimize') || taskLower.includes('performance')) return 'optimization';\n \n return 'general';\n }\n\n /**\n * Determine loop outcome\n */\n private determineLoopOutcome(ralphFrame: any, iterations: any[]): 'success' | 'failure' | 'unknown' {\n if (ralphFrame.digest_json?.status === 'completed') return 'success';\n if (iterations.length === 0) return 'unknown';\n \n const lastIteration = iterations[iterations.length - 1];\n if (lastIteration.outputs?.success) return 'success';\n \n return 'failure';\n }\n\n /**\n * Calculate confidence based on frequency\n */\n private calculateConfidence(frequency: number): number {\n // Simple confidence calculation based on sample size\n return Math.min(0.95, Math.log(frequency + 1) / Math.log(10));\n }\n\n /**\n * Save learned patterns to shared context\n */\n private async saveLearnedPatterns(patterns: LearnedPattern[]): Promise<void> {\n try {\n const context = await sharedContextLayer.getSharedContext();\n if (!context) return;\n\n // Convert to shared context format\n const contextPatterns = patterns.map(p => ({\n pattern: p.pattern,\n type: this.mapPatternType(p.type),\n frequency: p.frequency,\n lastSeen: Date.now(),\n resolution: p.strategy\n }));\n\n // Add to global patterns\n context.globalPatterns.push(...contextPatterns);\n\n // Keep only the most relevant patterns\n context.globalPatterns.sort((a, b) => b.frequency - a.frequency);\n context.globalPatterns = context.globalPatterns.slice(0, 100);\n\n await sharedContextLayer.updateSharedContext(context);\n \n logger.info(`Saved ${patterns.length} patterns to shared context`);\n\n } catch (error: unknown) {\n logger.error('Failed to save patterns', error as Error);\n }\n }\n\n /**\n * Map pattern types to shared context types\n */\n private mapPatternType(patternType: PatternType): 'error' | 'success' | 'decision' | 'learning' {\n switch (patternType) {\n case 'failure_avoidance': return 'error';\n case 'success_strategy': return 'success';\n case 'task_specific': return 'learning';\n default: return 'learning';\n }\n }\n\n // Additional helper methods for pattern analysis\n private analyzeIterations(iterations: any[]): any {\n return {\n avgDuration: iterations.length > 0 ? \n iterations.reduce((sum, i) => sum + (i.updated_at - i.created_at), 0) / iterations.length : 0,\n progressPattern: this.extractProgressPattern(iterations),\n commonIssues: this.extractCommonIssues(iterations)\n };\n }\n\n private extractProgressPattern(iterations: any[]): string {\n // Analyze how progress typically unfolds\n const progressSteps = iterations.map((_, i) => {\n const progress = i / iterations.length;\n return Math.round(progress * 100);\n });\n \n return progressSteps.join(' \u2192 ') + '%';\n }\n\n private extractCommonIssues(iterations: any[]): string[] {\n // Extract common error patterns from iteration outputs\n return iterations\n .filter(i => i.outputs?.errors?.length > 0)\n .flatMap(i => i.outputs.errors)\n .slice(0, 3);\n }\n\n private extractCriteriaPatterns(loops: LoopAnalysis[]): LearnedPattern[] {\n // Analyze common successful completion criteria\n const criteriaWords = loops.flatMap(l => l.criteria.toLowerCase().split(/\\s+/));\n const wordCounts = criteriaWords.reduce((acc, word) => {\n acc[word] = (acc[word] || 0) + 1;\n return acc;\n }, {} as Record<string, number>);\n\n const commonCriteria = Object.entries(wordCounts)\n .filter(([_, count]) => count >= this.config.minLoopCountForPattern)\n .sort((a, b) => b[1] - a[1])\n .slice(0, 3);\n\n return commonCriteria.map(([word, count]) => ({\n id: `criteria-${word}`,\n type: 'success_strategy' as PatternType,\n pattern: `Successful tasks often include \"${word}\" in completion criteria`,\n confidence: this.calculateConfidence(count),\n frequency: count,\n strategy: `Consider including \"${word}\" in task completion criteria`,\n examples: loops.filter(l => l.criteria.toLowerCase().includes(word)).slice(0, 2).map(l => l.task),\n metadata: { criteriaWord: word }\n }));\n }\n\n private extractSuccessFactors(loops: LoopAnalysis[]): LearnedPattern[] {\n // Placeholder for success factor analysis\n return [];\n }\n\n private analyzeFailurePoints(loops: LoopAnalysis[]): FailureAnalysis[] {\n // Placeholder for failure analysis\n return [];\n }\n\n private analyzeIterationSequences(loops: LoopAnalysis[]): any[] {\n // Placeholder for iteration sequence analysis\n return [];\n }\n\n private groupByTaskType(loops: LoopAnalysis[]): Record<string, LoopAnalysis[]> {\n return loops.reduce((acc, loop) => {\n const type = loop.taskType;\n if (!acc[type]) acc[type] = [];\n acc[type].push(loop);\n return acc;\n }, {} as Record<string, LoopAnalysis[]>);\n }\n\n private summarizeSuccessPattern(loops: LoopAnalysis[]): string {\n const avgIterations = loops.reduce((sum, l) => sum + l.iterationCount, 0) / loops.length;\n return `typically complete in ${Math.round(avgIterations)} iterations with ${Math.round(loops[0]?.successMetrics?.successRate * 100 || 0)}% success rate`;\n }\n\n private generateTaskStrategy(loops: LoopAnalysis[]): string {\n const avgIterations = loops.reduce((sum, l) => sum + l.iterationCount, 0) / loops.length;\n return `Plan for approximately ${Math.round(avgIterations)} iterations and focus on iterative improvement`;\n }\n\n private calculateAverageProgress(iterations: any[]): number {\n // Simple progress calculation\n return iterations.length > 0 ? iterations.length / 10 : 0; // Assume 10 iterations is 100% progress\n }\n}\n\n// Export default instance\nexport const patternLearner = new PatternLearner();"],
5
5
  "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -4,7 +4,7 @@ const __filename = __fileURLToPath(import.meta.url);
4
4
  const __dirname = __pathDirname(__filename);
5
5
  import { v4 as uuidv4 } from "uuid";
6
6
  import { logger } from "../../../core/monitoring/logger.js";
7
- import { FrameManager } from "../../../core/context/frame-manager.js";
7
+ import { FrameManager } from "../../../core/context/index.js";
8
8
  import { sessionManager } from "../../../core/session/index.js";
9
9
  import { RalphStackMemoryBridge } from "../bridge/ralph-stackmemory-bridge.js";
10
10
  class MultiLoopOrchestrator {