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,54 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "agent-workspace",
|
|
3
|
-
"version": "0.1.3",
|
|
4
|
-
"description": "Filesystem workspace management for agents — directory structure, typed I/O, and validation",
|
|
5
|
-
"type": "module",
|
|
6
|
-
"main": "./dist/index.cjs",
|
|
7
|
-
"module": "./dist/index.js",
|
|
8
|
-
"types": "./dist/index.d.ts",
|
|
9
|
-
"exports": {
|
|
10
|
-
".": {
|
|
11
|
-
"import": {
|
|
12
|
-
"types": "./dist/index.d.ts",
|
|
13
|
-
"default": "./dist/index.js"
|
|
14
|
-
},
|
|
15
|
-
"require": {
|
|
16
|
-
"types": "./dist/index.d.cts",
|
|
17
|
-
"default": "./dist/index.cjs"
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
},
|
|
21
|
-
"files": [
|
|
22
|
-
"dist",
|
|
23
|
-
"README.md"
|
|
24
|
-
],
|
|
25
|
-
"scripts": {
|
|
26
|
-
"build": "tsup",
|
|
27
|
-
"test": "vitest run",
|
|
28
|
-
"test:watch": "vitest",
|
|
29
|
-
"typecheck": "tsc --noEmit",
|
|
30
|
-
"prepublishOnly": "npm run build",
|
|
31
|
-
"version:patch": "npm version patch && git push && git push --tags",
|
|
32
|
-
"version:minor": "npm version minor && git push && git push --tags",
|
|
33
|
-
"version:major": "npm version major && git push && git push --tags",
|
|
34
|
-
"publish:npm": "npm run build && npm publish"
|
|
35
|
-
},
|
|
36
|
-
"engines": {
|
|
37
|
-
"node": ">=18"
|
|
38
|
-
},
|
|
39
|
-
"repository": {
|
|
40
|
-
"type": "git",
|
|
41
|
-
"url": "https://github.com/alexngai/agent-workspace.git"
|
|
42
|
-
},
|
|
43
|
-
"license": "MIT",
|
|
44
|
-
"author": "Alex Ngai",
|
|
45
|
-
"dependencies": {
|
|
46
|
-
"yaml": "^2.7.0"
|
|
47
|
-
},
|
|
48
|
-
"devDependencies": {
|
|
49
|
-
"@types/node": "^20.11.0",
|
|
50
|
-
"tsup": "^8.0.0",
|
|
51
|
-
"typescript": "^5.3.0",
|
|
52
|
-
"vitest": "^3.0.0"
|
|
53
|
-
}
|
|
54
|
-
}
|
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
import * as path from 'path';
|
|
2
|
-
import { writeJson, writeJsonl } from './writers/json.js';
|
|
3
|
-
import { writeMarkdown } from './writers/markdown.js';
|
|
4
|
-
import { writeRaw, copyDir, symlink } from './writers/raw.js';
|
|
5
|
-
import { readJson, readJsonl, readJsonDir, type ReadJsonOptions } from './readers/json.js';
|
|
6
|
-
import { readMarkdown, type ReadMarkdownOptions } from './readers/markdown.js';
|
|
7
|
-
import { readRaw, listFiles } from './readers/raw.js';
|
|
8
|
-
import { validateOutput } from './validation.js';
|
|
9
|
-
import type { MarkdownDocument, OutputSpec, ValidationResult } from './types.js';
|
|
10
|
-
|
|
11
|
-
export class WorkspaceHandle {
|
|
12
|
-
readonly id: string;
|
|
13
|
-
readonly path: string;
|
|
14
|
-
readonly createdAt: Date;
|
|
15
|
-
private readonly dirs: string[];
|
|
16
|
-
|
|
17
|
-
constructor(id: string, workspacePath: string, dirs: string[], createdAt: Date) {
|
|
18
|
-
this.id = id;
|
|
19
|
-
this.path = workspacePath;
|
|
20
|
-
this.dirs = dirs;
|
|
21
|
-
this.createdAt = createdAt;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
/** Get the absolute path to a section directory. */
|
|
25
|
-
dir(section: string): string {
|
|
26
|
-
if (!this.dirs.includes(section)) {
|
|
27
|
-
throw new Error(
|
|
28
|
-
`Unknown section "${section}". Available: ${this.dirs.join(', ')}`,
|
|
29
|
-
);
|
|
30
|
-
}
|
|
31
|
-
return path.join(this.path, section);
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
// -- Convenience accessors for default dirs --
|
|
35
|
-
|
|
36
|
-
get inputDir(): string {
|
|
37
|
-
return path.join(this.path, 'input');
|
|
38
|
-
}
|
|
39
|
-
get outputDir(): string {
|
|
40
|
-
return path.join(this.path, 'output');
|
|
41
|
-
}
|
|
42
|
-
get resourcesDir(): string {
|
|
43
|
-
return path.join(this.path, 'resources');
|
|
44
|
-
}
|
|
45
|
-
get scratchDir(): string {
|
|
46
|
-
return path.join(this.path, 'scratch');
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
// -- Writers --
|
|
50
|
-
|
|
51
|
-
async writeJson(section: string, filePath: string, data: unknown): Promise<void> {
|
|
52
|
-
return writeJson(this.dir(section), filePath, data);
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
async writeJsonl(section: string, filePath: string, items: unknown[]): Promise<void> {
|
|
56
|
-
return writeJsonl(this.dir(section), filePath, items);
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
async writeMarkdown(section: string, filePath: string, doc: MarkdownDocument): Promise<void> {
|
|
60
|
-
return writeMarkdown(this.dir(section), filePath, doc);
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
async writeRaw(section: string, filePath: string, content: string): Promise<void> {
|
|
64
|
-
return writeRaw(this.dir(section), filePath, content);
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
async copyDir(section: string, destName: string, srcPath: string): Promise<void> {
|
|
68
|
-
return copyDir(this.dir(section), destName, srcPath);
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
async symlink(section: string, linkName: string, targetPath: string): Promise<void> {
|
|
72
|
-
return symlink(this.dir(section), linkName, targetPath);
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
// -- Readers --
|
|
76
|
-
|
|
77
|
-
async readJson<T = unknown>(
|
|
78
|
-
section: string,
|
|
79
|
-
filePath: string,
|
|
80
|
-
options?: ReadJsonOptions<T>,
|
|
81
|
-
): Promise<T> {
|
|
82
|
-
return readJson(this.dir(section), filePath, options);
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
async readJsonl<T = unknown>(
|
|
86
|
-
section: string,
|
|
87
|
-
filePath: string,
|
|
88
|
-
options?: ReadJsonOptions<T>,
|
|
89
|
-
): Promise<T[]> {
|
|
90
|
-
return readJsonl(this.dir(section), filePath, options);
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
async readMarkdown<T = Record<string, unknown>>(
|
|
94
|
-
section: string,
|
|
95
|
-
filePath: string,
|
|
96
|
-
options?: ReadMarkdownOptions<T>,
|
|
97
|
-
): Promise<MarkdownDocument<T>> {
|
|
98
|
-
return readMarkdown(this.dir(section), filePath, options);
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
async readRaw(section: string, filePath: string): Promise<string> {
|
|
102
|
-
return readRaw(this.dir(section), filePath);
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
async listFiles(section: string, subPath: string = ''): Promise<string[]> {
|
|
106
|
-
return listFiles(this.dir(section), subPath);
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
async readJsonDir<T = unknown>(
|
|
110
|
-
section: string,
|
|
111
|
-
subPath: string,
|
|
112
|
-
options?: ReadJsonOptions<T>,
|
|
113
|
-
): Promise<Map<string, T>> {
|
|
114
|
-
return readJsonDir(this.dir(section), subPath, options);
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
// -- Validation --
|
|
118
|
-
|
|
119
|
-
async validateOutput(spec: OutputSpec): Promise<ValidationResult> {
|
|
120
|
-
return validateOutput(this.outputDir, spec);
|
|
121
|
-
}
|
|
122
|
-
}
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
// Core classes
|
|
2
|
-
export { WorkspaceManager } from './manager.js';
|
|
3
|
-
export { WorkspaceHandle } from './handle.js';
|
|
4
|
-
|
|
5
|
-
// Validation
|
|
6
|
-
export { validateOutput } from './validation.js';
|
|
7
|
-
|
|
8
|
-
// Standalone writer functions (for consumers who manage their own dirs)
|
|
9
|
-
export { writeJson, writeJsonl } from './writers/json.js';
|
|
10
|
-
export { writeMarkdown } from './writers/markdown.js';
|
|
11
|
-
export { writeRaw, copyDir, symlink } from './writers/raw.js';
|
|
12
|
-
|
|
13
|
-
// Standalone reader functions
|
|
14
|
-
export { readJson, readJsonl, readJsonDir } from './readers/json.js';
|
|
15
|
-
export { readMarkdown } from './readers/markdown.js';
|
|
16
|
-
export { readRaw, listFiles } from './readers/raw.js';
|
|
17
|
-
|
|
18
|
-
// Types
|
|
19
|
-
export type {
|
|
20
|
-
Schema,
|
|
21
|
-
CreateWorkspaceOptions,
|
|
22
|
-
WorkspaceManagerConfig,
|
|
23
|
-
WorkspaceMeta,
|
|
24
|
-
MarkdownDocument,
|
|
25
|
-
OutputFileSpec,
|
|
26
|
-
OutputSpec,
|
|
27
|
-
ValidationError,
|
|
28
|
-
ValidationResult,
|
|
29
|
-
} from './types.js';
|
|
30
|
-
|
|
31
|
-
export type { ReadJsonOptions } from './readers/json.js';
|
|
32
|
-
export type { ReadMarkdownOptions } from './readers/markdown.js';
|
|
@@ -1,102 +0,0 @@
|
|
|
1
|
-
import * as fs from 'fs/promises';
|
|
2
|
-
import * as path from 'path';
|
|
3
|
-
import * as os from 'os';
|
|
4
|
-
import * as crypto from 'crypto';
|
|
5
|
-
import { WorkspaceHandle } from './handle.js';
|
|
6
|
-
import type { CreateWorkspaceOptions, WorkspaceManagerConfig, WorkspaceMeta } from './types.js';
|
|
7
|
-
|
|
8
|
-
const DEFAULT_DIRS = ['input', 'output', 'resources', 'scratch'];
|
|
9
|
-
const META_FILE = '.workspace.json';
|
|
10
|
-
|
|
11
|
-
export class WorkspaceManager {
|
|
12
|
-
private readonly baseDir: string;
|
|
13
|
-
private readonly prefix: string;
|
|
14
|
-
|
|
15
|
-
constructor(config: WorkspaceManagerConfig = {}) {
|
|
16
|
-
this.baseDir = config.baseDir ?? os.tmpdir();
|
|
17
|
-
this.prefix = config.prefix ?? 'agent-workspaces';
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
/** Root directory that contains all workspaces. */
|
|
21
|
-
private get root(): string {
|
|
22
|
-
return path.join(this.baseDir, this.prefix);
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
/** Create a new workspace with standard + optional additional directories. */
|
|
26
|
-
async create(taskType: string, options: CreateWorkspaceOptions = {}): Promise<WorkspaceHandle> {
|
|
27
|
-
const id = `${taskType}-${Date.now()}-${crypto.randomUUID().slice(0, 8)}`;
|
|
28
|
-
const workspacePath = path.join(this.root, id);
|
|
29
|
-
|
|
30
|
-
const allDirs = [...DEFAULT_DIRS, ...(options.additionalDirs ?? [])];
|
|
31
|
-
|
|
32
|
-
// Create all directories in parallel
|
|
33
|
-
await fs.mkdir(workspacePath, { recursive: true });
|
|
34
|
-
await Promise.all(
|
|
35
|
-
allDirs.map((dir) => fs.mkdir(path.join(workspacePath, dir), { recursive: true })),
|
|
36
|
-
);
|
|
37
|
-
|
|
38
|
-
const meta: WorkspaceMeta = {
|
|
39
|
-
id,
|
|
40
|
-
taskType,
|
|
41
|
-
createdAt: new Date().toISOString(),
|
|
42
|
-
dirs: allDirs,
|
|
43
|
-
};
|
|
44
|
-
|
|
45
|
-
await fs.writeFile(path.join(workspacePath, META_FILE), JSON.stringify(meta, null, 2));
|
|
46
|
-
|
|
47
|
-
return new WorkspaceHandle(id, workspacePath, allDirs, new Date(meta.createdAt));
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
/** Remove a workspace from disk. */
|
|
51
|
-
async cleanup(handle: WorkspaceHandle): Promise<void> {
|
|
52
|
-
await fs.rm(handle.path, { recursive: true, force: true });
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
/** List all workspace handles under the managed root. */
|
|
56
|
-
async list(): Promise<WorkspaceHandle[]> {
|
|
57
|
-
try {
|
|
58
|
-
const entries = await fs.readdir(this.root, { withFileTypes: true });
|
|
59
|
-
const handles: WorkspaceHandle[] = [];
|
|
60
|
-
|
|
61
|
-
for (const entry of entries) {
|
|
62
|
-
if (!entry.isDirectory()) continue;
|
|
63
|
-
const metaPath = path.join(this.root, entry.name, META_FILE);
|
|
64
|
-
try {
|
|
65
|
-
const raw = await fs.readFile(metaPath, 'utf-8');
|
|
66
|
-
const meta: WorkspaceMeta = JSON.parse(raw);
|
|
67
|
-
handles.push(
|
|
68
|
-
new WorkspaceHandle(
|
|
69
|
-
meta.id,
|
|
70
|
-
path.join(this.root, entry.name),
|
|
71
|
-
meta.dirs,
|
|
72
|
-
new Date(meta.createdAt),
|
|
73
|
-
),
|
|
74
|
-
);
|
|
75
|
-
} catch {
|
|
76
|
-
// Skip directories without valid metadata
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
return handles;
|
|
81
|
-
} catch {
|
|
82
|
-
// Root doesn't exist yet — no workspaces
|
|
83
|
-
return [];
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
/** Remove workspaces older than `maxAgeMs` milliseconds. */
|
|
88
|
-
async pruneStale(maxAgeMs: number): Promise<number> {
|
|
89
|
-
const handles = await this.list();
|
|
90
|
-
const cutoff = Date.now() - maxAgeMs;
|
|
91
|
-
let pruned = 0;
|
|
92
|
-
|
|
93
|
-
for (const handle of handles) {
|
|
94
|
-
if (handle.createdAt.getTime() <= cutoff) {
|
|
95
|
-
await this.cleanup(handle);
|
|
96
|
-
pruned++;
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
return pruned;
|
|
101
|
-
}
|
|
102
|
-
}
|
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
import * as fs from 'fs/promises';
|
|
2
|
-
import * as path from 'path';
|
|
3
|
-
import type { Schema } from '../types.js';
|
|
4
|
-
|
|
5
|
-
export interface ReadJsonOptions<T = unknown> {
|
|
6
|
-
schema?: Schema<T>;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
/** Read and parse a JSON file. Optionally validate against a schema. */
|
|
10
|
-
export async function readJson<T = unknown>(
|
|
11
|
-
dir: string,
|
|
12
|
-
filePath: string,
|
|
13
|
-
options?: ReadJsonOptions<T>,
|
|
14
|
-
): Promise<T> {
|
|
15
|
-
const fullPath = path.join(dir, filePath);
|
|
16
|
-
const raw = await fs.readFile(fullPath, 'utf-8');
|
|
17
|
-
const data = JSON.parse(raw);
|
|
18
|
-
|
|
19
|
-
if (options?.schema) {
|
|
20
|
-
return options.schema.parse(data);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
return data as T;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
/** Read a JSONL file and return an array of parsed objects. Optionally validate each item. */
|
|
27
|
-
export async function readJsonl<T = unknown>(
|
|
28
|
-
dir: string,
|
|
29
|
-
filePath: string,
|
|
30
|
-
options?: ReadJsonOptions<T>,
|
|
31
|
-
): Promise<T[]> {
|
|
32
|
-
const fullPath = path.join(dir, filePath);
|
|
33
|
-
const raw = await fs.readFile(fullPath, 'utf-8');
|
|
34
|
-
const lines = raw.trimEnd().split('\n').filter((line) => line.length > 0);
|
|
35
|
-
|
|
36
|
-
return lines.map((line, index) => {
|
|
37
|
-
const data = JSON.parse(line);
|
|
38
|
-
if (options?.schema) {
|
|
39
|
-
try {
|
|
40
|
-
return options.schema.parse(data);
|
|
41
|
-
} catch (err) {
|
|
42
|
-
throw new Error(
|
|
43
|
-
`JSONL validation failed at line ${index + 1}: ${err instanceof Error ? err.message : String(err)}`,
|
|
44
|
-
);
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
return data as T;
|
|
48
|
-
});
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
/**
|
|
52
|
-
* Read all JSON files in a directory, returning a Map of filename → parsed content.
|
|
53
|
-
* Optionally validate each file against a schema.
|
|
54
|
-
*/
|
|
55
|
-
export async function readJsonDir<T = unknown>(
|
|
56
|
-
dir: string,
|
|
57
|
-
subPath: string,
|
|
58
|
-
options?: ReadJsonOptions<T>,
|
|
59
|
-
): Promise<Map<string, T>> {
|
|
60
|
-
const fullDir = path.join(dir, subPath);
|
|
61
|
-
const entries = await fs.readdir(fullDir);
|
|
62
|
-
const result = new Map<string, T>();
|
|
63
|
-
|
|
64
|
-
for (const entry of entries) {
|
|
65
|
-
if (!entry.endsWith('.json')) continue;
|
|
66
|
-
const data = await readJson<T>(fullDir, entry, options);
|
|
67
|
-
result.set(entry, data);
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
return result;
|
|
71
|
-
}
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import * as fs from 'fs/promises';
|
|
2
|
-
import * as path from 'path';
|
|
3
|
-
import { parse as yamlParse } from 'yaml';
|
|
4
|
-
import type { MarkdownDocument, Schema } from '../types.js';
|
|
5
|
-
|
|
6
|
-
export interface ReadMarkdownOptions<T = Record<string, unknown>> {
|
|
7
|
-
/** Schema to validate/parse the frontmatter. */
|
|
8
|
-
frontmatterSchema?: Schema<T>;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
/** Read a markdown file, parsing YAML frontmatter if present. */
|
|
12
|
-
export async function readMarkdown<T = Record<string, unknown>>(
|
|
13
|
-
dir: string,
|
|
14
|
-
filePath: string,
|
|
15
|
-
options?: ReadMarkdownOptions<T>,
|
|
16
|
-
): Promise<MarkdownDocument<T>> {
|
|
17
|
-
const fullPath = path.join(dir, filePath);
|
|
18
|
-
const raw = await fs.readFile(fullPath, 'utf-8');
|
|
19
|
-
|
|
20
|
-
const match = raw.match(/^---\n([\s\S]*?)\n---\n\n?([\s\S]*)$/);
|
|
21
|
-
|
|
22
|
-
let frontmatter: T;
|
|
23
|
-
let body: string;
|
|
24
|
-
|
|
25
|
-
if (match) {
|
|
26
|
-
const parsed = yamlParse(match[1]);
|
|
27
|
-
frontmatter = options?.frontmatterSchema ? options.frontmatterSchema.parse(parsed) : parsed;
|
|
28
|
-
body = match[2];
|
|
29
|
-
} else {
|
|
30
|
-
frontmatter = (options?.frontmatterSchema
|
|
31
|
-
? options.frontmatterSchema.parse({})
|
|
32
|
-
: {}) as T;
|
|
33
|
-
body = raw;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
return { frontmatter, body };
|
|
37
|
-
}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import * as fs from 'fs/promises';
|
|
2
|
-
import * as path from 'path';
|
|
3
|
-
|
|
4
|
-
/** Read a file as a raw string. */
|
|
5
|
-
export async function readRaw(dir: string, filePath: string): Promise<string> {
|
|
6
|
-
const fullPath = path.join(dir, filePath);
|
|
7
|
-
return fs.readFile(fullPath, 'utf-8');
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
/** List files in a section subdirectory, returning paths relative to the directory. */
|
|
11
|
-
export async function listFiles(dir: string, subPath: string = ''): Promise<string[]> {
|
|
12
|
-
const fullDir = path.join(dir, subPath);
|
|
13
|
-
const entries = await fs.readdir(fullDir, { withFileTypes: true });
|
|
14
|
-
const files: string[] = [];
|
|
15
|
-
|
|
16
|
-
for (const entry of entries) {
|
|
17
|
-
const relative = path.join(subPath, entry.name);
|
|
18
|
-
if (entry.isDirectory()) {
|
|
19
|
-
const nested = await listFiles(dir, relative);
|
|
20
|
-
files.push(...nested);
|
|
21
|
-
} else {
|
|
22
|
-
files.push(relative);
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
return files;
|
|
27
|
-
}
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Minimal schema interface — anything with a `parse` method works (Zod, Joi, custom).
|
|
3
|
-
* `parse` should throw on invalid data.
|
|
4
|
-
*/
|
|
5
|
-
export interface Schema<T = unknown> {
|
|
6
|
-
parse(data: unknown): T;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
/** Options for creating a workspace. */
|
|
10
|
-
export interface CreateWorkspaceOptions {
|
|
11
|
-
/** Extra top-level directories to create alongside the defaults. */
|
|
12
|
-
additionalDirs?: string[];
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
/** Configuration for WorkspaceManager. */
|
|
16
|
-
export interface WorkspaceManagerConfig {
|
|
17
|
-
/** Base directory where workspaces are created. Defaults to `os.tmpdir()`. */
|
|
18
|
-
baseDir?: string;
|
|
19
|
-
/** Namespace prefix for the workspaces directory. Defaults to `'agent-workspaces'`. */
|
|
20
|
-
prefix?: string;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
/** Metadata persisted alongside a workspace. */
|
|
24
|
-
export interface WorkspaceMeta {
|
|
25
|
-
id: string;
|
|
26
|
-
taskType: string;
|
|
27
|
-
createdAt: string;
|
|
28
|
-
dirs: string[];
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
/** Markdown document with optional YAML frontmatter. */
|
|
32
|
-
export interface MarkdownDocument<T = Record<string, unknown>> {
|
|
33
|
-
frontmatter: T;
|
|
34
|
-
body: string;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
/** Specification for a single expected output file. */
|
|
38
|
-
export interface OutputFileSpec {
|
|
39
|
-
/** Path relative to the output directory. */
|
|
40
|
-
path: string;
|
|
41
|
-
/** Expected file format. */
|
|
42
|
-
format: 'json' | 'jsonl' | 'markdown' | 'raw';
|
|
43
|
-
/** Whether the file must exist. */
|
|
44
|
-
required: boolean;
|
|
45
|
-
/** Human-readable description (included in error messages). */
|
|
46
|
-
description?: string;
|
|
47
|
-
/** Schema for JSON / JSONL validation — must have a `parse` method that throws on invalid data. */
|
|
48
|
-
schema?: Schema;
|
|
49
|
-
/** Custom validation function. Throw or return false to indicate failure. */
|
|
50
|
-
validate?: (content: unknown) => boolean | Promise<boolean>;
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
/** Full output specification. */
|
|
54
|
-
export interface OutputSpec {
|
|
55
|
-
files: OutputFileSpec[];
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
/** A single validation error. */
|
|
59
|
-
export interface ValidationError {
|
|
60
|
-
path: string;
|
|
61
|
-
message: string;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
/** Result of output validation. */
|
|
65
|
-
export interface ValidationResult {
|
|
66
|
-
valid: boolean;
|
|
67
|
-
errors: ValidationError[];
|
|
68
|
-
}
|
|
@@ -1,93 +0,0 @@
|
|
|
1
|
-
import * as fs from 'fs/promises';
|
|
2
|
-
import * as path from 'path';
|
|
3
|
-
import { readJson, readJsonl } from './readers/json.js';
|
|
4
|
-
import { readMarkdown } from './readers/markdown.js';
|
|
5
|
-
import { readRaw } from './readers/raw.js';
|
|
6
|
-
import type { OutputFileSpec, OutputSpec, ValidationError, ValidationResult } from './types.js';
|
|
7
|
-
|
|
8
|
-
/** Validate that expected output files exist and pass schema / custom validation. */
|
|
9
|
-
export async function validateOutput(
|
|
10
|
-
outputDir: string,
|
|
11
|
-
spec: OutputSpec,
|
|
12
|
-
): Promise<ValidationResult> {
|
|
13
|
-
const errors: ValidationError[] = [];
|
|
14
|
-
|
|
15
|
-
for (const fileSpec of spec.files) {
|
|
16
|
-
const fullPath = path.join(outputDir, fileSpec.path);
|
|
17
|
-
|
|
18
|
-
// Check existence
|
|
19
|
-
try {
|
|
20
|
-
await fs.access(fullPath);
|
|
21
|
-
} catch {
|
|
22
|
-
if (fileSpec.required) {
|
|
23
|
-
const desc = fileSpec.description ? ` (${fileSpec.description})` : '';
|
|
24
|
-
errors.push({
|
|
25
|
-
path: fileSpec.path,
|
|
26
|
-
message: `Required file missing${desc}`,
|
|
27
|
-
});
|
|
28
|
-
}
|
|
29
|
-
continue;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
// Read and validate content
|
|
33
|
-
try {
|
|
34
|
-
const content = await readFileByFormat(outputDir, fileSpec);
|
|
35
|
-
|
|
36
|
-
// Schema validation
|
|
37
|
-
if (fileSpec.schema) {
|
|
38
|
-
try {
|
|
39
|
-
if (fileSpec.format === 'jsonl' && Array.isArray(content)) {
|
|
40
|
-
for (const item of content) {
|
|
41
|
-
fileSpec.schema.parse(item);
|
|
42
|
-
}
|
|
43
|
-
} else {
|
|
44
|
-
fileSpec.schema.parse(content);
|
|
45
|
-
}
|
|
46
|
-
} catch (err) {
|
|
47
|
-
errors.push({
|
|
48
|
-
path: fileSpec.path,
|
|
49
|
-
message: `Schema validation failed: ${err instanceof Error ? err.message : String(err)}`,
|
|
50
|
-
});
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
// Custom validate callback
|
|
55
|
-
if (fileSpec.validate) {
|
|
56
|
-
try {
|
|
57
|
-
const result = await fileSpec.validate(content);
|
|
58
|
-
if (result === false) {
|
|
59
|
-
errors.push({
|
|
60
|
-
path: fileSpec.path,
|
|
61
|
-
message: 'Custom validation returned false',
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
} catch (err) {
|
|
65
|
-
errors.push({
|
|
66
|
-
path: fileSpec.path,
|
|
67
|
-
message: `Custom validation threw: ${err instanceof Error ? err.message : String(err)}`,
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
} catch (err) {
|
|
72
|
-
errors.push({
|
|
73
|
-
path: fileSpec.path,
|
|
74
|
-
message: `Failed to read file: ${err instanceof Error ? err.message : String(err)}`,
|
|
75
|
-
});
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
return { valid: errors.length === 0, errors };
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
async function readFileByFormat(outputDir: string, spec: OutputFileSpec): Promise<unknown> {
|
|
83
|
-
switch (spec.format) {
|
|
84
|
-
case 'json':
|
|
85
|
-
return readJson(outputDir, spec.path);
|
|
86
|
-
case 'jsonl':
|
|
87
|
-
return readJsonl(outputDir, spec.path);
|
|
88
|
-
case 'markdown':
|
|
89
|
-
return readMarkdown(outputDir, spec.path);
|
|
90
|
-
case 'raw':
|
|
91
|
-
return readRaw(outputDir, spec.path);
|
|
92
|
-
}
|
|
93
|
-
}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import * as fs from 'fs/promises';
|
|
2
|
-
import * as path from 'path';
|
|
3
|
-
|
|
4
|
-
/** Write a JSON file (pretty-printed). */
|
|
5
|
-
export async function writeJson(dir: string, filePath: string, data: unknown): Promise<void> {
|
|
6
|
-
const fullPath = path.join(dir, filePath);
|
|
7
|
-
await fs.mkdir(path.dirname(fullPath), { recursive: true });
|
|
8
|
-
await fs.writeFile(fullPath, JSON.stringify(data, null, 2) + '\n');
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
/** Write a JSONL file (one JSON object per line). */
|
|
12
|
-
export async function writeJsonl(dir: string, filePath: string, items: unknown[]): Promise<void> {
|
|
13
|
-
const fullPath = path.join(dir, filePath);
|
|
14
|
-
await fs.mkdir(path.dirname(fullPath), { recursive: true });
|
|
15
|
-
const content = items.map((item) => JSON.stringify(item)).join('\n') + '\n';
|
|
16
|
-
await fs.writeFile(fullPath, content);
|
|
17
|
-
}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import * as fs from 'fs/promises';
|
|
2
|
-
import * as path from 'path';
|
|
3
|
-
import { stringify as yamlStringify } from 'yaml';
|
|
4
|
-
import type { MarkdownDocument } from '../types.js';
|
|
5
|
-
|
|
6
|
-
/** Write a markdown file with optional YAML frontmatter. */
|
|
7
|
-
export async function writeMarkdown(
|
|
8
|
-
dir: string,
|
|
9
|
-
filePath: string,
|
|
10
|
-
doc: MarkdownDocument,
|
|
11
|
-
): Promise<void> {
|
|
12
|
-
const fullPath = path.join(dir, filePath);
|
|
13
|
-
await fs.mkdir(path.dirname(fullPath), { recursive: true });
|
|
14
|
-
|
|
15
|
-
let content = '';
|
|
16
|
-
if (doc.frontmatter && Object.keys(doc.frontmatter).length > 0) {
|
|
17
|
-
content += '---\n' + yamlStringify(doc.frontmatter).trimEnd() + '\n---\n\n';
|
|
18
|
-
}
|
|
19
|
-
content += doc.body;
|
|
20
|
-
|
|
21
|
-
// Ensure trailing newline
|
|
22
|
-
if (!content.endsWith('\n')) {
|
|
23
|
-
content += '\n';
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
await fs.writeFile(fullPath, content);
|
|
27
|
-
}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import * as fs from 'fs/promises';
|
|
2
|
-
import * as path from 'path';
|
|
3
|
-
|
|
4
|
-
/** Write raw string content to a file. */
|
|
5
|
-
export async function writeRaw(dir: string, filePath: string, content: string): Promise<void> {
|
|
6
|
-
const fullPath = path.join(dir, filePath);
|
|
7
|
-
await fs.mkdir(path.dirname(fullPath), { recursive: true });
|
|
8
|
-
await fs.writeFile(fullPath, content);
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
/** Recursively copy a directory into the workspace. */
|
|
12
|
-
export async function copyDir(dir: string, destName: string, srcPath: string): Promise<void> {
|
|
13
|
-
const fullDest = path.join(dir, destName);
|
|
14
|
-
await fs.cp(srcPath, fullDest, { recursive: true });
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
/** Create a symlink inside the workspace pointing to an external path. */
|
|
18
|
-
export async function symlink(dir: string, linkName: string, targetPath: string): Promise<void> {
|
|
19
|
-
const fullLink = path.join(dir, linkName);
|
|
20
|
-
await fs.mkdir(path.dirname(fullLink), { recursive: true });
|
|
21
|
-
await fs.symlink(targetPath, fullLink);
|
|
22
|
-
}
|