cognitive-core 0.2.0 → 0.2.2
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/.claude/settings.json +111 -2
- package/.sessionlog/settings.json +4 -0
- package/dist/atlas.d.ts +10 -0
- package/dist/atlas.d.ts.map +1 -1
- package/dist/atlas.js +65 -0
- package/dist/atlas.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -1
- package/dist/index.js.map +1 -1
- package/dist/learning/index.d.ts +1 -1
- package/dist/learning/index.d.ts.map +1 -1
- package/dist/learning/index.js.map +1 -1
- package/dist/learning/pipeline.d.ts +4 -31
- package/dist/learning/pipeline.d.ts.map +1 -1
- package/dist/learning/pipeline.js +12 -64
- package/dist/learning/pipeline.js.map +1 -1
- package/dist/learning/unified-pipeline.d.ts +30 -0
- package/dist/learning/unified-pipeline.d.ts.map +1 -1
- package/dist/learning/unified-pipeline.js +207 -0
- package/dist/learning/unified-pipeline.js.map +1 -1
- package/dist/memory/candidate-retrieval.d.ts.map +1 -1
- package/dist/memory/candidate-retrieval.js +3 -1
- package/dist/memory/candidate-retrieval.js.map +1 -1
- package/dist/memory/curated-loader.d.ts +21 -4
- package/dist/memory/curated-loader.d.ts.map +1 -1
- package/dist/memory/curated-loader.js +53 -16
- package/dist/memory/curated-loader.js.map +1 -1
- package/dist/memory/index.d.ts +2 -1
- package/dist/memory/index.d.ts.map +1 -1
- package/dist/memory/index.js +3 -1
- package/dist/memory/index.js.map +1 -1
- package/dist/memory/playbook.d.ts +6 -0
- package/dist/memory/playbook.d.ts.map +1 -1
- package/dist/memory/playbook.js +15 -0
- package/dist/memory/playbook.js.map +1 -1
- package/dist/memory/source-resolver.d.ts +120 -0
- package/dist/memory/source-resolver.d.ts.map +1 -0
- package/dist/memory/source-resolver.js +300 -0
- package/dist/memory/source-resolver.js.map +1 -0
- package/dist/types/config.d.ts +141 -0
- package/dist/types/config.d.ts.map +1 -1
- package/dist/types/config.js +40 -0
- package/dist/types/config.js.map +1 -1
- package/dist/types/index.d.ts +1 -1
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +1 -1
- package/dist/types/index.js.map +1 -1
- package/dist/utils/error-classifier.js +8 -8
- package/dist/utils/error-classifier.js.map +1 -1
- package/dist/workspace/efficacy-toolkit.d.ts +164 -0
- package/dist/workspace/efficacy-toolkit.d.ts.map +1 -0
- package/dist/workspace/efficacy-toolkit.js +281 -0
- package/dist/workspace/efficacy-toolkit.js.map +1 -0
- package/dist/workspace/index.d.ts +2 -1
- package/dist/workspace/index.d.ts.map +1 -1
- package/dist/workspace/index.js +3 -1
- package/dist/workspace/index.js.map +1 -1
- package/dist/workspace/templates/index.d.ts +3 -0
- package/dist/workspace/templates/index.d.ts.map +1 -1
- package/dist/workspace/templates/index.js +6 -0
- package/dist/workspace/templates/index.js.map +1 -1
- package/dist/workspace/templates/playbook-decay-detection.d.ts +46 -0
- package/dist/workspace/templates/playbook-decay-detection.d.ts.map +1 -0
- package/dist/workspace/templates/playbook-decay-detection.js +197 -0
- package/dist/workspace/templates/playbook-decay-detection.js.map +1 -0
- package/dist/workspace/templates/playbook-efficacy-audit.d.ts +46 -0
- package/dist/workspace/templates/playbook-efficacy-audit.d.ts.map +1 -0
- package/dist/workspace/templates/playbook-efficacy-audit.js +160 -0
- package/dist/workspace/templates/playbook-efficacy-audit.js.map +1 -0
- package/dist/workspace/templates/playbook-lifecycle-review.d.ts +51 -0
- package/dist/workspace/templates/playbook-lifecycle-review.d.ts.map +1 -0
- package/dist/workspace/templates/playbook-lifecycle-review.js +187 -0
- package/dist/workspace/templates/playbook-lifecycle-review.js.map +1 -0
- package/dist/workspace/types.d.ts +12 -54
- package/dist/workspace/types.d.ts.map +1 -1
- package/dist/workspace/types.js.map +1 -1
- package/package.json +8 -2
- package/playbooks/compound-engineering/adversarial-review.json +51 -0
- package/playbooks/compound-engineering/agent-native-architecture.json +59 -0
- package/playbooks/compound-engineering/agent-native-review.json +54 -0
- package/playbooks/compound-engineering/api-contract-review.json +52 -0
- package/playbooks/compound-engineering/brainstorm-requirements.json +55 -0
- package/playbooks/compound-engineering/bug-reproduction.json +62 -0
- package/playbooks/compound-engineering/confidence-calibration.json +49 -0
- package/playbooks/compound-engineering/correctness-review.json +49 -0
- package/playbooks/compound-engineering/data-migration-safety.json +59 -0
- package/playbooks/compound-engineering/deployment-verification.json +63 -0
- package/playbooks/compound-engineering/error-recovery-patterns.json +53 -0
- package/playbooks/compound-engineering/implementation-planning.json +64 -0
- package/playbooks/compound-engineering/issue-pattern-analysis.json +53 -0
- package/playbooks/compound-engineering/knowledge-compounding.json +63 -0
- package/playbooks/compound-engineering/learnings-research.json +54 -0
- package/playbooks/compound-engineering/maintainability-review.json +49 -0
- package/playbooks/compound-engineering/performance-review.json +54 -0
- package/playbooks/compound-engineering/plan-adversarial-review.json +56 -0
- package/playbooks/compound-engineering/plan-feasibility-review.json +56 -0
- package/playbooks/compound-engineering/project-standards-review.json +52 -0
- package/playbooks/compound-engineering/reliability-review.json +53 -0
- package/playbooks/compound-engineering/review-orchestration.json +64 -0
- package/playbooks/compound-engineering/security-review.json +54 -0
- package/playbooks/compound-engineering/systematic-execution.json +64 -0
- package/playbooks/compound-engineering/testing-review.json +50 -0
- package/src/atlas.ts +96 -0
- package/src/index.ts +27 -0
- package/src/learning/index.ts +1 -0
- package/src/learning/unified-pipeline.ts +271 -1
- package/src/memory/candidate-retrieval.ts +2 -1
- package/src/memory/curated-loader.ts +69 -16
- package/src/memory/index.ts +16 -0
- package/src/memory/playbook.ts +19 -0
- package/src/memory/source-resolver.ts +422 -0
- package/src/types/config.ts +46 -0
- package/src/types/index.ts +4 -0
- package/src/utils/error-classifier.ts +8 -8
- package/src/workspace/efficacy-toolkit.ts +496 -0
- package/src/workspace/index.ts +29 -0
- package/src/workspace/templates/index.ts +24 -0
- package/src/workspace/templates/playbook-decay-detection.ts +272 -0
- package/src/workspace/templates/playbook-efficacy-audit.ts +246 -0
- package/src/workspace/templates/playbook-lifecycle-review.ts +274 -0
- package/src/workspace/types.ts +22 -78
- package/tests/fixtures/behavioral-trajectories.ts +210 -0
- package/tests/integration/curated-sources-e2e.test.ts +502 -0
- package/tests/integration/pipeline-data-correctness.test.ts +794 -0
- package/tests/learning/meta-learner.test.ts +418 -0
- package/tests/learning/pipeline-memory-updates.test.ts +721 -0
- package/tests/learning/unified-pipeline-efficacy.test.ts +232 -0
- package/tests/memory/candidate-retrieval.test.ts +167 -0
- package/tests/memory/compound-engineering-seed.test.ts +338 -0
- package/tests/memory/curated-loader-extended.test.ts +225 -0
- package/tests/memory/meta.test.ts +399 -0
- package/tests/memory/playbook-quality-validation.test.ts +430 -0
- package/tests/memory/source-resolver.test.ts +700 -0
- package/tests/search/evaluator.test.ts +257 -0
- package/tests/search/verification-runner.test.ts +357 -0
- package/tests/utils/error-classifier.test.ts +149 -0
- package/tests/utils/trajectory-helpers.test.ts +163 -0
- package/tests/workspace/efficacy-toolkit.test.ts +404 -0
- package/tests/workspace/templates/playbook-efficacy.test.ts +377 -0
- package/.claude/settings.local.json +0 -11
- package/dist/learning/llm-extractor.d.ts +0 -88
- package/dist/learning/llm-extractor.d.ts.map +0 -1
- package/dist/learning/llm-extractor.js +0 -372
- package/dist/learning/llm-extractor.js.map +0 -1
- package/dist/learning/loop-coordinator.d.ts +0 -61
- package/dist/learning/loop-coordinator.d.ts.map +0 -1
- package/dist/learning/loop-coordinator.js +0 -96
- package/dist/learning/loop-coordinator.js.map +0 -1
- package/references/agent-workspace/CLAUDE.md +0 -74
- package/references/agent-workspace/README.md +0 -587
- package/references/agent-workspace/media/banner.png +0 -0
- package/references/agent-workspace/package-lock.json +0 -2061
- package/references/agent-workspace/package.json +0 -54
- package/references/agent-workspace/src/handle.ts +0 -122
- package/references/agent-workspace/src/index.ts +0 -32
- package/references/agent-workspace/src/manager.ts +0 -102
- package/references/agent-workspace/src/readers/json.ts +0 -71
- package/references/agent-workspace/src/readers/markdown.ts +0 -37
- package/references/agent-workspace/src/readers/raw.ts +0 -27
- package/references/agent-workspace/src/types.ts +0 -68
- package/references/agent-workspace/src/validation.ts +0 -93
- package/references/agent-workspace/src/writers/json.ts +0 -17
- package/references/agent-workspace/src/writers/markdown.ts +0 -27
- package/references/agent-workspace/src/writers/raw.ts +0 -22
- package/references/agent-workspace/tests/errors.test.ts +0 -652
- package/references/agent-workspace/tests/handle.test.ts +0 -144
- package/references/agent-workspace/tests/manager.test.ts +0 -124
- package/references/agent-workspace/tests/readers.test.ts +0 -205
- package/references/agent-workspace/tests/validation.test.ts +0 -196
- package/references/agent-workspace/tests/writers.test.ts +0 -108
- package/references/agent-workspace/tsconfig.json +0 -20
- package/references/agent-workspace/tsup.config.ts +0 -9
- package/references/minimem/.claude/settings.json +0 -7
- package/references/minimem/.sudocode/issues.jsonl +0 -18
- package/references/minimem/.sudocode/specs.jsonl +0 -1
- package/references/minimem/CLAUDE.md +0 -310
- package/references/minimem/README.md +0 -556
- package/references/minimem/claude-plugin/.claude-plugin/plugin.json +0 -10
- package/references/minimem/claude-plugin/.mcp.json +0 -7
- package/references/minimem/claude-plugin/README.md +0 -158
- package/references/minimem/claude-plugin/commands/recall.md +0 -47
- package/references/minimem/claude-plugin/commands/remember.md +0 -41
- package/references/minimem/claude-plugin/hooks/__tests__/hooks.test.ts +0 -272
- package/references/minimem/claude-plugin/hooks/hooks.json +0 -27
- package/references/minimem/claude-plugin/hooks/session-end.sh +0 -86
- package/references/minimem/claude-plugin/hooks/session-start.sh +0 -85
- package/references/minimem/claude-plugin/skills/memory/SKILL.md +0 -108
- package/references/minimem/package-lock.json +0 -5373
- package/references/minimem/package.json +0 -60
- package/references/minimem/scripts/postbuild.js +0 -35
- package/references/minimem/src/__tests__/edge-cases.test.ts +0 -371
- package/references/minimem/src/__tests__/errors.test.ts +0 -265
- package/references/minimem/src/__tests__/helpers.ts +0 -199
- package/references/minimem/src/__tests__/internal.test.ts +0 -407
- package/references/minimem/src/__tests__/knowledge.test.ts +0 -287
- package/references/minimem/src/__tests__/minimem.integration.test.ts +0 -1127
- package/references/minimem/src/__tests__/session.test.ts +0 -190
- package/references/minimem/src/cli/__tests__/commands.test.ts +0 -759
- package/references/minimem/src/cli/commands/__tests__/conflicts.test.ts +0 -141
- package/references/minimem/src/cli/commands/append.ts +0 -76
- package/references/minimem/src/cli/commands/config.ts +0 -262
- package/references/minimem/src/cli/commands/conflicts.ts +0 -413
- package/references/minimem/src/cli/commands/daemon.ts +0 -169
- package/references/minimem/src/cli/commands/index.ts +0 -12
- package/references/minimem/src/cli/commands/init.ts +0 -88
- package/references/minimem/src/cli/commands/mcp.ts +0 -177
- package/references/minimem/src/cli/commands/push-pull.ts +0 -213
- package/references/minimem/src/cli/commands/search.ts +0 -158
- package/references/minimem/src/cli/commands/status.ts +0 -84
- package/references/minimem/src/cli/commands/sync-init.ts +0 -290
- package/references/minimem/src/cli/commands/sync.ts +0 -70
- package/references/minimem/src/cli/commands/upsert.ts +0 -197
- package/references/minimem/src/cli/config.ts +0 -584
- package/references/minimem/src/cli/index.ts +0 -264
- package/references/minimem/src/cli/shared.ts +0 -161
- package/references/minimem/src/cli/sync/__tests__/central.test.ts +0 -152
- package/references/minimem/src/cli/sync/__tests__/conflicts.test.ts +0 -209
- package/references/minimem/src/cli/sync/__tests__/daemon.test.ts +0 -118
- package/references/minimem/src/cli/sync/__tests__/detection.test.ts +0 -207
- package/references/minimem/src/cli/sync/__tests__/integration.test.ts +0 -476
- package/references/minimem/src/cli/sync/__tests__/registry.test.ts +0 -363
- package/references/minimem/src/cli/sync/__tests__/state.test.ts +0 -255
- package/references/minimem/src/cli/sync/__tests__/validation.test.ts +0 -193
- package/references/minimem/src/cli/sync/__tests__/watcher.test.ts +0 -178
- package/references/minimem/src/cli/sync/central.ts +0 -292
- package/references/minimem/src/cli/sync/conflicts.ts +0 -204
- package/references/minimem/src/cli/sync/daemon.ts +0 -407
- package/references/minimem/src/cli/sync/detection.ts +0 -138
- package/references/minimem/src/cli/sync/index.ts +0 -107
- package/references/minimem/src/cli/sync/operations.ts +0 -373
- package/references/minimem/src/cli/sync/registry.ts +0 -279
- package/references/minimem/src/cli/sync/state.ts +0 -355
- package/references/minimem/src/cli/sync/validation.ts +0 -206
- package/references/minimem/src/cli/sync/watcher.ts +0 -234
- package/references/minimem/src/cli/version.ts +0 -34
- package/references/minimem/src/core/index.ts +0 -9
- package/references/minimem/src/core/indexer.ts +0 -628
- package/references/minimem/src/core/searcher.ts +0 -221
- package/references/minimem/src/db/schema.ts +0 -183
- package/references/minimem/src/db/sqlite-vec.ts +0 -24
- package/references/minimem/src/embeddings/__tests__/embeddings.test.ts +0 -431
- package/references/minimem/src/embeddings/batch-gemini.ts +0 -392
- package/references/minimem/src/embeddings/batch-openai.ts +0 -409
- package/references/minimem/src/embeddings/embeddings.ts +0 -434
- package/references/minimem/src/index.ts +0 -109
- package/references/minimem/src/internal.ts +0 -299
- package/references/minimem/src/minimem.ts +0 -1276
- package/references/minimem/src/search/__tests__/hybrid.test.ts +0 -247
- package/references/minimem/src/search/graph.ts +0 -234
- package/references/minimem/src/search/hybrid.ts +0 -151
- package/references/minimem/src/search/search.ts +0 -256
- package/references/minimem/src/server/__tests__/mcp.test.ts +0 -341
- package/references/minimem/src/server/__tests__/tools.test.ts +0 -364
- package/references/minimem/src/server/mcp.ts +0 -326
- package/references/minimem/src/server/tools.ts +0 -720
- package/references/minimem/src/session.ts +0 -460
- package/references/minimem/tsconfig.json +0 -19
- package/references/minimem/tsup.config.ts +0 -26
- package/references/minimem/vitest.config.ts +0 -24
- package/references/sessionlog/.husky/pre-commit +0 -1
- package/references/sessionlog/.lintstagedrc.json +0 -4
- package/references/sessionlog/.prettierignore +0 -4
- package/references/sessionlog/.prettierrc.json +0 -11
- package/references/sessionlog/LICENSE +0 -21
- package/references/sessionlog/README.md +0 -453
- package/references/sessionlog/eslint.config.js +0 -58
- package/references/sessionlog/package-lock.json +0 -3672
- package/references/sessionlog/package.json +0 -65
- package/references/sessionlog/src/__tests__/agent-hooks.test.ts +0 -570
- package/references/sessionlog/src/__tests__/agent-registry.test.ts +0 -127
- package/references/sessionlog/src/__tests__/claude-code-hooks.test.ts +0 -225
- package/references/sessionlog/src/__tests__/claude-generator.test.ts +0 -46
- package/references/sessionlog/src/__tests__/commit-msg.test.ts +0 -86
- package/references/sessionlog/src/__tests__/cursor-agent.test.ts +0 -224
- package/references/sessionlog/src/__tests__/e2e-live.test.ts +0 -890
- package/references/sessionlog/src/__tests__/event-log.test.ts +0 -183
- package/references/sessionlog/src/__tests__/flush-sentinel.test.ts +0 -105
- package/references/sessionlog/src/__tests__/gemini-agent.test.ts +0 -375
- package/references/sessionlog/src/__tests__/git-hooks.test.ts +0 -78
- package/references/sessionlog/src/__tests__/hook-managers.test.ts +0 -121
- package/references/sessionlog/src/__tests__/lifecycle-tasks.test.ts +0 -759
- package/references/sessionlog/src/__tests__/opencode-agent.test.ts +0 -338
- package/references/sessionlog/src/__tests__/redaction.test.ts +0 -136
- package/references/sessionlog/src/__tests__/session-repo.test.ts +0 -353
- package/references/sessionlog/src/__tests__/session-store.test.ts +0 -166
- package/references/sessionlog/src/__tests__/setup-ccweb.test.ts +0 -466
- package/references/sessionlog/src/__tests__/skill-live.test.ts +0 -461
- package/references/sessionlog/src/__tests__/summarize.test.ts +0 -348
- package/references/sessionlog/src/__tests__/task-plan-e2e.test.ts +0 -610
- package/references/sessionlog/src/__tests__/task-plan-live.test.ts +0 -632
- package/references/sessionlog/src/__tests__/transcript-timestamp.test.ts +0 -121
- package/references/sessionlog/src/__tests__/types.test.ts +0 -166
- package/references/sessionlog/src/__tests__/utils.test.ts +0 -333
- package/references/sessionlog/src/__tests__/validation.test.ts +0 -103
- package/references/sessionlog/src/__tests__/worktree.test.ts +0 -57
- package/references/sessionlog/src/agent/agents/claude-code.ts +0 -1089
- package/references/sessionlog/src/agent/agents/cursor.ts +0 -361
- package/references/sessionlog/src/agent/agents/gemini-cli.ts +0 -632
- package/references/sessionlog/src/agent/agents/opencode.ts +0 -540
- package/references/sessionlog/src/agent/registry.ts +0 -143
- package/references/sessionlog/src/agent/session-types.ts +0 -113
- package/references/sessionlog/src/agent/types.ts +0 -220
- package/references/sessionlog/src/cli.ts +0 -597
- package/references/sessionlog/src/commands/clean.ts +0 -133
- package/references/sessionlog/src/commands/disable.ts +0 -84
- package/references/sessionlog/src/commands/doctor.ts +0 -145
- package/references/sessionlog/src/commands/enable.ts +0 -202
- package/references/sessionlog/src/commands/explain.ts +0 -261
- package/references/sessionlog/src/commands/reset.ts +0 -105
- package/references/sessionlog/src/commands/resume.ts +0 -180
- package/references/sessionlog/src/commands/rewind.ts +0 -195
- package/references/sessionlog/src/commands/setup-ccweb.ts +0 -275
- package/references/sessionlog/src/commands/status.ts +0 -172
- package/references/sessionlog/src/config.ts +0 -165
- package/references/sessionlog/src/events/event-log.ts +0 -126
- package/references/sessionlog/src/git-operations.ts +0 -558
- package/references/sessionlog/src/hooks/git-hooks.ts +0 -165
- package/references/sessionlog/src/hooks/lifecycle.ts +0 -391
- package/references/sessionlog/src/index.ts +0 -650
- package/references/sessionlog/src/security/redaction.ts +0 -283
- package/references/sessionlog/src/session/state-machine.ts +0 -452
- package/references/sessionlog/src/store/checkpoint-store.ts +0 -509
- package/references/sessionlog/src/store/native-store.ts +0 -173
- package/references/sessionlog/src/store/provider-types.ts +0 -99
- package/references/sessionlog/src/store/session-store.ts +0 -266
- package/references/sessionlog/src/strategy/attribution.ts +0 -296
- package/references/sessionlog/src/strategy/common.ts +0 -207
- package/references/sessionlog/src/strategy/content-overlap.ts +0 -228
- package/references/sessionlog/src/strategy/manual-commit.ts +0 -988
- package/references/sessionlog/src/strategy/types.ts +0 -279
- package/references/sessionlog/src/summarize/claude-generator.ts +0 -115
- package/references/sessionlog/src/summarize/summarize.ts +0 -432
- package/references/sessionlog/src/types.ts +0 -508
- package/references/sessionlog/src/utils/chunk-files.ts +0 -49
- package/references/sessionlog/src/utils/commit-message.ts +0 -65
- package/references/sessionlog/src/utils/detect-agent.ts +0 -36
- package/references/sessionlog/src/utils/hook-managers.ts +0 -125
- package/references/sessionlog/src/utils/ide-tags.ts +0 -32
- package/references/sessionlog/src/utils/paths.ts +0 -79
- package/references/sessionlog/src/utils/preview-rewind.ts +0 -80
- package/references/sessionlog/src/utils/rewind-conflict.ts +0 -121
- package/references/sessionlog/src/utils/shadow-branch.ts +0 -109
- package/references/sessionlog/src/utils/string-utils.ts +0 -46
- package/references/sessionlog/src/utils/todo-extract.ts +0 -188
- package/references/sessionlog/src/utils/trailers.ts +0 -187
- package/references/sessionlog/src/utils/transcript-parse.ts +0 -177
- package/references/sessionlog/src/utils/transcript-timestamp.ts +0 -59
- package/references/sessionlog/src/utils/tree-ops.ts +0 -219
- package/references/sessionlog/src/utils/tty.ts +0 -72
- package/references/sessionlog/src/utils/validation.ts +0 -65
- package/references/sessionlog/src/utils/worktree.ts +0 -58
- package/references/sessionlog/src/wire-types.ts +0 -59
- package/references/sessionlog/templates/setup-env.sh +0 -153
- package/references/sessionlog/tsconfig.json +0 -18
- package/references/sessionlog/vitest.config.ts +0 -12
- package/references/skill-tree/.claude/settings.json +0 -6
- package/references/skill-tree/.sudocode/issues.jsonl +0 -19
- package/references/skill-tree/.sudocode/specs.jsonl +0 -3
- package/references/skill-tree/CLAUDE.md +0 -126
- package/references/skill-tree/README.md +0 -372
- package/references/skill-tree/docs/GAPS_v1.md +0 -221
- package/references/skill-tree/docs/INTEGRATION_PLAN.md +0 -467
- package/references/skill-tree/docs/TODOS.md +0 -91
- package/references/skill-tree/docs/anthropic_skill_guide.md +0 -1364
- package/references/skill-tree/docs/design/federated-skill-trees.md +0 -524
- package/references/skill-tree/docs/design/multi-agent-sync.md +0 -759
- package/references/skill-tree/docs/scraper/BRAINSTORM.md +0 -583
- package/references/skill-tree/docs/scraper/POC_PLAN.md +0 -420
- package/references/skill-tree/docs/scraper/README.md +0 -170
- package/references/skill-tree/examples/basic-usage.ts +0 -164
- package/references/skill-tree/package-lock.json +0 -1852
- package/references/skill-tree/package.json +0 -66
- package/references/skill-tree/scraper/README.md +0 -123
- package/references/skill-tree/scraper/docs/DESIGN.md +0 -683
- package/references/skill-tree/scraper/docs/PLAN.md +0 -336
- package/references/skill-tree/scraper/drizzle.config.ts +0 -10
- package/references/skill-tree/scraper/package-lock.json +0 -6329
- package/references/skill-tree/scraper/package.json +0 -68
- package/references/skill-tree/scraper/test/fixtures/invalid-skill/missing-description.md +0 -7
- package/references/skill-tree/scraper/test/fixtures/invalid-skill/missing-name.md +0 -7
- package/references/skill-tree/scraper/test/fixtures/minimal-skill/SKILL.md +0 -27
- package/references/skill-tree/scraper/test/fixtures/skill-json/SKILL.json +0 -21
- package/references/skill-tree/scraper/test/fixtures/skill-with-meta/SKILL.md +0 -54
- package/references/skill-tree/scraper/test/fixtures/skill-with-meta/_meta.json +0 -24
- package/references/skill-tree/scraper/test/fixtures/valid-skill/SKILL.md +0 -93
- package/references/skill-tree/scraper/test/fixtures/valid-skill/_meta.json +0 -22
- package/references/skill-tree/scraper/tsup.config.ts +0 -14
- package/references/skill-tree/scraper/vitest.config.ts +0 -17
- package/references/skill-tree/scripts/convert-to-vitest.ts +0 -166
- package/references/skill-tree/skills/skill-writer/SKILL.md +0 -339
- package/references/skill-tree/skills/skill-writer/references/examples.md +0 -326
- package/references/skill-tree/skills/skill-writer/references/patterns.md +0 -210
- package/references/skill-tree/skills/skill-writer/references/quality-checklist.md +0 -123
- package/references/skill-tree/test/run-all.ts +0 -106
- package/references/skill-tree/test/utils.ts +0 -128
- package/references/skill-tree/vitest.config.ts +0 -16
|
@@ -1,413 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* minimem sync:conflicts - Conflict management commands
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import fs from "node:fs/promises";
|
|
6
|
-
import path from "node:path";
|
|
7
|
-
import { spawn } from "node:child_process";
|
|
8
|
-
|
|
9
|
-
import {
|
|
10
|
-
resolveMemoryDir,
|
|
11
|
-
isInitialized,
|
|
12
|
-
formatPath,
|
|
13
|
-
getSyncConfig,
|
|
14
|
-
exitWithError,
|
|
15
|
-
warn,
|
|
16
|
-
} from "../config.js";
|
|
17
|
-
import {
|
|
18
|
-
listQuarantinedConflicts,
|
|
19
|
-
getConflictsDir,
|
|
20
|
-
getShadowsDir,
|
|
21
|
-
} from "../sync/conflicts.js";
|
|
22
|
-
import { getSyncStatePath, loadSyncState } from "../sync/state.js";
|
|
23
|
-
|
|
24
|
-
export type ConflictsOptions = {
|
|
25
|
-
dir?: string;
|
|
26
|
-
global?: boolean;
|
|
27
|
-
json?: boolean;
|
|
28
|
-
};
|
|
29
|
-
|
|
30
|
-
/**
|
|
31
|
-
* List all quarantined conflicts
|
|
32
|
-
*/
|
|
33
|
-
export async function conflictsCommand(options: ConflictsOptions): Promise<void> {
|
|
34
|
-
const memoryDir = resolveMemoryDir({
|
|
35
|
-
dir: options.dir,
|
|
36
|
-
global: options.global,
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
if (!(await isInitialized(memoryDir))) {
|
|
40
|
-
exitWithError(`${formatPath(memoryDir)} is not initialized.`);
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
try {
|
|
44
|
-
const conflicts = await listQuarantinedConflicts(memoryDir);
|
|
45
|
-
|
|
46
|
-
if (options.json) {
|
|
47
|
-
console.log(JSON.stringify(conflicts, null, 2));
|
|
48
|
-
return;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
if (conflicts.length === 0) {
|
|
52
|
-
console.log("No quarantined conflicts.");
|
|
53
|
-
return;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
console.log(`Quarantined conflicts in ${formatPath(memoryDir)}`);
|
|
57
|
-
console.log("-".repeat(50));
|
|
58
|
-
|
|
59
|
-
for (const conflict of conflicts) {
|
|
60
|
-
console.log(`\n${conflict.timestamp}:`);
|
|
61
|
-
for (const file of conflict.files) {
|
|
62
|
-
console.log(` - ${file}`);
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
console.log(`\nTotal: ${conflicts.length} conflict set(s)`);
|
|
67
|
-
console.log("\nUse 'minimem sync:resolve <timestamp>' to resolve a conflict.");
|
|
68
|
-
} catch (error) {
|
|
69
|
-
const message = error instanceof Error ? error.message : String(error);
|
|
70
|
-
exitWithError(message);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
export type ResolveOptions = {
|
|
75
|
-
dir?: string;
|
|
76
|
-
global?: boolean;
|
|
77
|
-
tool?: string;
|
|
78
|
-
};
|
|
79
|
-
|
|
80
|
-
/**
|
|
81
|
-
* Resolve a quarantined conflict
|
|
82
|
-
*/
|
|
83
|
-
export async function resolveCommand(
|
|
84
|
-
timestamp: string,
|
|
85
|
-
options: ResolveOptions
|
|
86
|
-
): Promise<void> {
|
|
87
|
-
const memoryDir = resolveMemoryDir({
|
|
88
|
-
dir: options.dir,
|
|
89
|
-
global: options.global,
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
if (!(await isInitialized(memoryDir))) {
|
|
93
|
-
exitWithError(`${formatPath(memoryDir)} is not initialized.`);
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
const conflictDir = path.join(getConflictsDir(memoryDir), timestamp);
|
|
97
|
-
|
|
98
|
-
try {
|
|
99
|
-
await fs.access(conflictDir);
|
|
100
|
-
} catch {
|
|
101
|
-
exitWithError(
|
|
102
|
-
`Conflict '${timestamp}' not found.`,
|
|
103
|
-
"Use 'minimem sync:conflicts' to list available conflicts."
|
|
104
|
-
);
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
try {
|
|
108
|
-
const files = await fs.readdir(conflictDir);
|
|
109
|
-
|
|
110
|
-
// Group files by base name
|
|
111
|
-
const fileGroups = new Map<string, { local?: string; remote?: string; base?: string }>();
|
|
112
|
-
for (const file of files) {
|
|
113
|
-
const match = file.match(/^(.+)\.(local|remote|base)$/);
|
|
114
|
-
if (match) {
|
|
115
|
-
const [, baseName, type] = match;
|
|
116
|
-
if (!fileGroups.has(baseName)) {
|
|
117
|
-
fileGroups.set(baseName, {});
|
|
118
|
-
}
|
|
119
|
-
const group = fileGroups.get(baseName)!;
|
|
120
|
-
group[type as "local" | "remote" | "base"] = path.join(conflictDir, file);
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
if (fileGroups.size === 0) {
|
|
125
|
-
exitWithError("No conflict files found in this directory.");
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
// Determine merge tool
|
|
129
|
-
const mergeTool = options.tool || process.env.MERGE_TOOL || await detectMergeTool();
|
|
130
|
-
|
|
131
|
-
if (!mergeTool) {
|
|
132
|
-
console.log("No merge tool detected. Available conflict files:");
|
|
133
|
-
for (const [baseName, group] of fileGroups) {
|
|
134
|
-
console.log(`\n${baseName.replace(/_/g, "/")}:`);
|
|
135
|
-
if (group.local) console.log(` Local: ${group.local}`);
|
|
136
|
-
if (group.remote) console.log(` Remote: ${group.remote}`);
|
|
137
|
-
if (group.base) console.log(` Base: ${group.base}`);
|
|
138
|
-
}
|
|
139
|
-
console.log("\nManually edit the files or set MERGE_TOOL environment variable.");
|
|
140
|
-
return;
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
console.log(`Using merge tool: ${mergeTool}`);
|
|
144
|
-
|
|
145
|
-
for (const [baseName, group] of fileGroups) {
|
|
146
|
-
const fileName = baseName.replace(/_/g, "/");
|
|
147
|
-
console.log(`\nResolving: ${fileName}`);
|
|
148
|
-
|
|
149
|
-
if (group.local && group.remote) {
|
|
150
|
-
// Launch merge tool
|
|
151
|
-
const args = group.base
|
|
152
|
-
? [group.local, group.base, group.remote]
|
|
153
|
-
: [group.local, group.remote];
|
|
154
|
-
|
|
155
|
-
const child = spawn(mergeTool, args, { stdio: "inherit" });
|
|
156
|
-
|
|
157
|
-
await new Promise<void>((resolve, reject) => {
|
|
158
|
-
child.on("close", (code) => {
|
|
159
|
-
if (code === 0) {
|
|
160
|
-
resolve();
|
|
161
|
-
} else {
|
|
162
|
-
reject(new Error(`Merge tool exited with code ${code}`));
|
|
163
|
-
}
|
|
164
|
-
});
|
|
165
|
-
child.on("error", reject);
|
|
166
|
-
});
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
console.log("\nMerge complete. Remove conflict directory when satisfied:");
|
|
171
|
-
console.log(` rm -rf "${conflictDir}"`);
|
|
172
|
-
} catch (error) {
|
|
173
|
-
const message = error instanceof Error ? error.message : String(error);
|
|
174
|
-
exitWithError(message);
|
|
175
|
-
}
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
/**
|
|
179
|
-
* Detect available merge tool
|
|
180
|
-
*/
|
|
181
|
-
async function detectMergeTool(): Promise<string | null> {
|
|
182
|
-
const tools = ["code", "meld", "kdiff3", "vimdiff", "opendiff"];
|
|
183
|
-
|
|
184
|
-
for (const tool of tools) {
|
|
185
|
-
try {
|
|
186
|
-
const { execSync } = await import("node:child_process");
|
|
187
|
-
execSync(`which ${tool}`, { stdio: "ignore" });
|
|
188
|
-
return tool;
|
|
189
|
-
} catch {
|
|
190
|
-
continue;
|
|
191
|
-
}
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
return null;
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
export type CleanupOptions = {
|
|
198
|
-
dir?: string;
|
|
199
|
-
global?: boolean;
|
|
200
|
-
days?: number;
|
|
201
|
-
dryRun?: boolean;
|
|
202
|
-
};
|
|
203
|
-
|
|
204
|
-
/**
|
|
205
|
-
* Clean up old quarantined conflicts
|
|
206
|
-
*/
|
|
207
|
-
export async function cleanupCommand(options: CleanupOptions): Promise<void> {
|
|
208
|
-
const memoryDir = resolveMemoryDir({
|
|
209
|
-
dir: options.dir,
|
|
210
|
-
global: options.global,
|
|
211
|
-
});
|
|
212
|
-
|
|
213
|
-
if (!(await isInitialized(memoryDir))) {
|
|
214
|
-
exitWithError(`${formatPath(memoryDir)} is not initialized.`);
|
|
215
|
-
}
|
|
216
|
-
|
|
217
|
-
const maxAgeDays = options.days ?? 30;
|
|
218
|
-
const cutoffDate = new Date(Date.now() - maxAgeDays * 24 * 60 * 60 * 1000);
|
|
219
|
-
|
|
220
|
-
try {
|
|
221
|
-
const conflictsDir = getConflictsDir(memoryDir);
|
|
222
|
-
let entries: string[] = [];
|
|
223
|
-
|
|
224
|
-
try {
|
|
225
|
-
entries = await fs.readdir(conflictsDir);
|
|
226
|
-
} catch {
|
|
227
|
-
console.log("No conflicts directory found.");
|
|
228
|
-
return;
|
|
229
|
-
}
|
|
230
|
-
|
|
231
|
-
let cleaned = 0;
|
|
232
|
-
let kept = 0;
|
|
233
|
-
|
|
234
|
-
for (const entry of entries) {
|
|
235
|
-
// Timestamps are in ISO format with : and . replaced with -
|
|
236
|
-
// e.g., 2026-02-03T07-20-56-704Z
|
|
237
|
-
const timestamp = entry.replace(/-(\d{2})-(\d{2})-(\d{3})Z$/, ":$1:$2.$3Z");
|
|
238
|
-
const entryDate = new Date(timestamp);
|
|
239
|
-
|
|
240
|
-
if (isNaN(entryDate.getTime())) {
|
|
241
|
-
console.log(` Skipping invalid timestamp: ${entry}`);
|
|
242
|
-
continue;
|
|
243
|
-
}
|
|
244
|
-
|
|
245
|
-
const entryPath = path.join(conflictsDir, entry);
|
|
246
|
-
|
|
247
|
-
if (entryDate < cutoffDate) {
|
|
248
|
-
if (options.dryRun) {
|
|
249
|
-
console.log(` Would remove: ${entry}`);
|
|
250
|
-
} else {
|
|
251
|
-
await fs.rm(entryPath, { recursive: true, force: true });
|
|
252
|
-
console.log(` Removed: ${entry}`);
|
|
253
|
-
}
|
|
254
|
-
cleaned++;
|
|
255
|
-
} else {
|
|
256
|
-
kept++;
|
|
257
|
-
}
|
|
258
|
-
}
|
|
259
|
-
|
|
260
|
-
if (options.dryRun) {
|
|
261
|
-
console.log(`\nWould remove ${cleaned} conflict(s), keep ${kept}`);
|
|
262
|
-
} else {
|
|
263
|
-
console.log(`\nRemoved ${cleaned} conflict(s), kept ${kept}`);
|
|
264
|
-
}
|
|
265
|
-
} catch (error) {
|
|
266
|
-
const message = error instanceof Error ? error.message : String(error);
|
|
267
|
-
exitWithError(message);
|
|
268
|
-
}
|
|
269
|
-
}
|
|
270
|
-
|
|
271
|
-
/**
|
|
272
|
-
* Sync logging
|
|
273
|
-
*/
|
|
274
|
-
const SYNC_LOG_FILE = "sync.log";
|
|
275
|
-
const MAX_LOG_ENTRIES = 1000;
|
|
276
|
-
|
|
277
|
-
export type SyncLogEntry = {
|
|
278
|
-
timestamp: string;
|
|
279
|
-
operation: "push" | "pull" | "sync";
|
|
280
|
-
result: "success" | "partial" | "failure";
|
|
281
|
-
pushed?: number;
|
|
282
|
-
pulled?: number;
|
|
283
|
-
conflicts?: number;
|
|
284
|
-
errors?: string[];
|
|
285
|
-
};
|
|
286
|
-
|
|
287
|
-
/**
|
|
288
|
-
* Get sync log path
|
|
289
|
-
*/
|
|
290
|
-
export function getSyncLogPath(memoryDir: string): string {
|
|
291
|
-
return path.join(memoryDir, ".minimem", SYNC_LOG_FILE);
|
|
292
|
-
}
|
|
293
|
-
|
|
294
|
-
/**
|
|
295
|
-
* Append to sync log
|
|
296
|
-
*/
|
|
297
|
-
export async function appendSyncLog(
|
|
298
|
-
memoryDir: string,
|
|
299
|
-
entry: SyncLogEntry
|
|
300
|
-
): Promise<void> {
|
|
301
|
-
const logPath = getSyncLogPath(memoryDir);
|
|
302
|
-
|
|
303
|
-
try {
|
|
304
|
-
await fs.mkdir(path.dirname(logPath), { recursive: true });
|
|
305
|
-
|
|
306
|
-
// Read existing log
|
|
307
|
-
let entries: SyncLogEntry[] = [];
|
|
308
|
-
try {
|
|
309
|
-
const content = await fs.readFile(logPath, "utf-8");
|
|
310
|
-
entries = content
|
|
311
|
-
.split("\n")
|
|
312
|
-
.filter(Boolean)
|
|
313
|
-
.map((line) => JSON.parse(line));
|
|
314
|
-
} catch {
|
|
315
|
-
// No existing log
|
|
316
|
-
}
|
|
317
|
-
|
|
318
|
-
// Add new entry and trim if needed
|
|
319
|
-
entries.push(entry);
|
|
320
|
-
if (entries.length > MAX_LOG_ENTRIES) {
|
|
321
|
-
entries = entries.slice(-MAX_LOG_ENTRIES);
|
|
322
|
-
}
|
|
323
|
-
|
|
324
|
-
// Write back
|
|
325
|
-
const content = entries.map((e) => JSON.stringify(e)).join("\n") + "\n";
|
|
326
|
-
await fs.writeFile(logPath, content);
|
|
327
|
-
} catch (error) {
|
|
328
|
-
// Log failures are non-fatal
|
|
329
|
-
const message = error instanceof Error ? error.message : String(error);
|
|
330
|
-
warn(`Failed to write sync log: ${message}`);
|
|
331
|
-
}
|
|
332
|
-
}
|
|
333
|
-
|
|
334
|
-
/**
|
|
335
|
-
* Read sync log
|
|
336
|
-
*/
|
|
337
|
-
export async function readSyncLog(memoryDir: string): Promise<SyncLogEntry[]> {
|
|
338
|
-
const logPath = getSyncLogPath(memoryDir);
|
|
339
|
-
|
|
340
|
-
try {
|
|
341
|
-
const content = await fs.readFile(logPath, "utf-8");
|
|
342
|
-
return content
|
|
343
|
-
.split("\n")
|
|
344
|
-
.filter(Boolean)
|
|
345
|
-
.map((line) => JSON.parse(line));
|
|
346
|
-
} catch {
|
|
347
|
-
return [];
|
|
348
|
-
}
|
|
349
|
-
}
|
|
350
|
-
|
|
351
|
-
export type LogOptions = {
|
|
352
|
-
dir?: string;
|
|
353
|
-
global?: boolean;
|
|
354
|
-
limit?: number;
|
|
355
|
-
json?: boolean;
|
|
356
|
-
};
|
|
357
|
-
|
|
358
|
-
/**
|
|
359
|
-
* Show sync log
|
|
360
|
-
*/
|
|
361
|
-
export async function logCommand(options: LogOptions): Promise<void> {
|
|
362
|
-
const memoryDir = resolveMemoryDir({
|
|
363
|
-
dir: options.dir,
|
|
364
|
-
global: options.global,
|
|
365
|
-
});
|
|
366
|
-
|
|
367
|
-
if (!(await isInitialized(memoryDir))) {
|
|
368
|
-
exitWithError(`${formatPath(memoryDir)} is not initialized.`);
|
|
369
|
-
}
|
|
370
|
-
|
|
371
|
-
try {
|
|
372
|
-
let entries = await readSyncLog(memoryDir);
|
|
373
|
-
|
|
374
|
-
const limit = options.limit ?? 20;
|
|
375
|
-
entries = entries.slice(-limit);
|
|
376
|
-
|
|
377
|
-
if (options.json) {
|
|
378
|
-
console.log(JSON.stringify(entries, null, 2));
|
|
379
|
-
return;
|
|
380
|
-
}
|
|
381
|
-
|
|
382
|
-
if (entries.length === 0) {
|
|
383
|
-
console.log("No sync history.");
|
|
384
|
-
return;
|
|
385
|
-
}
|
|
386
|
-
|
|
387
|
-
console.log(`Sync history for ${formatPath(memoryDir)}`);
|
|
388
|
-
console.log("-".repeat(60));
|
|
389
|
-
|
|
390
|
-
for (const entry of entries) {
|
|
391
|
-
const time = new Date(entry.timestamp).toLocaleString();
|
|
392
|
-
const status =
|
|
393
|
-
entry.result === "success" ? "OK" :
|
|
394
|
-
entry.result === "partial" ? "PARTIAL" : "FAILED";
|
|
395
|
-
|
|
396
|
-
let details = "";
|
|
397
|
-
if (entry.pushed) details += ` +${entry.pushed}`;
|
|
398
|
-
if (entry.pulled) details += ` -${entry.pulled}`;
|
|
399
|
-
if (entry.conflicts) details += ` !${entry.conflicts}`;
|
|
400
|
-
|
|
401
|
-
console.log(`${time} ${entry.operation.padEnd(6)} ${status.padEnd(8)}${details}`);
|
|
402
|
-
|
|
403
|
-
if (entry.errors && entry.errors.length > 0) {
|
|
404
|
-
for (const error of entry.errors.slice(0, 3)) {
|
|
405
|
-
console.log(` Error: ${error}`);
|
|
406
|
-
}
|
|
407
|
-
}
|
|
408
|
-
}
|
|
409
|
-
} catch (error) {
|
|
410
|
-
const message = error instanceof Error ? error.message : String(error);
|
|
411
|
-
exitWithError(message);
|
|
412
|
-
}
|
|
413
|
-
}
|
|
@@ -1,169 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* minimem daemon - Background sync daemon commands
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import fs from "node:fs/promises";
|
|
6
|
-
|
|
7
|
-
import {
|
|
8
|
-
startDaemon,
|
|
9
|
-
startDaemonBackground,
|
|
10
|
-
stopDaemon,
|
|
11
|
-
getDaemonStatus,
|
|
12
|
-
isDaemonRunning,
|
|
13
|
-
getDaemonLogPath,
|
|
14
|
-
} from "../sync/daemon.js";
|
|
15
|
-
import { exitWithError } from "../config.js";
|
|
16
|
-
|
|
17
|
-
export type DaemonOptions = {
|
|
18
|
-
background?: boolean;
|
|
19
|
-
foreground?: boolean;
|
|
20
|
-
};
|
|
21
|
-
|
|
22
|
-
/**
|
|
23
|
-
* Start the daemon
|
|
24
|
-
*/
|
|
25
|
-
export async function daemonCommand(options: DaemonOptions): Promise<void> {
|
|
26
|
-
// If --foreground is specified, run in foreground (used by background spawn)
|
|
27
|
-
if (options.foreground) {
|
|
28
|
-
console.log("Starting daemon in foreground...");
|
|
29
|
-
try {
|
|
30
|
-
await startDaemon();
|
|
31
|
-
} catch (error) {
|
|
32
|
-
const message = error instanceof Error ? error.message : String(error);
|
|
33
|
-
exitWithError(`Daemon: ${message}`);
|
|
34
|
-
}
|
|
35
|
-
return;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
// Check if already running
|
|
39
|
-
if (await isDaemonRunning()) {
|
|
40
|
-
console.log("Daemon is already running.");
|
|
41
|
-
console.log("Use 'minimem daemon:stop' to stop it.");
|
|
42
|
-
return;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
if (options.background) {
|
|
46
|
-
console.log("Starting daemon in background...");
|
|
47
|
-
try {
|
|
48
|
-
const pid = await startDaemonBackground();
|
|
49
|
-
console.log(`Daemon started with PID ${pid}`);
|
|
50
|
-
console.log(`Log file: ${getDaemonLogPath()}`);
|
|
51
|
-
} catch (error) {
|
|
52
|
-
const message = error instanceof Error ? error.message : String(error);
|
|
53
|
-
exitWithError(`Failed to start daemon: ${message}`);
|
|
54
|
-
}
|
|
55
|
-
} else {
|
|
56
|
-
console.log("Starting daemon in foreground...");
|
|
57
|
-
console.log("Press Ctrl+C to stop.");
|
|
58
|
-
console.log("");
|
|
59
|
-
try {
|
|
60
|
-
await startDaemon();
|
|
61
|
-
} catch (error) {
|
|
62
|
-
const message = error instanceof Error ? error.message : String(error);
|
|
63
|
-
exitWithError(`Daemon: ${message}`);
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
/**
|
|
69
|
-
* Stop the daemon
|
|
70
|
-
*/
|
|
71
|
-
export async function daemonStopCommand(): Promise<void> {
|
|
72
|
-
const status = await getDaemonStatus();
|
|
73
|
-
|
|
74
|
-
if (!status.running) {
|
|
75
|
-
console.log("Daemon is not running.");
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
console.log(`Stopping daemon (PID ${status.pid})...`);
|
|
80
|
-
|
|
81
|
-
const stopped = await stopDaemon();
|
|
82
|
-
|
|
83
|
-
if (stopped) {
|
|
84
|
-
console.log("Daemon stopped.");
|
|
85
|
-
} else {
|
|
86
|
-
exitWithError("Failed to stop daemon.");
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
/**
|
|
91
|
-
* Show daemon status
|
|
92
|
-
*/
|
|
93
|
-
export async function daemonStatusCommand(): Promise<void> {
|
|
94
|
-
const status = await getDaemonStatus();
|
|
95
|
-
|
|
96
|
-
if (status.running) {
|
|
97
|
-
console.log("Daemon status: running");
|
|
98
|
-
console.log(` PID: ${status.pid}`);
|
|
99
|
-
console.log(` Log: ${getDaemonLogPath()}`);
|
|
100
|
-
} else {
|
|
101
|
-
console.log("Daemon status: stopped");
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
export type LogOptions = {
|
|
106
|
-
lines?: number;
|
|
107
|
-
follow?: boolean;
|
|
108
|
-
};
|
|
109
|
-
|
|
110
|
-
/**
|
|
111
|
-
* Show daemon logs
|
|
112
|
-
*/
|
|
113
|
-
export async function daemonLogsCommand(options: LogOptions): Promise<void> {
|
|
114
|
-
const logPath = getDaemonLogPath();
|
|
115
|
-
|
|
116
|
-
try {
|
|
117
|
-
const content = await fs.readFile(logPath, "utf-8");
|
|
118
|
-
const lines = content.split("\n").filter(Boolean);
|
|
119
|
-
|
|
120
|
-
const numLines = options.lines ?? 50;
|
|
121
|
-
const displayLines = lines.slice(-numLines);
|
|
122
|
-
|
|
123
|
-
for (const line of displayLines) {
|
|
124
|
-
console.log(line);
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
if (options.follow) {
|
|
128
|
-
console.log("\n--- Following log (Ctrl+C to stop) ---\n");
|
|
129
|
-
|
|
130
|
-
// Simple follow implementation using polling
|
|
131
|
-
let lastSize = (await fs.stat(logPath)).size;
|
|
132
|
-
|
|
133
|
-
const poll = async () => {
|
|
134
|
-
try {
|
|
135
|
-
const stats = await fs.stat(logPath);
|
|
136
|
-
if (stats.size > lastSize) {
|
|
137
|
-
const fd = await fs.open(logPath, "r");
|
|
138
|
-
const buffer = Buffer.alloc(stats.size - lastSize);
|
|
139
|
-
await fd.read(buffer, 0, buffer.length, lastSize);
|
|
140
|
-
await fd.close();
|
|
141
|
-
|
|
142
|
-
process.stdout.write(buffer.toString());
|
|
143
|
-
lastSize = stats.size;
|
|
144
|
-
}
|
|
145
|
-
} catch {
|
|
146
|
-
// File may have been rotated
|
|
147
|
-
lastSize = 0;
|
|
148
|
-
}
|
|
149
|
-
};
|
|
150
|
-
|
|
151
|
-
const interval = setInterval(poll, 1000);
|
|
152
|
-
|
|
153
|
-
process.on("SIGINT", () => {
|
|
154
|
-
clearInterval(interval);
|
|
155
|
-
process.exit(0);
|
|
156
|
-
});
|
|
157
|
-
|
|
158
|
-
// Keep running
|
|
159
|
-
await new Promise(() => {});
|
|
160
|
-
}
|
|
161
|
-
} catch (error) {
|
|
162
|
-
if ((error as NodeJS.ErrnoException).code === "ENOENT") {
|
|
163
|
-
console.log("No daemon log found.");
|
|
164
|
-
} else {
|
|
165
|
-
const message = error instanceof Error ? error.message : String(error);
|
|
166
|
-
exitWithError(`Error reading log: ${message}`);
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* CLI Commands
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
export { init, type InitOptions } from "./init.js";
|
|
6
|
-
export { search, type SearchOptions } from "./search.js";
|
|
7
|
-
export { sync, type SyncOptions } from "./sync.js";
|
|
8
|
-
export { status, type StatusOptions } from "./status.js";
|
|
9
|
-
export { append, type AppendOptions } from "./append.js";
|
|
10
|
-
export { upsert, type UpsertOptions } from "./upsert.js";
|
|
11
|
-
export { mcp, type McpOptions } from "./mcp.js";
|
|
12
|
-
export { config, type ConfigOptions } from "./config.js";
|
|
@@ -1,88 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* minimem init - Initialize memory directory
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import fs from "node:fs/promises";
|
|
6
|
-
import path from "node:path";
|
|
7
|
-
|
|
8
|
-
import {
|
|
9
|
-
resolveMemoryDir,
|
|
10
|
-
saveConfig,
|
|
11
|
-
getInitConfig,
|
|
12
|
-
isInitialized,
|
|
13
|
-
formatPath,
|
|
14
|
-
} from "../config.js";
|
|
15
|
-
|
|
16
|
-
const MEMORY_TEMPLATE = `# Memory
|
|
17
|
-
|
|
18
|
-
This is your memory file. Add notes, decisions, and context here.
|
|
19
|
-
|
|
20
|
-
## Quick Start
|
|
21
|
-
|
|
22
|
-
- Add daily logs in the \`memory/\` directory (e.g., \`memory/2024-01-15.md\`)
|
|
23
|
-
- Use \`minimem search <query>\` to find relevant memories
|
|
24
|
-
- Use \`minimem append <text>\` to quickly add to today's log
|
|
25
|
-
|
|
26
|
-
## Notes
|
|
27
|
-
|
|
28
|
-
`;
|
|
29
|
-
|
|
30
|
-
export type InitOptions = {
|
|
31
|
-
global?: boolean;
|
|
32
|
-
force?: boolean;
|
|
33
|
-
};
|
|
34
|
-
|
|
35
|
-
export async function init(
|
|
36
|
-
dir: string | undefined,
|
|
37
|
-
options: InitOptions,
|
|
38
|
-
): Promise<void> {
|
|
39
|
-
const memoryDir = resolveMemoryDir({ dir, global: options.global });
|
|
40
|
-
const displayPath = formatPath(memoryDir);
|
|
41
|
-
|
|
42
|
-
// Check if already initialized
|
|
43
|
-
if (!options.force && (await isInitialized(memoryDir))) {
|
|
44
|
-
console.log(`Already initialized: ${displayPath}`);
|
|
45
|
-
console.log("Use --force to reinitialize");
|
|
46
|
-
return;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
console.log(`Initializing minimem in ${displayPath}...`);
|
|
50
|
-
|
|
51
|
-
// Create directories
|
|
52
|
-
await fs.mkdir(memoryDir, { recursive: true });
|
|
53
|
-
await fs.mkdir(path.join(memoryDir, "memory"), { recursive: true });
|
|
54
|
-
await fs.mkdir(path.join(memoryDir, ".minimem"), { recursive: true });
|
|
55
|
-
|
|
56
|
-
// Create MEMORY.md if it doesn't exist
|
|
57
|
-
const memoryFilePath = path.join(memoryDir, "MEMORY.md");
|
|
58
|
-
try {
|
|
59
|
-
await fs.access(memoryFilePath);
|
|
60
|
-
console.log(" MEMORY.md already exists, skipping");
|
|
61
|
-
} catch {
|
|
62
|
-
await fs.writeFile(memoryFilePath, MEMORY_TEMPLATE, "utf-8");
|
|
63
|
-
console.log(" Created MEMORY.md");
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
// Create config
|
|
67
|
-
const config = getInitConfig();
|
|
68
|
-
await saveConfig(memoryDir, config);
|
|
69
|
-
console.log(" Created .minimem/config.json");
|
|
70
|
-
|
|
71
|
-
// Create .gitignore for .minimem directory
|
|
72
|
-
const gitignorePath = path.join(memoryDir, ".minimem", ".gitignore");
|
|
73
|
-
await fs.writeFile(gitignorePath, "index.db\nindex.db-*\n", "utf-8");
|
|
74
|
-
console.log(" Created .minimem/.gitignore");
|
|
75
|
-
|
|
76
|
-
console.log();
|
|
77
|
-
console.log("Done! Your memory directory is ready.");
|
|
78
|
-
console.log();
|
|
79
|
-
console.log("Next steps:");
|
|
80
|
-
console.log(` 1. Set your embedding API key:`);
|
|
81
|
-
console.log(` export OPENAI_API_KEY=your-key`);
|
|
82
|
-
console.log(` # or: export GOOGLE_API_KEY=your-key`);
|
|
83
|
-
console.log();
|
|
84
|
-
console.log(` 2. Add some memories to MEMORY.md or memory/*.md`);
|
|
85
|
-
console.log();
|
|
86
|
-
console.log(` 3. Search your memories:`);
|
|
87
|
-
console.log(` minimem search "your query"${dir ? ` --dir ${dir}` : ""}`);
|
|
88
|
-
}
|