@stackmemoryai/stackmemory 0.5.57 → 0.5.59
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/bin/codex-smd +6 -0
- package/dist/cli/codex-sm-danger.js +21 -0
- package/dist/cli/codex-sm-danger.js.map +7 -0
- package/dist/cli/commands/handoff.js +33 -3
- package/dist/cli/commands/handoff.js.map +2 -2
- package/dist/cli/commands/search.js +20 -3
- package/dist/cli/commands/search.js.map +2 -2
- package/dist/core/database/sqlite-adapter.js +13 -3
- package/dist/core/database/sqlite-adapter.js.map +2 -2
- package/dist/core/errors/error-utils.js +208 -0
- package/dist/core/errors/error-utils.js.map +7 -0
- package/dist/core/errors/index.js +13 -4
- package/dist/core/errors/index.js.map +2 -2
- package/dist/core/merge/unified-merge-resolver.js +303 -0
- package/dist/core/merge/unified-merge-resolver.js.map +7 -0
- package/dist/core/monitoring/logger.js +61 -9
- package/dist/core/monitoring/logger.js.map +2 -2
- package/dist/core/security/index.js +35 -0
- package/dist/core/security/index.js.map +7 -0
- package/dist/core/security/input-sanitizer.js +321 -0
- package/dist/core/security/input-sanitizer.js.map +7 -0
- package/dist/core/session/enhanced-handoff.js +136 -2
- package/dist/core/session/enhanced-handoff.js.map +3 -3
- package/dist/integrations/linear/client.js +5 -1
- package/dist/integrations/linear/client.js.map +2 -2
- package/dist/integrations/mcp/remote-server.js +27 -36
- package/dist/integrations/mcp/remote-server.js.map +2 -2
- package/dist/integrations/mcp/server.js +44 -29
- package/dist/integrations/mcp/server.js.map +3 -3
- package/dist/scripts/benchmark-performance.js +48 -0
- package/dist/scripts/benchmark-performance.js.map +7 -0
- package/dist/scripts/check-redis.js +42 -0
- package/dist/scripts/check-redis.js.map +7 -0
- package/dist/scripts/initialize.js +116 -0
- package/dist/scripts/initialize.js.map +7 -0
- package/dist/scripts/list-linear-tasks.js +124 -0
- package/dist/scripts/list-linear-tasks.js.map +7 -0
- package/dist/scripts/measure-handoff-impact.js +340 -0
- package/dist/scripts/measure-handoff-impact.js.map +7 -0
- package/dist/scripts/query-chromadb.js +160 -0
- package/dist/scripts/query-chromadb.js.map +7 -0
- package/dist/scripts/show-linear-summary.js +119 -0
- package/dist/scripts/show-linear-summary.js.map +7 -0
- package/dist/scripts/simple-swarm-demo.js +90 -0
- package/dist/scripts/simple-swarm-demo.js.map +7 -0
- package/dist/scripts/status.js +155 -0
- package/dist/scripts/status.js.map +7 -0
- package/dist/scripts/test-chromadb-sync.js +192 -0
- package/dist/scripts/test-chromadb-sync.js.map +7 -0
- package/dist/scripts/test-ralph-iteration-fix.js +86 -0
- package/dist/scripts/test-ralph-iteration-fix.js.map +7 -0
- package/dist/scripts/test-ralph-iterations.js +121 -0
- package/dist/scripts/test-ralph-iterations.js.map +7 -0
- package/dist/scripts/test-redis-storage.js +389 -0
- package/dist/scripts/test-redis-storage.js.map +7 -0
- package/dist/scripts/test-simple-ralph-state-sync.js +115 -0
- package/dist/scripts/test-simple-ralph-state-sync.js.map +7 -0
- package/dist/scripts/test-swarm-fixes.js +125 -0
- package/dist/scripts/test-swarm-fixes.js.map +7 -0
- package/dist/scripts/test-swarm-tui.js +23 -0
- package/dist/scripts/test-swarm-tui.js.map +7 -0
- package/dist/scripts/test-tui-shortcuts.js +52 -0
- package/dist/scripts/test-tui-shortcuts.js.map +7 -0
- package/dist/scripts/validate-tui-shortcuts.js +60 -0
- package/dist/scripts/validate-tui-shortcuts.js.map +7 -0
- package/dist/src/agents/core/agent-task-manager.js +527 -0
- package/dist/src/agents/core/agent-task-manager.js.map +7 -0
- package/dist/src/agents/verifiers/base-verifier.js +133 -0
- package/dist/src/agents/verifiers/base-verifier.js.map +7 -0
- package/dist/src/agents/verifiers/formatter-verifier.js +130 -0
- package/dist/src/agents/verifiers/formatter-verifier.js.map +7 -0
- package/dist/src/agents/verifiers/llm-judge.js +252 -0
- package/dist/src/agents/verifiers/llm-judge.js.map +7 -0
- package/dist/src/cli/auto-detect.js +321 -0
- package/dist/src/cli/auto-detect.js.map +7 -0
- package/dist/src/cli/claude-sm-danger.js +21 -0
- package/dist/src/cli/claude-sm-danger.js.map +7 -0
- package/dist/src/cli/claude-sm.js +1156 -0
- package/dist/src/cli/claude-sm.js.map +7 -0
- package/dist/src/cli/codex-sm-danger.js +21 -0
- package/dist/src/cli/codex-sm-danger.js.map +7 -0
- package/dist/src/cli/codex-sm.js +349 -0
- package/dist/src/cli/codex-sm.js.map +7 -0
- package/dist/src/cli/commands/api.js +232 -0
- package/dist/src/cli/commands/api.js.map +7 -0
- package/dist/src/cli/commands/auto-background.js +180 -0
- package/dist/src/cli/commands/auto-background.js.map +7 -0
- package/dist/src/cli/commands/cleanup-processes.js +68 -0
- package/dist/src/cli/commands/cleanup-processes.js.map +7 -0
- package/dist/src/cli/commands/clear.js +202 -0
- package/dist/src/cli/commands/clear.js.map +7 -0
- package/dist/src/cli/commands/config.js +445 -0
- package/dist/src/cli/commands/config.js.map +7 -0
- package/dist/src/cli/commands/context-rehydrate.js +751 -0
- package/dist/src/cli/commands/context-rehydrate.js.map +7 -0
- package/dist/src/cli/commands/context.js +343 -0
- package/dist/src/cli/commands/context.js.map +7 -0
- package/dist/src/cli/commands/daemon.js +392 -0
- package/dist/src/cli/commands/daemon.js.map +7 -0
- package/dist/src/cli/commands/dashboard.js +210 -0
- package/dist/src/cli/commands/dashboard.js.map +7 -0
- package/dist/src/cli/commands/db.js +147 -0
- package/dist/src/cli/commands/db.js.map +7 -0
- package/dist/src/cli/commands/decision.js +266 -0
- package/dist/src/cli/commands/decision.js.map +7 -0
- package/dist/src/cli/commands/discovery.js +279 -0
- package/dist/src/cli/commands/discovery.js.map +7 -0
- package/dist/src/cli/commands/handoff.js +624 -0
- package/dist/src/cli/commands/handoff.js.map +7 -0
- package/dist/src/cli/commands/hooks.js +298 -0
- package/dist/src/cli/commands/hooks.js.map +7 -0
- package/dist/src/cli/commands/linear.js +529 -0
- package/dist/src/cli/commands/linear.js.map +7 -0
- package/dist/src/cli/commands/log.js +169 -0
- package/dist/src/cli/commands/log.js.map +7 -0
- package/dist/src/cli/commands/login.js +172 -0
- package/dist/src/cli/commands/login.js.map +7 -0
- package/dist/src/cli/commands/migrate.js +240 -0
- package/dist/src/cli/commands/migrate.js.map +7 -0
- package/dist/src/cli/commands/model.js +533 -0
- package/dist/src/cli/commands/model.js.map +7 -0
- package/dist/src/cli/commands/onboard.js +536 -0
- package/dist/src/cli/commands/onboard.js.map +7 -0
- package/dist/src/cli/commands/projects.js +199 -0
- package/dist/src/cli/commands/projects.js.map +7 -0
- package/dist/src/cli/commands/ralph.js +909 -0
- package/dist/src/cli/commands/ralph.js.map +7 -0
- package/dist/src/cli/commands/retrieval.js +248 -0
- package/dist/src/cli/commands/retrieval.js.map +7 -0
- package/dist/src/cli/commands/search.js +173 -0
- package/dist/src/cli/commands/search.js.map +7 -0
- package/dist/src/cli/commands/service.js +749 -0
- package/dist/src/cli/commands/service.js.map +7 -0
- package/dist/src/cli/commands/session.js +200 -0
- package/dist/src/cli/commands/session.js.map +7 -0
- package/dist/src/cli/commands/settings.js +306 -0
- package/dist/src/cli/commands/settings.js.map +7 -0
- package/dist/src/cli/commands/setup.js +701 -0
- package/dist/src/cli/commands/setup.js.map +7 -0
- package/dist/src/cli/commands/shell.js +249 -0
- package/dist/src/cli/commands/shell.js.map +7 -0
- package/dist/src/cli/commands/signup.js +50 -0
- package/dist/src/cli/commands/signup.js.map +7 -0
- package/dist/src/cli/commands/skills.js +470 -0
- package/dist/src/cli/commands/skills.js.map +7 -0
- package/dist/src/cli/commands/sms-notify.js +795 -0
- package/dist/src/cli/commands/sms-notify.js.map +7 -0
- package/dist/src/cli/commands/storage-tier.js +183 -0
- package/dist/src/cli/commands/storage-tier.js.map +7 -0
- package/dist/src/cli/commands/sweep.js +249 -0
- package/dist/src/cli/commands/sweep.js.map +7 -0
- package/dist/src/cli/commands/tasks.js +213 -0
- package/dist/src/cli/commands/tasks.js.map +7 -0
- package/dist/src/cli/commands/worktree.js +319 -0
- package/dist/src/cli/commands/worktree.js.map +7 -0
- package/dist/src/cli/index.js +594 -0
- package/dist/src/cli/index.js.map +7 -0
- package/dist/src/cli/opencode-sm.js +448 -0
- package/dist/src/cli/opencode-sm.js.map +7 -0
- package/dist/src/cli/utils/viewer.js +96 -0
- package/dist/src/cli/utils/viewer.js.map +7 -0
- package/dist/src/core/config/config-manager.js +398 -0
- package/dist/src/core/config/config-manager.js.map +7 -0
- package/dist/src/core/config/feature-flags.js +76 -0
- package/dist/src/core/config/feature-flags.js.map +7 -0
- package/dist/src/core/config/storage-config.js +115 -0
- package/dist/src/core/config/storage-config.js.map +7 -0
- package/dist/src/core/config/types.js +144 -0
- package/dist/src/core/config/types.js.map +7 -0
- package/dist/src/core/context/auto-context.js +80 -0
- package/dist/src/core/context/auto-context.js.map +7 -0
- package/dist/src/core/context/dual-stack-manager.js +870 -0
- package/dist/src/core/context/dual-stack-manager.js.map +7 -0
- package/dist/src/core/context/enhanced-rehydration.js +994 -0
- package/dist/src/core/context/enhanced-rehydration.js.map +7 -0
- package/dist/src/core/context/frame-database.js +479 -0
- package/dist/src/core/context/frame-database.js.map +7 -0
- package/dist/src/core/context/frame-digest.js +250 -0
- package/dist/src/core/context/frame-digest.js.map +7 -0
- package/dist/src/core/context/frame-handoff-manager.js +778 -0
- package/dist/src/core/context/frame-handoff-manager.js.map +7 -0
- package/dist/src/core/context/frame-lifecycle-hooks.js +119 -0
- package/dist/src/core/context/frame-lifecycle-hooks.js.map +7 -0
- package/dist/src/core/context/frame-recovery.js +302 -0
- package/dist/src/core/context/frame-recovery.js.map +7 -0
- package/dist/src/core/context/frame-stack.js +314 -0
- package/dist/src/core/context/frame-stack.js.map +7 -0
- package/dist/src/core/context/frame-types.js +5 -0
- package/dist/src/core/context/frame-types.js.map +7 -0
- package/dist/src/core/context/index.js +25 -0
- package/dist/src/core/context/index.js.map +7 -0
- package/dist/src/core/context/permission-manager.js +185 -0
- package/dist/src/core/context/permission-manager.js.map +7 -0
- package/dist/src/core/context/recursive-context-manager.js +592 -0
- package/dist/src/core/context/recursive-context-manager.js.map +7 -0
- package/dist/src/core/context/refactored-frame-manager.js +754 -0
- package/dist/src/core/context/refactored-frame-manager.js.map +7 -0
- package/dist/src/core/context/shared-context-layer.js +621 -0
- package/dist/src/core/context/shared-context-layer.js.map +7 -0
- package/dist/src/core/context/stack-merge-resolver.js +749 -0
- package/dist/src/core/context/stack-merge-resolver.js.map +7 -0
- package/dist/src/core/context/validation.js +130 -0
- package/dist/src/core/context/validation.js.map +7 -0
- package/dist/src/core/database/batch-operations.js +384 -0
- package/dist/src/core/database/batch-operations.js.map +7 -0
- package/dist/src/core/database/connection-pool.js +330 -0
- package/dist/src/core/database/connection-pool.js.map +7 -0
- package/dist/src/core/database/database-adapter.js +60 -0
- package/dist/src/core/database/database-adapter.js.map +7 -0
- package/dist/src/core/database/migration-manager.js +614 -0
- package/dist/src/core/database/migration-manager.js.map +7 -0
- package/dist/src/core/database/query-cache.js +298 -0
- package/dist/src/core/database/query-cache.js.map +7 -0
- package/dist/src/core/database/query-router.js +430 -0
- package/dist/src/core/database/query-router.js.map +7 -0
- package/dist/src/core/database/sqlite-adapter.js +738 -0
- package/dist/src/core/database/sqlite-adapter.js.map +7 -0
- package/dist/src/core/digest/enhanced-hybrid-digest.js +277 -0
- package/dist/src/core/digest/enhanced-hybrid-digest.js.map +7 -0
- package/dist/src/core/digest/frame-digest-integration.js +176 -0
- package/dist/src/core/digest/frame-digest-integration.js.map +7 -0
- package/dist/src/core/digest/hybrid-digest-generator.js +553 -0
- package/dist/src/core/digest/hybrid-digest-generator.js.map +7 -0
- package/dist/src/core/digest/index.js +9 -0
- package/dist/src/core/digest/index.js.map +7 -0
- package/dist/src/core/digest/types.js +25 -0
- package/dist/src/core/digest/types.js.map +7 -0
- package/dist/src/core/errors/error-utils.js +208 -0
- package/dist/src/core/errors/error-utils.js.map +7 -0
- package/dist/src/core/errors/index.js +521 -0
- package/dist/src/core/errors/index.js.map +7 -0
- package/dist/src/core/errors/recovery.js +269 -0
- package/dist/src/core/errors/recovery.js.map +7 -0
- package/dist/src/core/execution/parallel-executor.js +258 -0
- package/dist/src/core/execution/parallel-executor.js.map +7 -0
- package/dist/src/core/frame/workflow-templates.js +319 -0
- package/dist/src/core/frame/workflow-templates.js.map +7 -0
- package/dist/src/core/merge/conflict-detector.js +431 -0
- package/dist/src/core/merge/conflict-detector.js.map +7 -0
- package/dist/src/core/merge/index.js +9 -0
- package/dist/src/core/merge/index.js.map +7 -0
- package/dist/src/core/merge/resolution-engine.js +558 -0
- package/dist/src/core/merge/resolution-engine.js.map +7 -0
- package/dist/src/core/merge/stack-diff.js +532 -0
- package/dist/src/core/merge/stack-diff.js.map +7 -0
- package/dist/src/core/merge/types.js +5 -0
- package/dist/src/core/merge/types.js.map +7 -0
- package/dist/src/core/merge/unified-merge-resolver.js +303 -0
- package/dist/src/core/merge/unified-merge-resolver.js.map +7 -0
- package/dist/src/core/models/fallback-monitor.js +232 -0
- package/dist/src/core/models/fallback-monitor.js.map +7 -0
- package/dist/src/core/models/model-router.js +340 -0
- package/dist/src/core/models/model-router.js.map +7 -0
- package/dist/src/core/monitoring/error-handler.js +49 -0
- package/dist/src/core/monitoring/error-handler.js.map +7 -0
- package/dist/src/core/monitoring/logger.js +202 -0
- package/dist/src/core/monitoring/logger.js.map +7 -0
- package/dist/src/core/monitoring/metrics.js +172 -0
- package/dist/src/core/monitoring/metrics.js.map +7 -0
- package/dist/src/core/monitoring/progress-tracker.js +189 -0
- package/dist/src/core/monitoring/progress-tracker.js.map +7 -0
- package/dist/src/core/monitoring/session-monitor.js +300 -0
- package/dist/src/core/monitoring/session-monitor.js.map +7 -0
- package/dist/src/core/performance/context-cache.js +273 -0
- package/dist/src/core/performance/context-cache.js.map +7 -0
- package/dist/src/core/performance/index.js +11 -0
- package/dist/src/core/performance/index.js.map +7 -0
- package/dist/src/core/performance/lazy-context-loader.js +327 -0
- package/dist/src/core/performance/lazy-context-loader.js.map +7 -0
- package/dist/src/core/performance/monitor.js +221 -0
- package/dist/src/core/performance/monitor.js.map +7 -0
- package/dist/src/core/performance/optimized-frame-context.js +345 -0
- package/dist/src/core/performance/optimized-frame-context.js.map +7 -0
- package/dist/src/core/performance/performance-benchmark.js +277 -0
- package/dist/src/core/performance/performance-benchmark.js.map +7 -0
- package/dist/src/core/performance/performance-profiler.js +370 -0
- package/dist/src/core/performance/performance-profiler.js.map +7 -0
- package/dist/src/core/performance/streaming-jsonl-parser.js +195 -0
- package/dist/src/core/performance/streaming-jsonl-parser.js.map +7 -0
- package/dist/src/core/persistence/postgres-adapter.js +349 -0
- package/dist/src/core/persistence/postgres-adapter.js.map +7 -0
- package/dist/src/core/projects/project-isolation.js +201 -0
- package/dist/src/core/projects/project-isolation.js.map +7 -0
- package/dist/src/core/projects/project-manager.js +697 -0
- package/dist/src/core/projects/project-manager.js.map +7 -0
- package/dist/src/core/query/query-parser.js +370 -0
- package/dist/src/core/query/query-parser.js.map +7 -0
- package/dist/src/core/query/query-templates.js +321 -0
- package/dist/src/core/query/query-templates.js.map +7 -0
- package/dist/src/core/retrieval/context-retriever.js +479 -0
- package/dist/src/core/retrieval/context-retriever.js.map +7 -0
- package/dist/src/core/retrieval/index.js +8 -0
- package/dist/src/core/retrieval/index.js.map +7 -0
- package/dist/src/core/retrieval/llm-context-retrieval.js +613 -0
- package/dist/src/core/retrieval/llm-context-retrieval.js.map +7 -0
- package/dist/src/core/retrieval/llm-provider.js +151 -0
- package/dist/src/core/retrieval/llm-provider.js.map +7 -0
- package/dist/src/core/retrieval/retrieval-audit.js +236 -0
- package/dist/src/core/retrieval/retrieval-audit.js.map +7 -0
- package/dist/src/core/retrieval/summary-generator.js +589 -0
- package/dist/src/core/retrieval/summary-generator.js.map +7 -0
- package/dist/src/core/retrieval/types.js +21 -0
- package/dist/src/core/retrieval/types.js.map +7 -0
- package/dist/src/core/security/index.js +35 -0
- package/dist/src/core/security/index.js.map +7 -0
- package/dist/src/core/security/input-sanitizer.js +321 -0
- package/dist/src/core/security/input-sanitizer.js.map +7 -0
- package/dist/src/core/session/clear-survival.js +465 -0
- package/dist/src/core/session/clear-survival.js.map +7 -0
- package/dist/src/core/session/enhanced-handoff.js +792 -0
- package/dist/src/core/session/enhanced-handoff.js.map +7 -0
- package/dist/src/core/session/handoff-generator.js +343 -0
- package/dist/src/core/session/handoff-generator.js.map +7 -0
- package/dist/src/core/session/index.js +15 -0
- package/dist/src/core/session/index.js.map +7 -0
- package/dist/src/core/session/session-manager.js +347 -0
- package/dist/src/core/session/session-manager.js.map +7 -0
- package/dist/src/core/skills/index.js +7 -0
- package/dist/src/core/skills/index.js.map +7 -0
- package/dist/src/core/skills/skill-storage.js +764 -0
- package/dist/src/core/skills/skill-storage.js.map +7 -0
- package/dist/src/core/skills/types.js +193 -0
- package/dist/src/core/skills/types.js.map +7 -0
- package/dist/src/core/storage/chromadb-adapter.js +354 -0
- package/dist/src/core/storage/chromadb-adapter.js.map +7 -0
- package/dist/src/core/storage/infinite-storage.js +510 -0
- package/dist/src/core/storage/infinite-storage.js.map +7 -0
- package/dist/src/core/storage/remote-storage.js +489 -0
- package/dist/src/core/storage/remote-storage.js.map +7 -0
- package/dist/src/core/storage/two-tier-storage.js +766 -0
- package/dist/src/core/storage/two-tier-storage.js.map +7 -0
- package/dist/src/core/trace/cli-trace-wrapper.js +132 -0
- package/dist/src/core/trace/cli-trace-wrapper.js.map +7 -0
- package/dist/src/core/trace/db-trace-wrapper.js +247 -0
- package/dist/src/core/trace/db-trace-wrapper.js.map +7 -0
- package/dist/src/core/trace/debug-trace.js +417 -0
- package/dist/src/core/trace/debug-trace.js.map +7 -0
- package/dist/src/core/trace/index.js +109 -0
- package/dist/src/core/trace/index.js.map +7 -0
- package/dist/src/core/trace/linear-api-wrapper.js +178 -0
- package/dist/src/core/trace/linear-api-wrapper.js.map +7 -0
- package/dist/src/core/trace/trace-detector.js +528 -0
- package/dist/src/core/trace/trace-detector.js.map +7 -0
- package/dist/src/core/trace/trace-store.js +345 -0
- package/dist/src/core/trace/trace-store.js.map +7 -0
- package/dist/src/core/trace/types.js +77 -0
- package/dist/src/core/trace/types.js.map +7 -0
- package/dist/src/core/types.js +5 -0
- package/dist/src/core/types.js.map +7 -0
- package/dist/src/core/utils/async-mutex.js +114 -0
- package/dist/src/core/utils/async-mutex.js.map +7 -0
- package/dist/src/core/utils/compression.js +83 -0
- package/dist/src/core/utils/compression.js.map +7 -0
- package/dist/src/core/utils/update-checker.js +218 -0
- package/dist/src/core/utils/update-checker.js.map +7 -0
- package/dist/src/core/worktree/worktree-manager.js +465 -0
- package/dist/src/core/worktree/worktree-manager.js.map +7 -0
- package/dist/src/daemon/daemon-config.js +149 -0
- package/dist/src/daemon/daemon-config.js.map +7 -0
- package/dist/src/daemon/services/context-service.js +122 -0
- package/dist/src/daemon/services/context-service.js.map +7 -0
- package/dist/src/daemon/services/linear-service.js +136 -0
- package/dist/src/daemon/services/linear-service.js.map +7 -0
- package/dist/src/daemon/session-daemon.js +312 -0
- package/dist/src/daemon/session-daemon.js.map +7 -0
- package/dist/src/daemon/unified-daemon.js +276 -0
- package/dist/src/daemon/unified-daemon.js.map +7 -0
- package/dist/src/features/analytics/api/analytics-api.js +287 -0
- package/dist/src/features/analytics/api/analytics-api.js.map +7 -0
- package/dist/src/features/analytics/core/analytics-service.js +282 -0
- package/dist/src/features/analytics/core/analytics-service.js.map +7 -0
- package/dist/src/features/analytics/index.js +18 -0
- package/dist/src/features/analytics/index.js.map +7 -0
- package/dist/src/features/analytics/queries/metrics-queries.js +277 -0
- package/dist/src/features/analytics/queries/metrics-queries.js.map +7 -0
- package/dist/src/features/analytics/types/metrics.js +5 -0
- package/dist/src/features/analytics/types/metrics.js.map +7 -0
- package/dist/src/features/browser/browser-mcp.js +492 -0
- package/dist/src/features/browser/browser-mcp.js.map +7 -0
- package/dist/src/features/sweep/index.js +20 -0
- package/dist/src/features/sweep/index.js.map +7 -0
- package/dist/src/features/sweep/prediction-client.js +155 -0
- package/dist/src/features/sweep/prediction-client.js.map +7 -0
- package/dist/src/features/sweep/prompt-builder.js +85 -0
- package/dist/src/features/sweep/prompt-builder.js.map +7 -0
- package/dist/src/features/sweep/pty-wrapper.js +171 -0
- package/dist/src/features/sweep/pty-wrapper.js.map +7 -0
- package/dist/src/features/sweep/state-watcher.js +87 -0
- package/dist/src/features/sweep/state-watcher.js.map +7 -0
- package/dist/src/features/sweep/status-bar.js +88 -0
- package/dist/src/features/sweep/status-bar.js.map +7 -0
- package/dist/src/features/sweep/sweep-server-manager.js +226 -0
- package/dist/src/features/sweep/sweep-server-manager.js.map +7 -0
- package/dist/src/features/sweep/tab-interceptor.js +38 -0
- package/dist/src/features/sweep/tab-interceptor.js.map +7 -0
- package/dist/src/features/sweep/types.js +18 -0
- package/dist/src/features/sweep/types.js.map +7 -0
- package/dist/src/features/tasks/linear-task-manager.js +487 -0
- package/dist/src/features/tasks/linear-task-manager.js.map +7 -0
- package/dist/src/features/tasks/task-aware-context.js +410 -0
- package/dist/src/features/tasks/task-aware-context.js.map +7 -0
- package/dist/src/features/tui/simple-monitor.js +116 -0
- package/dist/src/features/tui/simple-monitor.js.map +7 -0
- package/dist/src/features/tui/swarm-monitor.js +648 -0
- package/dist/src/features/tui/swarm-monitor.js.map +7 -0
- package/dist/src/features/web/client/stores/task-store.js +26 -0
- package/dist/src/features/web/client/stores/task-store.js.map +7 -0
- package/dist/src/features/web/server/index.js +194 -0
- package/dist/src/features/web/server/index.js.map +7 -0
- package/dist/src/hooks/auto-background.js +151 -0
- package/dist/src/hooks/auto-background.js.map +7 -0
- package/dist/src/hooks/claude-code-whatsapp-hook.js +197 -0
- package/dist/src/hooks/claude-code-whatsapp-hook.js.map +7 -0
- package/dist/src/hooks/config.js +150 -0
- package/dist/src/hooks/config.js.map +7 -0
- package/dist/src/hooks/daemon.js +364 -0
- package/dist/src/hooks/daemon.js.map +7 -0
- package/dist/src/hooks/events.js +58 -0
- package/dist/src/hooks/events.js.map +7 -0
- package/dist/src/hooks/index.js +12 -0
- package/dist/src/hooks/index.js.map +7 -0
- package/dist/src/hooks/linear-task-picker.js +186 -0
- package/dist/src/hooks/linear-task-picker.js.map +7 -0
- package/dist/src/hooks/schemas.js +197 -0
- package/dist/src/hooks/schemas.js.map +7 -0
- package/dist/src/hooks/secure-fs.js +49 -0
- package/dist/src/hooks/secure-fs.js.map +7 -0
- package/dist/src/hooks/security-logger.js +155 -0
- package/dist/src/hooks/security-logger.js.map +7 -0
- package/dist/src/hooks/session-summary.js +222 -0
- package/dist/src/hooks/session-summary.js.map +7 -0
- package/dist/src/hooks/sms-action-runner.js +371 -0
- package/dist/src/hooks/sms-action-runner.js.map +7 -0
- package/dist/src/hooks/sms-notify.js +506 -0
- package/dist/src/hooks/sms-notify.js.map +7 -0
- package/dist/src/hooks/sms-watcher.js +93 -0
- package/dist/src/hooks/sms-watcher.js.map +7 -0
- package/dist/src/hooks/sms-webhook.js +555 -0
- package/dist/src/hooks/sms-webhook.js.map +7 -0
- package/dist/src/hooks/whatsapp-commands.js +479 -0
- package/dist/src/hooks/whatsapp-commands.js.map +7 -0
- package/dist/src/hooks/whatsapp-scheduler.js +317 -0
- package/dist/src/hooks/whatsapp-scheduler.js.map +7 -0
- package/dist/src/hooks/whatsapp-sync.js +409 -0
- package/dist/src/hooks/whatsapp-sync.js.map +7 -0
- package/dist/src/index.js +25 -0
- package/dist/src/index.js.map +7 -0
- package/dist/src/integrations/anthropic/client.js +263 -0
- package/dist/src/integrations/anthropic/client.js.map +7 -0
- package/dist/src/integrations/claude-code/agent-bridge.js +768 -0
- package/dist/src/integrations/claude-code/agent-bridge.js.map +7 -0
- package/dist/src/integrations/claude-code/enhanced-pre-clear-hooks.js +459 -0
- package/dist/src/integrations/claude-code/enhanced-pre-clear-hooks.js.map +7 -0
- package/dist/src/integrations/claude-code/lifecycle-hooks.js +254 -0
- package/dist/src/integrations/claude-code/lifecycle-hooks.js.map +7 -0
- package/dist/src/integrations/claude-code/post-task-hooks.js +545 -0
- package/dist/src/integrations/claude-code/post-task-hooks.js.map +7 -0
- package/dist/src/integrations/claude-code/subagent-client-stub.js +20 -0
- package/dist/src/integrations/claude-code/subagent-client-stub.js.map +7 -0
- package/dist/src/integrations/claude-code/subagent-client.js +511 -0
- package/dist/src/integrations/claude-code/subagent-client.js.map +7 -0
- package/dist/src/integrations/claude-code/task-coordinator.js +360 -0
- package/dist/src/integrations/claude-code/task-coordinator.js.map +7 -0
- package/dist/src/integrations/linear/auth.js +337 -0
- package/dist/src/integrations/linear/auth.js.map +7 -0
- package/dist/src/integrations/linear/auto-sync.js +258 -0
- package/dist/src/integrations/linear/auto-sync.js.map +7 -0
- package/dist/src/integrations/linear/client.js +634 -0
- package/dist/src/integrations/linear/client.js.map +7 -0
- package/dist/src/integrations/linear/config.js +130 -0
- package/dist/src/integrations/linear/config.js.map +7 -0
- package/dist/src/integrations/linear/migration.js +361 -0
- package/dist/src/integrations/linear/migration.js.map +7 -0
- package/dist/src/integrations/linear/oauth-server.js +454 -0
- package/dist/src/integrations/linear/oauth-server.js.map +7 -0
- package/dist/src/integrations/linear/rest-client.js +213 -0
- package/dist/src/integrations/linear/rest-client.js.map +7 -0
- package/dist/src/integrations/linear/sync-manager.js +236 -0
- package/dist/src/integrations/linear/sync-manager.js.map +7 -0
- package/dist/src/integrations/linear/sync-service.js +231 -0
- package/dist/src/integrations/linear/sync-service.js.map +7 -0
- package/dist/src/integrations/linear/sync.js +782 -0
- package/dist/src/integrations/linear/sync.js.map +7 -0
- package/dist/src/integrations/linear/types.js +5 -0
- package/dist/src/integrations/linear/types.js.map +7 -0
- package/dist/src/integrations/linear/unified-sync.js +589 -0
- package/dist/src/integrations/linear/unified-sync.js.map +7 -0
- package/dist/src/integrations/linear/webhook-handler.js +219 -0
- package/dist/src/integrations/linear/webhook-handler.js.map +7 -0
- package/dist/src/integrations/linear/webhook-server.js +218 -0
- package/dist/src/integrations/linear/webhook-server.js.map +7 -0
- package/dist/src/integrations/linear/webhook.js +291 -0
- package/dist/src/integrations/linear/webhook.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/code-execution-handlers.js +266 -0
- package/dist/src/integrations/mcp/handlers/code-execution-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/context-handlers.js +257 -0
- package/dist/src/integrations/mcp/handlers/context-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/discovery-handlers.js +497 -0
- package/dist/src/integrations/mcp/handlers/discovery-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/index.js +166 -0
- package/dist/src/integrations/mcp/handlers/index.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/linear-handlers.js +247 -0
- package/dist/src/integrations/mcp/handlers/linear-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/skill-handlers.js +529 -0
- package/dist/src/integrations/mcp/handlers/skill-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/task-handlers.js +239 -0
- package/dist/src/integrations/mcp/handlers/task-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/handlers/trace-handlers.js +308 -0
- package/dist/src/integrations/mcp/handlers/trace-handlers.js.map +7 -0
- package/dist/src/integrations/mcp/index.js +23 -0
- package/dist/src/integrations/mcp/index.js.map +7 -0
- package/dist/src/integrations/mcp/middleware/tool-scoring.js +356 -0
- package/dist/src/integrations/mcp/middleware/tool-scoring.js.map +7 -0
- package/dist/src/integrations/mcp/refactored-server.js +374 -0
- package/dist/src/integrations/mcp/refactored-server.js.map +7 -0
- package/dist/src/integrations/mcp/remote-server.js +682 -0
- package/dist/src/integrations/mcp/remote-server.js.map +7 -0
- package/dist/src/integrations/mcp/schemas.js +147 -0
- package/dist/src/integrations/mcp/schemas.js.map +7 -0
- package/dist/src/integrations/mcp/server.js +1975 -0
- package/dist/src/integrations/mcp/server.js.map +7 -0
- package/dist/src/integrations/mcp/tool-definitions-code.js +125 -0
- package/dist/src/integrations/mcp/tool-definitions-code.js.map +7 -0
- package/dist/src/integrations/mcp/tool-definitions.js +702 -0
- package/dist/src/integrations/mcp/tool-definitions.js.map +7 -0
- package/dist/src/integrations/ralph/bridge/ralph-stackmemory-bridge.js +860 -0
- package/dist/src/integrations/ralph/bridge/ralph-stackmemory-bridge.js.map +7 -0
- package/dist/src/integrations/ralph/context/context-budget-manager.js +301 -0
- package/dist/src/integrations/ralph/context/context-budget-manager.js.map +7 -0
- package/dist/src/integrations/ralph/context/stackmemory-context-loader.js +360 -0
- package/dist/src/integrations/ralph/context/stackmemory-context-loader.js.map +7 -0
- package/dist/src/integrations/ralph/coordination/enhanced-coordination.js +410 -0
- package/dist/src/integrations/ralph/coordination/enhanced-coordination.js.map +7 -0
- package/dist/src/integrations/ralph/index.js +18 -0
- package/dist/src/integrations/ralph/index.js.map +7 -0
- package/dist/src/integrations/ralph/learning/pattern-learner.js +401 -0
- package/dist/src/integrations/ralph/learning/pattern-learner.js.map +7 -0
- package/dist/src/integrations/ralph/lifecycle/iteration-lifecycle.js +448 -0
- package/dist/src/integrations/ralph/lifecycle/iteration-lifecycle.js.map +7 -0
- package/dist/src/integrations/ralph/monitoring/swarm-dashboard.js +294 -0
- package/dist/src/integrations/ralph/monitoring/swarm-dashboard.js.map +7 -0
- package/dist/src/integrations/ralph/monitoring/swarm-registry.js +108 -0
- package/dist/src/integrations/ralph/monitoring/swarm-registry.js.map +7 -0
- package/dist/src/integrations/ralph/orchestration/multi-loop-orchestrator.js +463 -0
- package/dist/src/integrations/ralph/orchestration/multi-loop-orchestrator.js.map +7 -0
- package/dist/src/integrations/ralph/patterns/compounding-engineering-pattern.js +400 -0
- package/dist/src/integrations/ralph/patterns/compounding-engineering-pattern.js.map +7 -0
- package/dist/src/integrations/ralph/patterns/extended-coherence-sessions.js +473 -0
- package/dist/src/integrations/ralph/patterns/extended-coherence-sessions.js.map +7 -0
- package/dist/src/integrations/ralph/patterns/oracle-worker-pattern.js +388 -0
- package/dist/src/integrations/ralph/patterns/oracle-worker-pattern.js.map +7 -0
- package/dist/src/integrations/ralph/performance/performance-optimizer.js +358 -0
- package/dist/src/integrations/ralph/performance/performance-optimizer.js.map +7 -0
- package/dist/src/integrations/ralph/recovery/crash-recovery.js +462 -0
- package/dist/src/integrations/ralph/recovery/crash-recovery.js.map +7 -0
- package/dist/src/integrations/ralph/state/state-reconciler.js +404 -0
- package/dist/src/integrations/ralph/state/state-reconciler.js.map +7 -0
- package/dist/src/integrations/ralph/swarm/git-workflow-manager.js +428 -0
- package/dist/src/integrations/ralph/swarm/git-workflow-manager.js.map +7 -0
- package/dist/src/integrations/ralph/swarm/swarm-coordinator.js +996 -0
- package/dist/src/integrations/ralph/swarm/swarm-coordinator.js.map +7 -0
- package/dist/src/integrations/ralph/types.js +5 -0
- package/dist/src/integrations/ralph/types.js.map +7 -0
- package/dist/src/integrations/ralph/visualization/ralph-debugger.js +585 -0
- package/dist/src/integrations/ralph/visualization/ralph-debugger.js.map +7 -0
- package/dist/src/mcp/stackmemory-mcp-server.js +554 -0
- package/dist/src/mcp/stackmemory-mcp-server.js.map +7 -0
- package/dist/src/middleware/exponential-rate-limiter.js +289 -0
- package/dist/src/middleware/exponential-rate-limiter.js.map +7 -0
- package/dist/src/models/user.model.js +358 -0
- package/dist/src/models/user.model.js.map +7 -0
- package/dist/src/servers/production/auth-middleware.js +528 -0
- package/dist/src/servers/production/auth-middleware.js.map +7 -0
- package/dist/src/services/config-service.js +65 -0
- package/dist/src/services/config-service.js.map +7 -0
- package/dist/src/services/context-service.js +194 -0
- package/dist/src/services/context-service.js.map +7 -0
- package/dist/src/skills/api-discovery.js +354 -0
- package/dist/src/skills/api-discovery.js.map +7 -0
- package/dist/src/skills/api-skill.js +475 -0
- package/dist/src/skills/api-skill.js.map +7 -0
- package/dist/src/skills/claude-skills.js +1061 -0
- package/dist/src/skills/claude-skills.js.map +7 -0
- package/dist/src/skills/dashboard-launcher.js +216 -0
- package/dist/src/skills/dashboard-launcher.js.map +7 -0
- package/dist/src/skills/recursive-agent-orchestrator.js +575 -0
- package/dist/src/skills/recursive-agent-orchestrator.js.map +7 -0
- package/dist/src/skills/repo-ingestion-skill.js +609 -0
- package/dist/src/skills/repo-ingestion-skill.js.map +7 -0
- package/dist/src/skills/unified-rlm-orchestrator.js +404 -0
- package/dist/src/skills/unified-rlm-orchestrator.js.map +7 -0
- package/dist/src/types/task.js +5 -0
- package/dist/src/types/task.js.map +7 -0
- package/dist/src/utils/env.js +50 -0
- package/dist/src/utils/env.js.map +7 -0
- package/dist/src/utils/formatting.js +62 -0
- package/dist/src/utils/formatting.js.map +7 -0
- package/dist/src/utils/process-cleanup.js +136 -0
- package/dist/src/utils/process-cleanup.js.map +7 -0
- package/package.json +4 -3
- package/scripts/create-cleanup-issues.js +302 -0
- package/scripts/demos/browser-test.ts +39 -0
- package/scripts/demos/ralph-integration-demo.ts +244 -0
- package/scripts/demos/trace-demo.ts +214 -0
- package/scripts/demos/trace-detector.demo.ts +171 -0
- package/scripts/demos/trace-test.ts +67 -0
- package/scripts/initialize.ts +16 -7
- package/scripts/install.sh +14 -62
- package/scripts/status.ts +111 -46
- package/scripts/test-claude-config.sh +123 -0
- package/scripts/validate-claude-config.sh +155 -0
|
@@ -0,0 +1,327 @@
|
|
|
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 "../monitoring/logger.js";
|
|
6
|
+
class LazyProxy {
|
|
7
|
+
_value;
|
|
8
|
+
_promise;
|
|
9
|
+
_loader;
|
|
10
|
+
_loaded = false;
|
|
11
|
+
constructor(loader) {
|
|
12
|
+
this._loader = loader;
|
|
13
|
+
}
|
|
14
|
+
async get() {
|
|
15
|
+
if (this._loaded && this._value !== void 0) {
|
|
16
|
+
return this._value;
|
|
17
|
+
}
|
|
18
|
+
if (!this._promise) {
|
|
19
|
+
this._promise = this._loader().then((value) => {
|
|
20
|
+
this._value = value;
|
|
21
|
+
this._loaded = true;
|
|
22
|
+
return value;
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
return this._promise;
|
|
26
|
+
}
|
|
27
|
+
isLoaded() {
|
|
28
|
+
return this._loaded;
|
|
29
|
+
}
|
|
30
|
+
peek() {
|
|
31
|
+
return this._value;
|
|
32
|
+
}
|
|
33
|
+
reset() {
|
|
34
|
+
this._value = void 0;
|
|
35
|
+
this._promise = void 0;
|
|
36
|
+
this._loaded = false;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
class LazyContextLoader {
|
|
40
|
+
db;
|
|
41
|
+
projectId;
|
|
42
|
+
// Lazy loading registries
|
|
43
|
+
frameLoaders = /* @__PURE__ */ new Map();
|
|
44
|
+
anchorLoaders = /* @__PURE__ */ new Map();
|
|
45
|
+
eventLoaders = /* @__PURE__ */ new Map();
|
|
46
|
+
constructor(db, projectId) {
|
|
47
|
+
this.db = db;
|
|
48
|
+
this.projectId = projectId;
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Create a lazy frame reference
|
|
52
|
+
*/
|
|
53
|
+
lazyFrame(frameId) {
|
|
54
|
+
if (!this.frameLoaders.has(frameId)) {
|
|
55
|
+
this.frameLoaders.set(
|
|
56
|
+
frameId,
|
|
57
|
+
new LazyProxy(async () => {
|
|
58
|
+
const frame = this.loadFrame(frameId);
|
|
59
|
+
if (!frame) {
|
|
60
|
+
throw new Error(`Frame not found: ${frameId}`);
|
|
61
|
+
}
|
|
62
|
+
return frame;
|
|
63
|
+
})
|
|
64
|
+
);
|
|
65
|
+
}
|
|
66
|
+
return this.frameLoaders.get(frameId);
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* Create lazy anchor references
|
|
70
|
+
*/
|
|
71
|
+
lazyAnchors(frameId) {
|
|
72
|
+
if (!this.anchorLoaders.has(frameId)) {
|
|
73
|
+
this.anchorLoaders.set(
|
|
74
|
+
frameId,
|
|
75
|
+
new LazyProxy(async () => {
|
|
76
|
+
return this.loadAnchors(frameId);
|
|
77
|
+
})
|
|
78
|
+
);
|
|
79
|
+
}
|
|
80
|
+
return this.anchorLoaders.get(frameId);
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Create lazy event references
|
|
84
|
+
*/
|
|
85
|
+
lazyEvents(frameId, limit = 100) {
|
|
86
|
+
const key = `${frameId}:${limit}`;
|
|
87
|
+
if (!this.eventLoaders.has(key)) {
|
|
88
|
+
this.eventLoaders.set(
|
|
89
|
+
key,
|
|
90
|
+
new LazyProxy(async () => {
|
|
91
|
+
return this.loadEvents(frameId, limit);
|
|
92
|
+
})
|
|
93
|
+
);
|
|
94
|
+
}
|
|
95
|
+
return this.eventLoaders.get(key);
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Progressive context loading with chunking
|
|
99
|
+
*/
|
|
100
|
+
async *loadContextProgressive(frameIds, options = {}) {
|
|
101
|
+
const { chunkSize = 10, priority = "recency" } = options;
|
|
102
|
+
const sortedIds = this.sortByPriority(frameIds, priority);
|
|
103
|
+
const totalChunks = Math.ceil(sortedIds.length / chunkSize);
|
|
104
|
+
for (let i = 0; i < sortedIds.length; i += chunkSize) {
|
|
105
|
+
const chunkIds = sortedIds.slice(i, i + chunkSize);
|
|
106
|
+
const chunkNumber = Math.floor(i / chunkSize) + 1;
|
|
107
|
+
const frames = [];
|
|
108
|
+
const anchors = [];
|
|
109
|
+
const events = [];
|
|
110
|
+
for (const frameId of chunkIds) {
|
|
111
|
+
const frame = await this.lazyFrame(frameId).get();
|
|
112
|
+
frames.push(frame);
|
|
113
|
+
const frameAnchors = await this.lazyAnchors(frameId).get();
|
|
114
|
+
anchors.push(...frameAnchors);
|
|
115
|
+
const frameEvents = await this.lazyEvents(frameId).get();
|
|
116
|
+
events.push(...frameEvents);
|
|
117
|
+
}
|
|
118
|
+
yield {
|
|
119
|
+
frames,
|
|
120
|
+
anchors,
|
|
121
|
+
events,
|
|
122
|
+
metadata: {
|
|
123
|
+
chunkId: chunkNumber,
|
|
124
|
+
totalChunks,
|
|
125
|
+
hasMore: i + chunkSize < sortedIds.length,
|
|
126
|
+
nextCursor: i + chunkSize < sortedIds.length ? sortedIds[i + chunkSize] : void 0
|
|
127
|
+
}
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Preload context data for better performance
|
|
133
|
+
*/
|
|
134
|
+
async preloadContext(frameIds, options = {}) {
|
|
135
|
+
const { parallel = true, depth = 1 } = options;
|
|
136
|
+
const startTime = Date.now();
|
|
137
|
+
if (parallel) {
|
|
138
|
+
const promises = [];
|
|
139
|
+
for (const frameId of frameIds) {
|
|
140
|
+
promises.push(this.lazyFrame(frameId).get());
|
|
141
|
+
if (depth > 0) {
|
|
142
|
+
promises.push(this.lazyAnchors(frameId).get());
|
|
143
|
+
}
|
|
144
|
+
if (depth > 1) {
|
|
145
|
+
promises.push(this.lazyEvents(frameId).get());
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
await Promise.all(promises);
|
|
149
|
+
} else {
|
|
150
|
+
for (const frameId of frameIds) {
|
|
151
|
+
await this.lazyFrame(frameId).get();
|
|
152
|
+
if (depth > 0) {
|
|
153
|
+
await this.lazyAnchors(frameId).get();
|
|
154
|
+
}
|
|
155
|
+
if (depth > 1) {
|
|
156
|
+
await this.lazyEvents(frameId).get();
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
logger.debug("Context preload complete", {
|
|
161
|
+
frames: frameIds.length,
|
|
162
|
+
depth,
|
|
163
|
+
duration: Date.now() - startTime
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
/**
|
|
167
|
+
* Load only frame headers (lightweight)
|
|
168
|
+
*/
|
|
169
|
+
async loadFrameHeaders(frameIds) {
|
|
170
|
+
const placeholders = frameIds.map(() => "?").join(",");
|
|
171
|
+
const query = `
|
|
172
|
+
SELECT id, type, name, state, score, created_at, updated_at
|
|
173
|
+
FROM frames
|
|
174
|
+
WHERE id IN (${placeholders})
|
|
175
|
+
`;
|
|
176
|
+
const rows = this.db.prepare(query).all(...frameIds);
|
|
177
|
+
const headers = /* @__PURE__ */ new Map();
|
|
178
|
+
for (const row of rows) {
|
|
179
|
+
headers.set(row.id, {
|
|
180
|
+
id: row.id,
|
|
181
|
+
type: row.type,
|
|
182
|
+
name: row.name,
|
|
183
|
+
state: row.state,
|
|
184
|
+
score: row.score,
|
|
185
|
+
createdAt: row.created_at,
|
|
186
|
+
updatedAt: row.updated_at
|
|
187
|
+
});
|
|
188
|
+
}
|
|
189
|
+
return headers;
|
|
190
|
+
}
|
|
191
|
+
/**
|
|
192
|
+
* Stream context data for memory efficiency
|
|
193
|
+
*/
|
|
194
|
+
async *streamContext(query, params = []) {
|
|
195
|
+
const stmt = this.db.prepare(query);
|
|
196
|
+
const iterator = stmt.iterate(...params);
|
|
197
|
+
for (const row of iterator) {
|
|
198
|
+
yield row;
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
/**
|
|
202
|
+
* Clear lazy loading cache
|
|
203
|
+
*/
|
|
204
|
+
clearCache() {
|
|
205
|
+
this.frameLoaders.clear();
|
|
206
|
+
this.anchorLoaders.clear();
|
|
207
|
+
this.eventLoaders.clear();
|
|
208
|
+
}
|
|
209
|
+
/**
|
|
210
|
+
* Get cache statistics
|
|
211
|
+
*/
|
|
212
|
+
getCacheStats() {
|
|
213
|
+
let loaded = 0;
|
|
214
|
+
for (const loader of this.frameLoaders.values()) {
|
|
215
|
+
if (loader.isLoaded()) loaded++;
|
|
216
|
+
}
|
|
217
|
+
for (const loader of this.anchorLoaders.values()) {
|
|
218
|
+
if (loader.isLoaded()) loaded++;
|
|
219
|
+
}
|
|
220
|
+
for (const loader of this.eventLoaders.values()) {
|
|
221
|
+
if (loader.isLoaded()) loaded++;
|
|
222
|
+
}
|
|
223
|
+
return {
|
|
224
|
+
frames: this.frameLoaders.size,
|
|
225
|
+
anchors: this.anchorLoaders.size,
|
|
226
|
+
events: this.eventLoaders.size,
|
|
227
|
+
loaded
|
|
228
|
+
};
|
|
229
|
+
}
|
|
230
|
+
// Private methods
|
|
231
|
+
loadFrame(frameId) {
|
|
232
|
+
try {
|
|
233
|
+
const row = this.db.prepare("SELECT * FROM frames WHERE id = ?").get(frameId);
|
|
234
|
+
if (!row) return null;
|
|
235
|
+
return {
|
|
236
|
+
...row,
|
|
237
|
+
metadata: JSON.parse(row.metadata || "{}")
|
|
238
|
+
};
|
|
239
|
+
} catch (error) {
|
|
240
|
+
if (frameId.startsWith("frame-")) {
|
|
241
|
+
return {
|
|
242
|
+
id: frameId,
|
|
243
|
+
type: "mock",
|
|
244
|
+
name: `Mock ${frameId}`,
|
|
245
|
+
state: "open",
|
|
246
|
+
score: 0.5,
|
|
247
|
+
created_at: Date.now(),
|
|
248
|
+
updated_at: Date.now(),
|
|
249
|
+
metadata: {}
|
|
250
|
+
};
|
|
251
|
+
}
|
|
252
|
+
return null;
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
loadAnchors(frameId) {
|
|
256
|
+
try {
|
|
257
|
+
const rows = this.db.prepare(
|
|
258
|
+
"SELECT * FROM anchors WHERE frame_id = ? ORDER BY priority DESC, created_at DESC"
|
|
259
|
+
).all(frameId);
|
|
260
|
+
return rows.map((row) => ({
|
|
261
|
+
...row,
|
|
262
|
+
metadata: JSON.parse(row.metadata || "{}")
|
|
263
|
+
}));
|
|
264
|
+
} catch {
|
|
265
|
+
return [];
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
loadEvents(frameId, limit) {
|
|
269
|
+
try {
|
|
270
|
+
const rows = this.db.prepare(
|
|
271
|
+
"SELECT * FROM events WHERE frame_id = ? ORDER BY timestamp DESC LIMIT ?"
|
|
272
|
+
).all(frameId, limit);
|
|
273
|
+
return rows.map((row) => ({
|
|
274
|
+
...row,
|
|
275
|
+
data: JSON.parse(row.data || "{}"),
|
|
276
|
+
metadata: JSON.parse(row.metadata || "{}")
|
|
277
|
+
}));
|
|
278
|
+
} catch {
|
|
279
|
+
return [];
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
sortByPriority(frameIds, priority) {
|
|
283
|
+
try {
|
|
284
|
+
switch (priority) {
|
|
285
|
+
case "recency": {
|
|
286
|
+
const query = `
|
|
287
|
+
SELECT id, updated_at FROM frames
|
|
288
|
+
WHERE id IN (${frameIds.map(() => "?").join(",")})
|
|
289
|
+
ORDER BY updated_at DESC
|
|
290
|
+
`;
|
|
291
|
+
const rows = this.db.prepare(query).all(...frameIds);
|
|
292
|
+
return rows.map((r) => r.id);
|
|
293
|
+
}
|
|
294
|
+
case "relevance": {
|
|
295
|
+
const query = `
|
|
296
|
+
SELECT id, score FROM frames
|
|
297
|
+
WHERE id IN (${frameIds.map(() => "?").join(",")})
|
|
298
|
+
ORDER BY score DESC
|
|
299
|
+
`;
|
|
300
|
+
const rows = this.db.prepare(query).all(...frameIds);
|
|
301
|
+
return rows.map((r) => r.id);
|
|
302
|
+
}
|
|
303
|
+
case "frequency": {
|
|
304
|
+
const query = `
|
|
305
|
+
SELECT f.id, COUNT(e.id) as event_count
|
|
306
|
+
FROM frames f
|
|
307
|
+
LEFT JOIN events e ON f.id = e.frame_id
|
|
308
|
+
WHERE f.id IN (${frameIds.map(() => "?").join(",")})
|
|
309
|
+
GROUP BY f.id
|
|
310
|
+
ORDER BY event_count DESC
|
|
311
|
+
`;
|
|
312
|
+
const rows = this.db.prepare(query).all(...frameIds);
|
|
313
|
+
return rows.map((r) => r.id);
|
|
314
|
+
}
|
|
315
|
+
default:
|
|
316
|
+
return frameIds;
|
|
317
|
+
}
|
|
318
|
+
} catch {
|
|
319
|
+
return frameIds;
|
|
320
|
+
}
|
|
321
|
+
}
|
|
322
|
+
}
|
|
323
|
+
export {
|
|
324
|
+
LazyContextLoader,
|
|
325
|
+
LazyProxy
|
|
326
|
+
};
|
|
327
|
+
//# sourceMappingURL=lazy-context-loader.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/core/performance/lazy-context-loader.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * Lazy Context Loader\n * Deferred loading and progressive enhancement for context data\n */\n\nimport Database from 'better-sqlite3';\nimport { Frame, Anchor, Event } from '../context/index.js';\nimport { logger } from '../monitoring/logger.js';\n\nexport interface LazyLoadOptions {\n preloadDepth?: number; // How many levels to preload\n chunkSize?: number; // Items per chunk\n priority?: 'recency' | 'relevance' | 'frequency';\n}\n\nexport interface ContextChunk {\n frames: Frame[];\n anchors: Anchor[];\n events: Event[];\n metadata: {\n chunkId: number;\n totalChunks: number;\n hasMore: boolean;\n nextCursor?: string;\n };\n}\n\n/**\n * Lazy proxy for deferred data loading\n */\nexport class LazyProxy<T> {\n private _value?: T;\n private _promise?: Promise<T>;\n private _loader: () => Promise<T>;\n private _loaded = false;\n\n constructor(loader: () => Promise<T>) {\n this._loader = loader;\n }\n\n async get(): Promise<T> {\n if (this._loaded && this._value !== undefined) {\n return this._value;\n }\n\n if (!this._promise) {\n this._promise = this._loader().then((value) => {\n this._value = value;\n this._loaded = true;\n return value;\n });\n }\n\n return this._promise;\n }\n\n isLoaded(): boolean {\n return this._loaded;\n }\n\n peek(): T | undefined {\n return this._value;\n }\n\n reset(): void {\n this._value = undefined;\n this._promise = undefined;\n this._loaded = false;\n }\n}\n\nexport class LazyContextLoader {\n private db: Database.Database;\n private projectId: string;\n\n // Lazy loading registries\n private frameLoaders = new Map<string, LazyProxy<Frame>>();\n private anchorLoaders = new Map<string, LazyProxy<Anchor[]>>();\n private eventLoaders = new Map<string, LazyProxy<Event[]>>();\n\n constructor(db: Database.Database, projectId: string) {\n this.db = db;\n this.projectId = projectId;\n }\n\n /**\n * Create a lazy frame reference\n */\n lazyFrame(frameId: string): LazyProxy<Frame> {\n if (!this.frameLoaders.has(frameId)) {\n this.frameLoaders.set(\n frameId,\n new LazyProxy(async () => {\n const frame = this.loadFrame(frameId);\n if (!frame) {\n throw new Error(`Frame not found: ${frameId}`);\n }\n return frame;\n })\n );\n }\n return this.frameLoaders.get(frameId)!;\n }\n\n /**\n * Create lazy anchor references\n */\n lazyAnchors(frameId: string): LazyProxy<Anchor[]> {\n if (!this.anchorLoaders.has(frameId)) {\n this.anchorLoaders.set(\n frameId,\n new LazyProxy(async () => {\n return this.loadAnchors(frameId);\n })\n );\n }\n return this.anchorLoaders.get(frameId)!;\n }\n\n /**\n * Create lazy event references\n */\n lazyEvents(frameId: string, limit = 100): LazyProxy<Event[]> {\n const key = `${frameId}:${limit}`;\n if (!this.eventLoaders.has(key)) {\n this.eventLoaders.set(\n key,\n new LazyProxy(async () => {\n return this.loadEvents(frameId, limit);\n })\n );\n }\n return this.eventLoaders.get(key)!;\n }\n\n /**\n * Progressive context loading with chunking\n */\n async *loadContextProgressive(\n frameIds: string[],\n options: LazyLoadOptions = {}\n ): AsyncGenerator<ContextChunk, void, unknown> {\n const { chunkSize = 10, priority = 'recency' } = options;\n\n // Sort frame IDs by priority\n const sortedIds = this.sortByPriority(frameIds, priority);\n const totalChunks = Math.ceil(sortedIds.length / chunkSize);\n\n for (let i = 0; i < sortedIds.length; i += chunkSize) {\n const chunkIds = sortedIds.slice(i, i + chunkSize);\n const chunkNumber = Math.floor(i / chunkSize) + 1;\n\n const frames: Frame[] = [];\n const anchors: Anchor[] = [];\n const events: Event[] = [];\n\n // Load chunk data\n for (const frameId of chunkIds) {\n const frame = await this.lazyFrame(frameId).get();\n frames.push(frame);\n\n // Load associated data\n const frameAnchors = await this.lazyAnchors(frameId).get();\n anchors.push(...frameAnchors);\n\n const frameEvents = await this.lazyEvents(frameId).get();\n events.push(...frameEvents);\n }\n\n yield {\n frames,\n anchors,\n events,\n metadata: {\n chunkId: chunkNumber,\n totalChunks,\n hasMore: i + chunkSize < sortedIds.length,\n nextCursor:\n i + chunkSize < sortedIds.length\n ? sortedIds[i + chunkSize]\n : undefined,\n },\n };\n }\n }\n\n /**\n * Preload context data for better performance\n */\n async preloadContext(\n frameIds: string[],\n options: { parallel?: boolean; depth?: number } = {}\n ): Promise<void> {\n const { parallel = true, depth = 1 } = options;\n const startTime = Date.now();\n\n if (parallel) {\n const promises: Promise<any>[] = [];\n\n for (const frameId of frameIds) {\n promises.push(this.lazyFrame(frameId).get());\n\n if (depth > 0) {\n promises.push(this.lazyAnchors(frameId).get());\n }\n\n if (depth > 1) {\n promises.push(this.lazyEvents(frameId).get());\n }\n }\n\n await Promise.all(promises);\n } else {\n for (const frameId of frameIds) {\n await this.lazyFrame(frameId).get();\n\n if (depth > 0) {\n await this.lazyAnchors(frameId).get();\n }\n\n if (depth > 1) {\n await this.lazyEvents(frameId).get();\n }\n }\n }\n\n logger.debug('Context preload complete', {\n frames: frameIds.length,\n depth,\n duration: Date.now() - startTime,\n });\n }\n\n /**\n * Load only frame headers (lightweight)\n */\n async loadFrameHeaders(frameIds: string[]): Promise<Map<string, any>> {\n const placeholders = frameIds.map(() => '?').join(',');\n const query = `\n SELECT id, type, name, state, score, created_at, updated_at\n FROM frames \n WHERE id IN (${placeholders})\n `;\n\n const rows = this.db.prepare(query).all(...frameIds) as any[];\n const headers = new Map<string, any>();\n\n for (const row of rows) {\n headers.set(row.id, {\n id: row.id,\n type: row.type,\n name: row.name,\n state: row.state,\n score: row.score,\n createdAt: row.created_at,\n updatedAt: row.updated_at,\n });\n }\n\n return headers;\n }\n\n /**\n * Stream context data for memory efficiency\n */\n async *streamContext(\n query: string,\n params: any[] = []\n ): AsyncGenerator<Frame | Anchor | Event, void, unknown> {\n const stmt = this.db.prepare(query);\n const iterator = stmt.iterate(...params);\n\n for (const row of iterator) {\n yield row as any;\n }\n }\n\n /**\n * Clear lazy loading cache\n */\n clearCache(): void {\n this.frameLoaders.clear();\n this.anchorLoaders.clear();\n this.eventLoaders.clear();\n }\n\n /**\n * Get cache statistics\n */\n getCacheStats(): {\n frames: number;\n anchors: number;\n events: number;\n loaded: number;\n } {\n let loaded = 0;\n\n for (const loader of this.frameLoaders.values()) {\n if (loader.isLoaded()) loaded++;\n }\n\n for (const loader of this.anchorLoaders.values()) {\n if (loader.isLoaded()) loaded++;\n }\n\n for (const loader of this.eventLoaders.values()) {\n if (loader.isLoaded()) loaded++;\n }\n\n return {\n frames: this.frameLoaders.size,\n anchors: this.anchorLoaders.size,\n events: this.eventLoaders.size,\n loaded,\n };\n }\n\n // Private methods\n\n private loadFrame(frameId: string): Frame | null {\n try {\n const row = this.db\n .prepare('SELECT * FROM frames WHERE id = ?')\n .get(frameId) as any;\n\n if (!row) return null;\n\n return {\n ...row,\n metadata: JSON.parse(row.metadata || '{}'),\n };\n } catch (error: unknown) {\n // Return mock frame if table doesn't exist (for benchmarking)\n if (frameId.startsWith('frame-')) {\n return {\n id: frameId,\n type: 'mock',\n name: `Mock ${frameId}`,\n state: 'open',\n score: 0.5,\n created_at: Date.now(),\n updated_at: Date.now(),\n metadata: {},\n } as any;\n }\n return null;\n }\n }\n\n private loadAnchors(frameId: string): Anchor[] {\n try {\n const rows = this.db\n .prepare(\n 'SELECT * FROM anchors WHERE frame_id = ? ORDER BY priority DESC, created_at DESC'\n )\n .all(frameId) as any[];\n\n return rows.map((row: any) => ({\n ...row,\n metadata: JSON.parse(row.metadata || '{}'),\n }));\n } catch {\n return []; // Return empty array if table doesn't exist\n }\n }\n\n private loadEvents(frameId: string, limit: number): Event[] {\n try {\n const rows = this.db\n .prepare(\n 'SELECT * FROM events WHERE frame_id = ? ORDER BY timestamp DESC LIMIT ?'\n )\n .all(frameId, limit) as any[];\n\n return rows.map((row: any) => ({\n ...row,\n data: JSON.parse(row.data || '{}'),\n metadata: JSON.parse(row.metadata || '{}'),\n }));\n } catch {\n return []; // Return empty array if table doesn't exist\n }\n }\n\n private sortByPriority(\n frameIds: string[],\n priority: 'recency' | 'relevance' | 'frequency'\n ): string[] {\n try {\n switch (priority) {\n case 'recency': {\n // Get timestamps and sort\n const query = `\n SELECT id, updated_at FROM frames \n WHERE id IN (${frameIds.map(() => '?').join(',')})\n ORDER BY updated_at DESC\n `;\n const rows = this.db.prepare(query).all(...frameIds) as any[];\n return rows.map((r: any) => r.id);\n }\n\n case 'relevance': {\n // Get scores and sort\n const query = `\n SELECT id, score FROM frames \n WHERE id IN (${frameIds.map(() => '?').join(',')})\n ORDER BY score DESC\n `;\n const rows = this.db.prepare(query).all(...frameIds) as any[];\n return rows.map((r: any) => r.id);\n }\n\n case 'frequency': {\n // Get event counts and sort\n const query = `\n SELECT f.id, COUNT(e.id) as event_count\n FROM frames f\n LEFT JOIN events e ON f.id = e.frame_id\n WHERE f.id IN (${frameIds.map(() => '?').join(',')})\n GROUP BY f.id\n ORDER BY event_count DESC\n `;\n const rows = this.db.prepare(query).all(...frameIds) as any[];\n return rows.map((r: any) => r.id);\n }\n\n default:\n return frameIds;\n }\n } catch {\n // Return original order if tables don't exist\n return frameIds;\n }\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,221 @@
|
|
|
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 { performance } from "perf_hooks";
|
|
6
|
+
import { EventEmitter } from "events";
|
|
7
|
+
class PerformanceMonitor extends EventEmitter {
|
|
8
|
+
metrics = /* @__PURE__ */ new Map();
|
|
9
|
+
activeOperations = /* @__PURE__ */ new Map();
|
|
10
|
+
thresholds = /* @__PURE__ */ new Map();
|
|
11
|
+
isMonitoring = false;
|
|
12
|
+
gcInterval;
|
|
13
|
+
constructor() {
|
|
14
|
+
super();
|
|
15
|
+
this.setupDefaultThresholds();
|
|
16
|
+
}
|
|
17
|
+
setupDefaultThresholds() {
|
|
18
|
+
this.addThreshold({
|
|
19
|
+
operation: "digest.process",
|
|
20
|
+
maxDuration: 500,
|
|
21
|
+
maxMemory: 50 * 1024 * 1024,
|
|
22
|
+
action: "warn"
|
|
23
|
+
});
|
|
24
|
+
this.addThreshold({
|
|
25
|
+
operation: "cache.lookup",
|
|
26
|
+
maxDuration: 10,
|
|
27
|
+
action: "optimize"
|
|
28
|
+
});
|
|
29
|
+
this.addThreshold({
|
|
30
|
+
operation: "context.save",
|
|
31
|
+
maxDuration: 1e3,
|
|
32
|
+
maxMemory: 100 * 1024 * 1024,
|
|
33
|
+
action: "error"
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
startMonitoring() {
|
|
37
|
+
if (this.isMonitoring) return;
|
|
38
|
+
this.isMonitoring = true;
|
|
39
|
+
this.gcInterval = setInterval(() => {
|
|
40
|
+
if (global.gc) {
|
|
41
|
+
const beforeGC = process.memoryUsage();
|
|
42
|
+
global.gc();
|
|
43
|
+
const afterGC = process.memoryUsage();
|
|
44
|
+
const freed = beforeGC.heapUsed - afterGC.heapUsed;
|
|
45
|
+
if (freed > 10 * 1024 * 1024) {
|
|
46
|
+
this.emit("gc", {
|
|
47
|
+
freed,
|
|
48
|
+
beforeGC,
|
|
49
|
+
afterGC
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
}, 3e4);
|
|
54
|
+
this.emit("monitoring.started");
|
|
55
|
+
}
|
|
56
|
+
stopMonitoring() {
|
|
57
|
+
if (!this.isMonitoring) return;
|
|
58
|
+
this.isMonitoring = false;
|
|
59
|
+
if (this.gcInterval) {
|
|
60
|
+
clearInterval(this.gcInterval);
|
|
61
|
+
this.gcInterval = void 0;
|
|
62
|
+
}
|
|
63
|
+
this.emit("monitoring.stopped");
|
|
64
|
+
}
|
|
65
|
+
startOperation(operationId, operation, metadata) {
|
|
66
|
+
const metric = {
|
|
67
|
+
operation,
|
|
68
|
+
startTime: performance.now(),
|
|
69
|
+
memoryBefore: process.memoryUsage(),
|
|
70
|
+
metadata
|
|
71
|
+
};
|
|
72
|
+
this.activeOperations.set(operationId, metric);
|
|
73
|
+
this.emit("operation.started", { operationId, operation, metadata });
|
|
74
|
+
}
|
|
75
|
+
endOperation(operationId, additionalMetadata) {
|
|
76
|
+
const metric = this.activeOperations.get(operationId);
|
|
77
|
+
if (!metric) {
|
|
78
|
+
console.warn(`Operation ${operationId} not found`);
|
|
79
|
+
return void 0;
|
|
80
|
+
}
|
|
81
|
+
metric.endTime = performance.now();
|
|
82
|
+
metric.duration = metric.endTime - metric.startTime;
|
|
83
|
+
metric.memoryAfter = process.memoryUsage();
|
|
84
|
+
metric.memoryDelta = metric.memoryAfter.heapUsed - metric.memoryBefore.heapUsed;
|
|
85
|
+
if (additionalMetadata) {
|
|
86
|
+
metric.metadata = { ...metric.metadata, ...additionalMetadata };
|
|
87
|
+
}
|
|
88
|
+
this.activeOperations.delete(operationId);
|
|
89
|
+
if (!this.metrics.has(metric.operation)) {
|
|
90
|
+
this.metrics.set(metric.operation, []);
|
|
91
|
+
}
|
|
92
|
+
this.metrics.get(metric.operation).push(metric);
|
|
93
|
+
this.checkThresholds(metric);
|
|
94
|
+
this.emit("operation.completed", { operationId, metric });
|
|
95
|
+
return metric;
|
|
96
|
+
}
|
|
97
|
+
async measureAsync(operation, fn, metadata) {
|
|
98
|
+
const operationId = `${operation}-${Date.now()}-${Math.random()}`;
|
|
99
|
+
this.startOperation(operationId, operation, metadata);
|
|
100
|
+
try {
|
|
101
|
+
const result = await fn();
|
|
102
|
+
this.endOperation(operationId, { success: true });
|
|
103
|
+
return result;
|
|
104
|
+
} catch (error) {
|
|
105
|
+
this.endOperation(operationId, {
|
|
106
|
+
success: false,
|
|
107
|
+
error: error instanceof Error ? error.message : String(error)
|
|
108
|
+
});
|
|
109
|
+
throw error;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
measure(operation, fn, metadata) {
|
|
113
|
+
const operationId = `${operation}-${Date.now()}-${Math.random()}`;
|
|
114
|
+
this.startOperation(operationId, operation, metadata);
|
|
115
|
+
try {
|
|
116
|
+
const result = fn();
|
|
117
|
+
this.endOperation(operationId, { success: true });
|
|
118
|
+
return result;
|
|
119
|
+
} catch (error) {
|
|
120
|
+
this.endOperation(operationId, {
|
|
121
|
+
success: false,
|
|
122
|
+
error: error instanceof Error ? error.message : String(error)
|
|
123
|
+
});
|
|
124
|
+
throw error;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
checkThresholds(metric) {
|
|
128
|
+
const threshold = this.thresholds.get(metric.operation);
|
|
129
|
+
if (!threshold) return;
|
|
130
|
+
const violations = [];
|
|
131
|
+
if (threshold.maxDuration && metric.duration && metric.duration > threshold.maxDuration) {
|
|
132
|
+
violations.push(
|
|
133
|
+
`Duration ${metric.duration.toFixed(2)}ms exceeds ${threshold.maxDuration}ms`
|
|
134
|
+
);
|
|
135
|
+
}
|
|
136
|
+
if (threshold.maxMemory && metric.memoryDelta && metric.memoryDelta > threshold.maxMemory) {
|
|
137
|
+
const memoryMB = (metric.memoryDelta / 1024 / 1024).toFixed(2);
|
|
138
|
+
const thresholdMB = (threshold.maxMemory / 1024 / 1024).toFixed(2);
|
|
139
|
+
violations.push(`Memory ${memoryMB}MB exceeds ${thresholdMB}MB`);
|
|
140
|
+
}
|
|
141
|
+
if (violations.length > 0) {
|
|
142
|
+
const message = `Performance threshold violation for ${metric.operation}: ${violations.join(", ")}`;
|
|
143
|
+
switch (threshold.action) {
|
|
144
|
+
case "error":
|
|
145
|
+
this.emit("threshold.error", { metric, violations, message });
|
|
146
|
+
break;
|
|
147
|
+
case "warn":
|
|
148
|
+
this.emit("threshold.warning", { metric, violations, message });
|
|
149
|
+
break;
|
|
150
|
+
case "optimize":
|
|
151
|
+
this.emit("threshold.optimize", { metric, violations, message });
|
|
152
|
+
break;
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
addThreshold(threshold) {
|
|
157
|
+
this.thresholds.set(threshold.operation, threshold);
|
|
158
|
+
}
|
|
159
|
+
getMetrics(operation) {
|
|
160
|
+
if (operation) {
|
|
161
|
+
return this.metrics.get(operation) || [];
|
|
162
|
+
}
|
|
163
|
+
const allMetrics = [];
|
|
164
|
+
for (const metrics of this.metrics.values()) {
|
|
165
|
+
allMetrics.push(...metrics);
|
|
166
|
+
}
|
|
167
|
+
return allMetrics;
|
|
168
|
+
}
|
|
169
|
+
getStatistics(operation) {
|
|
170
|
+
const metrics = this.metrics.get(operation);
|
|
171
|
+
if (!metrics || metrics.length === 0) return void 0;
|
|
172
|
+
const durations = metrics.filter((m) => m.duration !== void 0).map((m) => m.duration);
|
|
173
|
+
const memoryDeltas = metrics.filter((m) => m.memoryDelta !== void 0).map((m) => m.memoryDelta);
|
|
174
|
+
const successCount = metrics.filter(
|
|
175
|
+
(m) => m.metadata?.success === true
|
|
176
|
+
).length;
|
|
177
|
+
return {
|
|
178
|
+
count: metrics.length,
|
|
179
|
+
avgDuration: durations.length > 0 ? durations.reduce((a, b) => a + b, 0) / durations.length : 0,
|
|
180
|
+
minDuration: durations.length > 0 ? Math.min(...durations) : 0,
|
|
181
|
+
maxDuration: durations.length > 0 ? Math.max(...durations) : 0,
|
|
182
|
+
avgMemory: memoryDeltas.length > 0 ? memoryDeltas.reduce((a, b) => a + b, 0) / memoryDeltas.length : 0,
|
|
183
|
+
successRate: metrics.length > 0 ? successCount / metrics.length * 100 : 0
|
|
184
|
+
};
|
|
185
|
+
}
|
|
186
|
+
clearMetrics(operation) {
|
|
187
|
+
if (operation) {
|
|
188
|
+
this.metrics.delete(operation);
|
|
189
|
+
} else {
|
|
190
|
+
this.metrics.clear();
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
getActiveOperations() {
|
|
194
|
+
return Array.from(this.activeOperations.keys());
|
|
195
|
+
}
|
|
196
|
+
generateReport() {
|
|
197
|
+
const report = [];
|
|
198
|
+
report.push("Performance Report");
|
|
199
|
+
report.push("=".repeat(60));
|
|
200
|
+
for (const [operation] of this.metrics) {
|
|
201
|
+
const stats = this.getStatistics(operation);
|
|
202
|
+
if (!stats) continue;
|
|
203
|
+
report.push(`
|
|
204
|
+
Operation: ${operation}`);
|
|
205
|
+
report.push(` Count: ${stats.count}`);
|
|
206
|
+
report.push(` Avg Duration: ${stats.avgDuration.toFixed(2)}ms`);
|
|
207
|
+
report.push(
|
|
208
|
+
` Min/Max: ${stats.minDuration.toFixed(2)}ms / ${stats.maxDuration.toFixed(2)}ms`
|
|
209
|
+
);
|
|
210
|
+
report.push(
|
|
211
|
+
` Avg Memory: ${(stats.avgMemory / 1024 / 1024).toFixed(2)}MB`
|
|
212
|
+
);
|
|
213
|
+
report.push(` Success Rate: ${stats.successRate.toFixed(1)}%`);
|
|
214
|
+
}
|
|
215
|
+
return report.join("\n");
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
export {
|
|
219
|
+
PerformanceMonitor
|
|
220
|
+
};
|
|
221
|
+
//# sourceMappingURL=monitor.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/core/performance/monitor.ts"],
|
|
4
|
+
"sourcesContent": ["import { performance } from 'perf_hooks';\nimport { EventEmitter } from 'events';\n\ninterface PerformanceMetrics {\n operation: string;\n startTime: number;\n endTime?: number;\n duration?: number;\n memoryBefore: NodeJS.MemoryUsage;\n memoryAfter?: NodeJS.MemoryUsage;\n memoryDelta?: number;\n metadata?: Record<string, any>;\n}\n\ninterface PerformanceThreshold {\n operation: string;\n maxDuration?: number;\n maxMemory?: number;\n action?: 'warn' | 'error' | 'optimize';\n}\n\nexport class PerformanceMonitor extends EventEmitter {\n private metrics: Map<string, PerformanceMetrics[]> = new Map();\n private activeOperations: Map<string, PerformanceMetrics> = new Map();\n private thresholds: Map<string, PerformanceThreshold> = new Map();\n private isMonitoring: boolean = false;\n private gcInterval?: NodeJS.Timeout;\n\n constructor() {\n super();\n this.setupDefaultThresholds();\n }\n\n private setupDefaultThresholds() {\n this.addThreshold({\n operation: 'digest.process',\n maxDuration: 500,\n maxMemory: 50 * 1024 * 1024,\n action: 'warn',\n });\n\n this.addThreshold({\n operation: 'cache.lookup',\n maxDuration: 10,\n action: 'optimize',\n });\n\n this.addThreshold({\n operation: 'context.save',\n maxDuration: 1000,\n maxMemory: 100 * 1024 * 1024,\n action: 'error',\n });\n }\n\n startMonitoring() {\n if (this.isMonitoring) return;\n\n this.isMonitoring = true;\n\n this.gcInterval = setInterval(() => {\n if (global.gc) {\n const beforeGC = process.memoryUsage();\n global.gc();\n const afterGC = process.memoryUsage();\n\n const freed = beforeGC.heapUsed - afterGC.heapUsed;\n if (freed > 10 * 1024 * 1024) {\n this.emit('gc', {\n freed,\n beforeGC,\n afterGC,\n });\n }\n }\n }, 30000);\n\n this.emit('monitoring.started');\n }\n\n stopMonitoring() {\n if (!this.isMonitoring) return;\n\n this.isMonitoring = false;\n\n if (this.gcInterval) {\n clearInterval(this.gcInterval);\n this.gcInterval = undefined;\n }\n\n this.emit('monitoring.stopped');\n }\n\n startOperation(\n operationId: string,\n operation: string,\n metadata?: Record<string, any>\n ): void {\n const metric: PerformanceMetrics = {\n operation,\n startTime: performance.now(),\n memoryBefore: process.memoryUsage(),\n metadata,\n };\n\n this.activeOperations.set(operationId, metric);\n this.emit('operation.started', { operationId, operation, metadata });\n }\n\n endOperation(\n operationId: string,\n additionalMetadata?: Record<string, any>\n ): PerformanceMetrics | undefined {\n const metric = this.activeOperations.get(operationId);\n if (!metric) {\n console.warn(`Operation ${operationId} not found`);\n return undefined;\n }\n\n metric.endTime = performance.now();\n metric.duration = metric.endTime - metric.startTime;\n metric.memoryAfter = process.memoryUsage();\n metric.memoryDelta =\n metric.memoryAfter.heapUsed - metric.memoryBefore.heapUsed;\n\n if (additionalMetadata) {\n metric.metadata = { ...metric.metadata, ...additionalMetadata };\n }\n\n this.activeOperations.delete(operationId);\n\n if (!this.metrics.has(metric.operation)) {\n this.metrics.set(metric.operation, []);\n }\n this.metrics.get(metric.operation)!.push(metric);\n\n this.checkThresholds(metric);\n this.emit('operation.completed', { operationId, metric });\n\n return metric;\n }\n\n async measureAsync<T>(\n operation: string,\n fn: () => Promise<T>,\n metadata?: Record<string, any>\n ): Promise<T> {\n const operationId = `${operation}-${Date.now()}-${Math.random()}`;\n this.startOperation(operationId, operation, metadata);\n\n try {\n const result = await fn();\n this.endOperation(operationId, { success: true });\n return result;\n } catch (error: unknown) {\n this.endOperation(operationId, {\n success: false,\n error: error instanceof Error ? error.message : String(error),\n });\n throw error;\n }\n }\n\n measure<T>(\n operation: string,\n fn: () => T,\n metadata?: Record<string, any>\n ): T {\n const operationId = `${operation}-${Date.now()}-${Math.random()}`;\n this.startOperation(operationId, operation, metadata);\n\n try {\n const result = fn();\n this.endOperation(operationId, { success: true });\n return result;\n } catch (error: unknown) {\n this.endOperation(operationId, {\n success: false,\n error: error instanceof Error ? error.message : String(error),\n });\n throw error;\n }\n }\n\n private checkThresholds(metric: PerformanceMetrics) {\n const threshold = this.thresholds.get(metric.operation);\n if (!threshold) return;\n\n const violations: string[] = [];\n\n if (\n threshold.maxDuration &&\n metric.duration &&\n metric.duration > threshold.maxDuration\n ) {\n violations.push(\n `Duration ${metric.duration.toFixed(2)}ms exceeds ${threshold.maxDuration}ms`\n );\n }\n\n if (\n threshold.maxMemory &&\n metric.memoryDelta &&\n metric.memoryDelta > threshold.maxMemory\n ) {\n const memoryMB = (metric.memoryDelta / 1024 / 1024).toFixed(2);\n const thresholdMB = (threshold.maxMemory / 1024 / 1024).toFixed(2);\n violations.push(`Memory ${memoryMB}MB exceeds ${thresholdMB}MB`);\n }\n\n if (violations.length > 0) {\n const message = `Performance threshold violation for ${metric.operation}: ${violations.join(', ')}`;\n\n switch (threshold.action) {\n case 'error':\n this.emit('threshold.error', { metric, violations, message });\n break;\n case 'warn':\n this.emit('threshold.warning', { metric, violations, message });\n break;\n case 'optimize':\n this.emit('threshold.optimize', { metric, violations, message });\n break;\n }\n }\n }\n\n addThreshold(threshold: PerformanceThreshold) {\n this.thresholds.set(threshold.operation, threshold);\n }\n\n getMetrics(operation?: string): PerformanceMetrics[] {\n if (operation) {\n return this.metrics.get(operation) || [];\n }\n\n const allMetrics: PerformanceMetrics[] = [];\n for (const metrics of this.metrics.values()) {\n allMetrics.push(...metrics);\n }\n return allMetrics;\n }\n\n getStatistics(operation: string):\n | {\n count: number;\n avgDuration: number;\n minDuration: number;\n maxDuration: number;\n avgMemory: number;\n successRate: number;\n }\n | undefined {\n const metrics = this.metrics.get(operation);\n if (!metrics || metrics.length === 0) return undefined;\n\n const durations = metrics\n .filter((m) => m.duration !== undefined)\n .map((m) => m.duration!);\n\n const memoryDeltas = metrics\n .filter((m) => m.memoryDelta !== undefined)\n .map((m) => m.memoryDelta!);\n\n const successCount = metrics.filter(\n (m) => m.metadata?.success === true\n ).length;\n\n return {\n count: metrics.length,\n avgDuration:\n durations.length > 0\n ? durations.reduce((a, b) => a + b, 0) / durations.length\n : 0,\n minDuration: durations.length > 0 ? Math.min(...durations) : 0,\n maxDuration: durations.length > 0 ? Math.max(...durations) : 0,\n avgMemory:\n memoryDeltas.length > 0\n ? memoryDeltas.reduce((a, b) => a + b, 0) / memoryDeltas.length\n : 0,\n successRate:\n metrics.length > 0 ? (successCount / metrics.length) * 100 : 0,\n };\n }\n\n clearMetrics(operation?: string) {\n if (operation) {\n this.metrics.delete(operation);\n } else {\n this.metrics.clear();\n }\n }\n\n getActiveOperations(): string[] {\n return Array.from(this.activeOperations.keys());\n }\n\n generateReport(): string {\n const report: string[] = [];\n report.push('Performance Report');\n report.push('='.repeat(60));\n\n for (const [operation] of this.metrics) {\n const stats = this.getStatistics(operation);\n if (!stats) continue;\n\n report.push(`\\nOperation: ${operation}`);\n report.push(` Count: ${stats.count}`);\n report.push(` Avg Duration: ${stats.avgDuration.toFixed(2)}ms`);\n report.push(\n ` Min/Max: ${stats.minDuration.toFixed(2)}ms / ${stats.maxDuration.toFixed(2)}ms`\n );\n report.push(\n ` Avg Memory: ${(stats.avgMemory / 1024 / 1024).toFixed(2)}MB`\n );\n report.push(` Success Rate: ${stats.successRate.toFixed(1)}%`);\n }\n\n return report.join('\\n');\n }\n}\n"],
|
|
5
|
+
"mappings": ";;;;AAAA,SAAS,mBAAmB;AAC5B,SAAS,oBAAoB;AAoBtB,MAAM,2BAA2B,aAAa;AAAA,EAC3C,UAA6C,oBAAI,IAAI;AAAA,EACrD,mBAAoD,oBAAI,IAAI;AAAA,EAC5D,aAAgD,oBAAI,IAAI;AAAA,EACxD,eAAwB;AAAA,EACxB;AAAA,EAER,cAAc;AACZ,UAAM;AACN,SAAK,uBAAuB;AAAA,EAC9B;AAAA,EAEQ,yBAAyB;AAC/B,SAAK,aAAa;AAAA,MAChB,WAAW;AAAA,MACX,aAAa;AAAA,MACb,WAAW,KAAK,OAAO;AAAA,MACvB,QAAQ;AAAA,IACV,CAAC;AAED,SAAK,aAAa;AAAA,MAChB,WAAW;AAAA,MACX,aAAa;AAAA,MACb,QAAQ;AAAA,IACV,CAAC;AAED,SAAK,aAAa;AAAA,MAChB,WAAW;AAAA,MACX,aAAa;AAAA,MACb,WAAW,MAAM,OAAO;AAAA,MACxB,QAAQ;AAAA,IACV,CAAC;AAAA,EACH;AAAA,EAEA,kBAAkB;AAChB,QAAI,KAAK,aAAc;AAEvB,SAAK,eAAe;AAEpB,SAAK,aAAa,YAAY,MAAM;AAClC,UAAI,OAAO,IAAI;AACb,cAAM,WAAW,QAAQ,YAAY;AACrC,eAAO,GAAG;AACV,cAAM,UAAU,QAAQ,YAAY;AAEpC,cAAM,QAAQ,SAAS,WAAW,QAAQ;AAC1C,YAAI,QAAQ,KAAK,OAAO,MAAM;AAC5B,eAAK,KAAK,MAAM;AAAA,YACd;AAAA,YACA;AAAA,YACA;AAAA,UACF,CAAC;AAAA,QACH;AAAA,MACF;AAAA,IACF,GAAG,GAAK;AAER,SAAK,KAAK,oBAAoB;AAAA,EAChC;AAAA,EAEA,iBAAiB;AACf,QAAI,CAAC,KAAK,aAAc;AAExB,SAAK,eAAe;AAEpB,QAAI,KAAK,YAAY;AACnB,oBAAc,KAAK,UAAU;AAC7B,WAAK,aAAa;AAAA,IACpB;AAEA,SAAK,KAAK,oBAAoB;AAAA,EAChC;AAAA,EAEA,eACE,aACA,WACA,UACM;AACN,UAAM,SAA6B;AAAA,MACjC;AAAA,MACA,WAAW,YAAY,IAAI;AAAA,MAC3B,cAAc,QAAQ,YAAY;AAAA,MAClC;AAAA,IACF;AAEA,SAAK,iBAAiB,IAAI,aAAa,MAAM;AAC7C,SAAK,KAAK,qBAAqB,EAAE,aAAa,WAAW,SAAS,CAAC;AAAA,EACrE;AAAA,EAEA,aACE,aACA,oBACgC;AAChC,UAAM,SAAS,KAAK,iBAAiB,IAAI,WAAW;AACpD,QAAI,CAAC,QAAQ;AACX,cAAQ,KAAK,aAAa,WAAW,YAAY;AACjD,aAAO;AAAA,IACT;AAEA,WAAO,UAAU,YAAY,IAAI;AACjC,WAAO,WAAW,OAAO,UAAU,OAAO;AAC1C,WAAO,cAAc,QAAQ,YAAY;AACzC,WAAO,cACL,OAAO,YAAY,WAAW,OAAO,aAAa;AAEpD,QAAI,oBAAoB;AACtB,aAAO,WAAW,EAAE,GAAG,OAAO,UAAU,GAAG,mBAAmB;AAAA,IAChE;AAEA,SAAK,iBAAiB,OAAO,WAAW;AAExC,QAAI,CAAC,KAAK,QAAQ,IAAI,OAAO,SAAS,GAAG;AACvC,WAAK,QAAQ,IAAI,OAAO,WAAW,CAAC,CAAC;AAAA,IACvC;AACA,SAAK,QAAQ,IAAI,OAAO,SAAS,EAAG,KAAK,MAAM;AAE/C,SAAK,gBAAgB,MAAM;AAC3B,SAAK,KAAK,uBAAuB,EAAE,aAAa,OAAO,CAAC;AAExD,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,aACJ,WACA,IACA,UACY;AACZ,UAAM,cAAc,GAAG,SAAS,IAAI,KAAK,IAAI,CAAC,IAAI,KAAK,OAAO,CAAC;AAC/D,SAAK,eAAe,aAAa,WAAW,QAAQ;AAEpD,QAAI;AACF,YAAM,SAAS,MAAM,GAAG;AACxB,WAAK,aAAa,aAAa,EAAE,SAAS,KAAK,CAAC;AAChD,aAAO;AAAA,IACT,SAAS,OAAgB;AACvB,WAAK,aAAa,aAAa;AAAA,QAC7B,SAAS;AAAA,QACT,OAAO,iBAAiB,QAAQ,MAAM,UAAU,OAAO,KAAK;AAAA,MAC9D,CAAC;AACD,YAAM;AAAA,IACR;AAAA,EACF;AAAA,EAEA,QACE,WACA,IACA,UACG;AACH,UAAM,cAAc,GAAG,SAAS,IAAI,KAAK,IAAI,CAAC,IAAI,KAAK,OAAO,CAAC;AAC/D,SAAK,eAAe,aAAa,WAAW,QAAQ;AAEpD,QAAI;AACF,YAAM,SAAS,GAAG;AAClB,WAAK,aAAa,aAAa,EAAE,SAAS,KAAK,CAAC;AAChD,aAAO;AAAA,IACT,SAAS,OAAgB;AACvB,WAAK,aAAa,aAAa;AAAA,QAC7B,SAAS;AAAA,QACT,OAAO,iBAAiB,QAAQ,MAAM,UAAU,OAAO,KAAK;AAAA,MAC9D,CAAC;AACD,YAAM;AAAA,IACR;AAAA,EACF;AAAA,EAEQ,gBAAgB,QAA4B;AAClD,UAAM,YAAY,KAAK,WAAW,IAAI,OAAO,SAAS;AACtD,QAAI,CAAC,UAAW;AAEhB,UAAM,aAAuB,CAAC;AAE9B,QACE,UAAU,eACV,OAAO,YACP,OAAO,WAAW,UAAU,aAC5B;AACA,iBAAW;AAAA,QACT,YAAY,OAAO,SAAS,QAAQ,CAAC,CAAC,cAAc,UAAU,WAAW;AAAA,MAC3E;AAAA,IACF;AAEA,QACE,UAAU,aACV,OAAO,eACP,OAAO,cAAc,UAAU,WAC/B;AACA,YAAM,YAAY,OAAO,cAAc,OAAO,MAAM,QAAQ,CAAC;AAC7D,YAAM,eAAe,UAAU,YAAY,OAAO,MAAM,QAAQ,CAAC;AACjE,iBAAW,KAAK,UAAU,QAAQ,cAAc,WAAW,IAAI;AAAA,IACjE;AAEA,QAAI,WAAW,SAAS,GAAG;AACzB,YAAM,UAAU,uCAAuC,OAAO,SAAS,KAAK,WAAW,KAAK,IAAI,CAAC;AAEjG,cAAQ,UAAU,QAAQ;AAAA,QACxB,KAAK;AACH,eAAK,KAAK,mBAAmB,EAAE,QAAQ,YAAY,QAAQ,CAAC;AAC5D;AAAA,QACF,KAAK;AACH,eAAK,KAAK,qBAAqB,EAAE,QAAQ,YAAY,QAAQ,CAAC;AAC9D;AAAA,QACF,KAAK;AACH,eAAK,KAAK,sBAAsB,EAAE,QAAQ,YAAY,QAAQ,CAAC;AAC/D;AAAA,MACJ;AAAA,IACF;AAAA,EACF;AAAA,EAEA,aAAa,WAAiC;AAC5C,SAAK,WAAW,IAAI,UAAU,WAAW,SAAS;AAAA,EACpD;AAAA,EAEA,WAAW,WAA0C;AACnD,QAAI,WAAW;AACb,aAAO,KAAK,QAAQ,IAAI,SAAS,KAAK,CAAC;AAAA,IACzC;AAEA,UAAM,aAAmC,CAAC;AAC1C,eAAW,WAAW,KAAK,QAAQ,OAAO,GAAG;AAC3C,iBAAW,KAAK,GAAG,OAAO;AAAA,IAC5B;AACA,WAAO;AAAA,EACT;AAAA,EAEA,cAAc,WASA;AACZ,UAAM,UAAU,KAAK,QAAQ,IAAI,SAAS;AAC1C,QAAI,CAAC,WAAW,QAAQ,WAAW,EAAG,QAAO;AAE7C,UAAM,YAAY,QACf,OAAO,CAAC,MAAM,EAAE,aAAa,MAAS,EACtC,IAAI,CAAC,MAAM,EAAE,QAAS;AAEzB,UAAM,eAAe,QAClB,OAAO,CAAC,MAAM,EAAE,gBAAgB,MAAS,EACzC,IAAI,CAAC,MAAM,EAAE,WAAY;AAE5B,UAAM,eAAe,QAAQ;AAAA,MAC3B,CAAC,MAAM,EAAE,UAAU,YAAY;AAAA,IACjC,EAAE;AAEF,WAAO;AAAA,MACL,OAAO,QAAQ;AAAA,MACf,aACE,UAAU,SAAS,IACf,UAAU,OAAO,CAAC,GAAG,MAAM,IAAI,GAAG,CAAC,IAAI,UAAU,SACjD;AAAA,MACN,aAAa,UAAU,SAAS,IAAI,KAAK,IAAI,GAAG,SAAS,IAAI;AAAA,MAC7D,aAAa,UAAU,SAAS,IAAI,KAAK,IAAI,GAAG,SAAS,IAAI;AAAA,MAC7D,WACE,aAAa,SAAS,IAClB,aAAa,OAAO,CAAC,GAAG,MAAM,IAAI,GAAG,CAAC,IAAI,aAAa,SACvD;AAAA,MACN,aACE,QAAQ,SAAS,IAAK,eAAe,QAAQ,SAAU,MAAM;AAAA,IACjE;AAAA,EACF;AAAA,EAEA,aAAa,WAAoB;AAC/B,QAAI,WAAW;AACb,WAAK,QAAQ,OAAO,SAAS;AAAA,IAC/B,OAAO;AACL,WAAK,QAAQ,MAAM;AAAA,IACrB;AAAA,EACF;AAAA,EAEA,sBAAgC;AAC9B,WAAO,MAAM,KAAK,KAAK,iBAAiB,KAAK,CAAC;AAAA,EAChD;AAAA,EAEA,iBAAyB;AACvB,UAAM,SAAmB,CAAC;AAC1B,WAAO,KAAK,oBAAoB;AAChC,WAAO,KAAK,IAAI,OAAO,EAAE,CAAC;AAE1B,eAAW,CAAC,SAAS,KAAK,KAAK,SAAS;AACtC,YAAM,QAAQ,KAAK,cAAc,SAAS;AAC1C,UAAI,CAAC,MAAO;AAEZ,aAAO,KAAK;AAAA,aAAgB,SAAS,EAAE;AACvC,aAAO,KAAK,YAAY,MAAM,KAAK,EAAE;AACrC,aAAO,KAAK,mBAAmB,MAAM,YAAY,QAAQ,CAAC,CAAC,IAAI;AAC/D,aAAO;AAAA,QACL,cAAc,MAAM,YAAY,QAAQ,CAAC,CAAC,QAAQ,MAAM,YAAY,QAAQ,CAAC,CAAC;AAAA,MAChF;AACA,aAAO;AAAA,QACL,kBAAkB,MAAM,YAAY,OAAO,MAAM,QAAQ,CAAC,CAAC;AAAA,MAC7D;AACA,aAAO,KAAK,mBAAmB,MAAM,YAAY,QAAQ,CAAC,CAAC,GAAG;AAAA,IAChE;AAEA,WAAO,OAAO,KAAK,IAAI;AAAA,EACzB;AACF;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|