@stackmemoryai/stackmemory 0.3.0 → 0.3.3
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 +52 -272
- package/dist/cli/codex-sm.js +48 -19
- package/dist/cli/codex-sm.js.map +2 -2
- package/dist/cli/commands/clear.js +191 -0
- package/dist/cli/commands/clear.js.map +7 -0
- package/dist/cli/commands/config.js +152 -1
- package/dist/cli/commands/config.js.map +2 -2
- package/dist/cli/commands/dashboard.js +178 -0
- package/dist/cli/commands/dashboard.js.map +7 -0
- package/dist/cli/commands/handoff.js +125 -8
- package/dist/cli/commands/handoff.js.map +2 -2
- package/dist/cli/commands/linear-create.js +132 -0
- package/dist/cli/commands/linear-create.js.map +7 -0
- package/dist/cli/commands/linear-list.js +69 -0
- package/dist/cli/commands/linear-list.js.map +7 -0
- package/dist/cli/commands/linear-migrate.js +40 -0
- package/dist/cli/commands/linear-migrate.js.map +7 -0
- package/dist/cli/commands/linear.js +185 -36
- package/dist/cli/commands/linear.js.map +2 -2
- package/dist/cli/commands/monitor.js +309 -0
- package/dist/cli/commands/monitor.js.map +7 -0
- package/dist/cli/commands/quality.js +414 -0
- package/dist/cli/commands/quality.js.map +7 -0
- package/dist/cli/commands/storage.js +275 -0
- package/dist/cli/commands/storage.js.map +7 -0
- package/dist/cli/commands/tui.js +66 -0
- package/dist/cli/commands/tui.js.map +7 -0
- package/dist/cli/commands/workflow.js +134 -0
- package/dist/cli/commands/workflow.js.map +7 -0
- package/dist/cli/index.js +105 -9
- package/dist/cli/index.js.map +3 -3
- package/dist/core/analytics/team-analytics.js +374 -0
- package/dist/core/analytics/team-analytics.js.map +7 -0
- package/dist/core/context/context-bridge.js +234 -0
- package/dist/core/context/context-bridge.js.map +7 -0
- package/dist/core/context/dual-stack-manager.js +850 -0
- package/dist/core/context/dual-stack-manager.js.map +7 -0
- package/dist/core/context/frame-handoff-manager.js +384 -0
- package/dist/core/context/frame-handoff-manager.js.map +7 -0
- package/dist/core/context/frame-manager.js +132 -12
- package/dist/core/context/frame-manager.js.map +2 -2
- package/dist/core/context/permission-manager.js +181 -0
- package/dist/core/context/permission-manager.js.map +7 -0
- package/dist/core/context/shared-context-layer.js +386 -0
- package/dist/core/context/shared-context-layer.js.map +7 -0
- package/dist/core/context/stack-merge-resolver.js +600 -0
- package/dist/core/context/stack-merge-resolver.js.map +7 -0
- package/dist/core/context/validation.js +121 -0
- package/dist/core/context/validation.js.map +7 -0
- package/dist/core/database/connection-pool.js +266 -175
- package/dist/core/database/connection-pool.js.map +2 -2
- package/dist/core/database/database-adapter.js +51 -0
- package/dist/core/database/database-adapter.js.map +7 -0
- package/dist/core/database/migration-manager.js +514 -0
- package/dist/core/database/migration-manager.js.map +7 -0
- package/dist/core/database/paradedb-adapter.js +970 -0
- package/dist/core/database/paradedb-adapter.js.map +7 -0
- package/dist/core/database/query-router.js +421 -0
- package/dist/core/database/query-router.js.map +7 -0
- package/dist/core/database/sqlite-adapter.js +547 -0
- package/dist/core/database/sqlite-adapter.js.map +7 -0
- package/dist/core/errors/index.js +21 -1
- package/dist/core/errors/index.js.map +2 -2
- package/dist/core/frame/workflow-templates-stub.js +42 -0
- package/dist/core/frame/workflow-templates-stub.js.map +7 -0
- package/dist/core/frame/workflow-templates.js +276 -0
- package/dist/core/frame/workflow-templates.js.map +7 -0
- package/dist/core/merge/conflict-detector.js +5 -2
- package/dist/core/merge/conflict-detector.js.map +2 -2
- package/dist/core/merge/resolution-engine.js +3 -14
- package/dist/core/merge/resolution-engine.js.map +2 -2
- package/dist/core/merge/stack-diff.js.map +2 -2
- package/dist/core/monitoring/logger.js +18 -3
- package/dist/core/monitoring/logger.js.map +2 -2
- package/dist/core/monitoring/session-monitor.js +296 -0
- package/dist/core/monitoring/session-monitor.js.map +7 -0
- package/dist/core/retrieval/context-retriever.js +475 -0
- package/dist/core/retrieval/context-retriever.js.map +7 -0
- package/dist/core/retrieval/graph-retrieval.js +658 -0
- package/dist/core/retrieval/graph-retrieval.js.map +7 -0
- package/dist/core/retrieval/hierarchical-retrieval.js +652 -0
- package/dist/core/retrieval/hierarchical-retrieval.js.map +7 -0
- package/dist/core/retrieval/retrieval-benchmarks.js +517 -0
- package/dist/core/retrieval/retrieval-benchmarks.js.map +7 -0
- package/dist/core/session/clear-survival-stub.js +49 -0
- package/dist/core/session/clear-survival-stub.js.map +7 -0
- package/dist/core/session/clear-survival.js +426 -0
- package/dist/core/session/clear-survival.js.map +7 -0
- package/dist/core/session/handoff-generator.js +339 -0
- package/dist/core/session/handoff-generator.js.map +7 -0
- package/dist/core/session/session-manager.js +61 -26
- package/dist/core/session/session-manager.js.map +3 -3
- package/dist/core/skills/index.js +3 -0
- package/dist/core/skills/index.js.map +7 -0
- package/dist/core/skills/skill-storage.js +749 -0
- package/dist/core/skills/skill-storage.js.map +7 -0
- package/dist/core/skills/types.js +189 -0
- package/dist/core/skills/types.js.map +7 -0
- package/dist/core/storage/railway-optimized-storage.js +550 -0
- package/dist/core/storage/railway-optimized-storage.js.map +7 -0
- package/dist/core/storage/remote-storage.js +456 -0
- package/dist/core/storage/remote-storage.js.map +7 -0
- package/dist/core/trace/trace-detector.js +136 -5
- package/dist/core/trace/trace-detector.js.map +2 -2
- package/dist/core/trace/trace-store.js.map +2 -2
- package/dist/features/tui/components/analytics-panel.js +136 -0
- package/dist/features/tui/components/analytics-panel.js.map +7 -0
- package/dist/features/tui/components/frame-visualizer.js +377 -0
- package/dist/features/tui/components/frame-visualizer.js.map +7 -0
- package/dist/features/tui/components/pr-tracker.js +123 -0
- package/dist/features/tui/components/pr-tracker.js.map +7 -0
- package/dist/features/tui/components/session-monitor.js +286 -0
- package/dist/features/tui/components/session-monitor.js.map +7 -0
- package/dist/features/tui/components/subagent-fleet.js +388 -0
- package/dist/features/tui/components/subagent-fleet.js.map +7 -0
- package/dist/features/tui/components/task-board.js +475 -0
- package/dist/features/tui/components/task-board.js.map +7 -0
- package/dist/features/tui/index.js +397 -0
- package/dist/features/tui/index.js.map +7 -0
- package/dist/features/tui/services/data-service.js +654 -0
- package/dist/features/tui/services/data-service.js.map +7 -0
- package/dist/features/tui/services/websocket-client.js +149 -0
- package/dist/features/tui/services/websocket-client.js.map +7 -0
- package/dist/features/tui/terminal-compat.js +205 -0
- package/dist/features/tui/terminal-compat.js.map +7 -0
- package/dist/features/tui/types.js +1 -0
- package/dist/features/tui/types.js.map +7 -0
- package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js +455 -0
- package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js.map +7 -0
- package/dist/integrations/claude-code/lifecycle-hooks.js +250 -0
- package/dist/integrations/claude-code/lifecycle-hooks.js.map +7 -0
- package/dist/integrations/claude-code/post-task-hooks.js +541 -0
- package/dist/integrations/claude-code/post-task-hooks.js.map +7 -0
- package/dist/integrations/linear/client.js +22 -4
- package/dist/integrations/linear/client.js.map +2 -2
- package/dist/integrations/linear/migration.js +299 -0
- package/dist/integrations/linear/migration.js.map +7 -0
- package/dist/integrations/linear/oauth-server.js +396 -0
- package/dist/integrations/linear/oauth-server.js.map +7 -0
- package/dist/integrations/linear/rest-client.js +199 -0
- package/dist/integrations/linear/rest-client.js.map +7 -0
- package/dist/integrations/linear/sync.js +14 -2
- package/dist/integrations/linear/sync.js.map +2 -2
- package/dist/integrations/linear/webhook-handler.js +200 -0
- package/dist/integrations/linear/webhook-handler.js.map +7 -0
- package/dist/integrations/mcp/handlers/skill-handlers.js +514 -0
- package/dist/integrations/mcp/handlers/skill-handlers.js.map +7 -0
- package/dist/integrations/mcp/middleware/tool-scoring.js +352 -0
- package/dist/integrations/mcp/middleware/tool-scoring.js.map +7 -0
- package/dist/integrations/mcp/refactored-server.js +31 -3
- package/dist/integrations/mcp/refactored-server.js.map +2 -2
- package/dist/integrations/mcp/server.js +25 -7
- package/dist/integrations/mcp/server.js.map +2 -2
- package/dist/mcp/stackmemory-mcp-server.js.map +1 -1
- package/dist/models/user.model.js +3 -0
- package/dist/models/user.model.js.map +2 -2
- package/dist/services/context-service.js.map +2 -2
- package/dist/utils/formatting.js +58 -0
- package/dist/utils/formatting.js.map +7 -0
- package/package.json +24 -5
- package/dist/cli/__tests__/index.test.js +0 -290
- package/dist/cli/__tests__/index.test.js.map +0 -7
- package/dist/core/config/__tests__/config-manager.test.js +0 -248
- package/dist/core/config/__tests__/config-manager.test.js.map +0 -7
- package/dist/core/context/__tests__/frame-manager.test.js +0 -879
- package/dist/core/context/__tests__/frame-manager.test.js.map +0 -7
- package/dist/core/digest/__tests__/enhanced-hybrid-digest.test.js +0 -379
- package/dist/core/digest/__tests__/enhanced-hybrid-digest.test.js.map +0 -7
- package/dist/core/digest/__tests__/frame-digest-integration.test.js +0 -230
- package/dist/core/digest/__tests__/frame-digest-integration.test.js.map +0 -7
- package/dist/core/errors/__tests__/error-handling.test.js +0 -270
- package/dist/core/errors/__tests__/error-handling.test.js.map +0 -7
- package/dist/core/merge/__tests__/conflict-scenarios.test.js +0 -414
- package/dist/core/merge/__tests__/conflict-scenarios.test.js.map +0 -7
- package/dist/core/query/__tests__/query-parser.test.js +0 -301
- package/dist/core/query/__tests__/query-parser.test.js.map +0 -7
- package/dist/core/query/__tests__/query-templates.test.js +0 -210
- package/dist/core/query/__tests__/query-templates.test.js.map +0 -7
- package/dist/core/trace/trace-detector.test.js +0 -401
- package/dist/core/trace/trace-detector.test.js.map +0 -7
- package/dist/features/tasks/__tests__/pebbles-task-store.test.js +0 -747
- package/dist/features/tasks/__tests__/pebbles-task-store.test.js.map +0 -7
- package/dist/integrations/linear/__tests__/auth.test.js +0 -558
- package/dist/integrations/linear/__tests__/auth.test.js.map +0 -7
- package/dist/integrations/linear/__tests__/sync-service.test.js +0 -760
- package/dist/integrations/linear/__tests__/sync-service.test.js.map +0 -7
- package/dist/integrations/mcp/__tests__/server.test.js +0 -798
- package/dist/integrations/mcp/__tests__/server.test.js.map +0 -7
- package/dist/scripts/benchmark-performance.d.ts +0 -7
- package/dist/scripts/benchmark-performance.d.ts.map +0 -1
- package/dist/scripts/benchmark-performance.js +0 -44
- package/dist/scripts/benchmark-performance.js.map +0 -1
- package/dist/scripts/cancel-duplicate-tasks.d.ts +0 -7
- package/dist/scripts/cancel-duplicate-tasks.d.ts.map +0 -1
- package/dist/scripts/cancel-duplicate-tasks.js +0 -172
- package/dist/scripts/cancel-duplicate-tasks.js.map +0 -1
- package/dist/scripts/cleanup-duplicate-tasks.d.ts +0 -12
- package/dist/scripts/cleanup-duplicate-tasks.d.ts.map +0 -1
- package/dist/scripts/cleanup-duplicate-tasks.js +0 -215
- package/dist/scripts/cleanup-duplicate-tasks.js.map +0 -1
- package/dist/scripts/initialize.d.ts +0 -6
- package/dist/scripts/initialize.d.ts.map +0 -1
- package/dist/scripts/initialize.js +0 -93
- package/dist/scripts/initialize.js.map +0 -1
- package/dist/scripts/list-linear-tasks.d.ts +0 -6
- package/dist/scripts/list-linear-tasks.d.ts.map +0 -1
- package/dist/scripts/list-linear-tasks.js +0 -121
- package/dist/scripts/list-linear-tasks.js.map +0 -1
- package/dist/scripts/merge-linear-duplicates-safe.d.ts +0 -7
- package/dist/scripts/merge-linear-duplicates-safe.d.ts.map +0 -1
- package/dist/scripts/merge-linear-duplicates-safe.js +0 -267
- package/dist/scripts/merge-linear-duplicates-safe.js.map +0 -1
- package/dist/scripts/show-linear-summary.d.ts +0 -6
- package/dist/scripts/show-linear-summary.d.ts.map +0 -1
- package/dist/scripts/show-linear-summary.js +0 -120
- package/dist/scripts/show-linear-summary.js.map +0 -1
- package/dist/scripts/status.d.ts +0 -6
- package/dist/scripts/status.d.ts.map +0 -1
- package/dist/scripts/status.js +0 -101
- package/dist/scripts/status.js.map +0 -1
- package/dist/src/agents/core/agent-task-manager.d.ts +0 -154
- package/dist/src/agents/core/agent-task-manager.d.ts.map +0 -1
- package/dist/src/agents/core/agent-task-manager.js +0 -504
- package/dist/src/agents/core/agent-task-manager.js.map +0 -1
- package/dist/src/agents/verifiers/base-verifier.d.ts +0 -112
- package/dist/src/agents/verifiers/base-verifier.d.ts.map +0 -1
- package/dist/src/agents/verifiers/base-verifier.js +0 -130
- package/dist/src/agents/verifiers/base-verifier.js.map +0 -1
- package/dist/src/agents/verifiers/formatter-verifier.d.ts +0 -14
- package/dist/src/agents/verifiers/formatter-verifier.d.ts.map +0 -1
- package/dist/src/agents/verifiers/formatter-verifier.js +0 -107
- package/dist/src/agents/verifiers/formatter-verifier.js.map +0 -1
- package/dist/src/agents/verifiers/llm-judge.d.ts +0 -46
- package/dist/src/agents/verifiers/llm-judge.d.ts.map +0 -1
- package/dist/src/agents/verifiers/llm-judge.js +0 -248
- package/dist/src/agents/verifiers/llm-judge.js.map +0 -1
- package/dist/src/cli/auto-detect.d.ts +0 -61
- package/dist/src/cli/auto-detect.d.ts.map +0 -1
- package/dist/src/cli/auto-detect.js +0 -350
- package/dist/src/cli/auto-detect.js.map +0 -1
- package/dist/src/cli/browser-test.d.ts +0 -6
- package/dist/src/cli/browser-test.d.ts.map +0 -1
- package/dist/src/cli/browser-test.js +0 -32
- package/dist/src/cli/browser-test.js.map +0 -1
- package/dist/src/cli/claude-sm.d.ts +0 -7
- package/dist/src/cli/claude-sm.d.ts.map +0 -1
- package/dist/src/cli/claude-sm.js +0 -412
- package/dist/src/cli/claude-sm.js.map +0 -1
- package/dist/src/cli/commands/agent.d.ts +0 -9
- package/dist/src/cli/commands/agent.d.ts.map +0 -1
- package/dist/src/cli/commands/agent.js +0 -303
- package/dist/src/cli/commands/agent.js.map +0 -1
- package/dist/src/cli/commands/config.d.ts +0 -6
- package/dist/src/cli/commands/config.d.ts.map +0 -1
- package/dist/src/cli/commands/config.js +0 -224
- package/dist/src/cli/commands/config.js.map +0 -1
- package/dist/src/cli/commands/context.d.ts +0 -7
- package/dist/src/cli/commands/context.d.ts.map +0 -1
- package/dist/src/cli/commands/context.js +0 -365
- package/dist/src/cli/commands/context.js.map +0 -1
- package/dist/src/cli/commands/handoff.d.ts +0 -6
- package/dist/src/cli/commands/handoff.d.ts.map +0 -1
- package/dist/src/cli/commands/handoff.js +0 -212
- package/dist/src/cli/commands/handoff.js.map +0 -1
- package/dist/src/cli/commands/linear-test.d.ts +0 -6
- package/dist/src/cli/commands/linear-test.d.ts.map +0 -1
- package/dist/src/cli/commands/linear-test.js +0 -123
- package/dist/src/cli/commands/linear-test.js.map +0 -1
- package/dist/src/cli/commands/linear.d.ts +0 -6
- package/dist/src/cli/commands/linear.d.ts.map +0 -1
- package/dist/src/cli/commands/linear.js +0 -393
- package/dist/src/cli/commands/linear.js.map +0 -1
- package/dist/src/cli/commands/log.d.ts +0 -7
- package/dist/src/cli/commands/log.d.ts.map +0 -1
- package/dist/src/cli/commands/log.js +0 -168
- package/dist/src/cli/commands/log.js.map +0 -1
- package/dist/src/cli/commands/onboard.d.ts +0 -8
- package/dist/src/cli/commands/onboard.d.ts.map +0 -1
- package/dist/src/cli/commands/onboard.js +0 -363
- package/dist/src/cli/commands/onboard.js.map +0 -1
- package/dist/src/cli/commands/projects.d.ts +0 -8
- package/dist/src/cli/commands/projects.d.ts.map +0 -1
- package/dist/src/cli/commands/projects.js +0 -220
- package/dist/src/cli/commands/projects.js.map +0 -1
- package/dist/src/cli/commands/search.d.ts +0 -7
- package/dist/src/cli/commands/search.d.ts.map +0 -1
- package/dist/src/cli/commands/search.js +0 -162
- package/dist/src/cli/commands/search.js.map +0 -1
- package/dist/src/cli/commands/session.d.ts +0 -7
- package/dist/src/cli/commands/session.d.ts.map +0 -1
- package/dist/src/cli/commands/session.js +0 -222
- package/dist/src/cli/commands/session.js.map +0 -1
- package/dist/src/cli/commands/tasks.d.ts +0 -7
- package/dist/src/cli/commands/tasks.d.ts.map +0 -1
- package/dist/src/cli/commands/tasks.js +0 -229
- package/dist/src/cli/commands/tasks.js.map +0 -1
- package/dist/src/cli/commands/webhook.d.ts +0 -3
- package/dist/src/cli/commands/webhook.d.ts.map +0 -1
- package/dist/src/cli/commands/webhook.js +0 -157
- package/dist/src/cli/commands/webhook.js.map +0 -1
- package/dist/src/cli/commands/worktree.d.ts +0 -8
- package/dist/src/cli/commands/worktree.d.ts.map +0 -1
- package/dist/src/cli/commands/worktree.js +0 -339
- package/dist/src/cli/commands/worktree.js.map +0 -1
- package/dist/src/cli/index.d.ts +0 -8
- package/dist/src/cli/index.d.ts.map +0 -1
- package/dist/src/cli/index.js +0 -995
- package/dist/src/cli/index.js.map +0 -1
- package/dist/src/cli/utils/viewer.d.ts +0 -3
- package/dist/src/cli/utils/viewer.d.ts.map +0 -1
- package/dist/src/cli/utils/viewer.js +0 -91
- package/dist/src/cli/utils/viewer.js.map +0 -1
- package/dist/src/core/config/config-manager.d.ts +0 -95
- package/dist/src/core/config/config-manager.d.ts.map +0 -1
- package/dist/src/core/config/config-manager.js +0 -359
- package/dist/src/core/config/config-manager.js.map +0 -1
- package/dist/src/core/config/types.d.ts +0 -72
- package/dist/src/core/config/types.d.ts.map +0 -1
- package/dist/src/core/config/types.js +0 -127
- package/dist/src/core/config/types.js.map +0 -1
- package/dist/src/core/context/auto-context.d.ts +0 -22
- package/dist/src/core/context/auto-context.d.ts.map +0 -1
- package/dist/src/core/context/auto-context.js +0 -77
- package/dist/src/core/context/auto-context.js.map +0 -1
- package/dist/src/core/context/compaction-handler.d.ts +0 -119
- package/dist/src/core/context/compaction-handler.d.ts.map +0 -1
- package/dist/src/core/context/compaction-handler.js +0 -306
- package/dist/src/core/context/compaction-handler.js.map +0 -1
- package/dist/src/core/context/frame-database.d.ts +0 -59
- package/dist/src/core/context/frame-database.d.ts.map +0 -1
- package/dist/src/core/context/frame-database.js +0 -333
- package/dist/src/core/context/frame-database.js.map +0 -1
- package/dist/src/core/context/frame-digest.d.ts +0 -59
- package/dist/src/core/context/frame-digest.d.ts.map +0 -1
- package/dist/src/core/context/frame-digest.js +0 -264
- package/dist/src/core/context/frame-digest.js.map +0 -1
- package/dist/src/core/context/frame-manager.d.ts +0 -112
- package/dist/src/core/context/frame-manager.d.ts.map +0 -1
- package/dist/src/core/context/frame-manager.js +0 -600
- package/dist/src/core/context/frame-manager.js.map +0 -1
- package/dist/src/core/context/frame-stack.d.ts +0 -85
- package/dist/src/core/context/frame-stack.d.ts.map +0 -1
- package/dist/src/core/context/frame-stack.js +0 -287
- package/dist/src/core/context/frame-stack.js.map +0 -1
- package/dist/src/core/context/frame-types.d.ts +0 -67
- package/dist/src/core/context/frame-types.d.ts.map +0 -1
- package/dist/src/core/context/frame-types.js +0 -6
- package/dist/src/core/context/frame-types.js.map +0 -1
- package/dist/src/core/context/index.d.ts +0 -11
- package/dist/src/core/context/index.d.ts.map +0 -1
- package/dist/src/core/context/index.js +0 -14
- package/dist/src/core/context/index.js.map +0 -1
- package/dist/src/core/context/model-aware-compaction.d.ts +0 -101
- package/dist/src/core/context/model-aware-compaction.d.ts.map +0 -1
- package/dist/src/core/context/model-aware-compaction.js +0 -616
- package/dist/src/core/context/model-aware-compaction.js.map +0 -1
- package/dist/src/core/context/refactored-frame-manager.d.ts +0 -99
- package/dist/src/core/context/refactored-frame-manager.d.ts.map +0 -1
- package/dist/src/core/context/refactored-frame-manager.js +0 -340
- package/dist/src/core/context/refactored-frame-manager.js.map +0 -1
- package/dist/src/core/database/batch-operations.d.ts +0 -118
- package/dist/src/core/database/batch-operations.d.ts.map +0 -1
- package/dist/src/core/database/batch-operations.js +0 -339
- package/dist/src/core/database/batch-operations.js.map +0 -1
- package/dist/src/core/database/connection-pool.d.ts +0 -79
- package/dist/src/core/database/connection-pool.d.ts.map +0 -1
- package/dist/src/core/database/connection-pool.js +0 -236
- package/dist/src/core/database/connection-pool.js.map +0 -1
- package/dist/src/core/database/query-cache.d.ts +0 -135
- package/dist/src/core/database/query-cache.d.ts.map +0 -1
- package/dist/src/core/database/query-cache.js +0 -294
- package/dist/src/core/database/query-cache.js.map +0 -1
- package/dist/src/core/digest/enhanced-hybrid-digest.d.ts +0 -125
- package/dist/src/core/digest/enhanced-hybrid-digest.d.ts.map +0 -1
- package/dist/src/core/digest/enhanced-hybrid-digest.js +0 -282
- package/dist/src/core/digest/enhanced-hybrid-digest.js.map +0 -1
- package/dist/src/core/digest/frame-digest-integration.d.ts +0 -67
- package/dist/src/core/digest/frame-digest-integration.d.ts.map +0 -1
- package/dist/src/core/digest/frame-digest-integration.js +0 -198
- package/dist/src/core/digest/frame-digest-integration.js.map +0 -1
- package/dist/src/core/digest/hybrid-digest-generator.d.ts +0 -76
- package/dist/src/core/digest/hybrid-digest-generator.d.ts.map +0 -1
- package/dist/src/core/digest/hybrid-digest-generator.js +0 -629
- package/dist/src/core/digest/hybrid-digest-generator.js.map +0 -1
- package/dist/src/core/digest/index.d.ts +0 -9
- package/dist/src/core/digest/index.d.ts.map +0 -1
- package/dist/src/core/digest/index.js +0 -9
- package/dist/src/core/digest/index.js.map +0 -1
- package/dist/src/core/digest/types.d.ts +0 -154
- package/dist/src/core/digest/types.d.ts.map +0 -1
- package/dist/src/core/digest/types.js +0 -18
- package/dist/src/core/digest/types.js.map +0 -1
- package/dist/src/core/errors/index.d.ts +0 -143
- package/dist/src/core/errors/index.d.ts.map +0 -1
- package/dist/src/core/errors/index.js +0 -282
- package/dist/src/core/errors/index.js.map +0 -1
- package/dist/src/core/errors/recovery.d.ts +0 -86
- package/dist/src/core/errors/recovery.d.ts.map +0 -1
- package/dist/src/core/errors/recovery.js +0 -274
- package/dist/src/core/errors/recovery.js.map +0 -1
- package/dist/src/core/merge/conflict-detector.d.ts +0 -122
- package/dist/src/core/merge/conflict-detector.d.ts.map +0 -1
- package/dist/src/core/merge/conflict-detector.js +0 -468
- package/dist/src/core/merge/conflict-detector.js.map +0 -1
- package/dist/src/core/merge/index.d.ts +0 -9
- package/dist/src/core/merge/index.d.ts.map +0 -1
- package/dist/src/core/merge/index.js +0 -9
- package/dist/src/core/merge/index.js.map +0 -1
- package/dist/src/core/merge/resolution-engine.d.ts +0 -120
- package/dist/src/core/merge/resolution-engine.d.ts.map +0 -1
- package/dist/src/core/merge/resolution-engine.js +0 -573
- package/dist/src/core/merge/resolution-engine.js.map +0 -1
- package/dist/src/core/merge/stack-diff.d.ts +0 -97
- package/dist/src/core/merge/stack-diff.d.ts.map +0 -1
- package/dist/src/core/merge/stack-diff.js +0 -516
- package/dist/src/core/merge/stack-diff.js.map +0 -1
- package/dist/src/core/merge/types.d.ts +0 -110
- package/dist/src/core/merge/types.d.ts.map +0 -1
- package/dist/src/core/merge/types.js +0 -6
- package/dist/src/core/merge/types.js.map +0 -1
- package/dist/src/core/monitoring/error-handler.d.ts +0 -46
- package/dist/src/core/monitoring/error-handler.d.ts.map +0 -1
- package/dist/src/core/monitoring/error-handler.js +0 -212
- package/dist/src/core/monitoring/error-handler.js.map +0 -1
- package/dist/src/core/monitoring/logger.d.ts +0 -24
- package/dist/src/core/monitoring/logger.d.ts.map +0 -1
- package/dist/src/core/monitoring/logger.js +0 -126
- package/dist/src/core/monitoring/logger.js.map +0 -1
- package/dist/src/core/monitoring/metrics.d.ts +0 -10
- package/dist/src/core/monitoring/metrics.d.ts.map +0 -1
- package/dist/src/core/monitoring/metrics.js +0 -152
- package/dist/src/core/monitoring/metrics.js.map +0 -1
- package/dist/src/core/monitoring/progress-tracker.d.ts +0 -95
- package/dist/src/core/monitoring/progress-tracker.d.ts.map +0 -1
- package/dist/src/core/monitoring/progress-tracker.js +0 -178
- package/dist/src/core/monitoring/progress-tracker.js.map +0 -1
- package/dist/src/core/performance/context-cache.d.ts +0 -109
- package/dist/src/core/performance/context-cache.d.ts.map +0 -1
- package/dist/src/core/performance/context-cache.js +0 -280
- package/dist/src/core/performance/context-cache.js.map +0 -1
- package/dist/src/core/performance/index.d.ts +0 -3
- package/dist/src/core/performance/index.d.ts.map +0 -1
- package/dist/src/core/performance/index.js +0 -3
- package/dist/src/core/performance/index.js.map +0 -1
- package/dist/src/core/performance/lazy-context-loader.d.ts +0 -93
- package/dist/src/core/performance/lazy-context-loader.d.ts.map +0 -1
- package/dist/src/core/performance/lazy-context-loader.js +0 -332
- package/dist/src/core/performance/lazy-context-loader.js.map +0 -1
- package/dist/src/core/performance/monitor.d.ts +0 -48
- package/dist/src/core/performance/monitor.d.ts.map +0 -1
- package/dist/src/core/performance/monitor.js +0 -226
- package/dist/src/core/performance/monitor.js.map +0 -1
- package/dist/src/core/performance/optimized-frame-context.d.ts +0 -74
- package/dist/src/core/performance/optimized-frame-context.d.ts.map +0 -1
- package/dist/src/core/performance/optimized-frame-context.js +0 -330
- package/dist/src/core/performance/optimized-frame-context.js.map +0 -1
- package/dist/src/core/performance/performance-benchmark.d.ts +0 -50
- package/dist/src/core/performance/performance-benchmark.d.ts.map +0 -1
- package/dist/src/core/performance/performance-benchmark.js +0 -290
- package/dist/src/core/performance/performance-benchmark.js.map +0 -1
- package/dist/src/core/performance/performance-profiler.d.ts +0 -151
- package/dist/src/core/performance/performance-profiler.d.ts.map +0 -1
- package/dist/src/core/performance/performance-profiler.js +0 -346
- package/dist/src/core/performance/performance-profiler.js.map +0 -1
- package/dist/src/core/performance/streaming-jsonl-parser.d.ts +0 -41
- package/dist/src/core/performance/streaming-jsonl-parser.d.ts.map +0 -1
- package/dist/src/core/performance/streaming-jsonl-parser.js +0 -193
- package/dist/src/core/performance/streaming-jsonl-parser.js.map +0 -1
- package/dist/src/core/persistence/postgres-adapter.d.ts +0 -31
- package/dist/src/core/persistence/postgres-adapter.d.ts.map +0 -1
- package/dist/src/core/persistence/postgres-adapter.js +0 -330
- package/dist/src/core/persistence/postgres-adapter.js.map +0 -1
- package/dist/src/core/projects/project-manager.d.ts +0 -130
- package/dist/src/core/projects/project-manager.d.ts.map +0 -1
- package/dist/src/core/projects/project-manager.js +0 -709
- package/dist/src/core/projects/project-manager.js.map +0 -1
- package/dist/src/core/query/query-parser.d.ts +0 -109
- package/dist/src/core/query/query-parser.d.ts.map +0 -1
- package/dist/src/core/query/query-parser.js +0 -415
- package/dist/src/core/query/query-parser.js.map +0 -1
- package/dist/src/core/query/query-templates.d.ts +0 -44
- package/dist/src/core/query/query-templates.d.ts.map +0 -1
- package/dist/src/core/query/query-templates.js +0 -326
- package/dist/src/core/query/query-templates.js.map +0 -1
- package/dist/src/core/retrieval/index.d.ts +0 -8
- package/dist/src/core/retrieval/index.d.ts.map +0 -1
- package/dist/src/core/retrieval/index.js +0 -8
- package/dist/src/core/retrieval/index.js.map +0 -1
- package/dist/src/core/retrieval/llm-context-retrieval.d.ts +0 -73
- package/dist/src/core/retrieval/llm-context-retrieval.d.ts.map +0 -1
- package/dist/src/core/retrieval/llm-context-retrieval.js +0 -597
- package/dist/src/core/retrieval/llm-context-retrieval.js.map +0 -1
- package/dist/src/core/retrieval/summary-generator.d.ts +0 -63
- package/dist/src/core/retrieval/summary-generator.d.ts.map +0 -1
- package/dist/src/core/retrieval/summary-generator.js +0 -622
- package/dist/src/core/retrieval/summary-generator.js.map +0 -1
- package/dist/src/core/retrieval/types.d.ts +0 -257
- package/dist/src/core/retrieval/types.d.ts.map +0 -1
- package/dist/src/core/retrieval/types.js +0 -18
- package/dist/src/core/retrieval/types.js.map +0 -1
- package/dist/src/core/session/index.d.ts +0 -2
- package/dist/src/core/session/index.d.ts.map +0 -1
- package/dist/src/core/session/index.js +0 -2
- package/dist/src/core/session/index.js.map +0 -1
- package/dist/src/core/session/session-manager.d.ts +0 -69
- package/dist/src/core/session/session-manager.d.ts.map +0 -1
- package/dist/src/core/session/session-manager.js +0 -311
- package/dist/src/core/session/session-manager.js.map +0 -1
- package/dist/src/core/trace/cli-trace-wrapper.d.ts +0 -23
- package/dist/src/core/trace/cli-trace-wrapper.d.ts.map +0 -1
- package/dist/src/core/trace/cli-trace-wrapper.js +0 -141
- package/dist/src/core/trace/cli-trace-wrapper.js.map +0 -1
- package/dist/src/core/trace/db-trace-wrapper.d.ts +0 -36
- package/dist/src/core/trace/db-trace-wrapper.d.ts.map +0 -1
- package/dist/src/core/trace/db-trace-wrapper.js +0 -252
- package/dist/src/core/trace/db-trace-wrapper.js.map +0 -1
- package/dist/src/core/trace/debug-trace.d.ts +0 -84
- package/dist/src/core/trace/debug-trace.d.ts.map +0 -1
- package/dist/src/core/trace/debug-trace.js +0 -402
- package/dist/src/core/trace/debug-trace.js.map +0 -1
- package/dist/src/core/trace/error-test.d.ts +0 -6
- package/dist/src/core/trace/error-test.d.ts.map +0 -1
- package/dist/src/core/trace/error-test.js +0 -128
- package/dist/src/core/trace/error-test.js.map +0 -1
- package/dist/src/core/trace/index.d.ts +0 -25
- package/dist/src/core/trace/index.d.ts.map +0 -1
- package/dist/src/core/trace/index.js +0 -121
- package/dist/src/core/trace/index.js.map +0 -1
- package/dist/src/core/trace/linear-api-wrapper.d.ts +0 -17
- package/dist/src/core/trace/linear-api-wrapper.d.ts.map +0 -1
- package/dist/src/core/trace/linear-api-wrapper.js +0 -205
- package/dist/src/core/trace/linear-api-wrapper.js.map +0 -1
- package/dist/src/core/trace/performance-test.d.ts +0 -6
- package/dist/src/core/trace/performance-test.d.ts.map +0 -1
- package/dist/src/core/trace/performance-test.js +0 -111
- package/dist/src/core/trace/performance-test.js.map +0 -1
- package/dist/src/core/trace/trace-demo.d.ts +0 -8
- package/dist/src/core/trace/trace-demo.d.ts.map +0 -1
- package/dist/src/core/trace/trace-demo.js +0 -154
- package/dist/src/core/trace/trace-demo.js.map +0 -1
- package/dist/src/core/trace/trace-detector.d.ts +0 -108
- package/dist/src/core/trace/trace-detector.d.ts.map +0 -1
- package/dist/src/core/trace/trace-detector.demo.d.ts +0 -5
- package/dist/src/core/trace/trace-detector.demo.d.ts.map +0 -1
- package/dist/src/core/trace/trace-detector.demo.js +0 -145
- package/dist/src/core/trace/trace-detector.demo.js.map +0 -1
- package/dist/src/core/trace/trace-detector.js +0 -425
- package/dist/src/core/trace/trace-detector.js.map +0 -1
- package/dist/src/core/trace/trace-store.d.ts +0 -60
- package/dist/src/core/trace/trace-store.d.ts.map +0 -1
- package/dist/src/core/trace/trace-store.js +0 -323
- package/dist/src/core/trace/trace-store.js.map +0 -1
- package/dist/src/core/trace/types.d.ts +0 -81
- package/dist/src/core/trace/types.d.ts.map +0 -1
- package/dist/src/core/trace/types.js +0 -70
- package/dist/src/core/trace/types.js.map +0 -1
- package/dist/src/core/types.d.ts +0 -35
- package/dist/src/core/types.d.ts.map +0 -1
- package/dist/src/core/types.js +0 -2
- package/dist/src/core/types.js.map +0 -1
- package/dist/src/core/utils/update-checker.d.ts +0 -38
- package/dist/src/core/utils/update-checker.d.ts.map +0 -1
- package/dist/src/core/utils/update-checker.js +0 -213
- package/dist/src/core/utils/update-checker.js.map +0 -1
- package/dist/src/core/worktree/worktree-manager.d.ts +0 -110
- package/dist/src/core/worktree/worktree-manager.d.ts.map +0 -1
- package/dist/src/core/worktree/worktree-manager.js +0 -456
- package/dist/src/core/worktree/worktree-manager.js.map +0 -1
- package/dist/src/features/analytics/api/analytics-api.d.ts +0 -24
- package/dist/src/features/analytics/api/analytics-api.d.ts.map +0 -1
- package/dist/src/features/analytics/api/analytics-api.js +0 -289
- package/dist/src/features/analytics/api/analytics-api.js.map +0 -1
- package/dist/src/features/analytics/core/analytics-service.d.ts +0 -29
- package/dist/src/features/analytics/core/analytics-service.d.ts.map +0 -1
- package/dist/src/features/analytics/core/analytics-service.js +0 -275
- package/dist/src/features/analytics/core/analytics-service.js.map +0 -1
- package/dist/src/features/analytics/index.d.ts +0 -12
- package/dist/src/features/analytics/index.d.ts.map +0 -1
- package/dist/src/features/analytics/index.js +0 -11
- package/dist/src/features/analytics/index.js.map +0 -1
- package/dist/src/features/analytics/queries/metrics-queries.d.ts +0 -11
- package/dist/src/features/analytics/queries/metrics-queries.d.ts.map +0 -1
- package/dist/src/features/analytics/queries/metrics-queries.js +0 -240
- package/dist/src/features/analytics/queries/metrics-queries.js.map +0 -1
- package/dist/src/features/analytics/types/metrics.d.ts +0 -60
- package/dist/src/features/analytics/types/metrics.d.ts.map +0 -1
- package/dist/src/features/analytics/types/metrics.js +0 -2
- package/dist/src/features/analytics/types/metrics.js.map +0 -1
- package/dist/src/features/browser/browser-mcp.d.ts +0 -94
- package/dist/src/features/browser/browser-mcp.d.ts.map +0 -1
- package/dist/src/features/browser/browser-mcp.js +0 -459
- package/dist/src/features/browser/browser-mcp.js.map +0 -1
- package/dist/src/features/tasks/pebbles-task-store.d.ts +0 -128
- package/dist/src/features/tasks/pebbles-task-store.d.ts.map +0 -1
- package/dist/src/features/tasks/pebbles-task-store.js +0 -572
- package/dist/src/features/tasks/pebbles-task-store.js.map +0 -1
- package/dist/src/features/tasks/task-aware-context.d.ts +0 -103
- package/dist/src/features/tasks/task-aware-context.d.ts.map +0 -1
- package/dist/src/features/tasks/task-aware-context.js +0 -412
- package/dist/src/features/tasks/task-aware-context.js.map +0 -1
- package/dist/src/index.d.ts +0 -21
- package/dist/src/index.d.ts.map +0 -1
- package/dist/src/index.js +0 -9
- package/dist/src/index.js.map +0 -1
- package/dist/src/integrations/linear/auth.d.ts +0 -99
- package/dist/src/integrations/linear/auth.d.ts.map +0 -1
- package/dist/src/integrations/linear/auth.js +0 -319
- package/dist/src/integrations/linear/auth.js.map +0 -1
- package/dist/src/integrations/linear/auto-sync.d.ts +0 -77
- package/dist/src/integrations/linear/auto-sync.d.ts.map +0 -1
- package/dist/src/integrations/linear/auto-sync.js +0 -268
- package/dist/src/integrations/linear/auto-sync.js.map +0 -1
- package/dist/src/integrations/linear/client.d.ts +0 -127
- package/dist/src/integrations/linear/client.d.ts.map +0 -1
- package/dist/src/integrations/linear/client.js +0 -446
- package/dist/src/integrations/linear/client.js.map +0 -1
- package/dist/src/integrations/linear/config.d.ts +0 -51
- package/dist/src/integrations/linear/config.d.ts.map +0 -1
- package/dist/src/integrations/linear/config.js +0 -103
- package/dist/src/integrations/linear/config.js.map +0 -1
- package/dist/src/integrations/linear/sync-manager.d.ts +0 -78
- package/dist/src/integrations/linear/sync-manager.d.ts.map +0 -1
- package/dist/src/integrations/linear/sync-manager.js +0 -235
- package/dist/src/integrations/linear/sync-manager.js.map +0 -1
- package/dist/src/integrations/linear/sync-service.d.ts +0 -46
- package/dist/src/integrations/linear/sync-service.d.ts.map +0 -1
- package/dist/src/integrations/linear/sync-service.js +0 -217
- package/dist/src/integrations/linear/sync-service.js.map +0 -1
- package/dist/src/integrations/linear/sync.d.ts +0 -125
- package/dist/src/integrations/linear/sync.d.ts.map +0 -1
- package/dist/src/integrations/linear/sync.js +0 -563
- package/dist/src/integrations/linear/sync.js.map +0 -1
- package/dist/src/integrations/linear/types.d.ts +0 -90
- package/dist/src/integrations/linear/types.d.ts.map +0 -1
- package/dist/src/integrations/linear/types.js +0 -2
- package/dist/src/integrations/linear/types.js.map +0 -1
- package/dist/src/integrations/linear/webhook-server.d.ts +0 -32
- package/dist/src/integrations/linear/webhook-server.d.ts.map +0 -1
- package/dist/src/integrations/linear/webhook-server.js +0 -190
- package/dist/src/integrations/linear/webhook-server.js.map +0 -1
- package/dist/src/integrations/linear/webhook.d.ts +0 -108
- package/dist/src/integrations/linear/webhook.d.ts.map +0 -1
- package/dist/src/integrations/linear/webhook.js +0 -291
- package/dist/src/integrations/linear/webhook.js.map +0 -1
- package/dist/src/integrations/mcp/handlers/context-handlers.d.ts +0 -39
- package/dist/src/integrations/mcp/handlers/context-handlers.d.ts.map +0 -1
- package/dist/src/integrations/mcp/handlers/context-handlers.js +0 -266
- package/dist/src/integrations/mcp/handlers/context-handlers.js.map +0 -1
- package/dist/src/integrations/mcp/handlers/index.d.ts +0 -37
- package/dist/src/integrations/mcp/handlers/index.d.ts.map +0 -1
- package/dist/src/integrations/mcp/handlers/index.js +0 -134
- package/dist/src/integrations/mcp/handlers/index.js.map +0 -1
- package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts +0 -33
- package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts.map +0 -1
- package/dist/src/integrations/mcp/handlers/linear-handlers.js +0 -251
- package/dist/src/integrations/mcp/handlers/linear-handlers.js.map +0 -1
- package/dist/src/integrations/mcp/handlers/task-handlers.d.ts +0 -42
- package/dist/src/integrations/mcp/handlers/task-handlers.d.ts.map +0 -1
- package/dist/src/integrations/mcp/handlers/task-handlers.js +0 -238
- package/dist/src/integrations/mcp/handlers/task-handlers.js.map +0 -1
- package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts +0 -41
- package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts.map +0 -1
- package/dist/src/integrations/mcp/handlers/trace-handlers.js +0 -298
- package/dist/src/integrations/mcp/handlers/trace-handlers.js.map +0 -1
- package/dist/src/integrations/mcp/index.d.ts +0 -13
- package/dist/src/integrations/mcp/index.d.ts.map +0 -1
- package/dist/src/integrations/mcp/index.js +0 -17
- package/dist/src/integrations/mcp/index.js.map +0 -1
- package/dist/src/integrations/mcp/refactored-server.d.ts +0 -76
- package/dist/src/integrations/mcp/refactored-server.d.ts.map +0 -1
- package/dist/src/integrations/mcp/refactored-server.js +0 -351
- package/dist/src/integrations/mcp/refactored-server.js.map +0 -1
- package/dist/src/integrations/mcp/server.d.ts +0 -54
- package/dist/src/integrations/mcp/server.d.ts.map +0 -1
- package/dist/src/integrations/mcp/server.js +0 -1616
- package/dist/src/integrations/mcp/server.js.map +0 -1
- package/dist/src/integrations/mcp/tool-definitions.d.ts +0 -44
- package/dist/src/integrations/mcp/tool-definitions.d.ts.map +0 -1
- package/dist/src/integrations/mcp/tool-definitions.js +0 -563
- package/dist/src/integrations/mcp/tool-definitions.js.map +0 -1
- package/dist/src/integrations/mcp/trace-test.d.ts +0 -5
- package/dist/src/integrations/mcp/trace-test.d.ts.map +0 -1
- package/dist/src/integrations/mcp/trace-test.js +0 -54
- package/dist/src/integrations/mcp/trace-test.js.map +0 -1
- package/dist/src/integrations/pg-aiguide/embedding-provider.d.ts +0 -48
- package/dist/src/integrations/pg-aiguide/embedding-provider.d.ts.map +0 -1
- package/dist/src/integrations/pg-aiguide/embedding-provider.js +0 -190
- package/dist/src/integrations/pg-aiguide/embedding-provider.js.map +0 -1
- package/dist/src/integrations/pg-aiguide/semantic-search.d.ts +0 -34
- package/dist/src/integrations/pg-aiguide/semantic-search.d.ts.map +0 -1
- package/dist/src/integrations/pg-aiguide/semantic-search.js +0 -176
- package/dist/src/integrations/pg-aiguide/semantic-search.js.map +0 -1
- package/dist/src/integrations/pg-aiguide/timescale-analytics.d.ts +0 -44
- package/dist/src/integrations/pg-aiguide/timescale-analytics.d.ts.map +0 -1
- package/dist/src/integrations/pg-aiguide/timescale-analytics.js +0 -215
- package/dist/src/integrations/pg-aiguide/timescale-analytics.js.map +0 -1
- package/dist/src/mcp/stackmemory-mcp-server.d.ts +0 -9
- package/dist/src/mcp/stackmemory-mcp-server.d.ts.map +0 -1
- package/dist/src/mcp/stackmemory-mcp-server.js +0 -519
- package/dist/src/mcp/stackmemory-mcp-server.js.map +0 -1
- package/dist/src/middleware/exponential-rate-limiter.d.ts +0 -78
- package/dist/src/middleware/exponential-rate-limiter.d.ts.map +0 -1
- package/dist/src/middleware/exponential-rate-limiter.js +0 -293
- package/dist/src/middleware/exponential-rate-limiter.js.map +0 -1
- package/dist/src/models/user.model.d.ts +0 -62
- package/dist/src/models/user.model.d.ts.map +0 -1
- package/dist/src/models/user.model.js +0 -311
- package/dist/src/models/user.model.js.map +0 -1
- package/dist/src/servers/production/auth-middleware.d.ts +0 -76
- package/dist/src/servers/production/auth-middleware.d.ts.map +0 -1
- package/dist/src/servers/production/auth-middleware.js +0 -558
- package/dist/src/servers/production/auth-middleware.js.map +0 -1
- package/dist/src/servers/railway/index.d.ts +0 -7
- package/dist/src/servers/railway/index.d.ts.map +0 -1
- package/dist/src/servers/railway/index.js +0 -401
- package/dist/src/servers/railway/index.js.map +0 -1
- package/dist/src/services/config-service.d.ts +0 -44
- package/dist/src/services/config-service.d.ts.map +0 -1
- package/dist/src/services/config-service.js +0 -61
- package/dist/src/services/config-service.js.map +0 -1
- package/dist/src/services/context-service.d.ts +0 -17
- package/dist/src/services/context-service.d.ts.map +0 -1
- package/dist/src/services/context-service.js +0 -173
- package/dist/src/services/context-service.js.map +0 -1
- package/dist/src/types/task.d.ts +0 -27
- package/dist/src/types/task.d.ts.map +0 -1
- package/dist/src/types/task.js +0 -2
- package/dist/src/types/task.js.map +0 -1
- package/dist/src/utils/logger.d.ts +0 -13
- package/dist/src/utils/logger.d.ts.map +0 -1
- package/dist/src/utils/logger.js +0 -52
- package/dist/src/utils/logger.js.map +0 -1
- package/dist/src/validation/schemas.d.ts +0 -633
- package/dist/src/validation/schemas.d.ts.map +0 -1
- package/dist/src/validation/schemas.js +0 -347
- package/dist/src/validation/schemas.js.map +0 -1
|
@@ -0,0 +1,455 @@
|
|
|
1
|
+
import { EventEmitter } from "events";
|
|
2
|
+
import * as fs from "fs/promises";
|
|
3
|
+
import * as path from "path";
|
|
4
|
+
import { execSync } from "child_process";
|
|
5
|
+
class EnhancedPreClearHooks extends EventEmitter {
|
|
6
|
+
frameManager;
|
|
7
|
+
dbManager;
|
|
8
|
+
clearSurvival;
|
|
9
|
+
handoffGenerator;
|
|
10
|
+
projectRoot;
|
|
11
|
+
constructor(frameManager, dbManager, clearSurvival, handoffGenerator, projectRoot) {
|
|
12
|
+
super();
|
|
13
|
+
this.frameManager = frameManager;
|
|
14
|
+
this.dbManager = dbManager;
|
|
15
|
+
this.clearSurvival = clearSurvival;
|
|
16
|
+
this.handoffGenerator = handoffGenerator;
|
|
17
|
+
this.projectRoot = projectRoot;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Comprehensive pre-clear context capture
|
|
21
|
+
*/
|
|
22
|
+
async capturePreClearContext(trigger) {
|
|
23
|
+
console.log("\u{1F50D} Capturing comprehensive session context...");
|
|
24
|
+
const context = {
|
|
25
|
+
sessionId: await this.dbManager.getCurrentSessionId(),
|
|
26
|
+
timestamp: (/* @__PURE__ */ new Date()).toISOString(),
|
|
27
|
+
trigger,
|
|
28
|
+
contextUsage: await this.analyzeContextUsage(),
|
|
29
|
+
workingState: await this.captureWorkingState(),
|
|
30
|
+
conversationState: await this.captureConversationState(),
|
|
31
|
+
codeContext: await this.captureCodeContext(),
|
|
32
|
+
cognitiveState: await this.captureCognitiveState(),
|
|
33
|
+
environment: await this.captureEnvironment()
|
|
34
|
+
};
|
|
35
|
+
await this.saveEnhancedContext(context);
|
|
36
|
+
this.emit("context:captured", context);
|
|
37
|
+
console.log("\u2705 Comprehensive context captured");
|
|
38
|
+
return context;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Analyze current context usage with detailed breakdown
|
|
42
|
+
*/
|
|
43
|
+
async analyzeContextUsage() {
|
|
44
|
+
const sessionId = await this.dbManager.getCurrentSessionId();
|
|
45
|
+
const frames = await this.dbManager.getRecentFrames(sessionId, 1e3);
|
|
46
|
+
const traces = await this.dbManager.getRecentTraces(sessionId, 1e3);
|
|
47
|
+
const frameTokens = frames.length * 200;
|
|
48
|
+
const traceTokens = traces.length * 100;
|
|
49
|
+
const conversationTokens = await this.estimateConversationTokens();
|
|
50
|
+
const codeBlockTokens = await this.estimateCodeBlockTokens();
|
|
51
|
+
const estimatedTokens = frameTokens + traceTokens + conversationTokens + codeBlockTokens;
|
|
52
|
+
const maxTokens = 1e5;
|
|
53
|
+
return {
|
|
54
|
+
estimatedTokens,
|
|
55
|
+
maxTokens,
|
|
56
|
+
percentage: estimatedTokens / maxTokens,
|
|
57
|
+
components: {
|
|
58
|
+
frames: frameTokens,
|
|
59
|
+
traces: traceTokens,
|
|
60
|
+
conversations: conversationTokens,
|
|
61
|
+
codeBlocks: codeBlockTokens
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Capture current working state
|
|
67
|
+
*/
|
|
68
|
+
async captureWorkingState() {
|
|
69
|
+
const activeFrame = await this.getCurrentActiveFrame();
|
|
70
|
+
const recentTraces = await this.dbManager.getRecentTraces(
|
|
71
|
+
await this.dbManager.getCurrentSessionId(),
|
|
72
|
+
50
|
|
73
|
+
);
|
|
74
|
+
const activeFiles = this.extractActiveFiles(recentTraces);
|
|
75
|
+
const recentCommands = recentTraces.filter((t) => t.type === "bash" || t.type === "command").map((t) => t.content.command).slice(0, 10);
|
|
76
|
+
const pendingActions = this.extractPendingActions(activeFrame);
|
|
77
|
+
const blockers = this.extractBlockers(recentTraces);
|
|
78
|
+
return {
|
|
79
|
+
currentTask: activeFrame?.description || "No active task",
|
|
80
|
+
activeFiles,
|
|
81
|
+
recentCommands,
|
|
82
|
+
pendingActions,
|
|
83
|
+
blockers
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Capture conversation state and recent context
|
|
88
|
+
*/
|
|
89
|
+
async captureConversationState() {
|
|
90
|
+
const sessionId = await this.dbManager.getCurrentSessionId();
|
|
91
|
+
const recentTraces = await this.dbManager.getRecentTraces(sessionId, 100);
|
|
92
|
+
const userMessages = recentTraces.filter((t) => t.type === "user_message" || t.type === "input").slice(0, 5);
|
|
93
|
+
const assistantMessages = recentTraces.filter((t) => t.type === "assistant_message" || t.type === "response").slice(0, 5);
|
|
94
|
+
const conversationTopic = this.inferConversationTopic(recentTraces);
|
|
95
|
+
const recentContext = this.buildRecentContextSummary(recentTraces);
|
|
96
|
+
return {
|
|
97
|
+
lastUserMessage: userMessages[0]?.content.message || "No recent user message",
|
|
98
|
+
lastAssistantMessage: assistantMessages[0]?.content.message || "No recent assistant message",
|
|
99
|
+
conversationTopic,
|
|
100
|
+
messageCount: userMessages.length + assistantMessages.length,
|
|
101
|
+
recentContext
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Capture comprehensive code context
|
|
106
|
+
*/
|
|
107
|
+
async captureCodeContext() {
|
|
108
|
+
const gitStatus = await this.captureGitStatus();
|
|
109
|
+
const modifiedFiles = await this.captureModifiedFiles();
|
|
110
|
+
const testResults = await this.captureTestResults();
|
|
111
|
+
const buildStatus = await this.captureBuildStatus();
|
|
112
|
+
const dependencies = await this.captureDependencies();
|
|
113
|
+
return {
|
|
114
|
+
modifiedFiles,
|
|
115
|
+
gitStatus,
|
|
116
|
+
testResults,
|
|
117
|
+
buildStatus,
|
|
118
|
+
dependencies
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Capture cognitive state and mental model
|
|
123
|
+
*/
|
|
124
|
+
async captureCognitiveState() {
|
|
125
|
+
const sessionId = await this.dbManager.getCurrentSessionId();
|
|
126
|
+
const recentTraces = await this.dbManager.getRecentTraces(sessionId, 100);
|
|
127
|
+
const currentFocus = await this.extractCurrentFocus();
|
|
128
|
+
const mentalModel = this.extractMentalModel(recentTraces);
|
|
129
|
+
const assumptions = this.extractAssumptions(recentTraces);
|
|
130
|
+
const hypotheses = this.extractHypotheses(recentTraces);
|
|
131
|
+
const explorationPaths = this.extractExplorationPaths(recentTraces);
|
|
132
|
+
return {
|
|
133
|
+
currentFocus,
|
|
134
|
+
mentalModel,
|
|
135
|
+
assumptions,
|
|
136
|
+
hypotheses,
|
|
137
|
+
explorationPaths
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
/**
|
|
141
|
+
* Capture environment snapshot
|
|
142
|
+
*/
|
|
143
|
+
async captureEnvironment() {
|
|
144
|
+
const gitBranch = await this.getCurrentGitBranch();
|
|
145
|
+
const packageJson = await this.getPackageJson();
|
|
146
|
+
const environmentVars = this.getRelevantEnvVars();
|
|
147
|
+
return {
|
|
148
|
+
workingDirectory: this.projectRoot,
|
|
149
|
+
gitBranch,
|
|
150
|
+
nodeVersion: process.version,
|
|
151
|
+
packageJson,
|
|
152
|
+
environmentVars
|
|
153
|
+
};
|
|
154
|
+
}
|
|
155
|
+
/**
|
|
156
|
+
* Save enhanced context to multiple locations for reliability
|
|
157
|
+
*/
|
|
158
|
+
async saveEnhancedContext(context) {
|
|
159
|
+
const timestamp = context.timestamp.replace(/[:.]/g, "-");
|
|
160
|
+
const primaryPath = path.join(
|
|
161
|
+
this.projectRoot,
|
|
162
|
+
".stackmemory",
|
|
163
|
+
"pre-clear",
|
|
164
|
+
`context-${timestamp}.json`
|
|
165
|
+
);
|
|
166
|
+
const backupPath = path.join(
|
|
167
|
+
this.projectRoot,
|
|
168
|
+
".stackmemory",
|
|
169
|
+
"pre-clear",
|
|
170
|
+
"latest-context.json"
|
|
171
|
+
);
|
|
172
|
+
const markdownPath = path.join(
|
|
173
|
+
this.projectRoot,
|
|
174
|
+
".stackmemory",
|
|
175
|
+
"pre-clear",
|
|
176
|
+
`context-${timestamp}.md`
|
|
177
|
+
);
|
|
178
|
+
await fs.mkdir(path.dirname(primaryPath), { recursive: true });
|
|
179
|
+
await fs.writeFile(primaryPath, JSON.stringify(context, null, 2), "utf-8");
|
|
180
|
+
await fs.writeFile(backupPath, JSON.stringify(context, null, 2), "utf-8");
|
|
181
|
+
const markdown = this.generateMarkdownSummary(context);
|
|
182
|
+
await fs.writeFile(markdownPath, markdown, "utf-8");
|
|
183
|
+
console.log(
|
|
184
|
+
`\u{1F4C1} Context saved to ${path.relative(this.projectRoot, primaryPath)}`
|
|
185
|
+
);
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* Generate human-readable markdown summary
|
|
189
|
+
*/
|
|
190
|
+
generateMarkdownSummary(context) {
|
|
191
|
+
const lines = [
|
|
192
|
+
`# Pre-Clear Context Snapshot`,
|
|
193
|
+
`**Timestamp**: ${new Date(context.timestamp).toLocaleString()}`,
|
|
194
|
+
`**Trigger**: ${context.trigger}`,
|
|
195
|
+
`**Session ID**: ${context.sessionId}`,
|
|
196
|
+
"",
|
|
197
|
+
`## \u{1F4CA} Context Usage`,
|
|
198
|
+
`- **Total Tokens**: ${context.contextUsage.estimatedTokens.toLocaleString()} / ${context.contextUsage.maxTokens.toLocaleString()} (${Math.round(context.contextUsage.percentage * 100)}%)`,
|
|
199
|
+
`- **Frames**: ${context.contextUsage.components.frames} tokens`,
|
|
200
|
+
`- **Traces**: ${context.contextUsage.components.traces} tokens`,
|
|
201
|
+
`- **Conversations**: ${context.contextUsage.components.conversations} tokens`,
|
|
202
|
+
`- **Code Blocks**: ${context.contextUsage.components.codeBlocks} tokens`,
|
|
203
|
+
"",
|
|
204
|
+
`## \u{1F3AF} Current Work State`,
|
|
205
|
+
`**Task**: ${context.workingState.currentTask}`,
|
|
206
|
+
`**Active Files** (${context.workingState.activeFiles.length}):`,
|
|
207
|
+
...context.workingState.activeFiles.slice(0, 10).map((f) => `- ${f}`),
|
|
208
|
+
"",
|
|
209
|
+
`**Recent Commands**:`,
|
|
210
|
+
...context.workingState.recentCommands.slice(0, 5).map((c) => `- \`${c}\``),
|
|
211
|
+
"",
|
|
212
|
+
`## \u{1F4AC} Conversation State`,
|
|
213
|
+
`**Topic**: ${context.conversationState.conversationTopic}`,
|
|
214
|
+
`**Messages**: ${context.conversationState.messageCount}`,
|
|
215
|
+
`**Last User**: ${context.conversationState.lastUserMessage.substring(0, 100)}...`,
|
|
216
|
+
"",
|
|
217
|
+
`## \u{1F4DD} Code Context`,
|
|
218
|
+
`**Git Branch**: ${context.codeContext.gitStatus.branch}`,
|
|
219
|
+
`**Modified Files**: ${context.codeContext.modifiedFiles.length}`,
|
|
220
|
+
`**Staged**: ${context.codeContext.gitStatus.staged.length}`,
|
|
221
|
+
`**Unstaged**: ${context.codeContext.gitStatus.unstaged.length}`,
|
|
222
|
+
"",
|
|
223
|
+
`## \u{1F9E0} Cognitive State`,
|
|
224
|
+
`**Current Focus**: ${context.cognitiveState.currentFocus}`,
|
|
225
|
+
`**Mental Model**:`,
|
|
226
|
+
...context.cognitiveState.mentalModel.slice(0, 5).map((m) => `- ${m}`),
|
|
227
|
+
"",
|
|
228
|
+
`## \u{1F30D} Environment`,
|
|
229
|
+
`**Directory**: ${context.environment.workingDirectory}`,
|
|
230
|
+
`**Node Version**: ${context.environment.nodeVersion}`,
|
|
231
|
+
`**Git Branch**: ${context.environment.gitBranch}`,
|
|
232
|
+
""
|
|
233
|
+
];
|
|
234
|
+
return lines.filter((l) => l !== void 0).join("\n");
|
|
235
|
+
}
|
|
236
|
+
// Helper methods (simplified implementations)
|
|
237
|
+
async estimateConversationTokens() {
|
|
238
|
+
return 15e3;
|
|
239
|
+
}
|
|
240
|
+
async estimateCodeBlockTokens() {
|
|
241
|
+
return 8e3;
|
|
242
|
+
}
|
|
243
|
+
async getCurrentActiveFrame() {
|
|
244
|
+
const stack = await this.frameManager.getStack();
|
|
245
|
+
return stack.frames.find((f) => f.status === "open");
|
|
246
|
+
}
|
|
247
|
+
extractActiveFiles(traces) {
|
|
248
|
+
const files = /* @__PURE__ */ new Set();
|
|
249
|
+
traces.forEach((trace) => {
|
|
250
|
+
if (trace.content?.file_path) files.add(trace.content.file_path);
|
|
251
|
+
if (trace.content?.path) files.add(trace.content.path);
|
|
252
|
+
});
|
|
253
|
+
return Array.from(files).slice(0, 20);
|
|
254
|
+
}
|
|
255
|
+
extractPendingActions(frame) {
|
|
256
|
+
if (!frame?.metadata?.pendingActions) return [];
|
|
257
|
+
return frame.metadata.pendingActions;
|
|
258
|
+
}
|
|
259
|
+
extractBlockers(traces) {
|
|
260
|
+
return traces.filter((t) => t.type === "error" && !t.metadata?.resolved).map((t) => t.content.error || "Unknown error").slice(0, 5);
|
|
261
|
+
}
|
|
262
|
+
inferConversationTopic(traces) {
|
|
263
|
+
return "Code implementation and debugging";
|
|
264
|
+
}
|
|
265
|
+
buildRecentContextSummary(traces) {
|
|
266
|
+
return traces.slice(0, 10).map(
|
|
267
|
+
(t) => `${t.type}: ${t.content.summary || t.content.description || "No description"}`
|
|
268
|
+
).filter((s) => s.length > 10);
|
|
269
|
+
}
|
|
270
|
+
async captureGitStatus() {
|
|
271
|
+
try {
|
|
272
|
+
const branch = execSync("git branch --show-current", {
|
|
273
|
+
encoding: "utf-8",
|
|
274
|
+
cwd: this.projectRoot
|
|
275
|
+
}).trim();
|
|
276
|
+
const staged = execSync("git diff --cached --name-only", {
|
|
277
|
+
encoding: "utf-8",
|
|
278
|
+
cwd: this.projectRoot
|
|
279
|
+
}).trim().split("\n").filter(Boolean);
|
|
280
|
+
const unstaged = execSync("git diff --name-only", {
|
|
281
|
+
encoding: "utf-8",
|
|
282
|
+
cwd: this.projectRoot
|
|
283
|
+
}).trim().split("\n").filter(Boolean);
|
|
284
|
+
const untracked = execSync("git ls-files --others --exclude-standard", {
|
|
285
|
+
encoding: "utf-8",
|
|
286
|
+
cwd: this.projectRoot
|
|
287
|
+
}).trim().split("\n").filter(Boolean);
|
|
288
|
+
return {
|
|
289
|
+
branch,
|
|
290
|
+
ahead: 0,
|
|
291
|
+
// Would implement git status parsing
|
|
292
|
+
behind: 0,
|
|
293
|
+
staged,
|
|
294
|
+
unstaged,
|
|
295
|
+
untracked,
|
|
296
|
+
lastCommit: {
|
|
297
|
+
hash: "abc123",
|
|
298
|
+
// Would get from git log
|
|
299
|
+
message: "Recent commit",
|
|
300
|
+
timestamp: (/* @__PURE__ */ new Date()).toISOString()
|
|
301
|
+
}
|
|
302
|
+
};
|
|
303
|
+
} catch (error) {
|
|
304
|
+
return {
|
|
305
|
+
branch: "unknown",
|
|
306
|
+
ahead: 0,
|
|
307
|
+
behind: 0,
|
|
308
|
+
staged: [],
|
|
309
|
+
unstaged: [],
|
|
310
|
+
untracked: [],
|
|
311
|
+
lastCommit: { hash: "", message: "", timestamp: "" }
|
|
312
|
+
};
|
|
313
|
+
}
|
|
314
|
+
}
|
|
315
|
+
async captureModifiedFiles() {
|
|
316
|
+
try {
|
|
317
|
+
const output = execSync("git diff --name-status", {
|
|
318
|
+
encoding: "utf-8",
|
|
319
|
+
cwd: this.projectRoot
|
|
320
|
+
});
|
|
321
|
+
return output.trim().split("\n").filter(Boolean).map((line) => {
|
|
322
|
+
const [status, path2] = line.split(" ");
|
|
323
|
+
return {
|
|
324
|
+
path: path2,
|
|
325
|
+
lastModified: (/* @__PURE__ */ new Date()).toISOString(),
|
|
326
|
+
changeType: status === "A" ? "created" : status === "D" ? "deleted" : "modified",
|
|
327
|
+
lineChanges: { added: 0, removed: 0 },
|
|
328
|
+
// Would get from git diff --stat
|
|
329
|
+
purpose: "Code changes",
|
|
330
|
+
relatedFiles: []
|
|
331
|
+
};
|
|
332
|
+
});
|
|
333
|
+
} catch (error) {
|
|
334
|
+
return [];
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
async captureTestResults() {
|
|
338
|
+
return void 0;
|
|
339
|
+
}
|
|
340
|
+
async captureBuildStatus() {
|
|
341
|
+
return void 0;
|
|
342
|
+
}
|
|
343
|
+
async captureDependencies() {
|
|
344
|
+
try {
|
|
345
|
+
const packageJsonPath = path.join(this.projectRoot, "package.json");
|
|
346
|
+
const content = await fs.readFile(packageJsonPath, "utf-8");
|
|
347
|
+
const packageJson = JSON.parse(content);
|
|
348
|
+
const deps = [];
|
|
349
|
+
Object.entries(packageJson.dependencies || {}).forEach(
|
|
350
|
+
([name, version]) => {
|
|
351
|
+
deps.push({
|
|
352
|
+
name,
|
|
353
|
+
version,
|
|
354
|
+
type: "dependency",
|
|
355
|
+
critical: ["react", "express", "next"].includes(name)
|
|
356
|
+
});
|
|
357
|
+
}
|
|
358
|
+
);
|
|
359
|
+
return deps;
|
|
360
|
+
} catch (error) {
|
|
361
|
+
return [];
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
async extractCurrentFocus() {
|
|
365
|
+
const activeFrame = await this.getCurrentActiveFrame();
|
|
366
|
+
return activeFrame?.description || "No current focus";
|
|
367
|
+
}
|
|
368
|
+
extractMentalModel(traces) {
|
|
369
|
+
return [
|
|
370
|
+
"Component architecture",
|
|
371
|
+
"Data flow patterns",
|
|
372
|
+
"Error handling strategy"
|
|
373
|
+
];
|
|
374
|
+
}
|
|
375
|
+
extractAssumptions(traces) {
|
|
376
|
+
return [
|
|
377
|
+
"User input is validated",
|
|
378
|
+
"Database is available",
|
|
379
|
+
"Network is stable"
|
|
380
|
+
];
|
|
381
|
+
}
|
|
382
|
+
extractHypotheses(traces) {
|
|
383
|
+
return [
|
|
384
|
+
"Bug is in validation logic",
|
|
385
|
+
"Performance issue is database-related"
|
|
386
|
+
];
|
|
387
|
+
}
|
|
388
|
+
extractExplorationPaths(traces) {
|
|
389
|
+
return [
|
|
390
|
+
"Try different algorithm",
|
|
391
|
+
"Refactor data structure",
|
|
392
|
+
"Add caching layer"
|
|
393
|
+
];
|
|
394
|
+
}
|
|
395
|
+
async getCurrentGitBranch() {
|
|
396
|
+
try {
|
|
397
|
+
return execSync("git branch --show-current", {
|
|
398
|
+
encoding: "utf-8",
|
|
399
|
+
cwd: this.projectRoot
|
|
400
|
+
}).trim();
|
|
401
|
+
} catch (error) {
|
|
402
|
+
return "unknown";
|
|
403
|
+
}
|
|
404
|
+
}
|
|
405
|
+
async getPackageJson() {
|
|
406
|
+
try {
|
|
407
|
+
const content = await fs.readFile(
|
|
408
|
+
path.join(this.projectRoot, "package.json"),
|
|
409
|
+
"utf-8"
|
|
410
|
+
);
|
|
411
|
+
return JSON.parse(content);
|
|
412
|
+
} catch (error) {
|
|
413
|
+
return null;
|
|
414
|
+
}
|
|
415
|
+
}
|
|
416
|
+
getRelevantEnvVars() {
|
|
417
|
+
const relevantVars = ["NODE_ENV", "DEBUG", "PORT", "DATABASE_URL"];
|
|
418
|
+
const result = {};
|
|
419
|
+
relevantVars.forEach((varName) => {
|
|
420
|
+
if (process.env[varName]) {
|
|
421
|
+
result[varName] = process.env[varName];
|
|
422
|
+
}
|
|
423
|
+
});
|
|
424
|
+
return result;
|
|
425
|
+
}
|
|
426
|
+
/**
|
|
427
|
+
* Restore context after /clear
|
|
428
|
+
*/
|
|
429
|
+
async restoreFromEnhancedContext() {
|
|
430
|
+
const latestPath = path.join(
|
|
431
|
+
this.projectRoot,
|
|
432
|
+
".stackmemory",
|
|
433
|
+
"pre-clear",
|
|
434
|
+
"latest-context.json"
|
|
435
|
+
);
|
|
436
|
+
try {
|
|
437
|
+
const content = await fs.readFile(latestPath, "utf-8");
|
|
438
|
+
const context = JSON.parse(content);
|
|
439
|
+
console.log("\u{1F4DA} Restoring enhanced context...");
|
|
440
|
+
console.log(` Session: ${context.sessionId}`);
|
|
441
|
+
console.log(` Task: ${context.workingState.currentTask}`);
|
|
442
|
+
console.log(` Files: ${context.workingState.activeFiles.length}`);
|
|
443
|
+
console.log(` Focus: ${context.cognitiveState.currentFocus}`);
|
|
444
|
+
await this.clearSurvival.restoreFromLedger();
|
|
445
|
+
return true;
|
|
446
|
+
} catch (error) {
|
|
447
|
+
console.error("Failed to restore enhanced context:", error);
|
|
448
|
+
return false;
|
|
449
|
+
}
|
|
450
|
+
}
|
|
451
|
+
}
|
|
452
|
+
export {
|
|
453
|
+
EnhancedPreClearHooks
|
|
454
|
+
};
|
|
455
|
+
//# sourceMappingURL=enhanced-pre-clear-hooks.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/integrations/claude-code/enhanced-pre-clear-hooks.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * Enhanced Pre-Clear Context Preservation System\n * Comprehensive session state capture before /clear or /compact operations\n */\n\nimport { EventEmitter } from 'events';\nimport { ClearSurvival } from '../../core/session/clear-survival';\nimport { HandoffGenerator } from '../../core/session/handoff-generator';\nimport { FrameManager } from '../../core/frame/frame-manager';\nimport { DatabaseManager } from '../../core/storage/database-manager';\nimport * as fs from 'fs/promises';\nimport * as path from 'path';\nimport { execSync } from 'child_process';\n\nexport interface PreClearContext {\n // Session metadata\n sessionId: string;\n timestamp: string;\n trigger:\n | 'manual_clear'\n | 'auto_compact'\n | 'context_overflow'\n | 'user_request';\n\n // Context analysis\n contextUsage: {\n estimatedTokens: number;\n maxTokens: number;\n percentage: number;\n components: {\n frames: number;\n traces: number;\n conversations: number;\n codeBlocks: number;\n };\n };\n\n // Active work state\n workingState: {\n currentTask: string;\n activeFiles: string[];\n recentCommands: string[];\n pendingActions: string[];\n blockers: string[];\n };\n\n // Conversation state\n conversationState: {\n lastUserMessage: string;\n lastAssistantMessage: string;\n conversationTopic: string;\n messageCount: number;\n recentContext: string[];\n };\n\n // Code context\n codeContext: {\n modifiedFiles: FileContext[];\n gitStatus: GitStatus;\n testResults?: TestResults;\n buildStatus?: BuildStatus;\n dependencies: DependencyInfo[];\n };\n\n // Cognitive state\n cognitiveState: {\n currentFocus: string;\n mentalModel: string[];\n assumptions: string[];\n hypotheses: string[];\n explorationPaths: string[];\n };\n\n // Environment snapshot\n environment: {\n workingDirectory: string;\n gitBranch: string;\n nodeVersion?: string;\n packageJson?: any;\n environmentVars: Record<string, string>;\n };\n}\n\ninterface FileContext {\n path: string;\n lastModified: string;\n changeType: 'created' | 'modified' | 'deleted';\n lineChanges: { added: number; removed: number };\n purpose: string;\n relatedFiles: string[];\n}\n\ninterface GitStatus {\n branch: string;\n ahead: number;\n behind: number;\n staged: string[];\n unstaged: string[];\n untracked: string[];\n lastCommit: {\n hash: string;\n message: string;\n timestamp: string;\n };\n}\n\ninterface TestResults {\n framework: string;\n passed: number;\n failed: number;\n skipped: number;\n coverage?: number;\n failures: string[];\n}\n\ninterface BuildStatus {\n success: boolean;\n errors: string[];\n warnings: string[];\n timestamp: string;\n}\n\ninterface DependencyInfo {\n name: string;\n version: string;\n type: 'dependency' | 'devDependency' | 'global';\n critical: boolean;\n}\n\nexport class EnhancedPreClearHooks extends EventEmitter {\n private frameManager: FrameManager;\n private dbManager: DatabaseManager;\n private clearSurvival: ClearSurvival;\n private handoffGenerator: HandoffGenerator;\n private projectRoot: string;\n\n constructor(\n frameManager: FrameManager,\n dbManager: DatabaseManager,\n clearSurvival: ClearSurvival,\n handoffGenerator: HandoffGenerator,\n projectRoot: string\n ) {\n super();\n this.frameManager = frameManager;\n this.dbManager = dbManager;\n this.clearSurvival = clearSurvival;\n this.handoffGenerator = handoffGenerator;\n this.projectRoot = projectRoot;\n }\n\n /**\n * Comprehensive pre-clear context capture\n */\n async capturePreClearContext(\n trigger: PreClearContext['trigger']\n ): Promise<PreClearContext> {\n console.log('\uD83D\uDD0D Capturing comprehensive session context...');\n\n const context: PreClearContext = {\n sessionId: await this.dbManager.getCurrentSessionId(),\n timestamp: new Date().toISOString(),\n trigger,\n\n contextUsage: await this.analyzeContextUsage(),\n workingState: await this.captureWorkingState(),\n conversationState: await this.captureConversationState(),\n codeContext: await this.captureCodeContext(),\n cognitiveState: await this.captureCognitiveState(),\n environment: await this.captureEnvironment(),\n };\n\n // Save comprehensive context\n await this.saveEnhancedContext(context);\n\n // Emit for other systems to react\n this.emit('context:captured', context);\n\n console.log('\u2705 Comprehensive context captured');\n return context;\n }\n\n /**\n * Analyze current context usage with detailed breakdown\n */\n private async analyzeContextUsage(): Promise<\n PreClearContext['contextUsage']\n > {\n const sessionId = await this.dbManager.getCurrentSessionId();\n const frames = await this.dbManager.getRecentFrames(sessionId, 1000);\n const traces = await this.dbManager.getRecentTraces(sessionId, 1000);\n\n // Estimate token usage by component\n const frameTokens = frames.length * 200; // Average tokens per frame\n const traceTokens = traces.length * 100; // Average tokens per trace\n const conversationTokens = await this.estimateConversationTokens();\n const codeBlockTokens = await this.estimateCodeBlockTokens();\n\n const estimatedTokens =\n frameTokens + traceTokens + conversationTokens + codeBlockTokens;\n const maxTokens = 100000; // Claude's limit\n\n return {\n estimatedTokens,\n maxTokens,\n percentage: estimatedTokens / maxTokens,\n components: {\n frames: frameTokens,\n traces: traceTokens,\n conversations: conversationTokens,\n codeBlocks: codeBlockTokens,\n },\n };\n }\n\n /**\n * Capture current working state\n */\n private async captureWorkingState(): Promise<\n PreClearContext['workingState']\n > {\n const activeFrame = await this.getCurrentActiveFrame();\n const recentTraces = await this.dbManager.getRecentTraces(\n await this.dbManager.getCurrentSessionId(),\n 50\n );\n\n // Extract active files from recent operations\n const activeFiles = this.extractActiveFiles(recentTraces);\n\n // Get recent commands\n const recentCommands = recentTraces\n .filter((t) => t.type === 'bash' || t.type === 'command')\n .map((t) => t.content.command)\n .slice(0, 10);\n\n // Identify pending actions from frame metadata\n const pendingActions = this.extractPendingActions(activeFrame);\n\n // Identify blockers\n const blockers = this.extractBlockers(recentTraces);\n\n return {\n currentTask: activeFrame?.description || 'No active task',\n activeFiles,\n recentCommands,\n pendingActions,\n blockers,\n };\n }\n\n /**\n * Capture conversation state and recent context\n */\n private async captureConversationState(): Promise<\n PreClearContext['conversationState']\n > {\n const sessionId = await this.dbManager.getCurrentSessionId();\n const recentTraces = await this.dbManager.getRecentTraces(sessionId, 100);\n\n // Find last user and assistant messages\n const userMessages = recentTraces\n .filter((t) => t.type === 'user_message' || t.type === 'input')\n .slice(0, 5);\n\n const assistantMessages = recentTraces\n .filter((t) => t.type === 'assistant_message' || t.type === 'response')\n .slice(0, 5);\n\n // Extract conversation topic from recent interactions\n const conversationTopic = this.inferConversationTopic(recentTraces);\n\n // Build recent context summary\n const recentContext = this.buildRecentContextSummary(recentTraces);\n\n return {\n lastUserMessage:\n userMessages[0]?.content.message || 'No recent user message',\n lastAssistantMessage:\n assistantMessages[0]?.content.message || 'No recent assistant message',\n conversationTopic,\n messageCount: userMessages.length + assistantMessages.length,\n recentContext,\n };\n }\n\n /**\n * Capture comprehensive code context\n */\n private async captureCodeContext(): Promise<PreClearContext['codeContext']> {\n const gitStatus = await this.captureGitStatus();\n const modifiedFiles = await this.captureModifiedFiles();\n const testResults = await this.captureTestResults();\n const buildStatus = await this.captureBuildStatus();\n const dependencies = await this.captureDependencies();\n\n return {\n modifiedFiles,\n gitStatus,\n testResults,\n buildStatus,\n dependencies,\n };\n }\n\n /**\n * Capture cognitive state and mental model\n */\n private async captureCognitiveState(): Promise<\n PreClearContext['cognitiveState']\n > {\n const sessionId = await this.dbManager.getCurrentSessionId();\n const recentTraces = await this.dbManager.getRecentTraces(sessionId, 100);\n\n // Extract cognitive elements from traces and frames\n const currentFocus = await this.extractCurrentFocus();\n const mentalModel = this.extractMentalModel(recentTraces);\n const assumptions = this.extractAssumptions(recentTraces);\n const hypotheses = this.extractHypotheses(recentTraces);\n const explorationPaths = this.extractExplorationPaths(recentTraces);\n\n return {\n currentFocus,\n mentalModel,\n assumptions,\n hypotheses,\n explorationPaths,\n };\n }\n\n /**\n * Capture environment snapshot\n */\n private async captureEnvironment(): Promise<PreClearContext['environment']> {\n const gitBranch = await this.getCurrentGitBranch();\n const packageJson = await this.getPackageJson();\n const environmentVars = this.getRelevantEnvVars();\n\n return {\n workingDirectory: this.projectRoot,\n gitBranch,\n nodeVersion: process.version,\n packageJson,\n environmentVars,\n };\n }\n\n /**\n * Save enhanced context to multiple locations for reliability\n */\n private async saveEnhancedContext(context: PreClearContext): Promise<void> {\n const timestamp = context.timestamp.replace(/[:.]/g, '-');\n\n // Save to primary location\n const primaryPath = path.join(\n this.projectRoot,\n '.stackmemory',\n 'pre-clear',\n `context-${timestamp}.json`\n );\n\n // Save to backup location\n const backupPath = path.join(\n this.projectRoot,\n '.stackmemory',\n 'pre-clear',\n 'latest-context.json'\n );\n\n // Create markdown summary\n const markdownPath = path.join(\n this.projectRoot,\n '.stackmemory',\n 'pre-clear',\n `context-${timestamp}.md`\n );\n\n await fs.mkdir(path.dirname(primaryPath), { recursive: true });\n\n // Save JSON\n await fs.writeFile(primaryPath, JSON.stringify(context, null, 2), 'utf-8');\n await fs.writeFile(backupPath, JSON.stringify(context, null, 2), 'utf-8');\n\n // Save markdown summary\n const markdown = this.generateMarkdownSummary(context);\n await fs.writeFile(markdownPath, markdown, 'utf-8');\n\n console.log(\n `\uD83D\uDCC1 Context saved to ${path.relative(this.projectRoot, primaryPath)}`\n );\n }\n\n /**\n * Generate human-readable markdown summary\n */\n private generateMarkdownSummary(context: PreClearContext): string {\n const lines = [\n `# Pre-Clear Context Snapshot`,\n `**Timestamp**: ${new Date(context.timestamp).toLocaleString()}`,\n `**Trigger**: ${context.trigger}`,\n `**Session ID**: ${context.sessionId}`,\n '',\n\n `## \uD83D\uDCCA Context Usage`,\n `- **Total Tokens**: ${context.contextUsage.estimatedTokens.toLocaleString()} / ${context.contextUsage.maxTokens.toLocaleString()} (${Math.round(context.contextUsage.percentage * 100)}%)`,\n `- **Frames**: ${context.contextUsage.components.frames} tokens`,\n `- **Traces**: ${context.contextUsage.components.traces} tokens`,\n `- **Conversations**: ${context.contextUsage.components.conversations} tokens`,\n `- **Code Blocks**: ${context.contextUsage.components.codeBlocks} tokens`,\n '',\n\n `## \uD83C\uDFAF Current Work State`,\n `**Task**: ${context.workingState.currentTask}`,\n `**Active Files** (${context.workingState.activeFiles.length}):`,\n ...context.workingState.activeFiles.slice(0, 10).map((f) => `- ${f}`),\n '',\n `**Recent Commands**:`,\n ...context.workingState.recentCommands\n .slice(0, 5)\n .map((c) => `- \\`${c}\\``),\n '',\n\n `## \uD83D\uDCAC Conversation State`,\n `**Topic**: ${context.conversationState.conversationTopic}`,\n `**Messages**: ${context.conversationState.messageCount}`,\n `**Last User**: ${context.conversationState.lastUserMessage.substring(0, 100)}...`,\n '',\n\n `## \uD83D\uDCDD Code Context`,\n `**Git Branch**: ${context.codeContext.gitStatus.branch}`,\n `**Modified Files**: ${context.codeContext.modifiedFiles.length}`,\n `**Staged**: ${context.codeContext.gitStatus.staged.length}`,\n `**Unstaged**: ${context.codeContext.gitStatus.unstaged.length}`,\n '',\n\n `## \uD83E\uDDE0 Cognitive State`,\n `**Current Focus**: ${context.cognitiveState.currentFocus}`,\n `**Mental Model**:`,\n ...context.cognitiveState.mentalModel.slice(0, 5).map((m) => `- ${m}`),\n '',\n\n `## \uD83C\uDF0D Environment`,\n `**Directory**: ${context.environment.workingDirectory}`,\n `**Node Version**: ${context.environment.nodeVersion}`,\n `**Git Branch**: ${context.environment.gitBranch}`,\n '',\n ];\n\n return lines.filter((l) => l !== undefined).join('\\n');\n }\n\n // Helper methods (simplified implementations)\n\n private async estimateConversationTokens(): Promise<number> {\n // Simplified - would analyze recent conversation history\n return 15000;\n }\n\n private async estimateCodeBlockTokens(): Promise<number> {\n // Simplified - would analyze code blocks in context\n return 8000;\n }\n\n private async getCurrentActiveFrame(): Promise<any> {\n const stack = await this.frameManager.getStack();\n return stack.frames.find((f) => f.status === 'open');\n }\n\n private extractActiveFiles(traces: any[]): string[] {\n const files = new Set<string>();\n traces.forEach((trace) => {\n if (trace.content?.file_path) files.add(trace.content.file_path);\n if (trace.content?.path) files.add(trace.content.path);\n });\n return Array.from(files).slice(0, 20);\n }\n\n private extractPendingActions(frame: any): string[] {\n if (!frame?.metadata?.pendingActions) return [];\n return frame.metadata.pendingActions;\n }\n\n private extractBlockers(traces: any[]): string[] {\n return traces\n .filter((t) => t.type === 'error' && !t.metadata?.resolved)\n .map((t) => t.content.error || 'Unknown error')\n .slice(0, 5);\n }\n\n private inferConversationTopic(traces: any[]): string {\n // Simplified - would use NLP to infer topic\n return 'Code implementation and debugging';\n }\n\n private buildRecentContextSummary(traces: any[]): string[] {\n return traces\n .slice(0, 10)\n .map(\n (t) =>\n `${t.type}: ${t.content.summary || t.content.description || 'No description'}`\n )\n .filter((s) => s.length > 10);\n }\n\n private async captureGitStatus(): Promise<GitStatus> {\n try {\n const branch = execSync('git branch --show-current', {\n encoding: 'utf-8',\n cwd: this.projectRoot,\n }).trim();\n const staged = execSync('git diff --cached --name-only', {\n encoding: 'utf-8',\n cwd: this.projectRoot,\n })\n .trim()\n .split('\\n')\n .filter(Boolean);\n const unstaged = execSync('git diff --name-only', {\n encoding: 'utf-8',\n cwd: this.projectRoot,\n })\n .trim()\n .split('\\n')\n .filter(Boolean);\n const untracked = execSync('git ls-files --others --exclude-standard', {\n encoding: 'utf-8',\n cwd: this.projectRoot,\n })\n .trim()\n .split('\\n')\n .filter(Boolean);\n\n return {\n branch,\n ahead: 0, // Would implement git status parsing\n behind: 0,\n staged,\n unstaged,\n untracked,\n lastCommit: {\n hash: 'abc123', // Would get from git log\n message: 'Recent commit',\n timestamp: new Date().toISOString(),\n },\n };\n } catch (error) {\n return {\n branch: 'unknown',\n ahead: 0,\n behind: 0,\n staged: [],\n unstaged: [],\n untracked: [],\n lastCommit: { hash: '', message: '', timestamp: '' },\n };\n }\n }\n\n private async captureModifiedFiles(): Promise<FileContext[]> {\n try {\n const output = execSync('git diff --name-status', {\n encoding: 'utf-8',\n cwd: this.projectRoot,\n });\n return output\n .trim()\n .split('\\n')\n .filter(Boolean)\n .map((line) => {\n const [status, path] = line.split('\\t');\n return {\n path,\n lastModified: new Date().toISOString(),\n changeType:\n status === 'A'\n ? 'created'\n : status === 'D'\n ? 'deleted'\n : 'modified',\n lineChanges: { added: 0, removed: 0 }, // Would get from git diff --stat\n purpose: 'Code changes',\n relatedFiles: [],\n };\n });\n } catch (error) {\n return [];\n }\n }\n\n private async captureTestResults(): Promise<TestResults | undefined> {\n // Would implement test result parsing\n return undefined;\n }\n\n private async captureBuildStatus(): Promise<BuildStatus | undefined> {\n // Would implement build status checking\n return undefined;\n }\n\n private async captureDependencies(): Promise<DependencyInfo[]> {\n try {\n const packageJsonPath = path.join(this.projectRoot, 'package.json');\n const content = await fs.readFile(packageJsonPath, 'utf-8');\n const packageJson = JSON.parse(content);\n\n const deps: DependencyInfo[] = [];\n\n Object.entries(packageJson.dependencies || {}).forEach(\n ([name, version]) => {\n deps.push({\n name,\n version: version as string,\n type: 'dependency',\n critical: ['react', 'express', 'next'].includes(name),\n });\n }\n );\n\n return deps;\n } catch (error) {\n return [];\n }\n }\n\n private async extractCurrentFocus(): Promise<string> {\n const activeFrame = await this.getCurrentActiveFrame();\n return activeFrame?.description || 'No current focus';\n }\n\n private extractMentalModel(traces: any[]): string[] {\n // Would extract mental model concepts from traces\n return [\n 'Component architecture',\n 'Data flow patterns',\n 'Error handling strategy',\n ];\n }\n\n private extractAssumptions(traces: any[]): string[] {\n // Would extract assumptions from traces\n return [\n 'User input is validated',\n 'Database is available',\n 'Network is stable',\n ];\n }\n\n private extractHypotheses(traces: any[]): string[] {\n // Would extract hypotheses being tested\n return [\n 'Bug is in validation logic',\n 'Performance issue is database-related',\n ];\n }\n\n private extractExplorationPaths(traces: any[]): string[] {\n // Would extract different approaches being explored\n return [\n 'Try different algorithm',\n 'Refactor data structure',\n 'Add caching layer',\n ];\n }\n\n private async getCurrentGitBranch(): Promise<string> {\n try {\n return execSync('git branch --show-current', {\n encoding: 'utf-8',\n cwd: this.projectRoot,\n }).trim();\n } catch (error) {\n return 'unknown';\n }\n }\n\n private async getPackageJson(): Promise<any> {\n try {\n const content = await fs.readFile(\n path.join(this.projectRoot, 'package.json'),\n 'utf-8'\n );\n return JSON.parse(content);\n } catch (error) {\n return null;\n }\n }\n\n private getRelevantEnvVars(): Record<string, string> {\n const relevantVars = ['NODE_ENV', 'DEBUG', 'PORT', 'DATABASE_URL'];\n const result: Record<string, string> = {};\n\n relevantVars.forEach((varName) => {\n if (process.env[varName]) {\n result[varName] = process.env[varName]!;\n }\n });\n\n return result;\n }\n\n /**\n * Restore context after /clear\n */\n async restoreFromEnhancedContext(): Promise<boolean> {\n const latestPath = path.join(\n this.projectRoot,\n '.stackmemory',\n 'pre-clear',\n 'latest-context.json'\n );\n\n try {\n const content = await fs.readFile(latestPath, 'utf-8');\n const context: PreClearContext = JSON.parse(content);\n\n console.log('\uD83D\uDCDA Restoring enhanced context...');\n console.log(` Session: ${context.sessionId}`);\n console.log(` Task: ${context.workingState.currentTask}`);\n console.log(` Files: ${context.workingState.activeFiles.length}`);\n console.log(` Focus: ${context.cognitiveState.currentFocus}`);\n\n // Restore using existing systems\n await this.clearSurvival.restoreFromLedger();\n\n // Additional restoration logic would go here\n\n return true;\n } catch (error) {\n console.error('Failed to restore enhanced context:', error);\n return false;\n }\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["path"]
|
|
7
|
+
}
|