## Wave 14 — 5 new primitives (44 crates total, 713 tests green) All specs written as task.toml → passed through kei-agent-runtime prepare → composed prompts via capability fragments → Agent tool invocation. First fully-dogfooded wave. - kei-prune (9 tests): biological pruning. `candidates(idle_days)` + `mark_retired(id)` on sidecar `prune_retirements` table (agents.status CHECK precluded 'retired' value). - kei-discover (8 tests): federated marketplace discovery stub. UNIQUE slug via custom migration + FTS5 on slug+description. Engine-native via kei-entity-store. Typed DuplicateSlug error. - kei-brain-view (6-8 tests): stdout visualizer for ledger taxonomy graph + agent lineage. Tree / stats / lineage subcommands. NO_COLOR env respected. No kei-entity-store dep (direct rusqlite). - kei-hibernate (6 tests): whole-brain tar.zst export/import. Manifest with sha256 per-file, version gate, safe_join on extract, dry-run mode. tar 0.4 + zstd 0.13. - kei-ledger-sign (7 tests): ed25519 creator attestation. keygen / sign / verify CLI. Canonical message `dna|spec_sha|creator_id` with pipe rejection. chmod 600 on key storage (unix). Tamper-detection on load via pubkey re-derivation. ## Phase 2 cleanup shipped in same commit - LOC splits: walk.rs 221→91 (path_safety.rs + wikilink.rs extracted), prepare.rs 228→199 (dead build_ledger_row removed, fn helpers split). - Clippy pass: 6 warnings fixed (derivable_impls, manual_contains, type_complexity x2, doc_overindented_list_items x2) in kei-entity-store, kei-ledger, kei-spawn. - DNA eprintln removed from kei-agent-runtime/src/dna.rs (stderr pollution from library parse). - kei-pipe integrations: hot_reload.rs (kei-watch wrapper, sync API, 50ms debounce) + scheduler_bridge.rs (kei-scheduler executor, shell exec documented). +6 tests. - Workspace [workspace.dependencies] centralised: rusqlite/chrono/ anyhow/thiserror/tempfile/toml — future crates opt in via `.workspace = true`. Existing pins preserved. ## Substrate dogfood verified task.toml → `kei-agent-runtime prepare` → DNA + composed prompt from capability fragments → Agent tool invocation. kei-spawn also tested end-to-end (prompt.md written to tasks/<agent-id>/, ledger row created). Verified: cargo check --workspace clean, 713 tests passing, substrate_integration.sh ✓, hook_wiring_integration.sh ✓. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com> |
||
|---|---|---|
| .. | ||
| _rust | ||
| templates | ||
| design-scrape.sh | ||
| figma-tokens.sh | ||
| frontend-inspect.sh | ||
| harden-base.sh | ||
| kei-ci-lint.sh | ||
| kei-docs-scaffold.sh | ||
| kei-sleep-queue.sh | ||
| kei-sleep-setup.sh | ||
| kei-sleep-sync.sh | ||
| live-preview.sh | ||
| log-ship.sh | ||
| MANIFEST.toml | ||
| metrics-scrape.sh | ||
| provision-hetzner.sh | ||
| provision-vultr.sh | ||
| README.md | ||
| screenshot-decode.sh | ||
| tomd.sh | ||
_primitives — first-class building blocks
_primitives/ holds standalone utilities that agents, hooks, and skills
(including /compose-solution) depend on. Unlike _blocks/ (behavioral
markdown) or _manifests/ (agent TOML), primitives are executable shell
programs installed at $HOME/.claude/agents/_primitives/ by install.sh.
Current primitives
| Primitive | Purpose | Invocation |
|---|---|---|
tomd.sh |
Universal non-native-format → markdown converter (PDF, DOCX, XLSX, PPTX, CSV, images, code). | ~/.claude/agents/_primitives/tomd.sh <file> |
tomd.sh is ported from the KeiAgent project (user's personal CLI
predecessor) bin/keiagent-tomd — same format matrix, KeiSeiKit-style
error tags ([tomd]), configurable cache directory (KEISEI_TOMD_CACHE).
Hook integration
hooks/tomd-preread.sh is a PreToolUse(Read) hook that auto-redirects
Claude to the converted markdown when a Read targets .docx / .doc / .xlsx / .pptx / .csv. Cached under $KEISEI_TOMD_CACHE (default
/tmp/keisei-tomd-cache).
/compose-solution discovery
Phase 3 prior-art sweep greps _primitives/ alongside _blocks/,
_manifests/, skills/, _bridges/, hooks/. If a user task involves
file-format parsing, the meta-composer surfaces tomd automatically —
reuse over rewrite (RULE "No Patching").