@vinaes/succ 1.4.0 → 1.5.42
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 +64 -10
- package/dist/cli.js +81 -1
- package/dist/cli.js.map +1 -1
- package/dist/commands/agents-md.d.ts.map +1 -1
- package/dist/commands/agents-md.js +3 -2
- package/dist/commands/agents-md.js.map +1 -1
- package/dist/commands/analyze-profile.d.ts.map +1 -1
- package/dist/commands/analyze-profile.js +32 -8
- package/dist/commands/analyze-profile.js.map +1 -1
- package/dist/commands/analyze-recursive.d.ts.map +1 -1
- package/dist/commands/analyze-recursive.js +6 -2
- package/dist/commands/analyze-recursive.js.map +1 -1
- package/dist/commands/analyze-utils.d.ts.map +1 -1
- package/dist/commands/analyze-utils.js +17 -4
- package/dist/commands/analyze-utils.js.map +1 -1
- package/dist/commands/benchmark-quality.d.ts.map +1 -1
- package/dist/commands/benchmark-quality.js +11 -4
- package/dist/commands/benchmark-quality.js.map +1 -1
- package/dist/commands/benchmark-sqlite-vec.d.ts.map +1 -1
- package/dist/commands/benchmark-sqlite-vec.js +4 -0
- package/dist/commands/benchmark-sqlite-vec.js.map +1 -1
- package/dist/commands/benchmark.d.ts.map +1 -1
- package/dist/commands/benchmark.js +5 -1
- package/dist/commands/benchmark.js.map +1 -1
- package/dist/commands/codex-chat.d.ts +8 -0
- package/dist/commands/codex-chat.d.ts.map +1 -0
- package/dist/commands/codex-chat.js +161 -0
- package/dist/commands/codex-chat.js.map +1 -0
- package/dist/commands/config.d.ts.map +1 -1
- package/dist/commands/config.js +32 -4
- package/dist/commands/config.js.map +1 -1
- package/dist/commands/daemon.d.ts.map +1 -1
- package/dist/commands/daemon.js +13 -4
- package/dist/commands/daemon.js.map +1 -1
- package/dist/commands/index-code.d.ts +4 -0
- package/dist/commands/index-code.d.ts.map +1 -1
- package/dist/commands/index-code.js +1 -1
- package/dist/commands/index-code.js.map +1 -1
- package/dist/commands/init.d.ts.map +1 -1
- package/dist/commands/init.js +305 -203
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/memories.d.ts.map +1 -1
- package/dist/commands/memories.js +25 -14
- package/dist/commands/memories.js.map +1 -1
- package/dist/commands/progress.d.ts.map +1 -1
- package/dist/commands/progress.js +3 -2
- package/dist/commands/progress.js.map +1 -1
- package/dist/commands/reindex.d.ts.map +1 -1
- package/dist/commands/reindex.js +54 -36
- package/dist/commands/reindex.js.map +1 -1
- package/dist/commands/retention.d.ts.map +1 -1
- package/dist/commands/retention.js +7 -5
- package/dist/commands/retention.js.map +1 -1
- package/dist/commands/scan-code.d.ts +76 -0
- package/dist/commands/scan-code.d.ts.map +1 -0
- package/dist/commands/scan-code.js +385 -0
- package/dist/commands/scan-code.js.map +1 -0
- package/dist/commands/score.d.ts.map +1 -1
- package/dist/commands/score.js +3 -2
- package/dist/commands/score.js.map +1 -1
- package/dist/commands/session.d.ts +33 -0
- package/dist/commands/session.d.ts.map +1 -0
- package/dist/commands/session.js +163 -0
- package/dist/commands/session.js.map +1 -0
- package/dist/commands/setup.d.ts.map +1 -1
- package/dist/commands/setup.js +254 -15
- package/dist/commands/setup.js.map +1 -1
- package/dist/commands/soul.js +3 -2
- package/dist/commands/soul.js.map +1 -1
- package/dist/commands/status.d.ts.map +1 -1
- package/dist/commands/status.js +14 -5
- package/dist/commands/status.js.map +1 -1
- package/dist/commands/watch.d.ts.map +1 -1
- package/dist/commands/watch.js +13 -4
- package/dist/commands/watch.js.map +1 -1
- package/dist/daemon/analyzer.d.ts.map +1 -1
- package/dist/daemon/analyzer.js +21 -5
- package/dist/daemon/analyzer.js.map +1 -1
- package/dist/daemon/client.d.ts.map +1 -1
- package/dist/daemon/client.js +32 -8
- package/dist/daemon/client.js.map +1 -1
- package/dist/daemon/routes/analyzer.d.ts +3 -0
- package/dist/daemon/routes/analyzer.d.ts.map +1 -0
- package/dist/daemon/routes/analyzer.js +27 -0
- package/dist/daemon/routes/analyzer.js.map +1 -0
- package/dist/daemon/routes/hooks.d.ts +14 -0
- package/dist/daemon/routes/hooks.d.ts.map +1 -0
- package/dist/daemon/routes/hooks.js +1212 -0
- package/dist/daemon/routes/hooks.js.map +1 -0
- package/dist/daemon/routes/memory.d.ts +4 -0
- package/dist/daemon/routes/memory.d.ts.map +1 -0
- package/dist/daemon/routes/memory.js +71 -0
- package/dist/daemon/routes/memory.js.map +1 -0
- package/dist/daemon/routes/reflection.d.ts +10 -0
- package/dist/daemon/routes/reflection.d.ts.map +1 -0
- package/dist/daemon/routes/reflection.js +397 -0
- package/dist/daemon/routes/reflection.js.map +1 -0
- package/dist/daemon/routes/search.d.ts +5 -0
- package/dist/daemon/routes/search.d.ts.map +1 -0
- package/dist/daemon/routes/search.js +93 -0
- package/dist/daemon/routes/search.js.map +1 -0
- package/dist/daemon/routes/sessions.d.ts +3 -0
- package/dist/daemon/routes/sessions.d.ts.map +1 -0
- package/dist/daemon/routes/sessions.js +160 -0
- package/dist/daemon/routes/sessions.js.map +1 -0
- package/dist/daemon/routes/skills.d.ts +3 -0
- package/dist/daemon/routes/skills.d.ts.map +1 -0
- package/dist/daemon/routes/skills.js +36 -0
- package/dist/daemon/routes/skills.js.map +1 -0
- package/dist/daemon/routes/status.d.ts +3 -0
- package/dist/daemon/routes/status.d.ts.map +1 -0
- package/dist/daemon/routes/status.js +47 -0
- package/dist/daemon/routes/status.js.map +1 -0
- package/dist/daemon/routes/types.d.ts +240 -0
- package/dist/daemon/routes/types.d.ts.map +1 -0
- package/dist/daemon/routes/types.js +97 -0
- package/dist/daemon/routes/types.js.map +1 -0
- package/dist/daemon/routes/versioning.d.ts +27 -0
- package/dist/daemon/routes/versioning.d.ts.map +1 -0
- package/dist/daemon/routes/versioning.js +44 -0
- package/dist/daemon/routes/versioning.js.map +1 -0
- package/dist/daemon/routes/watcher.d.ts +3 -0
- package/dist/daemon/routes/watcher.d.ts.map +1 -0
- package/dist/daemon/routes/watcher.js +28 -0
- package/dist/daemon/routes/watcher.js.map +1 -0
- package/dist/daemon/service.d.ts +5 -23
- package/dist/daemon/service.d.ts.map +1 -1
- package/dist/daemon/service.js +201 -933
- package/dist/daemon/service.js.map +1 -1
- package/dist/daemon/session-processor.d.ts +4 -8
- package/dist/daemon/session-processor.d.ts.map +1 -1
- package/dist/daemon/session-processor.js +39 -38
- package/dist/daemon/session-processor.js.map +1 -1
- package/dist/lib/ai-readiness.d.ts.map +1 -1
- package/dist/lib/ai-readiness.js +33 -8
- package/dist/lib/ai-readiness.js.map +1 -1
- package/dist/lib/analyze-state.d.ts.map +1 -1
- package/dist/lib/analyze-state.js +25 -3
- package/dist/lib/analyze-state.js.map +1 -1
- package/dist/lib/auto-memory/consolidation.d.ts +41 -0
- package/dist/lib/auto-memory/consolidation.d.ts.map +1 -0
- package/dist/lib/auto-memory/consolidation.js +151 -0
- package/dist/lib/auto-memory/consolidation.js.map +1 -0
- package/dist/lib/bpe.d.ts.map +1 -1
- package/dist/lib/bpe.js +9 -10
- package/dist/lib/bpe.js.map +1 -1
- package/dist/lib/brain-export.d.ts +65 -0
- package/dist/lib/brain-export.d.ts.map +1 -0
- package/dist/lib/brain-export.js +413 -0
- package/dist/lib/brain-export.js.map +1 -0
- package/dist/lib/checkpoint.d.ts.map +1 -1
- package/dist/lib/checkpoint.js +22 -6
- package/dist/lib/checkpoint.js.map +1 -1
- package/dist/lib/chunker.d.ts.map +1 -1
- package/dist/lib/chunker.js +6 -1
- package/dist/lib/chunker.js.map +1 -1
- package/dist/lib/claude-ws-transport.d.ts.map +1 -1
- package/dist/lib/claude-ws-transport.js +12 -4
- package/dist/lib/claude-ws-transport.js.map +1 -1
- package/dist/lib/command-safety.d.ts +64 -0
- package/dist/lib/command-safety.d.ts.map +1 -0
- package/dist/lib/command-safety.js +625 -0
- package/dist/lib/command-safety.js.map +1 -0
- package/dist/lib/compact-briefing.d.ts.map +1 -1
- package/dist/lib/compact-briefing.js +10 -13
- package/dist/lib/compact-briefing.js.map +1 -1
- package/dist/lib/config-defaults.d.ts.map +1 -1
- package/dist/lib/config-defaults.js +3 -0
- package/dist/lib/config-defaults.js.map +1 -1
- package/dist/lib/config-display.d.ts +4 -0
- package/dist/lib/config-display.d.ts.map +1 -1
- package/dist/lib/config-display.js +6 -1
- package/dist/lib/config-display.js.map +1 -1
- package/dist/lib/config-types.d.ts +156 -0
- package/dist/lib/config-types.d.ts.map +1 -1
- package/dist/lib/config-validation.d.ts.map +1 -1
- package/dist/lib/config-validation.js +5 -0
- package/dist/lib/config-validation.js.map +1 -1
- package/dist/lib/config.d.ts.map +1 -1
- package/dist/lib/config.js +92 -9
- package/dist/lib/config.js.map +1 -1
- package/dist/lib/consolidate.d.ts.map +1 -1
- package/dist/lib/consolidate.js +66 -47
- package/dist/lib/consolidate.js.map +1 -1
- package/dist/lib/content-sanitizer.d.ts +29 -0
- package/dist/lib/content-sanitizer.d.ts.map +1 -0
- package/dist/lib/content-sanitizer.js +72 -0
- package/dist/lib/content-sanitizer.js.map +1 -0
- package/dist/lib/cross-repo.d.ts +44 -0
- package/dist/lib/cross-repo.d.ts.map +1 -0
- package/dist/lib/cross-repo.js +108 -0
- package/dist/lib/cross-repo.js.map +1 -0
- package/dist/lib/daemon-port.d.ts +12 -0
- package/dist/lib/daemon-port.d.ts.map +1 -0
- package/dist/lib/daemon-port.js +20 -0
- package/dist/lib/daemon-port.js.map +1 -0
- package/dist/lib/db/auto-memory.d.ts +40 -0
- package/dist/lib/db/auto-memory.d.ts.map +1 -0
- package/dist/lib/db/auto-memory.js +74 -0
- package/dist/lib/db/auto-memory.js.map +1 -0
- package/dist/lib/db/bm25-indexes.d.ts.map +1 -1
- package/dist/lib/db/bm25-indexes.js +16 -4
- package/dist/lib/db/bm25-indexes.js.map +1 -1
- package/dist/lib/db/documents.d.ts.map +1 -1
- package/dist/lib/db/documents.js +4 -1
- package/dist/lib/db/documents.js.map +1 -1
- package/dist/lib/db/global-memories.d.ts +2 -10
- package/dist/lib/db/global-memories.d.ts.map +1 -1
- package/dist/lib/db/global-memories.js +13 -6
- package/dist/lib/db/global-memories.js.map +1 -1
- package/dist/lib/db/graph.d.ts +5 -1
- package/dist/lib/db/graph.d.ts.map +1 -1
- package/dist/lib/db/graph.js +38 -8
- package/dist/lib/db/graph.js.map +1 -1
- package/dist/lib/db/hybrid-search.d.ts +4 -2
- package/dist/lib/db/hybrid-search.d.ts.map +1 -1
- package/dist/lib/db/hybrid-search.js +29 -11
- package/dist/lib/db/hybrid-search.js.map +1 -1
- package/dist/lib/db/index.d.ts +6 -1
- package/dist/lib/db/index.d.ts.map +1 -1
- package/dist/lib/db/index.js +5 -1
- package/dist/lib/db/index.js.map +1 -1
- package/dist/lib/db/memories.d.ts +19 -14
- package/dist/lib/db/memories.d.ts.map +1 -1
- package/dist/lib/db/memories.js +100 -37
- package/dist/lib/db/memories.js.map +1 -1
- package/dist/lib/db/parse-helpers.d.ts +14 -0
- package/dist/lib/db/parse-helpers.d.ts.map +1 -0
- package/dist/lib/db/parse-helpers.js +59 -0
- package/dist/lib/db/parse-helpers.js.map +1 -0
- package/dist/lib/db/recall-events.d.ts +49 -0
- package/dist/lib/db/recall-events.d.ts.map +1 -0
- package/dist/lib/db/recall-events.js +196 -0
- package/dist/lib/db/recall-events.js.map +1 -0
- package/dist/lib/db/retention.d.ts +4 -3
- package/dist/lib/db/retention.d.ts.map +1 -1
- package/dist/lib/db/retention.js +12 -1
- package/dist/lib/db/retention.js.map +1 -1
- package/dist/lib/db/schema.d.ts +2 -0
- package/dist/lib/db/schema.d.ts.map +1 -1
- package/dist/lib/db/schema.js +140 -80
- package/dist/lib/db/schema.js.map +1 -1
- package/dist/lib/db/skills.d.ts.map +1 -1
- package/dist/lib/db/skills.js +10 -6
- package/dist/lib/db/skills.js.map +1 -1
- package/dist/lib/diff-brain.d.ts +24 -0
- package/dist/lib/diff-brain.d.ts.map +1 -0
- package/dist/lib/diff-brain.js +114 -0
- package/dist/lib/diff-brain.js.map +1 -0
- package/dist/lib/diff-parser.d.ts +74 -0
- package/dist/lib/diff-parser.d.ts.map +1 -0
- package/dist/lib/diff-parser.js +200 -0
- package/dist/lib/diff-parser.js.map +1 -0
- package/dist/lib/embedding-pool.d.ts.map +1 -1
- package/dist/lib/embedding-pool.js +5 -1
- package/dist/lib/embedding-pool.js.map +1 -1
- package/dist/lib/embeddings.d.ts +12 -0
- package/dist/lib/embeddings.d.ts.map +1 -1
- package/dist/lib/embeddings.js +77 -19
- package/dist/lib/embeddings.js.map +1 -1
- package/dist/lib/errors.d.ts +2 -0
- package/dist/lib/errors.d.ts.map +1 -1
- package/dist/lib/errors.js +4 -0
- package/dist/lib/errors.js.map +1 -1
- package/dist/lib/fault-logger.d.ts.map +1 -1
- package/dist/lib/fault-logger.js +22 -7
- package/dist/lib/fault-logger.js.map +1 -1
- package/dist/lib/git/co-change.d.ts +39 -0
- package/dist/lib/git/co-change.d.ts.map +1 -0
- package/dist/lib/git/co-change.js +139 -0
- package/dist/lib/git/co-change.js.map +1 -0
- package/dist/lib/graph/bridge-edges.d.ts +93 -0
- package/dist/lib/graph/bridge-edges.d.ts.map +1 -0
- package/dist/lib/graph/bridge-edges.js +276 -0
- package/dist/lib/graph/bridge-edges.js.map +1 -0
- package/dist/lib/graph/centrality.d.ts +11 -0
- package/dist/lib/graph/centrality.d.ts.map +1 -1
- package/dist/lib/graph/centrality.js +51 -3
- package/dist/lib/graph/centrality.js.map +1 -1
- package/dist/lib/graph/cleanup.d.ts.map +1 -1
- package/dist/lib/graph/cleanup.js +2 -1
- package/dist/lib/graph/cleanup.js.map +1 -1
- package/dist/lib/graph/community-detection.d.ts +17 -2
- package/dist/lib/graph/community-detection.d.ts.map +1 -1
- package/dist/lib/graph/community-detection.js +147 -48
- package/dist/lib/graph/community-detection.js.map +1 -1
- package/dist/lib/graph/community-summaries.d.ts +26 -0
- package/dist/lib/graph/community-summaries.d.ts.map +1 -0
- package/dist/lib/graph/community-summaries.js +130 -0
- package/dist/lib/graph/community-summaries.js.map +1 -0
- package/dist/lib/graph/contextual-proximity.d.ts.map +1 -1
- package/dist/lib/graph/contextual-proximity.js +11 -4
- package/dist/lib/graph/contextual-proximity.js.map +1 -1
- package/dist/lib/graph/graphology-bridge.d.ts +101 -0
- package/dist/lib/graph/graphology-bridge.d.ts.map +1 -0
- package/dist/lib/graph/graphology-bridge.js +488 -0
- package/dist/lib/graph/graphology-bridge.js.map +1 -0
- package/dist/lib/graph/llm-relations.d.ts.map +1 -1
- package/dist/lib/graph/llm-relations.js +27 -5
- package/dist/lib/graph/llm-relations.js.map +1 -1
- package/dist/lib/graph-export.d.ts.map +1 -1
- package/dist/lib/graph-export.js +2 -2
- package/dist/lib/graph-export.js.map +1 -1
- package/dist/lib/graph-scheduler.d.ts +0 -5
- package/dist/lib/graph-scheduler.d.ts.map +1 -1
- package/dist/lib/graph-scheduler.js +5 -1
- package/dist/lib/graph-scheduler.js.map +1 -1
- package/dist/lib/guardrails.d.ts +50 -0
- package/dist/lib/guardrails.d.ts.map +1 -0
- package/dist/lib/guardrails.js +502 -0
- package/dist/lib/guardrails.js.map +1 -0
- package/dist/lib/hook-rules.d.ts +1 -1
- package/dist/lib/hook-rules.d.ts.map +1 -1
- package/dist/lib/hook-rules.js +8 -2
- package/dist/lib/hook-rules.js.map +1 -1
- package/dist/lib/ifc/file-labels.d.ts +35 -0
- package/dist/lib/ifc/file-labels.d.ts.map +1 -0
- package/dist/lib/ifc/file-labels.js +208 -0
- package/dist/lib/ifc/file-labels.js.map +1 -0
- package/dist/lib/ifc/label.d.ts +38 -0
- package/dist/lib/ifc/label.d.ts.map +1 -0
- package/dist/lib/ifc/label.js +80 -0
- package/dist/lib/ifc/label.js.map +1 -0
- package/dist/lib/ifc/session-ifc.d.ts +92 -0
- package/dist/lib/ifc/session-ifc.d.ts.map +1 -0
- package/dist/lib/ifc/session-ifc.js +222 -0
- package/dist/lib/ifc/session-ifc.js.map +1 -0
- package/dist/lib/indexer.js +2 -2
- package/dist/lib/indexer.js.map +1 -1
- package/dist/lib/injection-detector.d.ts +83 -0
- package/dist/lib/injection-detector.d.ts.map +1 -0
- package/dist/lib/injection-detector.js +586 -0
- package/dist/lib/injection-detector.js.map +1 -0
- package/dist/lib/injection-semantic.d.ts +31 -0
- package/dist/lib/injection-semantic.d.ts.map +1 -0
- package/dist/lib/injection-semantic.js +230 -0
- package/dist/lib/injection-semantic.js.map +1 -0
- package/dist/lib/llm.d.ts.map +1 -1
- package/dist/lib/llm.js +19 -4
- package/dist/lib/llm.js.map +1 -1
- package/dist/lib/lock.d.ts.map +1 -1
- package/dist/lib/lock.js +24 -3
- package/dist/lib/lock.js.map +1 -1
- package/dist/lib/md-fetch.d.ts.map +1 -1
- package/dist/lib/md-fetch.js +9 -2
- package/dist/lib/md-fetch.js.map +1 -1
- package/dist/lib/observability.d.ts +75 -0
- package/dist/lib/observability.d.ts.map +1 -0
- package/dist/lib/observability.js +201 -0
- package/dist/lib/observability.js.map +1 -0
- package/dist/lib/ort-session.d.ts +26 -0
- package/dist/lib/ort-session.d.ts.map +1 -1
- package/dist/lib/ort-session.js +107 -3
- package/dist/lib/ort-session.js.map +1 -1
- package/dist/lib/prd/codebase-context.d.ts.map +1 -1
- package/dist/lib/prd/codebase-context.js +9 -2
- package/dist/lib/prd/codebase-context.js.map +1 -1
- package/dist/lib/prd/context.d.ts.map +1 -1
- package/dist/lib/prd/context.js +11 -3
- package/dist/lib/prd/context.js.map +1 -1
- package/dist/lib/prd/export.js +1 -1
- package/dist/lib/prd/export.js.map +1 -1
- package/dist/lib/prd/generate.d.ts.map +1 -1
- package/dist/lib/prd/generate.js +17 -4
- package/dist/lib/prd/generate.js.map +1 -1
- package/dist/lib/prd/parse.d.ts.map +1 -1
- package/dist/lib/prd/parse.js +6 -1
- package/dist/lib/prd/parse.js.map +1 -1
- package/dist/lib/prd/runner.d.ts +1 -2
- package/dist/lib/prd/runner.d.ts.map +1 -1
- package/dist/lib/prd/runner.js +43 -32
- package/dist/lib/prd/runner.js.map +1 -1
- package/dist/lib/prd/worktree.d.ts +1 -2
- package/dist/lib/prd/worktree.d.ts.map +1 -1
- package/dist/lib/prd/worktree.js +62 -70
- package/dist/lib/prd/worktree.js.map +1 -1
- package/dist/lib/precompute-context.d.ts.map +1 -1
- package/dist/lib/precompute-context.js +15 -34
- package/dist/lib/precompute-context.js.map +1 -1
- package/dist/lib/pricing.d.ts.map +1 -1
- package/dist/lib/pricing.js +5 -1
- package/dist/lib/pricing.js.map +1 -1
- package/dist/lib/process-registry.js +3 -3
- package/dist/lib/process-registry.js.map +1 -1
- package/dist/lib/public-api.d.ts +41 -1
- package/dist/lib/public-api.d.ts.map +1 -1
- package/dist/lib/public-api.js +38 -0
- package/dist/lib/public-api.js.map +1 -1
- package/dist/lib/quality.d.ts.map +1 -1
- package/dist/lib/quality.js +15 -6
- package/dist/lib/quality.js.map +1 -1
- package/dist/lib/query-expansion.d.ts +32 -0
- package/dist/lib/query-expansion.d.ts.map +1 -1
- package/dist/lib/query-expansion.js +62 -1
- package/dist/lib/query-expansion.js.map +1 -1
- package/dist/lib/reference-embeddings.d.ts.map +1 -1
- package/dist/lib/reference-embeddings.js +17 -4
- package/dist/lib/reference-embeddings.js.map +1 -1
- package/dist/lib/reflection-synthesizer.d.ts.map +1 -1
- package/dist/lib/reflection-synthesizer.js +7 -1
- package/dist/lib/reflection-synthesizer.js.map +1 -1
- package/dist/lib/reranker.d.ts +41 -0
- package/dist/lib/reranker.d.ts.map +1 -0
- package/dist/lib/reranker.js +294 -0
- package/dist/lib/reranker.js.map +1 -0
- package/dist/lib/retrieval-feedback.d.ts +100 -0
- package/dist/lib/retrieval-feedback.d.ts.map +1 -0
- package/dist/lib/retrieval-feedback.js +174 -0
- package/dist/lib/retrieval-feedback.js.map +1 -0
- package/dist/lib/review/context-pack.d.ts +58 -0
- package/dist/lib/review/context-pack.d.ts.map +1 -0
- package/dist/lib/review/context-pack.js +300 -0
- package/dist/lib/review/context-pack.js.map +1 -0
- package/dist/lib/search/hierarchical-summaries.d.ts +65 -0
- package/dist/lib/search/hierarchical-summaries.d.ts.map +1 -0
- package/dist/lib/search/hierarchical-summaries.js +423 -0
- package/dist/lib/search/hierarchical-summaries.js.map +1 -0
- package/dist/lib/search/hyde.d.ts +27 -0
- package/dist/lib/search/hyde.d.ts.map +1 -0
- package/dist/lib/search/hyde.js +141 -0
- package/dist/lib/search/hyde.js.map +1 -0
- package/dist/lib/search/late-chunking.d.ts +53 -0
- package/dist/lib/search/late-chunking.d.ts.map +1 -0
- package/dist/lib/search/late-chunking.js +230 -0
- package/dist/lib/search/late-chunking.js.map +1 -0
- package/dist/lib/search/ppr-retrieval.d.ts +49 -0
- package/dist/lib/search/ppr-retrieval.d.ts.map +1 -0
- package/dist/lib/search/ppr-retrieval.js +135 -0
- package/dist/lib/search/ppr-retrieval.js.map +1 -0
- package/dist/lib/search/repo-map.d.ts +43 -0
- package/dist/lib/search/repo-map.d.ts.map +1 -0
- package/dist/lib/search/repo-map.js +165 -0
- package/dist/lib/search/repo-map.js.map +1 -0
- package/dist/lib/session-analyzer.d.ts +90 -0
- package/dist/lib/session-analyzer.d.ts.map +1 -0
- package/dist/lib/session-analyzer.js +467 -0
- package/dist/lib/session-analyzer.js.map +1 -0
- package/dist/lib/session-observations.d.ts.map +1 -1
- package/dist/lib/session-observations.js +13 -3
- package/dist/lib/session-observations.js.map +1 -1
- package/dist/lib/session-summary.d.ts.map +1 -1
- package/dist/lib/session-summary.js +57 -50
- package/dist/lib/session-summary.js.map +1 -1
- package/dist/lib/session-surgeon.d.ts +53 -0
- package/dist/lib/session-surgeon.d.ts.map +1 -0
- package/dist/lib/session-surgeon.js +501 -0
- package/dist/lib/session-surgeon.js.map +1 -0
- package/dist/lib/similarity-utils.d.ts +26 -0
- package/dist/lib/similarity-utils.d.ts.map +1 -0
- package/dist/lib/similarity-utils.js +66 -0
- package/dist/lib/similarity-utils.js.map +1 -0
- package/dist/lib/skills.d.ts.map +1 -1
- package/dist/lib/skills.js +11 -11
- package/dist/lib/skills.js.map +1 -1
- package/dist/lib/storage/backends/interface.d.ts +13 -3
- package/dist/lib/storage/backends/interface.d.ts.map +1 -1
- package/dist/lib/storage/backends/postgresql.d.ts +52 -3
- package/dist/lib/storage/backends/postgresql.d.ts.map +1 -1
- package/dist/lib/storage/backends/postgresql.js +694 -49
- package/dist/lib/storage/backends/postgresql.js.map +1 -1
- package/dist/lib/storage/benchmark.js +2 -2
- package/dist/lib/storage/benchmark.js.map +1 -1
- package/dist/lib/storage/dispatcher/base.d.ts +114 -0
- package/dist/lib/storage/dispatcher/base.d.ts.map +1 -0
- package/dist/lib/storage/dispatcher/base.js +160 -0
- package/dist/lib/storage/dispatcher/base.js.map +1 -0
- package/dist/lib/storage/dispatcher/documents.d.ts +25 -0
- package/dist/lib/storage/dispatcher/documents.d.ts.map +1 -0
- package/dist/lib/storage/dispatcher/documents.js +194 -0
- package/dist/lib/storage/dispatcher/documents.js.map +1 -0
- package/dist/lib/storage/dispatcher/embeddings.d.ts +34 -0
- package/dist/lib/storage/dispatcher/embeddings.d.ts.map +1 -0
- package/dist/lib/storage/dispatcher/embeddings.js +144 -0
- package/dist/lib/storage/dispatcher/embeddings.js.map +1 -0
- package/dist/lib/storage/dispatcher/export-import.d.ts +139 -0
- package/dist/lib/storage/dispatcher/export-import.d.ts.map +1 -0
- package/dist/lib/storage/dispatcher/export-import.js +191 -0
- package/dist/lib/storage/dispatcher/export-import.js.map +1 -0
- package/dist/lib/storage/dispatcher/file-hashes.d.ts +13 -0
- package/dist/lib/storage/dispatcher/file-hashes.d.ts.map +1 -0
- package/dist/lib/storage/dispatcher/file-hashes.js +36 -0
- package/dist/lib/storage/dispatcher/file-hashes.js.map +1 -0
- package/dist/lib/storage/dispatcher/global-memories.d.ts +28 -0
- package/dist/lib/storage/dispatcher/global-memories.d.ts.map +1 -0
- package/dist/lib/storage/dispatcher/global-memories.js +151 -0
- package/dist/lib/storage/dispatcher/global-memories.js.map +1 -0
- package/dist/lib/storage/dispatcher/graph.d.ts +32 -0
- package/dist/lib/storage/dispatcher/graph.d.ts.map +1 -0
- package/dist/lib/storage/dispatcher/graph.js +146 -0
- package/dist/lib/storage/dispatcher/graph.js.map +1 -0
- package/dist/lib/storage/dispatcher/index.d.ts +34 -0
- package/dist/lib/storage/dispatcher/index.d.ts.map +1 -0
- package/dist/lib/storage/dispatcher/index.js +139 -0
- package/dist/lib/storage/dispatcher/index.js.map +1 -0
- package/dist/lib/storage/dispatcher/memories.d.ts +65 -0
- package/dist/lib/storage/dispatcher/memories.d.ts.map +1 -0
- package/dist/lib/storage/dispatcher/memories.js +466 -0
- package/dist/lib/storage/dispatcher/memories.js.map +1 -0
- package/dist/lib/storage/dispatcher/mixin-helper.d.ts +6 -0
- package/dist/lib/storage/dispatcher/mixin-helper.d.ts.map +1 -0
- package/dist/lib/storage/dispatcher/mixin-helper.js +10 -0
- package/dist/lib/storage/dispatcher/mixin-helper.js.map +1 -0
- package/dist/lib/storage/dispatcher/retention.d.ts +20 -0
- package/dist/lib/storage/dispatcher/retention.d.ts.map +1 -0
- package/dist/lib/storage/dispatcher/retention.js +123 -0
- package/dist/lib/storage/dispatcher/retention.js.map +1 -0
- package/dist/lib/storage/dispatcher/search.d.ts +34 -0
- package/dist/lib/storage/dispatcher/search.d.ts.map +1 -0
- package/dist/lib/storage/dispatcher/search.js +222 -0
- package/dist/lib/storage/dispatcher/search.js.map +1 -0
- package/dist/lib/storage/dispatcher/skills.d.ts +53 -0
- package/dist/lib/storage/dispatcher/skills.d.ts.map +1 -0
- package/dist/lib/storage/dispatcher/skills.js +98 -0
- package/dist/lib/storage/dispatcher/skills.js.map +1 -0
- package/dist/lib/storage/dispatcher/token-stats.d.ts +23 -0
- package/dist/lib/storage/dispatcher/token-stats.d.ts.map +1 -0
- package/dist/lib/storage/dispatcher/token-stats.js +92 -0
- package/dist/lib/storage/dispatcher/token-stats.js.map +1 -0
- package/dist/lib/storage/dispatcher/web-search.d.ts +10 -0
- package/dist/lib/storage/dispatcher/web-search.d.ts.map +1 -0
- package/dist/lib/storage/dispatcher/web-search.js +39 -0
- package/dist/lib/storage/dispatcher/web-search.js.map +1 -0
- package/dist/lib/storage/dispatcher-export.d.ts.map +1 -1
- package/dist/lib/storage/dispatcher-export.js +48 -39
- package/dist/lib/storage/dispatcher-export.js.map +1 -1
- package/dist/lib/storage/dispatcher.d.ts +1 -468
- package/dist/lib/storage/dispatcher.d.ts.map +1 -1
- package/dist/lib/storage/dispatcher.js +1 -1931
- package/dist/lib/storage/dispatcher.js.map +1 -1
- package/dist/lib/storage/index.d.ts +20 -5
- package/dist/lib/storage/index.d.ts.map +1 -1
- package/dist/lib/storage/index.js +36 -7
- package/dist/lib/storage/index.js.map +1 -1
- package/dist/lib/storage/migration/export-import.d.ts.map +1 -1
- package/dist/lib/storage/migration/export-import.js +9 -2
- package/dist/lib/storage/migration/export-import.js.map +1 -1
- package/dist/lib/storage/types.d.ts +152 -10
- package/dist/lib/storage/types.d.ts.map +1 -1
- package/dist/lib/storage/types.js +13 -0
- package/dist/lib/storage/types.js.map +1 -1
- package/dist/lib/storage/vector/interface.d.ts +4 -0
- package/dist/lib/storage/vector/interface.d.ts.map +1 -1
- package/dist/lib/storage/vector/qdrant.d.ts +13 -2
- package/dist/lib/storage/vector/qdrant.d.ts.map +1 -1
- package/dist/lib/storage/vector/qdrant.js +147 -61
- package/dist/lib/storage/vector/qdrant.js.map +1 -1
- package/dist/lib/token-budget.d.ts.map +1 -1
- package/dist/lib/token-budget.js +9 -2
- package/dist/lib/token-budget.js.map +1 -1
- package/dist/lib/transcript-utils.d.ts +60 -0
- package/dist/lib/transcript-utils.d.ts.map +1 -0
- package/dist/lib/transcript-utils.js +69 -0
- package/dist/lib/transcript-utils.js.map +1 -0
- package/dist/lib/tree-sitter/extractor.d.ts +1 -1
- package/dist/lib/tree-sitter/extractor.d.ts.map +1 -1
- package/dist/lib/tree-sitter/extractor.js +34 -9
- package/dist/lib/tree-sitter/extractor.js.map +1 -1
- package/dist/lib/tree-sitter/parser.d.ts.map +1 -1
- package/dist/lib/tree-sitter/parser.js +45 -11
- package/dist/lib/tree-sitter/parser.js.map +1 -1
- package/dist/lib/tree-sitter/public.d.ts +12 -0
- package/dist/lib/tree-sitter/public.d.ts.map +1 -1
- package/dist/lib/tree-sitter/public.js +33 -1
- package/dist/lib/tree-sitter/public.js.map +1 -1
- package/dist/lib/tree-sitter/queries.d.ts.map +1 -1
- package/dist/lib/tree-sitter/queries.js +8 -0
- package/dist/lib/tree-sitter/queries.js.map +1 -1
- package/dist/lib/version-check.d.ts +29 -0
- package/dist/lib/version-check.d.ts.map +1 -0
- package/dist/lib/version-check.js +187 -0
- package/dist/lib/version-check.js.map +1 -0
- package/dist/lib/working-memory-pipeline.d.ts.map +1 -1
- package/dist/lib/working-memory-pipeline.js +12 -3
- package/dist/lib/working-memory-pipeline.js.map +1 -1
- package/dist/lib/worktree-detect.d.ts +43 -0
- package/dist/lib/worktree-detect.d.ts.map +1 -0
- package/dist/lib/worktree-detect.js +154 -0
- package/dist/lib/worktree-detect.js.map +1 -0
- package/dist/lsp/client.d.ts +96 -0
- package/dist/lsp/client.d.ts.map +1 -0
- package/dist/lsp/client.js +435 -0
- package/dist/lsp/client.js.map +1 -0
- package/dist/lsp/installer.d.ts +39 -0
- package/dist/lsp/installer.d.ts.map +1 -0
- package/dist/lsp/installer.js +275 -0
- package/dist/lsp/installer.js.map +1 -0
- package/dist/lsp/manager.d.ts +62 -0
- package/dist/lsp/manager.d.ts.map +1 -0
- package/dist/lsp/manager.js +234 -0
- package/dist/lsp/manager.js.map +1 -0
- package/dist/lsp/servers.d.ts +52 -0
- package/dist/lsp/servers.d.ts.map +1 -0
- package/dist/lsp/servers.js +162 -0
- package/dist/lsp/servers.js.map +1 -0
- package/dist/mcp/helpers.d.ts.map +1 -1
- package/dist/mcp/helpers.js +8 -2
- package/dist/mcp/helpers.js.map +1 -1
- package/dist/mcp/profile.js +1 -1
- package/dist/mcp/server.d.ts +3 -2
- package/dist/mcp/server.d.ts.map +1 -1
- package/dist/mcp/server.js +19 -7
- package/dist/mcp/server.js.map +1 -1
- package/dist/mcp/tools/config.d.ts.map +1 -1
- package/dist/mcp/tools/config.js +28 -118
- package/dist/mcp/tools/config.js.map +1 -1
- package/dist/mcp/tools/dead-end.d.ts.map +1 -1
- package/dist/mcp/tools/dead-end.js +4 -3
- package/dist/mcp/tools/dead-end.js.map +1 -1
- package/dist/mcp/tools/debug.d.ts.map +1 -1
- package/dist/mcp/tools/debug.js +27 -112
- package/dist/mcp/tools/debug.js.map +1 -1
- package/dist/mcp/tools/graph.d.ts.map +1 -1
- package/dist/mcp/tools/graph.js +164 -176
- package/dist/mcp/tools/graph.js.map +1 -1
- package/dist/mcp/tools/indexing.d.ts +1 -1
- package/dist/mcp/tools/indexing.d.ts.map +1 -1
- package/dist/mcp/tools/indexing.js +63 -164
- package/dist/mcp/tools/indexing.js.map +1 -1
- package/dist/mcp/tools/memory/forget.d.ts +3 -0
- package/dist/mcp/tools/memory/forget.d.ts.map +1 -0
- package/dist/mcp/tools/memory/forget.js +175 -0
- package/dist/mcp/tools/memory/forget.js.map +1 -0
- package/dist/mcp/tools/memory/memory-helpers.d.ts +45 -0
- package/dist/mcp/tools/memory/memory-helpers.d.ts.map +1 -0
- package/dist/mcp/tools/memory/memory-helpers.js +291 -0
- package/dist/mcp/tools/memory/memory-helpers.js.map +1 -0
- package/dist/mcp/tools/memory/recall.d.ts +3 -0
- package/dist/mcp/tools/memory/recall.d.ts.map +1 -0
- package/dist/mcp/tools/memory/recall.js +495 -0
- package/dist/mcp/tools/memory/recall.js.map +1 -0
- package/dist/mcp/tools/memory/remember.d.ts +3 -0
- package/dist/mcp/tools/memory/remember.d.ts.map +1 -0
- package/dist/mcp/tools/memory/remember.js +256 -0
- package/dist/mcp/tools/memory/remember.js.map +1 -0
- package/dist/mcp/tools/memory/temporal-query.d.ts +8 -0
- package/dist/mcp/tools/memory/temporal-query.d.ts.map +1 -0
- package/dist/mcp/tools/memory/temporal-query.js +68 -0
- package/dist/mcp/tools/memory/temporal-query.js.map +1 -0
- package/dist/mcp/tools/memory.d.ts +0 -11
- package/dist/mcp/tools/memory.d.ts.map +1 -1
- package/dist/mcp/tools/memory.js +6 -1228
- package/dist/mcp/tools/memory.js.map +1 -1
- package/dist/mcp/tools/prd.d.ts.map +1 -1
- package/dist/mcp/tools/prd.js +19 -70
- package/dist/mcp/tools/prd.js.map +1 -1
- package/dist/mcp/tools/review.d.ts +8 -0
- package/dist/mcp/tools/review.d.ts.map +1 -0
- package/dist/mcp/tools/review.js +133 -0
- package/dist/mcp/tools/review.js.map +1 -0
- package/dist/mcp/tools/search.d.ts.map +1 -1
- package/dist/mcp/tools/search.js +79 -8
- package/dist/mcp/tools/search.js.map +1 -1
- package/dist/mcp/tools/status.d.ts.map +1 -1
- package/dist/mcp/tools/status.js +50 -75
- package/dist/mcp/tools/status.js.map +1 -1
- package/dist/mcp/tools/web-fetch.d.ts.map +1 -1
- package/dist/mcp/tools/web-fetch.js +5 -1
- package/dist/mcp/tools/web-fetch.js.map +1 -1
- package/dist/mcp/tools/web-search.d.ts.map +1 -1
- package/dist/mcp/tools/web-search.js +25 -103
- package/dist/mcp/tools/web-search.js.map +1 -1
- package/dist/prompts/guardrails.d.ts +14 -0
- package/dist/prompts/guardrails.d.ts.map +1 -0
- package/dist/prompts/guardrails.js +115 -0
- package/dist/prompts/guardrails.js.map +1 -0
- package/dist/prompts/index.d.ts +2 -1
- package/dist/prompts/index.d.ts.map +1 -1
- package/dist/prompts/index.js +3 -1
- package/dist/prompts/index.js.map +1 -1
- package/dist/prompts/prd.d.ts +0 -2
- package/dist/prompts/prd.d.ts.map +1 -1
- package/dist/prompts/prd.js +0 -2
- package/dist/prompts/prd.js.map +1 -1
- package/hooks/core/__tests__/adapter.test.cjs +340 -0
- package/hooks/core/adapter.cjs +463 -0
- package/hooks/core/config.cjs +83 -0
- package/hooks/core/daemon-boot.cjs +140 -0
- package/hooks/core/log.cjs +41 -0
- package/hooks/core/worktree.cjs +119 -0
- package/hooks/succ-post-tool.cjs +198 -134
- package/hooks/succ-pre-compact.cjs +262 -0
- package/hooks/succ-pre-tool.cjs +526 -182
- package/hooks/succ-session-end.cjs +40 -64
- package/hooks/succ-session-start.cjs +528 -427
- package/hooks/succ-stop-reflection.cjs +36 -62
- package/hooks/succ-user-prompt.cjs +137 -180
- package/package.json +17 -6
|
@@ -8,77 +8,51 @@
|
|
|
8
8
|
|
|
9
9
|
const fs = require('fs');
|
|
10
10
|
const path = require('path');
|
|
11
|
+
const adapter = require('./core/adapter.cjs');
|
|
12
|
+
const { getDaemonPort } = require('./core/daemon-boot.cjs');
|
|
11
13
|
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
while ((chunk = process.stdin.read()) !== null) {
|
|
17
|
-
input += chunk;
|
|
14
|
+
adapter.runHook('stop-reflection', async ({ hookInput, succDir }) => {
|
|
15
|
+
const tmpDir = path.join(succDir, '.tmp');
|
|
16
|
+
if (!fs.existsSync(tmpDir)) {
|
|
17
|
+
fs.mkdirSync(tmpDir, { recursive: true });
|
|
18
18
|
}
|
|
19
|
-
});
|
|
20
|
-
|
|
21
|
-
process.stdin.on('end', async () => {
|
|
22
|
-
try {
|
|
23
|
-
const hookInput = JSON.parse(input);
|
|
24
|
-
let projectDir = hookInput.cwd || process.cwd();
|
|
25
19
|
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
20
|
+
// Get session_id — fall back to hookInput.session_id when transcript_path is absent
|
|
21
|
+
// (session-start registers a synthetic session_id in that case)
|
|
22
|
+
const transcriptPath = hookInput.transcript_path || '';
|
|
23
|
+
const sessionId = transcriptPath
|
|
24
|
+
? path.basename(transcriptPath, '.jsonl')
|
|
25
|
+
: hookInput.session_id || null;
|
|
30
26
|
|
|
31
|
-
|
|
32
|
-
if (!fs.existsSync(path.join(projectDir, '.succ'))) {
|
|
33
|
-
process.exit(0);
|
|
34
|
-
}
|
|
27
|
+
const daemonPort = getDaemonPort(succDir);
|
|
35
28
|
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
fs.mkdirSync(tmpDir, { recursive: true });
|
|
39
|
-
}
|
|
29
|
+
// Check if this is a service session (e.g., reflection subagent)
|
|
30
|
+
const isServiceSession = process.env.SUCC_SERVICE_SESSION === '1';
|
|
40
31
|
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
32
|
+
// Notify daemon of stop activity (awaited)
|
|
33
|
+
const notifyDaemon = async () => {
|
|
34
|
+
if (!daemonPort || !sessionId) return;
|
|
44
35
|
|
|
45
|
-
// Read daemon port
|
|
46
|
-
let daemonPort = null;
|
|
47
36
|
try {
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
method: 'POST',
|
|
64
|
-
headers: { 'Content-Type': 'application/json' },
|
|
65
|
-
body: JSON.stringify({
|
|
66
|
-
session_id: sessionId,
|
|
67
|
-
type: 'stop',
|
|
68
|
-
transcript_path: transcriptPath,
|
|
69
|
-
is_service: isServiceSession,
|
|
70
|
-
}),
|
|
71
|
-
signal: AbortSignal.timeout(2000),
|
|
72
|
-
});
|
|
73
|
-
} catch {}
|
|
74
|
-
};
|
|
37
|
+
await fetch(`http://127.0.0.1:${daemonPort}/api/session/activity`, {
|
|
38
|
+
method: 'POST',
|
|
39
|
+
headers: { 'Content-Type': 'application/json' },
|
|
40
|
+
body: JSON.stringify({
|
|
41
|
+
session_id: sessionId,
|
|
42
|
+
type: 'stop',
|
|
43
|
+
transcript_path: transcriptPath,
|
|
44
|
+
is_service: isServiceSession,
|
|
45
|
+
}),
|
|
46
|
+
signal: AbortSignal.timeout(2000),
|
|
47
|
+
});
|
|
48
|
+
} catch {
|
|
49
|
+
// intentionally empty
|
|
50
|
+
}
|
|
51
|
+
};
|
|
75
52
|
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
} catch (err) {
|
|
80
|
-
process.exit(0);
|
|
81
|
-
}
|
|
53
|
+
// Wait for daemon notification before exit
|
|
54
|
+
await notifyDaemon();
|
|
55
|
+
process.exit(0);
|
|
82
56
|
});
|
|
83
57
|
|
|
84
58
|
// Safety timeout
|
|
@@ -12,209 +12,166 @@
|
|
|
12
12
|
|
|
13
13
|
const path = require('path');
|
|
14
14
|
const fs = require('fs');
|
|
15
|
+
const adapter = require('./core/adapter.cjs');
|
|
16
|
+
const { getDaemonPort } = require('./core/daemon-boot.cjs');
|
|
17
|
+
const { log: _log } = require('./core/log.cjs');
|
|
18
|
+
const { loadMergedConfig } = require('./core/config.cjs');
|
|
15
19
|
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
try {
|
|
19
|
-
const tmpDir = path.join(succDir, '.tmp');
|
|
20
|
-
if (!fs.existsSync(tmpDir)) {
|
|
21
|
-
fs.mkdirSync(tmpDir, { recursive: true });
|
|
22
|
-
}
|
|
23
|
-
const logFile = path.join(tmpDir, 'hooks.log');
|
|
24
|
-
const timestamp = new Date().toISOString();
|
|
25
|
-
fs.appendFileSync(logFile, `[${timestamp}] [user-prompt] ${message}\n`);
|
|
26
|
-
} catch {
|
|
27
|
-
// Logging failed, not critical
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
let input = '';
|
|
32
|
-
process.stdin.setEncoding('utf8');
|
|
33
|
-
process.stdin.on('readable', () => {
|
|
34
|
-
let chunk;
|
|
35
|
-
while ((chunk = process.stdin.read()) !== null) {
|
|
36
|
-
input += chunk;
|
|
37
|
-
}
|
|
38
|
-
});
|
|
20
|
+
adapter.runHook('user-prompt', async ({ agent, hookInput, projectDir, succDir }) => {
|
|
21
|
+
const log = (msg) => _log(succDir, 'user-prompt', msg);
|
|
39
22
|
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
23
|
+
const tmpDir = path.join(succDir, '.tmp');
|
|
24
|
+
if (!fs.existsSync(tmpDir)) {
|
|
25
|
+
fs.mkdirSync(tmpDir, { recursive: true });
|
|
26
|
+
}
|
|
44
27
|
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
}
|
|
28
|
+
// Get session_id from transcript_path (unique per session)
|
|
29
|
+
const transcriptPath = hookInput.transcript_path || '';
|
|
30
|
+
const sessionId = transcriptPath ? path.basename(transcriptPath, '.jsonl') : null;
|
|
49
31
|
|
|
50
|
-
|
|
51
|
-
if (!fs.existsSync(path.join(projectDir, '.succ'))) {
|
|
52
|
-
process.exit(0);
|
|
53
|
-
}
|
|
32
|
+
const daemonPort = getDaemonPort(succDir);
|
|
54
33
|
|
|
55
|
-
|
|
34
|
+
// Check if this is a service session (e.g., reflection subagent)
|
|
35
|
+
const isServiceSession = process.env.SUCC_SERVICE_SESSION === '1';
|
|
56
36
|
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
const sessionId = transcriptPath ? path.basename(transcriptPath, '.jsonl') : null;
|
|
37
|
+
// Collect all context parts — output a single JSON at the end to avoid broken hook parsing
|
|
38
|
+
const contextParts = [];
|
|
60
39
|
|
|
61
|
-
|
|
62
|
-
|
|
40
|
+
// Check for compact-pending fallback
|
|
41
|
+
// This handles the case where SessionStart hook output was lost after /compact
|
|
42
|
+
// See: https://github.com/anthropics/claude-code/issues/15174
|
|
43
|
+
const compactPendingFile = path.join(tmpDir, 'compact-pending');
|
|
44
|
+
if (fs.existsSync(compactPendingFile) && !isServiceSession) {
|
|
63
45
|
try {
|
|
64
|
-
const
|
|
65
|
-
|
|
66
|
-
|
|
46
|
+
const pendingContext = fs.readFileSync(compactPendingFile, 'utf8');
|
|
47
|
+
// Delete the file before outputting to avoid duplicate injection
|
|
48
|
+
fs.unlinkSync(compactPendingFile);
|
|
49
|
+
|
|
50
|
+
if (pendingContext.trim()) {
|
|
51
|
+
log(`Injecting compact-pending fallback context (${pendingContext.length} chars)`);
|
|
52
|
+
contextParts.push(
|
|
53
|
+
`<compact-fallback reason="SessionStart output may have been lost">\n${pendingContext}\n</compact-fallback>`
|
|
54
|
+
);
|
|
67
55
|
}
|
|
68
|
-
} catch {
|
|
56
|
+
} catch (err) {
|
|
57
|
+
log(`Error processing compact-pending: ${err.message || err}`);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
69
60
|
|
|
70
|
-
|
|
71
|
-
|
|
61
|
+
// Notify daemon of user activity
|
|
62
|
+
let daemonAlive = false;
|
|
63
|
+
if (daemonPort && sessionId) {
|
|
64
|
+
try {
|
|
65
|
+
const res = await fetch(`http://127.0.0.1:${daemonPort}/api/session/activity`, {
|
|
66
|
+
method: 'POST',
|
|
67
|
+
headers: { 'Content-Type': 'application/json' },
|
|
68
|
+
body: JSON.stringify({
|
|
69
|
+
session_id: sessionId,
|
|
70
|
+
type: 'user_prompt',
|
|
71
|
+
transcript_path: transcriptPath,
|
|
72
|
+
is_service: isServiceSession,
|
|
73
|
+
}),
|
|
74
|
+
signal: AbortSignal.timeout(2000),
|
|
75
|
+
});
|
|
76
|
+
if (res.ok) daemonAlive = true;
|
|
77
|
+
} catch {
|
|
78
|
+
// intentionally empty — daemon not reachable
|
|
79
|
+
}
|
|
80
|
+
}
|
|
72
81
|
|
|
73
|
-
|
|
82
|
+
// --- Skill Suggestions ---
|
|
83
|
+
// LLM-powered skill suggestions based on user prompt.
|
|
84
|
+
// Uses extractKeywords → BM25 search → LLM ranking.
|
|
85
|
+
// Respects cooldown to avoid suggesting on every prompt.
|
|
86
|
+
if (daemonAlive && !isServiceSession) {
|
|
87
|
+
const prompt = hookInput.prompt || hookInput.message || '';
|
|
88
|
+
|
|
89
|
+
// Load config to check if auto_suggest is enabled
|
|
90
|
+
const config = loadMergedConfig(projectDir);
|
|
91
|
+
const skillsConfig = config.skills || null;
|
|
92
|
+
|
|
93
|
+
// Defaults
|
|
94
|
+
const autoSuggest = skillsConfig?.auto_suggest || {};
|
|
95
|
+
const enabled = autoSuggest.enabled === true; // default: false (matches skills.ts)
|
|
96
|
+
const onUserPrompt = autoSuggest.on_user_prompt !== false; // default: true
|
|
97
|
+
const minPromptLength = autoSuggest.min_prompt_length || 20;
|
|
98
|
+
const cooldownPrompts = autoSuggest.cooldown_prompts || 3;
|
|
99
|
+
|
|
100
|
+
if (enabled && onUserPrompt && prompt.length >= minPromptLength) {
|
|
101
|
+
// Check cooldown (track prompts since last suggestion per session)
|
|
102
|
+
const cooldownFile = path.join(tmpDir, `skill-cooldown-${sessionId}`);
|
|
103
|
+
let promptsSinceLastSuggestion = 0;
|
|
74
104
|
|
|
75
|
-
// Check for compact-pending fallback
|
|
76
|
-
// This handles the case where SessionStart hook output was lost after /compact
|
|
77
|
-
// See: https://github.com/anthropics/claude-code/issues/15174
|
|
78
|
-
const compactPendingFile = path.join(tmpDir, 'compact-pending');
|
|
79
|
-
if (fs.existsSync(compactPendingFile) && !isServiceSession) {
|
|
80
105
|
try {
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
if (pendingContext.trim()) {
|
|
86
|
-
log(succDir, `Injecting compact-pending fallback context (${pendingContext.length} chars)`);
|
|
87
|
-
|
|
88
|
-
// Output as additionalContext - this will be injected into Claude's context
|
|
89
|
-
const output = {
|
|
90
|
-
hookSpecificOutput: {
|
|
91
|
-
hookEventName: 'UserPromptSubmit',
|
|
92
|
-
additionalContext: `<compact-fallback reason="SessionStart output may have been lost">\n${pendingContext}\n</compact-fallback>`
|
|
93
|
-
}
|
|
94
|
-
};
|
|
95
|
-
console.log(JSON.stringify(output));
|
|
106
|
+
if (fs.existsSync(cooldownFile)) {
|
|
107
|
+
promptsSinceLastSuggestion =
|
|
108
|
+
parseInt(fs.readFileSync(cooldownFile, 'utf8').trim(), 10) || 0;
|
|
96
109
|
}
|
|
97
|
-
} catch
|
|
98
|
-
|
|
110
|
+
} catch {
|
|
111
|
+
// intentionally empty
|
|
99
112
|
}
|
|
100
|
-
}
|
|
101
113
|
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
const config = JSON.parse(fs.readFileSync(configPath, 'utf8'));
|
|
136
|
-
if (config.skills) {
|
|
137
|
-
skillsConfig = config.skills;
|
|
138
|
-
break;
|
|
114
|
+
// Only suggest if cooldown has passed
|
|
115
|
+
if (promptsSinceLastSuggestion >= cooldownPrompts || promptsSinceLastSuggestion === 0) {
|
|
116
|
+
try {
|
|
117
|
+
const response = await fetch(`http://127.0.0.1:${daemonPort}/api/skills/suggest`, {
|
|
118
|
+
method: 'POST',
|
|
119
|
+
headers: { 'Content-Type': 'application/json' },
|
|
120
|
+
body: JSON.stringify({ prompt }),
|
|
121
|
+
signal: AbortSignal.timeout(15000), // 15s timeout for 2 LLM calls (extraction + ranking)
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
if (response.ok) {
|
|
125
|
+
const data = await response.json();
|
|
126
|
+
const suggestions = data.skills || [];
|
|
127
|
+
|
|
128
|
+
if (suggestions.length > 0) {
|
|
129
|
+
// Reset cooldown counter
|
|
130
|
+
fs.writeFileSync(cooldownFile, '0', 'utf8');
|
|
131
|
+
|
|
132
|
+
// Format suggestions
|
|
133
|
+
const lines = suggestions.map((s) => {
|
|
134
|
+
return `- **${s.name}**: ${s.reason} (confidence: ${(s.confidence * 100).toFixed(0)}%)`;
|
|
135
|
+
});
|
|
136
|
+
|
|
137
|
+
const suggestionContext = `<skill-suggestions hint="Use /${suggestions[0].name} to invoke">\n${lines.join('\n')}\n</skill-suggestions>`;
|
|
138
|
+
|
|
139
|
+
log(
|
|
140
|
+
`Suggesting ${suggestions.length} skill(s): ${suggestions.map((s) => s.name).join(', ')}`
|
|
141
|
+
);
|
|
142
|
+
|
|
143
|
+
contextParts.push(suggestionContext);
|
|
144
|
+
} else {
|
|
145
|
+
// No suggestions, increment cooldown
|
|
146
|
+
fs.writeFileSync(cooldownFile, String(promptsSinceLastSuggestion + 1), 'utf8');
|
|
139
147
|
}
|
|
140
|
-
} catch {
|
|
141
|
-
// Ignore parse errors
|
|
142
148
|
}
|
|
149
|
+
} catch (err) {
|
|
150
|
+
log(
|
|
151
|
+
`Skill suggestion error: ${err.message || err}${err.cause ? ' | cause: ' + (err.cause.message || err.cause) : ''} | port=${daemonPort}`
|
|
152
|
+
);
|
|
143
153
|
}
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
// Defaults
|
|
147
|
-
const autoSuggest = skillsConfig?.auto_suggest || {};
|
|
148
|
-
const enabled = autoSuggest.enabled !== false; // default: true
|
|
149
|
-
const onUserPrompt = autoSuggest.on_user_prompt !== false; // default: true
|
|
150
|
-
const minPromptLength = autoSuggest.min_prompt_length || 20;
|
|
151
|
-
const cooldownPrompts = autoSuggest.cooldown_prompts || 3;
|
|
152
|
-
|
|
153
|
-
if (enabled && onUserPrompt && prompt.length >= minPromptLength) {
|
|
154
|
-
// Check cooldown (track prompts since last suggestion per session)
|
|
155
|
-
const cooldownFile = path.join(tmpDir, `skill-cooldown-${sessionId}`);
|
|
156
|
-
let promptsSinceLastSuggestion = 0;
|
|
157
|
-
|
|
154
|
+
} else {
|
|
155
|
+
// Cooldown not passed, increment counter
|
|
158
156
|
try {
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
} catch {}
|
|
163
|
-
|
|
164
|
-
// Only suggest if cooldown has passed
|
|
165
|
-
if (promptsSinceLastSuggestion >= cooldownPrompts || promptsSinceLastSuggestion === 0) {
|
|
166
|
-
try {
|
|
167
|
-
const response = await fetch(`http://127.0.0.1:${daemonPort}/api/skills/suggest`, {
|
|
168
|
-
method: 'POST',
|
|
169
|
-
headers: { 'Content-Type': 'application/json' },
|
|
170
|
-
body: JSON.stringify({ prompt }),
|
|
171
|
-
signal: AbortSignal.timeout(15000), // 15s timeout for 2 LLM calls (extraction + ranking)
|
|
172
|
-
});
|
|
173
|
-
|
|
174
|
-
if (response.ok) {
|
|
175
|
-
const data = await response.json();
|
|
176
|
-
const suggestions = data.suggestions || [];
|
|
177
|
-
|
|
178
|
-
if (suggestions.length > 0) {
|
|
179
|
-
// Reset cooldown counter
|
|
180
|
-
fs.writeFileSync(cooldownFile, '0', 'utf8');
|
|
181
|
-
|
|
182
|
-
// Format suggestions
|
|
183
|
-
const lines = suggestions.map((s) => {
|
|
184
|
-
return `- **${s.name}**: ${s.reason} (confidence: ${(s.confidence * 100).toFixed(0)}%)`;
|
|
185
|
-
});
|
|
186
|
-
|
|
187
|
-
const suggestionContext = `<skill-suggestions hint="Use /${suggestions[0].name} to invoke">\n${lines.join('\n')}\n</skill-suggestions>`;
|
|
188
|
-
|
|
189
|
-
log(succDir, `Suggesting ${suggestions.length} skill(s): ${suggestions.map(s => s.name).join(', ')}`);
|
|
190
|
-
|
|
191
|
-
// Output as additionalContext
|
|
192
|
-
const output = {
|
|
193
|
-
hookSpecificOutput: {
|
|
194
|
-
hookEventName: 'UserPromptSubmit',
|
|
195
|
-
additionalContext: suggestionContext
|
|
196
|
-
}
|
|
197
|
-
};
|
|
198
|
-
console.log(JSON.stringify(output));
|
|
199
|
-
} else {
|
|
200
|
-
// No suggestions, increment cooldown
|
|
201
|
-
fs.writeFileSync(cooldownFile, String(promptsSinceLastSuggestion + 1), 'utf8');
|
|
202
|
-
}
|
|
203
|
-
}
|
|
204
|
-
} catch (err) {
|
|
205
|
-
log(succDir, `Skill suggestion error: ${err.message || err}`);
|
|
206
|
-
}
|
|
207
|
-
} else {
|
|
208
|
-
// Cooldown not passed, increment counter
|
|
209
|
-
try {
|
|
210
|
-
fs.writeFileSync(cooldownFile, String(promptsSinceLastSuggestion + 1), 'utf8');
|
|
211
|
-
} catch {}
|
|
157
|
+
fs.writeFileSync(cooldownFile, String(promptsSinceLastSuggestion + 1), 'utf8');
|
|
158
|
+
} catch {
|
|
159
|
+
// intentionally empty
|
|
212
160
|
}
|
|
213
161
|
}
|
|
214
162
|
}
|
|
163
|
+
}
|
|
215
164
|
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
165
|
+
// Emit a single hook payload with all collected context
|
|
166
|
+
if (contextParts.length > 0) {
|
|
167
|
+
const { json, exitCode } = adapter.formatOutput(agent, 'UserPromptSubmit', {
|
|
168
|
+
additionalContext: contextParts.join('\n\n'),
|
|
169
|
+
});
|
|
170
|
+
if (json && Object.keys(json).length > 0) {
|
|
171
|
+
console.log(JSON.stringify(json));
|
|
172
|
+
}
|
|
173
|
+
if (exitCode) process.exit(exitCode);
|
|
219
174
|
}
|
|
175
|
+
|
|
176
|
+
process.exit(0);
|
|
220
177
|
});
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@vinaes/succ",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.5.42",
|
|
4
4
|
"description": "Semantic Understanding for Code Contexts — persistent memory for AI coding assistants (Claude Code, Cursor, Windsurf, Continue.dev)",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"publishConfig": {
|
|
@@ -27,8 +27,9 @@
|
|
|
27
27
|
"succ-mcp": "./dist/mcp-server.js"
|
|
28
28
|
},
|
|
29
29
|
"scripts": {
|
|
30
|
-
"
|
|
31
|
-
"build:
|
|
30
|
+
"clean:dist": "node --input-type=module -e \"import { rmSync } from 'node:fs'; rmSync('dist', { recursive: true, force: true });\"",
|
|
31
|
+
"build": "npm run clean:dist && prettier --check src/ && eslint src/ && tsc",
|
|
32
|
+
"build:compile": "npm run clean:dist && tsc",
|
|
32
33
|
"dev": "tsx src/cli.ts",
|
|
33
34
|
"test": "vitest",
|
|
34
35
|
"test:storage": "vitest --run src/lib/storage/",
|
|
@@ -78,12 +79,21 @@
|
|
|
78
79
|
"commander": "^14.0.3",
|
|
79
80
|
"cross-spawn": "^7.0.6",
|
|
80
81
|
"glob": "^13.0.3",
|
|
81
|
-
"
|
|
82
|
+
"graphology": "^0.26.0",
|
|
83
|
+
"graphology-communities-louvain": "^2.0.2",
|
|
84
|
+
"graphology-library": "^0.8.0",
|
|
85
|
+
"graphology-metrics": "^2.1.0",
|
|
86
|
+
"graphology-shortest-path": "^2.0.2",
|
|
82
87
|
"inquirer": "^13.2.2",
|
|
83
88
|
"is-installed-globally": "^1.0.0",
|
|
89
|
+
"minimatch": "^10.2.4",
|
|
84
90
|
"onnxruntime-node": "1.24.1",
|
|
85
91
|
"ora": "^9.3.0",
|
|
92
|
+
"p-limit": "^7.3.0",
|
|
93
|
+
"parse-diff": "^0.11.1",
|
|
94
|
+
"smol-toml": "^1.6.0",
|
|
86
95
|
"sqlite-vec": "0.1.7-alpha.2",
|
|
96
|
+
"vscode-languageserver-protocol": "^3.17.5",
|
|
87
97
|
"web-tree-sitter": "^0.26.5",
|
|
88
98
|
"ws": "^8.19.0",
|
|
89
99
|
"zod": "^3.25.76"
|
|
@@ -93,16 +103,17 @@
|
|
|
93
103
|
"pg": "^8.13.0"
|
|
94
104
|
},
|
|
95
105
|
"devDependencies": {
|
|
106
|
+
"@eslint/js": "^10.0.1",
|
|
96
107
|
"@types/better-sqlite3": "^7.6.0",
|
|
97
|
-
"@types/inquirer": "^9.0.9",
|
|
98
108
|
"@types/node": "^25.2.3",
|
|
99
109
|
"@types/pg": "^8.11.0",
|
|
100
110
|
"@types/ws": "^8.18.1",
|
|
101
111
|
"@typescript-eslint/eslint-plugin": "^8.54.0",
|
|
102
112
|
"@typescript-eslint/parser": "^8.54.0",
|
|
103
|
-
"eslint": "^
|
|
113
|
+
"eslint": "^10.0.1",
|
|
104
114
|
"eslint-config-prettier": "^10.1.8",
|
|
105
115
|
"eslint-plugin-prettier": "^5.5.5",
|
|
116
|
+
"globals": "^17.3.0",
|
|
106
117
|
"prettier": "^3.8.1",
|
|
107
118
|
"tsx": "^4.0.0",
|
|
108
119
|
"typescript": "^5.0.0",
|