@stackmemoryai/stackmemory 0.5.59 → 0.5.61
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +105 -1
- package/dist/src/cli/claude-sm.js +130 -50
- package/dist/src/cli/claude-sm.js.map +2 -2
- package/dist/src/cli/index.js +18 -3
- package/dist/src/cli/index.js.map +3 -3
- package/dist/src/core/extensions/custom-tools.js +567 -0
- package/dist/src/core/extensions/custom-tools.js.map +7 -0
- package/dist/src/core/extensions/index.js +55 -0
- package/dist/src/core/extensions/index.js.map +7 -0
- package/dist/src/core/extensions/loader.js +709 -0
- package/dist/src/core/extensions/loader.js.map +7 -0
- package/dist/src/core/extensions/plugin-system.js +506 -0
- package/dist/src/core/extensions/plugin-system.js.map +7 -0
- package/dist/src/core/extensions/provider-adapter.js +617 -0
- package/dist/src/core/extensions/provider-adapter.js.map +7 -0
- package/dist/src/core/extensions/sandbox-runtime.js +664 -0
- package/dist/src/core/extensions/sandbox-runtime.js.map +7 -0
- package/dist/src/core/storage/chromadb-adapter.js +32 -6
- package/dist/src/core/storage/chromadb-adapter.js.map +2 -2
- package/dist/src/skills/repo-ingestion-skill.js +35 -12
- package/dist/src/skills/repo-ingestion-skill.js.map +2 -2
- package/package.json +11 -7
- package/scripts/background-sync-manager.js +145 -83
- package/scripts/claude-sm-autostart.js +17 -12
- package/scripts/gepa/README.md +275 -0
- package/scripts/gepa/config.json +53 -0
- package/scripts/gepa/evals/coding-tasks.jsonl +5 -0
- package/scripts/gepa/evals/fixtures/buggy-loop.js +18 -0
- package/scripts/gepa/evals/fixtures/callback-hell.js +53 -0
- package/scripts/gepa/generations/gen-000/baseline.md +124 -0
- package/scripts/gepa/hooks/auto-optimize.js +494 -0
- package/scripts/gepa/hooks/eval-tracker.js +203 -0
- package/scripts/gepa/hooks/reflect.js +311 -0
- package/scripts/gepa/optimize.js +611 -0
- package/scripts/gepa/state.json +14 -0
- package/scripts/test-pre-publish-quick.sh +1 -1
- package/dist/agents/core/agent-task-manager.js +0 -527
- package/dist/agents/core/agent-task-manager.js.map +0 -7
- package/dist/agents/testing-agent.js +0 -614
- package/dist/agents/testing-agent.js.map +0 -7
- package/dist/agents/verifiers/base-verifier.js +0 -133
- package/dist/agents/verifiers/base-verifier.js.map +0 -7
- package/dist/agents/verifiers/formatter-verifier.js +0 -130
- package/dist/agents/verifiers/formatter-verifier.js.map +0 -7
- package/dist/agents/verifiers/llm-judge.js +0 -252
- package/dist/agents/verifiers/llm-judge.js.map +0 -7
- package/dist/cli/auto-detect.js +0 -321
- package/dist/cli/auto-detect.js.map +0 -7
- package/dist/cli/browser-test.js +0 -33
- package/dist/cli/browser-test.js.map +0 -7
- package/dist/cli/claude-sm-danger.js +0 -21
- package/dist/cli/claude-sm-danger.js.map +0 -7
- package/dist/cli/claude-sm.js +0 -1156
- package/dist/cli/claude-sm.js.map +0 -7
- package/dist/cli/codex-sm-danger.js +0 -21
- package/dist/cli/codex-sm-danger.js.map +0 -7
- package/dist/cli/codex-sm.js +0 -349
- package/dist/cli/codex-sm.js.map +0 -7
- package/dist/cli/commands/api.js +0 -232
- package/dist/cli/commands/api.js.map +0 -7
- package/dist/cli/commands/auto-background.js +0 -180
- package/dist/cli/commands/auto-background.js.map +0 -7
- package/dist/cli/commands/cleanup-processes.js +0 -68
- package/dist/cli/commands/cleanup-processes.js.map +0 -7
- package/dist/cli/commands/clear.js +0 -202
- package/dist/cli/commands/clear.js.map +0 -7
- package/dist/cli/commands/config.js +0 -445
- package/dist/cli/commands/config.js.map +0 -7
- package/dist/cli/commands/context-rehydrate.js +0 -751
- package/dist/cli/commands/context-rehydrate.js.map +0 -7
- package/dist/cli/commands/context.js +0 -343
- package/dist/cli/commands/context.js.map +0 -7
- package/dist/cli/commands/daemon.js +0 -392
- package/dist/cli/commands/daemon.js.map +0 -7
- package/dist/cli/commands/dashboard.js +0 -210
- package/dist/cli/commands/dashboard.js.map +0 -7
- package/dist/cli/commands/db.js +0 -147
- package/dist/cli/commands/db.js.map +0 -7
- package/dist/cli/commands/decision.js +0 -266
- package/dist/cli/commands/decision.js.map +0 -7
- package/dist/cli/commands/discovery.js +0 -279
- package/dist/cli/commands/discovery.js.map +0 -7
- package/dist/cli/commands/handoff.js +0 -624
- package/dist/cli/commands/handoff.js.map +0 -7
- package/dist/cli/commands/hooks.js +0 -298
- package/dist/cli/commands/hooks.js.map +0 -7
- package/dist/cli/commands/linear-unified.js +0 -353
- package/dist/cli/commands/linear-unified.js.map +0 -7
- package/dist/cli/commands/linear.js +0 -529
- package/dist/cli/commands/linear.js.map +0 -7
- package/dist/cli/commands/log.js +0 -169
- package/dist/cli/commands/log.js.map +0 -7
- package/dist/cli/commands/login.js +0 -172
- package/dist/cli/commands/login.js.map +0 -7
- package/dist/cli/commands/migrate.js +0 -240
- package/dist/cli/commands/migrate.js.map +0 -7
- package/dist/cli/commands/model.js +0 -533
- package/dist/cli/commands/model.js.map +0 -7
- package/dist/cli/commands/monitor.js +0 -313
- package/dist/cli/commands/monitor.js.map +0 -7
- package/dist/cli/commands/onboard.js +0 -536
- package/dist/cli/commands/onboard.js.map +0 -7
- package/dist/cli/commands/projects.js +0 -199
- package/dist/cli/commands/projects.js.map +0 -7
- package/dist/cli/commands/quality.js +0 -413
- package/dist/cli/commands/quality.js.map +0 -7
- package/dist/cli/commands/ralph.js +0 -909
- package/dist/cli/commands/ralph.js.map +0 -7
- package/dist/cli/commands/retrieval.js +0 -248
- package/dist/cli/commands/retrieval.js.map +0 -7
- package/dist/cli/commands/search.js +0 -173
- package/dist/cli/commands/search.js.map +0 -7
- package/dist/cli/commands/service.js +0 -749
- package/dist/cli/commands/service.js.map +0 -7
- package/dist/cli/commands/session.js +0 -200
- package/dist/cli/commands/session.js.map +0 -7
- package/dist/cli/commands/settings.js +0 -306
- package/dist/cli/commands/settings.js.map +0 -7
- package/dist/cli/commands/setup.js +0 -701
- package/dist/cli/commands/setup.js.map +0 -7
- package/dist/cli/commands/shell.js +0 -249
- package/dist/cli/commands/shell.js.map +0 -7
- package/dist/cli/commands/signup.js +0 -50
- package/dist/cli/commands/signup.js.map +0 -7
- package/dist/cli/commands/skills.js +0 -470
- package/dist/cli/commands/skills.js.map +0 -7
- package/dist/cli/commands/sms-notify.js +0 -795
- package/dist/cli/commands/sms-notify.js.map +0 -7
- package/dist/cli/commands/storage-tier.js +0 -183
- package/dist/cli/commands/storage-tier.js.map +0 -7
- package/dist/cli/commands/storage.js +0 -360
- package/dist/cli/commands/storage.js.map +0 -7
- package/dist/cli/commands/sweep.js +0 -249
- package/dist/cli/commands/sweep.js.map +0 -7
- package/dist/cli/commands/tasks.js +0 -213
- package/dist/cli/commands/tasks.js.map +0 -7
- package/dist/cli/commands/test.js +0 -286
- package/dist/cli/commands/test.js.map +0 -7
- package/dist/cli/commands/workflow.js +0 -142
- package/dist/cli/commands/workflow.js.map +0 -7
- package/dist/cli/commands/worktree.js +0 -319
- package/dist/cli/commands/worktree.js.map +0 -7
- package/dist/cli/index.js +0 -594
- package/dist/cli/index.js.map +0 -7
- package/dist/cli/opencode-sm.js +0 -448
- package/dist/cli/opencode-sm.js.map +0 -7
- package/dist/cli/utils/viewer.js +0 -96
- package/dist/cli/utils/viewer.js.map +0 -7
- package/dist/core/analytics/team-analytics.js +0 -378
- package/dist/core/analytics/team-analytics.js.map +0 -7
- package/dist/core/config/config-manager.js +0 -398
- package/dist/core/config/config-manager.js.map +0 -7
- package/dist/core/config/feature-flags.js +0 -76
- package/dist/core/config/feature-flags.js.map +0 -7
- package/dist/core/config/storage-config.js +0 -115
- package/dist/core/config/storage-config.js.map +0 -7
- package/dist/core/config/types.js +0 -144
- package/dist/core/config/types.js.map +0 -7
- package/dist/core/context/auto-context.js +0 -80
- package/dist/core/context/auto-context.js.map +0 -7
- package/dist/core/context/dual-stack-manager.js +0 -870
- package/dist/core/context/dual-stack-manager.js.map +0 -7
- package/dist/core/context/enhanced-rehydration.js +0 -994
- package/dist/core/context/enhanced-rehydration.js.map +0 -7
- package/dist/core/context/frame-database.js +0 -479
- package/dist/core/context/frame-database.js.map +0 -7
- package/dist/core/context/frame-digest.js +0 -250
- package/dist/core/context/frame-digest.js.map +0 -7
- package/dist/core/context/frame-handoff-manager.js +0 -778
- package/dist/core/context/frame-handoff-manager.js.map +0 -7
- package/dist/core/context/frame-lifecycle-hooks.js +0 -119
- package/dist/core/context/frame-lifecycle-hooks.js.map +0 -7
- package/dist/core/context/frame-manager.js +0 -1069
- package/dist/core/context/frame-manager.js.map +0 -7
- package/dist/core/context/frame-recovery.js +0 -302
- package/dist/core/context/frame-recovery.js.map +0 -7
- package/dist/core/context/frame-stack.js +0 -314
- package/dist/core/context/frame-stack.js.map +0 -7
- package/dist/core/context/frame-types.js +0 -5
- package/dist/core/context/frame-types.js.map +0 -7
- package/dist/core/context/incremental-gc.js +0 -290
- package/dist/core/context/incremental-gc.js.map +0 -7
- package/dist/core/context/index.js +0 -25
- package/dist/core/context/index.js.map +0 -7
- package/dist/core/context/model-aware-compaction.js +0 -623
- package/dist/core/context/model-aware-compaction.js.map +0 -7
- package/dist/core/context/permission-manager.js +0 -185
- package/dist/core/context/permission-manager.js.map +0 -7
- package/dist/core/context/recursive-context-manager.js +0 -592
- package/dist/core/context/recursive-context-manager.js.map +0 -7
- package/dist/core/context/refactored-frame-manager.js +0 -754
- package/dist/core/context/refactored-frame-manager.js.map +0 -7
- package/dist/core/context/shared-context-layer.js +0 -621
- package/dist/core/context/shared-context-layer.js.map +0 -7
- package/dist/core/context/stack-merge-resolver.js +0 -749
- package/dist/core/context/stack-merge-resolver.js.map +0 -7
- package/dist/core/context/validation.js +0 -130
- package/dist/core/context/validation.js.map +0 -7
- package/dist/core/database/batch-operations.js +0 -384
- package/dist/core/database/batch-operations.js.map +0 -7
- package/dist/core/database/connection-pool.js +0 -330
- package/dist/core/database/connection-pool.js.map +0 -7
- package/dist/core/database/database-adapter.js +0 -60
- package/dist/core/database/database-adapter.js.map +0 -7
- package/dist/core/database/migration-manager.js +0 -614
- package/dist/core/database/migration-manager.js.map +0 -7
- package/dist/core/database/paradedb-adapter.js +0 -990
- package/dist/core/database/paradedb-adapter.js.map +0 -7
- package/dist/core/database/query-cache.js +0 -298
- package/dist/core/database/query-cache.js.map +0 -7
- package/dist/core/database/query-router.js +0 -430
- package/dist/core/database/query-router.js.map +0 -7
- package/dist/core/database/sqlite-adapter.js +0 -738
- package/dist/core/database/sqlite-adapter.js.map +0 -7
- package/dist/core/digest/enhanced-hybrid-digest.js +0 -277
- package/dist/core/digest/enhanced-hybrid-digest.js.map +0 -7
- package/dist/core/digest/frame-digest-integration.js +0 -176
- package/dist/core/digest/frame-digest-integration.js.map +0 -7
- package/dist/core/digest/hybrid-digest-generator.js +0 -553
- package/dist/core/digest/hybrid-digest-generator.js.map +0 -7
- package/dist/core/digest/index.js +0 -9
- package/dist/core/digest/index.js.map +0 -7
- package/dist/core/digest/types.js +0 -25
- package/dist/core/digest/types.js.map +0 -7
- package/dist/core/errors/error-utils.js +0 -208
- package/dist/core/errors/error-utils.js.map +0 -7
- package/dist/core/errors/index.js +0 -521
- package/dist/core/errors/index.js.map +0 -7
- package/dist/core/errors/recovery.js +0 -269
- package/dist/core/errors/recovery.js.map +0 -7
- package/dist/core/execution/parallel-executor.js +0 -258
- package/dist/core/execution/parallel-executor.js.map +0 -7
- package/dist/core/frame/workflow-templates.js +0 -319
- package/dist/core/frame/workflow-templates.js.map +0 -7
- package/dist/core/merge/conflict-detector.js +0 -431
- package/dist/core/merge/conflict-detector.js.map +0 -7
- package/dist/core/merge/index.js +0 -9
- package/dist/core/merge/index.js.map +0 -7
- package/dist/core/merge/resolution-engine.js +0 -558
- package/dist/core/merge/resolution-engine.js.map +0 -7
- package/dist/core/merge/stack-diff.js +0 -532
- package/dist/core/merge/stack-diff.js.map +0 -7
- package/dist/core/merge/unified-merge-resolver.js +0 -303
- package/dist/core/merge/unified-merge-resolver.js.map +0 -7
- package/dist/core/models/fallback-monitor.js +0 -232
- package/dist/core/models/fallback-monitor.js.map +0 -7
- package/dist/core/models/model-router.js +0 -340
- package/dist/core/models/model-router.js.map +0 -7
- package/dist/core/monitoring/error-handler.js +0 -49
- package/dist/core/monitoring/error-handler.js.map +0 -7
- package/dist/core/monitoring/logger.js +0 -202
- package/dist/core/monitoring/logger.js.map +0 -7
- package/dist/core/monitoring/metrics.js +0 -172
- package/dist/core/monitoring/metrics.js.map +0 -7
- package/dist/core/monitoring/progress-tracker.js +0 -189
- package/dist/core/monitoring/progress-tracker.js.map +0 -7
- package/dist/core/monitoring/session-monitor.js +0 -300
- package/dist/core/monitoring/session-monitor.js.map +0 -7
- package/dist/core/performance/context-cache.js +0 -273
- package/dist/core/performance/context-cache.js.map +0 -7
- package/dist/core/performance/index.js +0 -11
- package/dist/core/performance/index.js.map +0 -7
- package/dist/core/performance/lazy-context-loader.js +0 -327
- package/dist/core/performance/lazy-context-loader.js.map +0 -7
- package/dist/core/performance/monitor.js +0 -221
- package/dist/core/performance/monitor.js.map +0 -7
- package/dist/core/performance/optimized-frame-context.js +0 -345
- package/dist/core/performance/optimized-frame-context.js.map +0 -7
- package/dist/core/performance/performance-benchmark.js +0 -277
- package/dist/core/performance/performance-benchmark.js.map +0 -7
- package/dist/core/performance/performance-profiler.js +0 -370
- package/dist/core/performance/performance-profiler.js.map +0 -7
- package/dist/core/performance/streaming-jsonl-parser.js +0 -195
- package/dist/core/performance/streaming-jsonl-parser.js.map +0 -7
- package/dist/core/persistence/postgres-adapter.js +0 -349
- package/dist/core/persistence/postgres-adapter.js.map +0 -7
- package/dist/core/projects/project-isolation.js +0 -201
- package/dist/core/projects/project-isolation.js.map +0 -7
- package/dist/core/projects/project-manager.js +0 -697
- package/dist/core/projects/project-manager.js.map +0 -7
- package/dist/core/query/query-parser.js +0 -370
- package/dist/core/query/query-parser.js.map +0 -7
- package/dist/core/query/query-templates.js +0 -321
- package/dist/core/query/query-templates.js.map +0 -7
- package/dist/core/retrieval/context-retriever.js +0 -479
- package/dist/core/retrieval/context-retriever.js.map +0 -7
- package/dist/core/retrieval/graph-retrieval.js +0 -662
- package/dist/core/retrieval/graph-retrieval.js.map +0 -7
- package/dist/core/retrieval/hierarchical-retrieval.js +0 -656
- package/dist/core/retrieval/hierarchical-retrieval.js.map +0 -7
- package/dist/core/retrieval/index.js +0 -8
- package/dist/core/retrieval/index.js.map +0 -7
- package/dist/core/retrieval/llm-context-retrieval.js +0 -613
- package/dist/core/retrieval/llm-context-retrieval.js.map +0 -7
- package/dist/core/retrieval/llm-provider.js +0 -151
- package/dist/core/retrieval/llm-provider.js.map +0 -7
- package/dist/core/retrieval/retrieval-audit.js +0 -236
- package/dist/core/retrieval/retrieval-audit.js.map +0 -7
- package/dist/core/retrieval/retrieval-benchmarks.js +0 -521
- package/dist/core/retrieval/retrieval-benchmarks.js.map +0 -7
- package/dist/core/retrieval/summary-generator.js +0 -589
- package/dist/core/retrieval/summary-generator.js.map +0 -7
- package/dist/core/retrieval/types.js +0 -21
- package/dist/core/retrieval/types.js.map +0 -7
- package/dist/core/security/index.js +0 -35
- package/dist/core/security/index.js.map +0 -7
- package/dist/core/security/input-sanitizer.js +0 -321
- package/dist/core/security/input-sanitizer.js.map +0 -7
- package/dist/core/session/clear-survival.js +0 -465
- package/dist/core/session/clear-survival.js.map +0 -7
- package/dist/core/session/enhanced-handoff.js +0 -792
- package/dist/core/session/enhanced-handoff.js.map +0 -7
- package/dist/core/session/handoff-generator.js +0 -343
- package/dist/core/session/handoff-generator.js.map +0 -7
- package/dist/core/session/index.js +0 -15
- package/dist/core/session/index.js.map +0 -7
- package/dist/core/session/session-manager.js +0 -347
- package/dist/core/session/session-manager.js.map +0 -7
- package/dist/core/skills/index.js +0 -7
- package/dist/core/skills/index.js.map +0 -7
- package/dist/core/skills/skill-storage.js +0 -764
- package/dist/core/skills/skill-storage.js.map +0 -7
- package/dist/core/skills/types.js +0 -193
- package/dist/core/skills/types.js.map +0 -7
- package/dist/core/storage/chromadb-adapter.js +0 -354
- package/dist/core/storage/chromadb-adapter.js.map +0 -7
- package/dist/core/storage/infinite-storage.js +0 -510
- package/dist/core/storage/infinite-storage.js.map +0 -7
- package/dist/core/storage/railway-optimized-storage.js +0 -591
- package/dist/core/storage/railway-optimized-storage.js.map +0 -7
- package/dist/core/storage/remote-storage.js +0 -489
- package/dist/core/storage/remote-storage.js.map +0 -7
- package/dist/core/storage/two-tier-storage.js +0 -766
- package/dist/core/storage/two-tier-storage.js.map +0 -7
- package/dist/core/trace/cli-trace-wrapper.js +0 -132
- package/dist/core/trace/cli-trace-wrapper.js.map +0 -7
- package/dist/core/trace/db-trace-wrapper.js +0 -247
- package/dist/core/trace/db-trace-wrapper.js.map +0 -7
- package/dist/core/trace/debug-trace.js +0 -417
- package/dist/core/trace/debug-trace.js.map +0 -7
- package/dist/core/trace/index.js +0 -109
- package/dist/core/trace/index.js.map +0 -7
- package/dist/core/trace/linear-api-wrapper.js +0 -178
- package/dist/core/trace/linear-api-wrapper.js.map +0 -7
- package/dist/core/trace/trace-demo.js +0 -154
- package/dist/core/trace/trace-demo.js.map +0 -7
- package/dist/core/trace/trace-detector.demo.js +0 -142
- package/dist/core/trace/trace-detector.demo.js.map +0 -7
- package/dist/core/trace/trace-detector.js +0 -528
- package/dist/core/trace/trace-detector.js.map +0 -7
- package/dist/core/trace/trace-store.js +0 -345
- package/dist/core/trace/trace-store.js.map +0 -7
- package/dist/core/trace/types.js +0 -77
- package/dist/core/trace/types.js.map +0 -7
- package/dist/core/types.js +0 -5
- package/dist/core/types.js.map +0 -7
- package/dist/core/utils/async-mutex.js +0 -114
- package/dist/core/utils/async-mutex.js.map +0 -7
- package/dist/core/utils/compression.js +0 -83
- package/dist/core/utils/compression.js.map +0 -7
- package/dist/core/utils/update-checker.js +0 -218
- package/dist/core/utils/update-checker.js.map +0 -7
- package/dist/core/worktree/worktree-manager.js +0 -465
- package/dist/core/worktree/worktree-manager.js.map +0 -7
- package/dist/daemon/daemon-config.js +0 -149
- package/dist/daemon/daemon-config.js.map +0 -7
- package/dist/daemon/services/context-service.js +0 -122
- package/dist/daemon/services/context-service.js.map +0 -7
- package/dist/daemon/services/linear-service.js +0 -136
- package/dist/daemon/services/linear-service.js.map +0 -7
- package/dist/daemon/session-daemon.js +0 -312
- package/dist/daemon/session-daemon.js.map +0 -7
- package/dist/daemon/unified-daemon.js +0 -276
- package/dist/daemon/unified-daemon.js.map +0 -7
- package/dist/features/analytics/api/analytics-api.js +0 -287
- package/dist/features/analytics/api/analytics-api.js.map +0 -7
- package/dist/features/analytics/core/analytics-service.js +0 -282
- package/dist/features/analytics/core/analytics-service.js.map +0 -7
- package/dist/features/analytics/index.js +0 -18
- package/dist/features/analytics/index.js.map +0 -7
- package/dist/features/analytics/queries/metrics-queries.js +0 -277
- package/dist/features/analytics/queries/metrics-queries.js.map +0 -7
- package/dist/features/analytics/types/metrics.js +0 -5
- package/dist/features/analytics/types/metrics.js.map +0 -7
- package/dist/features/browser/browser-mcp.js +0 -492
- package/dist/features/browser/browser-mcp.js.map +0 -7
- package/dist/features/sweep/index.js +0 -20
- package/dist/features/sweep/index.js.map +0 -7
- package/dist/features/sweep/prediction-client.js +0 -155
- package/dist/features/sweep/prediction-client.js.map +0 -7
- package/dist/features/sweep/prompt-builder.js +0 -85
- package/dist/features/sweep/prompt-builder.js.map +0 -7
- package/dist/features/sweep/pty-wrapper.js +0 -171
- package/dist/features/sweep/pty-wrapper.js.map +0 -7
- package/dist/features/sweep/state-watcher.js +0 -87
- package/dist/features/sweep/state-watcher.js.map +0 -7
- package/dist/features/sweep/status-bar.js +0 -88
- package/dist/features/sweep/status-bar.js.map +0 -7
- package/dist/features/sweep/sweep-server-manager.js +0 -226
- package/dist/features/sweep/sweep-server-manager.js.map +0 -7
- package/dist/features/sweep/tab-interceptor.js +0 -38
- package/dist/features/sweep/tab-interceptor.js.map +0 -7
- package/dist/features/sweep/types.js +0 -18
- package/dist/features/sweep/types.js.map +0 -7
- package/dist/features/tasks/linear-task-manager.js +0 -487
- package/dist/features/tasks/linear-task-manager.js.map +0 -7
- package/dist/features/tasks/task-aware-context.js +0 -410
- package/dist/features/tasks/task-aware-context.js.map +0 -7
- package/dist/features/tui/simple-monitor.js +0 -116
- package/dist/features/tui/simple-monitor.js.map +0 -7
- package/dist/features/tui/swarm-monitor.js +0 -648
- package/dist/features/tui/swarm-monitor.js.map +0 -7
- package/dist/features/web/client/stores/task-store.js +0 -26
- package/dist/features/web/client/stores/task-store.js.map +0 -7
- package/dist/features/web/server/index.js +0 -194
- package/dist/features/web/server/index.js.map +0 -7
- package/dist/hooks/auto-background.js +0 -151
- package/dist/hooks/auto-background.js.map +0 -7
- package/dist/hooks/claude-code-whatsapp-hook.js +0 -197
- package/dist/hooks/claude-code-whatsapp-hook.js.map +0 -7
- package/dist/hooks/config.js +0 -150
- package/dist/hooks/config.js.map +0 -7
- package/dist/hooks/daemon.js +0 -364
- package/dist/hooks/daemon.js.map +0 -7
- package/dist/hooks/events.js +0 -58
- package/dist/hooks/events.js.map +0 -7
- package/dist/hooks/index.js +0 -12
- package/dist/hooks/index.js.map +0 -7
- package/dist/hooks/linear-task-picker.js +0 -186
- package/dist/hooks/linear-task-picker.js.map +0 -7
- package/dist/hooks/schemas.js +0 -197
- package/dist/hooks/schemas.js.map +0 -7
- package/dist/hooks/secure-fs.js +0 -49
- package/dist/hooks/secure-fs.js.map +0 -7
- package/dist/hooks/security-logger.js +0 -155
- package/dist/hooks/security-logger.js.map +0 -7
- package/dist/hooks/session-summary.js +0 -222
- package/dist/hooks/session-summary.js.map +0 -7
- package/dist/hooks/sms-action-runner.js +0 -371
- package/dist/hooks/sms-action-runner.js.map +0 -7
- package/dist/hooks/sms-notify.js +0 -506
- package/dist/hooks/sms-notify.js.map +0 -7
- package/dist/hooks/sms-watcher.js +0 -93
- package/dist/hooks/sms-watcher.js.map +0 -7
- package/dist/hooks/sms-webhook.js +0 -555
- package/dist/hooks/sms-webhook.js.map +0 -7
- package/dist/hooks/whatsapp-commands.js +0 -479
- package/dist/hooks/whatsapp-commands.js.map +0 -7
- package/dist/hooks/whatsapp-scheduler.js +0 -317
- package/dist/hooks/whatsapp-scheduler.js.map +0 -7
- package/dist/hooks/whatsapp-sync.js +0 -409
- package/dist/hooks/whatsapp-sync.js.map +0 -7
- package/dist/index.js +0 -25
- package/dist/index.js.map +0 -7
- package/dist/integrations/anthropic/client.js +0 -263
- package/dist/integrations/anthropic/client.js.map +0 -7
- package/dist/integrations/claude-code/agent-bridge.js +0 -768
- package/dist/integrations/claude-code/agent-bridge.js.map +0 -7
- package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js +0 -459
- package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js.map +0 -7
- package/dist/integrations/claude-code/lifecycle-hooks.js +0 -254
- package/dist/integrations/claude-code/lifecycle-hooks.js.map +0 -7
- package/dist/integrations/claude-code/post-task-hooks.js +0 -545
- package/dist/integrations/claude-code/post-task-hooks.js.map +0 -7
- package/dist/integrations/claude-code/subagent-client-stub.js +0 -20
- package/dist/integrations/claude-code/subagent-client-stub.js.map +0 -7
- package/dist/integrations/claude-code/subagent-client.js +0 -511
- package/dist/integrations/claude-code/subagent-client.js.map +0 -7
- package/dist/integrations/claude-code/task-coordinator.js +0 -360
- package/dist/integrations/claude-code/task-coordinator.js.map +0 -7
- package/dist/integrations/linear/auth.js +0 -337
- package/dist/integrations/linear/auth.js.map +0 -7
- package/dist/integrations/linear/auto-sync.js +0 -258
- package/dist/integrations/linear/auto-sync.js.map +0 -7
- package/dist/integrations/linear/client.js +0 -634
- package/dist/integrations/linear/client.js.map +0 -7
- package/dist/integrations/linear/config.js +0 -130
- package/dist/integrations/linear/config.js.map +0 -7
- package/dist/integrations/linear/migration.js +0 -361
- package/dist/integrations/linear/migration.js.map +0 -7
- package/dist/integrations/linear/oauth-server.js +0 -454
- package/dist/integrations/linear/oauth-server.js.map +0 -7
- package/dist/integrations/linear/rest-client.js +0 -213
- package/dist/integrations/linear/rest-client.js.map +0 -7
- package/dist/integrations/linear/sync-manager.js +0 -236
- package/dist/integrations/linear/sync-manager.js.map +0 -7
- package/dist/integrations/linear/sync-service.js +0 -231
- package/dist/integrations/linear/sync-service.js.map +0 -7
- package/dist/integrations/linear/sync.js +0 -782
- package/dist/integrations/linear/sync.js.map +0 -7
- package/dist/integrations/linear/types.js +0 -5
- package/dist/integrations/linear/types.js.map +0 -7
- package/dist/integrations/linear/unified-sync.js +0 -589
- package/dist/integrations/linear/unified-sync.js.map +0 -7
- package/dist/integrations/linear/webhook-handler.js +0 -219
- package/dist/integrations/linear/webhook-handler.js.map +0 -7
- package/dist/integrations/linear/webhook-server.js +0 -218
- package/dist/integrations/linear/webhook-server.js.map +0 -7
- package/dist/integrations/linear/webhook.js +0 -291
- package/dist/integrations/linear/webhook.js.map +0 -7
- package/dist/integrations/mcp/handlers/code-execution-handlers.js +0 -266
- package/dist/integrations/mcp/handlers/code-execution-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/context-handlers.js +0 -257
- package/dist/integrations/mcp/handlers/context-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/discovery-handlers.js +0 -497
- package/dist/integrations/mcp/handlers/discovery-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/index.js +0 -166
- package/dist/integrations/mcp/handlers/index.js.map +0 -7
- package/dist/integrations/mcp/handlers/linear-handlers.js +0 -247
- package/dist/integrations/mcp/handlers/linear-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/skill-handlers.js +0 -529
- package/dist/integrations/mcp/handlers/skill-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/task-handlers.js +0 -239
- package/dist/integrations/mcp/handlers/task-handlers.js.map +0 -7
- package/dist/integrations/mcp/handlers/trace-handlers.js +0 -308
- package/dist/integrations/mcp/handlers/trace-handlers.js.map +0 -7
- package/dist/integrations/mcp/index.js +0 -23
- package/dist/integrations/mcp/index.js.map +0 -7
- package/dist/integrations/mcp/middleware/tool-scoring.js +0 -356
- package/dist/integrations/mcp/middleware/tool-scoring.js.map +0 -7
- package/dist/integrations/mcp/refactored-server.js +0 -374
- package/dist/integrations/mcp/refactored-server.js.map +0 -7
- package/dist/integrations/mcp/remote-server.js +0 -682
- package/dist/integrations/mcp/remote-server.js.map +0 -7
- package/dist/integrations/mcp/schemas.js +0 -147
- package/dist/integrations/mcp/schemas.js.map +0 -7
- package/dist/integrations/mcp/server.js +0 -1975
- package/dist/integrations/mcp/server.js.map +0 -7
- package/dist/integrations/mcp/tool-definitions-code.js +0 -125
- package/dist/integrations/mcp/tool-definitions-code.js.map +0 -7
- package/dist/integrations/mcp/tool-definitions.js +0 -702
- package/dist/integrations/mcp/tool-definitions.js.map +0 -7
- package/dist/integrations/mcp/trace-test.js +0 -48
- package/dist/integrations/mcp/trace-test.js.map +0 -7
- package/dist/integrations/pg-aiguide/embedding-provider.js +0 -189
- package/dist/integrations/pg-aiguide/embedding-provider.js.map +0 -7
- package/dist/integrations/pg-aiguide/semantic-search.js +0 -187
- package/dist/integrations/pg-aiguide/semantic-search.js.map +0 -7
- package/dist/integrations/pg-aiguide/timescale-analytics.js +0 -224
- package/dist/integrations/pg-aiguide/timescale-analytics.js.map +0 -7
- package/dist/integrations/ralph/bridge/ralph-stackmemory-bridge.js +0 -860
- package/dist/integrations/ralph/bridge/ralph-stackmemory-bridge.js.map +0 -7
- package/dist/integrations/ralph/context/context-budget-manager.js +0 -301
- package/dist/integrations/ralph/context/context-budget-manager.js.map +0 -7
- package/dist/integrations/ralph/context/stackmemory-context-loader.js +0 -360
- package/dist/integrations/ralph/context/stackmemory-context-loader.js.map +0 -7
- package/dist/integrations/ralph/coordination/enhanced-coordination.js +0 -410
- package/dist/integrations/ralph/coordination/enhanced-coordination.js.map +0 -7
- package/dist/integrations/ralph/index.js +0 -18
- package/dist/integrations/ralph/index.js.map +0 -7
- package/dist/integrations/ralph/learning/pattern-learner.js +0 -401
- package/dist/integrations/ralph/learning/pattern-learner.js.map +0 -7
- package/dist/integrations/ralph/lifecycle/iteration-lifecycle.js +0 -448
- package/dist/integrations/ralph/lifecycle/iteration-lifecycle.js.map +0 -7
- package/dist/integrations/ralph/monitoring/swarm-dashboard.js +0 -294
- package/dist/integrations/ralph/monitoring/swarm-dashboard.js.map +0 -7
- package/dist/integrations/ralph/monitoring/swarm-registry.js +0 -108
- package/dist/integrations/ralph/monitoring/swarm-registry.js.map +0 -7
- package/dist/integrations/ralph/orchestration/multi-loop-orchestrator.js +0 -463
- package/dist/integrations/ralph/orchestration/multi-loop-orchestrator.js.map +0 -7
- package/dist/integrations/ralph/patterns/compounding-engineering-pattern.js +0 -400
- package/dist/integrations/ralph/patterns/compounding-engineering-pattern.js.map +0 -7
- package/dist/integrations/ralph/patterns/extended-coherence-sessions.js +0 -473
- package/dist/integrations/ralph/patterns/extended-coherence-sessions.js.map +0 -7
- package/dist/integrations/ralph/patterns/oracle-worker-pattern.js +0 -388
- package/dist/integrations/ralph/patterns/oracle-worker-pattern.js.map +0 -7
- package/dist/integrations/ralph/performance/performance-optimizer.js +0 -358
- package/dist/integrations/ralph/performance/performance-optimizer.js.map +0 -7
- package/dist/integrations/ralph/ralph-integration-demo.js +0 -182
- package/dist/integrations/ralph/ralph-integration-demo.js.map +0 -7
- package/dist/integrations/ralph/recovery/crash-recovery.js +0 -462
- package/dist/integrations/ralph/recovery/crash-recovery.js.map +0 -7
- package/dist/integrations/ralph/state/state-reconciler.js +0 -404
- package/dist/integrations/ralph/state/state-reconciler.js.map +0 -7
- package/dist/integrations/ralph/swarm/git-workflow-manager.js +0 -428
- package/dist/integrations/ralph/swarm/git-workflow-manager.js.map +0 -7
- package/dist/integrations/ralph/swarm/swarm-coordinator.js +0 -996
- package/dist/integrations/ralph/swarm/swarm-coordinator.js.map +0 -7
- package/dist/integrations/ralph/types.js +0 -5
- package/dist/integrations/ralph/types.js.map +0 -7
- package/dist/integrations/ralph/visualization/ralph-debugger.js +0 -585
- package/dist/integrations/ralph/visualization/ralph-debugger.js.map +0 -7
- package/dist/mcp/stackmemory-mcp-server.js +0 -554
- package/dist/mcp/stackmemory-mcp-server.js.map +0 -7
- package/dist/middleware/exponential-rate-limiter.js +0 -289
- package/dist/middleware/exponential-rate-limiter.js.map +0 -7
- package/dist/models/user.model.js +0 -358
- package/dist/models/user.model.js.map +0 -7
- package/dist/servers/production/auth-middleware.js +0 -528
- package/dist/servers/production/auth-middleware.js.map +0 -7
- package/dist/servers/railway/config.js +0 -55
- package/dist/servers/railway/config.js.map +0 -7
- package/dist/servers/railway/index-enhanced.js +0 -160
- package/dist/servers/railway/index-enhanced.js.map +0 -7
- package/dist/servers/railway/index.js +0 -1349
- package/dist/servers/railway/index.js.map +0 -7
- package/dist/servers/railway/simple.js +0 -64
- package/dist/servers/railway/simple.js.map +0 -7
- package/dist/servers/railway/storage-test.js +0 -459
- package/dist/servers/railway/storage-test.js.map +0 -7
- package/dist/services/config-service.js +0 -65
- package/dist/services/config-service.js.map +0 -7
- package/dist/services/context-service.js +0 -194
- package/dist/services/context-service.js.map +0 -7
- package/dist/skills/api-discovery.js +0 -354
- package/dist/skills/api-discovery.js.map +0 -7
- package/dist/skills/api-skill.js +0 -475
- package/dist/skills/api-skill.js.map +0 -7
- package/dist/skills/claude-skills.js +0 -1061
- package/dist/skills/claude-skills.js.map +0 -7
- package/dist/skills/dashboard-launcher.js +0 -216
- package/dist/skills/dashboard-launcher.js.map +0 -7
- package/dist/skills/recursive-agent-orchestrator.js +0 -575
- package/dist/skills/recursive-agent-orchestrator.js.map +0 -7
- package/dist/skills/repo-ingestion-skill.js +0 -609
- package/dist/skills/repo-ingestion-skill.js.map +0 -7
- package/dist/skills/security-secrets-scanner.js +0 -284
- package/dist/skills/security-secrets-scanner.js.map +0 -7
- package/dist/skills/unified-rlm-orchestrator.js +0 -404
- package/dist/skills/unified-rlm-orchestrator.js.map +0 -7
- package/dist/types/task.js +0 -5
- package/dist/types/task.js.map +0 -7
- package/dist/utils/env.js +0 -50
- package/dist/utils/env.js.map +0 -7
- package/dist/utils/formatting.js +0 -62
- package/dist/utils/formatting.js.map +0 -7
- package/dist/utils/process-cleanup.js +0 -136
- package/dist/utils/process-cleanup.js.map +0 -7
- package/dist/validation/schemas.js +0 -222
- package/dist/validation/schemas.js.map +0 -7
- /package/dist/{core/merge → src/core/extensions}/types.js +0 -0
- /package/dist/{core/merge → src/core/extensions}/types.js.map +0 -0
|
@@ -1,360 +0,0 @@
|
|
|
1
|
-
import { fileURLToPath as __fileURLToPath } from 'url';
|
|
2
|
-
import { dirname as __pathDirname } from 'path';
|
|
3
|
-
const __filename = __fileURLToPath(import.meta.url);
|
|
4
|
-
const __dirname = __pathDirname(__filename);
|
|
5
|
-
import { logger } from "../../../core/monitoring/logger.js";
|
|
6
|
-
import { FrameManager } from "../../../core/context/index.js";
|
|
7
|
-
import { sharedContextLayer } from "../../../core/context/shared-context-layer.js";
|
|
8
|
-
import { ContextRetriever } from "../../../core/retrieval/context-retriever.js";
|
|
9
|
-
import { sessionManager } from "../../../core/session/index.js";
|
|
10
|
-
import { ContextBudgetManager } from "./context-budget-manager.js";
|
|
11
|
-
class StackMemoryContextLoader {
|
|
12
|
-
frameManager;
|
|
13
|
-
contextRetriever;
|
|
14
|
-
budgetManager;
|
|
15
|
-
config;
|
|
16
|
-
constructor(config) {
|
|
17
|
-
this.config = {
|
|
18
|
-
maxTokens: 3200,
|
|
19
|
-
// Leave room for task description
|
|
20
|
-
lookbackDays: 30,
|
|
21
|
-
similarityThreshold: 0.7,
|
|
22
|
-
patternDetectionEnabled: true,
|
|
23
|
-
includeFailedAttempts: true,
|
|
24
|
-
crossSessionSearch: true,
|
|
25
|
-
...config
|
|
26
|
-
};
|
|
27
|
-
this.budgetManager = new ContextBudgetManager({
|
|
28
|
-
maxTokens: this.config.maxTokens,
|
|
29
|
-
priorityWeights: {
|
|
30
|
-
task: 0.15,
|
|
31
|
-
recentWork: 0.3,
|
|
32
|
-
patterns: 0.25,
|
|
33
|
-
decisions: 0.2,
|
|
34
|
-
dependencies: 0.1
|
|
35
|
-
}
|
|
36
|
-
});
|
|
37
|
-
logger.info("StackMemory context loader initialized", {
|
|
38
|
-
maxTokens: this.config.maxTokens,
|
|
39
|
-
lookbackDays: this.config.lookbackDays,
|
|
40
|
-
patternDetection: this.config.patternDetectionEnabled
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
async initialize() {
|
|
44
|
-
try {
|
|
45
|
-
await sessionManager.initialize();
|
|
46
|
-
await sharedContextLayer.initialize();
|
|
47
|
-
const session = await sessionManager.getOrCreateSession({});
|
|
48
|
-
if (session.database) {
|
|
49
|
-
this.frameManager = new FrameManager(session.database, session.projectId);
|
|
50
|
-
this.contextRetriever = new ContextRetriever(session.database);
|
|
51
|
-
}
|
|
52
|
-
logger.info("Context loader initialized successfully");
|
|
53
|
-
} catch (error) {
|
|
54
|
-
logger.error("Failed to initialize context loader", error);
|
|
55
|
-
throw error;
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
/**
|
|
59
|
-
* Load context for Ralph loop initialization
|
|
60
|
-
*/
|
|
61
|
-
async loadInitialContext(request) {
|
|
62
|
-
logger.info("Loading initial context for Ralph loop", {
|
|
63
|
-
task: request.task.substring(0, 100),
|
|
64
|
-
usePatterns: request.usePatterns,
|
|
65
|
-
useSimilarTasks: request.useSimilarTasks
|
|
66
|
-
});
|
|
67
|
-
const sources = [];
|
|
68
|
-
let totalTokens = 0;
|
|
69
|
-
try {
|
|
70
|
-
if (request.useSimilarTasks) {
|
|
71
|
-
const similarTasks2 = await this.findSimilarTasks(request.task);
|
|
72
|
-
if (similarTasks2.length > 0) {
|
|
73
|
-
const tasksContext = await this.extractTaskContext(similarTasks2);
|
|
74
|
-
sources.push({
|
|
75
|
-
type: "similar_tasks",
|
|
76
|
-
weight: 0.3,
|
|
77
|
-
content: tasksContext,
|
|
78
|
-
tokens: this.budgetManager.estimateTokens(tasksContext)
|
|
79
|
-
});
|
|
80
|
-
totalTokens += sources[sources.length - 1].tokens;
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
if (request.usePatterns) {
|
|
84
|
-
const patterns2 = await this.extractRelevantPatterns(request.task);
|
|
85
|
-
if (patterns2.length > 0) {
|
|
86
|
-
const patternsContext = await this.formatPatterns(patterns2);
|
|
87
|
-
sources.push({
|
|
88
|
-
type: "historical_patterns",
|
|
89
|
-
weight: 0.25,
|
|
90
|
-
content: patternsContext,
|
|
91
|
-
tokens: this.budgetManager.estimateTokens(patternsContext)
|
|
92
|
-
});
|
|
93
|
-
totalTokens += sources[sources.length - 1].tokens;
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
const decisions = await this.loadRecentDecisions();
|
|
97
|
-
if (decisions.length > 0) {
|
|
98
|
-
const decisionsContext = this.formatDecisions(decisions);
|
|
99
|
-
sources.push({
|
|
100
|
-
type: "recent_decisions",
|
|
101
|
-
weight: 0.2,
|
|
102
|
-
content: decisionsContext,
|
|
103
|
-
tokens: this.budgetManager.estimateTokens(decisionsContext)
|
|
104
|
-
});
|
|
105
|
-
totalTokens += sources[sources.length - 1].tokens;
|
|
106
|
-
}
|
|
107
|
-
const projectContext = await this.loadProjectContext(request.task);
|
|
108
|
-
if (projectContext) {
|
|
109
|
-
sources.push({
|
|
110
|
-
type: "project_context",
|
|
111
|
-
weight: 0.15,
|
|
112
|
-
content: projectContext,
|
|
113
|
-
tokens: this.budgetManager.estimateTokens(projectContext)
|
|
114
|
-
});
|
|
115
|
-
totalTokens += sources[sources.length - 1].tokens;
|
|
116
|
-
}
|
|
117
|
-
const budgetedSources = this.budgetManager.allocateBudget({ sources });
|
|
118
|
-
const synthesizedContext = this.synthesizeContext(budgetedSources.sources);
|
|
119
|
-
logger.info("Context loaded successfully", {
|
|
120
|
-
totalSources: sources.length,
|
|
121
|
-
totalTokens,
|
|
122
|
-
budgetedTokens: budgetedSources.sources.reduce((sum, s) => sum + s.tokens, 0)
|
|
123
|
-
});
|
|
124
|
-
return {
|
|
125
|
-
context: synthesizedContext,
|
|
126
|
-
sources: budgetedSources.sources,
|
|
127
|
-
metadata: {
|
|
128
|
-
totalTokens: budgetedSources.sources.reduce((sum, s) => sum + s.tokens, 0),
|
|
129
|
-
sourcesCount: budgetedSources.sources.length,
|
|
130
|
-
patterns: request.usePatterns ? patterns : [],
|
|
131
|
-
similarTasks: request.useSimilarTasks ? similarTasks : []
|
|
132
|
-
}
|
|
133
|
-
};
|
|
134
|
-
} catch (error) {
|
|
135
|
-
logger.error("Failed to load context", error);
|
|
136
|
-
throw error;
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
/**
|
|
140
|
-
* Find similar tasks from StackMemory history
|
|
141
|
-
*/
|
|
142
|
-
async findSimilarTasks(taskDescription) {
|
|
143
|
-
if (!this.frameManager || !this.contextRetriever) {
|
|
144
|
-
return [];
|
|
145
|
-
}
|
|
146
|
-
try {
|
|
147
|
-
const searchResults = await this.contextRetriever.search(taskDescription, {
|
|
148
|
-
maxResults: 10,
|
|
149
|
-
types: ["task", "subtask"],
|
|
150
|
-
timeFilter: {
|
|
151
|
-
days: this.config.lookbackDays
|
|
152
|
-
}
|
|
153
|
-
});
|
|
154
|
-
const similarities = [];
|
|
155
|
-
for (const result of searchResults) {
|
|
156
|
-
const similarity = this.calculateTaskSimilarity(taskDescription, result.content);
|
|
157
|
-
if (similarity >= this.config.similarityThreshold) {
|
|
158
|
-
similarities.push({
|
|
159
|
-
frameId: result.frameId,
|
|
160
|
-
task: result.content,
|
|
161
|
-
similarity,
|
|
162
|
-
outcome: await this.determineTaskOutcome(result.frameId),
|
|
163
|
-
createdAt: result.timestamp,
|
|
164
|
-
sessionId: result.sessionId || "unknown"
|
|
165
|
-
});
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
return similarities.sort((a, b) => {
|
|
169
|
-
const aScore = a.similarity * (a.outcome === "success" ? 1.2 : 1);
|
|
170
|
-
const bScore = b.similarity * (b.outcome === "success" ? 1.2 : 1);
|
|
171
|
-
return bScore - aScore;
|
|
172
|
-
}).slice(0, 5);
|
|
173
|
-
} catch (error) {
|
|
174
|
-
logger.error("Failed to find similar tasks", error);
|
|
175
|
-
return [];
|
|
176
|
-
}
|
|
177
|
-
}
|
|
178
|
-
/**
|
|
179
|
-
* Extract relevant patterns from historical data
|
|
180
|
-
*/
|
|
181
|
-
async extractRelevantPatterns(taskDescription) {
|
|
182
|
-
try {
|
|
183
|
-
const context = await sharedContextLayer.getSharedContext();
|
|
184
|
-
if (!context) return [];
|
|
185
|
-
const relevantPatterns = [];
|
|
186
|
-
for (const pattern of context.globalPatterns) {
|
|
187
|
-
const relevance = this.calculatePatternRelevance(taskDescription, pattern.pattern);
|
|
188
|
-
if (relevance >= 0.5) {
|
|
189
|
-
relevantPatterns.push({
|
|
190
|
-
pattern: pattern.pattern,
|
|
191
|
-
type: pattern.type,
|
|
192
|
-
frequency: pattern.frequency,
|
|
193
|
-
lastSeen: pattern.lastSeen,
|
|
194
|
-
relevance,
|
|
195
|
-
resolution: pattern.resolution,
|
|
196
|
-
examples: await this.getPatternExamples(pattern.pattern)
|
|
197
|
-
});
|
|
198
|
-
}
|
|
199
|
-
}
|
|
200
|
-
return relevantPatterns.sort((a, b) => b.relevance * Math.log(b.frequency + 1) - a.relevance * Math.log(a.frequency + 1)).slice(0, 8);
|
|
201
|
-
} catch (error) {
|
|
202
|
-
logger.error("Failed to extract patterns", error);
|
|
203
|
-
return [];
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
/**
|
|
207
|
-
* Load recent decisions that might be relevant
|
|
208
|
-
*/
|
|
209
|
-
async loadRecentDecisions() {
|
|
210
|
-
try {
|
|
211
|
-
const context = await sharedContextLayer.getSharedContext();
|
|
212
|
-
if (!context) return [];
|
|
213
|
-
const cutoff = Date.now() - 7 * 24 * 60 * 60 * 1e3;
|
|
214
|
-
return context.decisionLog.filter((d) => d.timestamp >= cutoff && d.outcome === "success").sort((a, b) => b.timestamp - a.timestamp).slice(0, 5);
|
|
215
|
-
} catch (error) {
|
|
216
|
-
logger.error("Failed to load recent decisions", error);
|
|
217
|
-
return [];
|
|
218
|
-
}
|
|
219
|
-
}
|
|
220
|
-
/**
|
|
221
|
-
* Load project-specific context
|
|
222
|
-
*/
|
|
223
|
-
async loadProjectContext(taskDescription) {
|
|
224
|
-
try {
|
|
225
|
-
if (!this.contextRetriever) return null;
|
|
226
|
-
const projectInfo = await this.contextRetriever.search(taskDescription, {
|
|
227
|
-
maxResults: 3,
|
|
228
|
-
types: ["task"],
|
|
229
|
-
projectSpecific: true
|
|
230
|
-
});
|
|
231
|
-
if (projectInfo.length === 0) return null;
|
|
232
|
-
const contextParts = [];
|
|
233
|
-
for (const info of projectInfo) {
|
|
234
|
-
contextParts.push(`Project context: ${info.content}`);
|
|
235
|
-
}
|
|
236
|
-
return contextParts.join("\n\n");
|
|
237
|
-
} catch (error) {
|
|
238
|
-
logger.error("Failed to load project context", error);
|
|
239
|
-
return null;
|
|
240
|
-
}
|
|
241
|
-
}
|
|
242
|
-
/**
|
|
243
|
-
* Calculate similarity between task descriptions
|
|
244
|
-
*/
|
|
245
|
-
calculateTaskSimilarity(task1, task2) {
|
|
246
|
-
const words1 = new Set(task1.toLowerCase().split(/\s+/));
|
|
247
|
-
const words2 = new Set(task2.toLowerCase().split(/\s+/));
|
|
248
|
-
const intersection = new Set([...words1].filter((x) => words2.has(x)));
|
|
249
|
-
const union = /* @__PURE__ */ new Set([...words1, ...words2]);
|
|
250
|
-
return intersection.size / union.size;
|
|
251
|
-
}
|
|
252
|
-
/**
|
|
253
|
-
* Calculate pattern relevance to current task
|
|
254
|
-
*/
|
|
255
|
-
calculatePatternRelevance(taskDescription, pattern) {
|
|
256
|
-
const taskWords = taskDescription.toLowerCase().split(/\s+/);
|
|
257
|
-
const patternWords = pattern.toLowerCase().split(/\s+/);
|
|
258
|
-
let matches = 0;
|
|
259
|
-
for (const word of taskWords) {
|
|
260
|
-
if (patternWords.some((p) => p.includes(word) || word.includes(p))) {
|
|
261
|
-
matches++;
|
|
262
|
-
}
|
|
263
|
-
}
|
|
264
|
-
return matches / taskWords.length;
|
|
265
|
-
}
|
|
266
|
-
/**
|
|
267
|
-
* Extract context from similar tasks
|
|
268
|
-
*/
|
|
269
|
-
async extractTaskContext(similarities) {
|
|
270
|
-
const contextParts = [];
|
|
271
|
-
contextParts.push("Similar tasks from history:");
|
|
272
|
-
for (const sim of similarities) {
|
|
273
|
-
contextParts.push(`
|
|
274
|
-
Task: ${sim.task}
|
|
275
|
-
Outcome: ${sim.outcome}
|
|
276
|
-
Similarity: ${Math.round(sim.similarity * 100)}%
|
|
277
|
-
${sim.outcome === "success" ? "\u2705 Successfully completed" : "\u274C Had issues"}
|
|
278
|
-
`.trim());
|
|
279
|
-
}
|
|
280
|
-
return contextParts.join("\n\n");
|
|
281
|
-
}
|
|
282
|
-
/**
|
|
283
|
-
* Format patterns for context inclusion
|
|
284
|
-
*/
|
|
285
|
-
async formatPatterns(patterns2) {
|
|
286
|
-
const contextParts = [];
|
|
287
|
-
contextParts.push("Relevant patterns from experience:");
|
|
288
|
-
for (const pattern of patterns2) {
|
|
289
|
-
contextParts.push(`
|
|
290
|
-
Pattern: ${pattern.pattern}
|
|
291
|
-
Type: ${pattern.type}
|
|
292
|
-
Frequency: ${pattern.frequency} occurrences
|
|
293
|
-
${pattern.resolution ? `Resolution: ${pattern.resolution}` : ""}
|
|
294
|
-
Relevance: ${Math.round(pattern.relevance * 100)}%
|
|
295
|
-
`.trim());
|
|
296
|
-
}
|
|
297
|
-
return contextParts.join("\n\n");
|
|
298
|
-
}
|
|
299
|
-
/**
|
|
300
|
-
* Format decisions for context inclusion
|
|
301
|
-
*/
|
|
302
|
-
formatDecisions(decisions) {
|
|
303
|
-
const contextParts = [];
|
|
304
|
-
contextParts.push("Recent successful decisions:");
|
|
305
|
-
for (const decision of decisions) {
|
|
306
|
-
contextParts.push(`
|
|
307
|
-
Decision: ${decision.decision}
|
|
308
|
-
Reasoning: ${decision.reasoning}
|
|
309
|
-
Date: ${new Date(decision.timestamp).toLocaleDateString()}
|
|
310
|
-
`.trim());
|
|
311
|
-
}
|
|
312
|
-
return contextParts.join("\n\n");
|
|
313
|
-
}
|
|
314
|
-
/**
|
|
315
|
-
* Synthesize all context sources into coherent input
|
|
316
|
-
*/
|
|
317
|
-
synthesizeContext(sources) {
|
|
318
|
-
if (sources.length === 0) {
|
|
319
|
-
return "No relevant historical context found.";
|
|
320
|
-
}
|
|
321
|
-
const contextParts = [];
|
|
322
|
-
contextParts.push("Context from StackMemory:");
|
|
323
|
-
const sortedSources = sources.sort((a, b) => b.weight - a.weight);
|
|
324
|
-
for (const source of sortedSources) {
|
|
325
|
-
contextParts.push(`
|
|
326
|
-
--- ${source.type.replace("_", " ").toUpperCase()} ---`);
|
|
327
|
-
contextParts.push(source.content);
|
|
328
|
-
}
|
|
329
|
-
contextParts.push("\nUse this context to inform your approach to the current task.");
|
|
330
|
-
return contextParts.join("\n");
|
|
331
|
-
}
|
|
332
|
-
/**
|
|
333
|
-
* Determine task outcome from frame history
|
|
334
|
-
*/
|
|
335
|
-
async determineTaskOutcome(frameId) {
|
|
336
|
-
try {
|
|
337
|
-
if (!this.frameManager) return "unknown";
|
|
338
|
-
const frame = await this.frameManager.getFrame(frameId);
|
|
339
|
-
if (!frame) return "unknown";
|
|
340
|
-
if (frame.state === "closed" && frame.outputs) {
|
|
341
|
-
return "success";
|
|
342
|
-
}
|
|
343
|
-
return frame.state === "closed" ? "failure" : "unknown";
|
|
344
|
-
} catch {
|
|
345
|
-
return "unknown";
|
|
346
|
-
}
|
|
347
|
-
}
|
|
348
|
-
/**
|
|
349
|
-
* Get examples of a specific pattern
|
|
350
|
-
*/
|
|
351
|
-
async getPatternExamples(pattern) {
|
|
352
|
-
return [];
|
|
353
|
-
}
|
|
354
|
-
}
|
|
355
|
-
const stackMemoryContextLoader = new StackMemoryContextLoader();
|
|
356
|
-
export {
|
|
357
|
-
StackMemoryContextLoader,
|
|
358
|
-
stackMemoryContextLoader
|
|
359
|
-
};
|
|
360
|
-
//# sourceMappingURL=stackmemory-context-loader.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 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/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
|
-
"mappings": "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",
|
|
6
|
-
"names": ["similarTasks", "patterns"]
|
|
7
|
-
}
|