KeiSeiKit-1.0/_primitives
Parfii-bot 2631766ff7 fix(kei-model-router): close 2 HIGH regressions from re-audit
Re-audit (codex + critic-bug) on commit 3b03fb7b confirmed all 10 original
findings closed, but flagged 2 HIGH regressions the fix itself introduced.

NEW-1 fix — non-Claude profile no longer falls back to Opus
  - main.rs::build_select_input: when Model::from_slug returns None
    (any non-Anthropic provider — codex/xai/deepseek/google/local),
    cmd_select bypasses posterior+kernel entirely and prints
    (provider, model_id) directly with reason="profile_default_non_claude".
  - Posterior machinery stays Claude-only by design — RULE 0.20 escalation
    ladder operates on Anthropic family. Cross-provider routing is
    registry-driven, not enum-driven.
  - Test non_claude_profile_triggers_provider_bypass:
    pick("codex-reviewer") = ("codex","gpt-5-codex");
    Model::from_slug("gpt-5-codex") = None — assertion locks behaviour.

NEW-2 fix — no-ledger path preserves profile-resolved fallback
  - print_decision_no_ledger signature changed from (dna, prompt) to
    (input: &DecisionInput, dna). Uses input.fallback.slug() so the
    Sonnet/Haiku selected by profile resolution survives instead of
    being overwritten with constructor-default Opus.
  - Test decision_input_preserves_set_fallback verifies the round-trip.

Verification (orchestrator-side):
  - cargo check        → clean
  - cargo test --release → 65 passed / 0 failed (was 63 → +2 regression tests)
  - Constructor Pattern → all files ≤ 200 LOC (main.rs 197 at limit)

DNA-INDEX.md regenerated by kei-registry hook (cosmetic).

=== STATUS-TRUTH MARKER ===
shipped: functional
stubs: 0
cargo-check: PASS
behaviour-verified: yes
follow-up-required:
  - CLI stdout for non-Claude profiles gains a "reason: profile_default_non_claude"
    line; downstream parsers must handle the new variant.
2026-05-13 22:44:00 +08:00
..
_rust fix(kei-model-router): close 2 HIGH regressions from re-audit 2026-05-13 22:44:00 +08:00
templates fix(kei-conflict-scan): close 3 backlog bugs + Phase C draft emission 2026-05-12 18:30:01 +08:00
design-scrape.sh KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00
figma-tokens.sh KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00
frontend-inspect.sh KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00
harden-base.sh KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00
kei-ci-lint.sh KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00
kei-docs-scaffold.sh KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00
kei-doctor.sh KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00
kei-sleep-queue.sh KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00
kei-sleep-setup.sh KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00
kei-sleep-sync.sh feat(sleep-sync): mirror time-metrics + ledger snapshots, surface in Phase B report 2026-05-02 04:02:28 +08:00
live-preview.sh KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00
log-ship.sh KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00
MANIFEST.toml feat(install): add profile=buddy for marketplace 1-click bot provisioning 2026-05-13 10:29:40 +08:00
metrics-scrape.sh KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00
provision-hetzner.sh KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00
provision-vultr.sh KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00
README.md KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00
screenshot-decode.sh KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00
tomd.sh KeiSeiKit-public — clean state 2026-05-01 12:09:03 +08:00

_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 a first-class primitive. Universal non-native-format → markdown converter with configurable cache directory (KEISEI_TOMD_CACHE) and KeiSeiKit-style error tags ([tomd]).

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").