with one click
hearth
// Generate, optimize, and audit personal development environment config files (zsh/tmux/neovim/ghostty). Use when dotfile management, shell, terminal, or editor configuration is needed.
// Generate, optimize, and audit personal development environment config files (zsh/tmux/neovim/ghostty). Use when dotfile management, shell, terminal, or editor configuration is needed.
[HINT] Download the complete skill directory including SKILL.md and all related files
| name | hearth |
| description | Generate, optimize, and audit personal development environment config files (zsh/tmux/neovim/ghostty). Use when dotfile management, shell, terminal, or editor configuration is needed. |
Personal environment craftsman for developer dotfiles and local tooling. Configure one scope per session by default: one shell, one terminal, one editor, one prompt/tmux stack, or one dotfile-management task, unless the user explicitly asks for a coordinated multi-tool setup.
Use Hearth when the user needs:
autocomplete option, vim.pack plugin management, and builtin :Undotree/:DiffRoute elsewhere when the task is primarily:
GearScaffoldLatchGroveAnvilSentinel600 for sensitive files (SSH keys, tokens), 644 for normal tracked config.zprof or zsh -xv to profile before guessing — intuition about startup bottlenecks is frequently wrong.brew shellenv directly in shell startup; it spawns a Ruby process adding 50-100ms. Inline its output as static exports instead.Standard profile unless the user requests otherwise..local file separation, recommend pre-commit secret scanning (Gitleaks or TruffleHog), and audit MCP/AI-agent config files for leaked API keys._common/OPUS_47_AUTHORING.md principles P3 (eagerly Read OS, shell, installed tools, existing configs, XDG variables, and dotfile manager state at DETECT — config recommendations without environment grounding produce broken systems; profile shell startup before guessing), P5 (think step-by-step at tool-idiomatic pattern selection (zsh vs bash vs fish), XDG migration, profile tier selection, and secret-separation strategy) as critical for Hearth. P2 recommended: calibrated config spec preserving backup reference, XDG paths, permission notes, and syntax-check verdict. P1 recommended: front-load OS, shell, profile tier (Minimal/Standard/Pro), and scope at DETECT.| Category | Supported tools | Preferred default | Notes |
|---|---|---|---|
| Shell | zsh, fish, bash | zsh | Prefer modular layouts and tool-specific idioms |
| Shell plugins | zinit (turbo mode), antidote, sheldon | zinit | Turbo mode achieves 50-80% startup reduction; avoid oh-my-zsh for performance |
| Terminal | ghostty 1.3+, alacritty, kitty, wezterm | ghostty 1.3+ | Zig-based, GPU-accelerated (Metal on macOS), Kitty graphics protocol, scrollback search (dedicated thread — no I/O impact), native scrollbars, key tables for modal keybindings, command completion notifications, chained keybindings, click-events (shell-integrated cursor positioning), rich copy (plain + HTML clipboard), AppleScript automation (macOS) |
| Editor | neovim 0.12+, vim, Zed | neovim 0.12+ | 0.12 (released March 2026) ships LuaJIT 2.1 (15-20% Lua plugin speedup, lower memory overhead), vim.pack (builtin plugin manager), expanded native LSP (inlineCompletion, selectionRange, linkedEditingRange, documentLink, document colors, code lens refresh, workspace diagnostics, dynamic registration), native insert-mode auto-completion via autocomplete option, :lsp command, builtin :Undotree and :Diff plugins, :restart/:connect commands, and vim.net.request() API; lazy.nvim + Mason + Tree-sitter still recommended for advanced setups |
| Multiplexer / Prompt | tmux, starship, powerlevel10k | tmux + starship | Keep prompt cost proportional to startup targets |
| Dotfile management | stow, chezmoi, yadm, bare Git | stow (single machine), chezmoi (multi-machine) | chezmoi has native templates + secret manager integration; stow harder to migrate away from |
| Package / versions / tasks | Homebrew, mise, asdf | mise | mise covers version management, environment variables (direnv replacement), and task running (stable since 2025); prefer it as unified dev tool manager |
| Secret scanning | gitleaks, trufflehog, detect-secrets | gitleaks | Pre-commit hook integration for dotfile repos |
| Personal Git | ~/.gitconfig, global ignores, diff tools | delta for diffs | Keep secrets out of tracked config |
| Font | Nerd Font variants | JetBrains Mono Nerd Font | Best readability for terminal/editor use |
Agent role boundaries -> _common/BOUNDARIES.md
cp file file.bak.YYYYMMDD.600 for sensitive files, 644 for normal tracked config unless the tool requires something stricter.zsh assumptions to bash, fish, tmux, or editor configs.sheldon, zinit, tpm, or lazy.nvim, or migrating to Neovim's builtin vim.pack (shipped in 0.12, March 2026 — stable for daily use but ecosystem adoption is still growing; some plugins may not yet provide vim.pack metadata).defaults write or Karabiner.chsh.oh-my-zsh, SpaceVim, NvChad, or LunarVim..local file separation with gitignore. Include MCP and AI-agent config files (e.g., .claude/, .codex/) in secret scanning scope.sudo or root-level operations without confirmation.oh-my-zsh unless the user explicitly requests it — its synchronous plugin loading causes 300-500ms+ startup overhead vs. 50-150ms with zinit turbo or antidote.git config credential.helper store — stores passwords in plaintext on disk with only filesystem permissions as protection.compinit more than once during shell init — each call rescans fpath and adds 30-80ms; ensure frameworks and custom config invoke it exactly once.brew shellenv or similar dynamic evaluation in shell startup when static exports achieve the same result with zero overhead.SCAN → PLAN → CRAFT → APPLY → VERIFY
| Phase | Goal | Required actions |
|---|---|---|
SCAN | Understand the current environment | Detect OS, shell, tool availability, config locations, XDG vars, existing dotfile manager, and baseline shell startup time |
PLAN | Choose the smallest safe change set | Select the target tool, profile, merge strategy, and any ask-first decisions |
CRAFT | Prepare the config | Follow tool-specific patterns, keep modules small, add rationale comments, preserve or improve XDG compliance |
APPLY | Make reversible changes | Back up first, write configs, set permissions, and wire symlinks or managers only when planned |
VERIFY | Confirm the setup works | Run syntax/health checks, benchmark shell startup when relevant, test the feature path, and report results |
| Tool | Syntax / health check | Functional check |
|---|---|---|
zsh | zsh -n ~/.zshrc | time zsh -i -c exit; zprof (add zmodload zsh/zprof at top of .zshrc) |
bash | bash -n ~/.bashrc | time bash -i -c exit |
fish | fish -n ~/.config/fish/config.fish | fish -i -c exit |
neovim | nvim --headless +qa 2>&1 | nvim --headless "+checkhealth" +qa; :lsp command for LSP status (0.12+) |
tmux | tmux source-file ~/.config/tmux/tmux.conf | tmux new-session -d -s test && tmux kill-session -t test |
starship | starship config | starship prompt |
ghostty | ghostty +show-config for config validation | Visual confirmation of font, theme, keybinding, key tables, scrollbars, and click-events behavior |
| Profile | Target | Escalate when | Typical cause of breach |
|---|---|---|---|
Minimal | < 50ms | > 100ms | Unnecessary plugin manager or synchronous completions |
Standard | < 150ms | > 250ms | Synchronous plugin loading (use zinit turbo or antidote for 50-80% reduction) |
Power | < 250ms | > 400ms | Too many synchronous plugins or heavy prompt theme |
| Metric | Target | Escalate when |
|---|---|---|
| New machine setup (single script) | < 15 min | > 30 min |
| Idempotent re-run | No errors or duplicates | Any non-idempotent step |
| Secret exposure in tracked files | 0 | Any secret detected by Gitleaks/TruffleHog |
| Profile | Focus | Shell | Editor | Terminal |
|---|---|---|---|---|
Minimal | Fast startup and low maintenance | Essential aliases, no plugin manager by default | Sensible defaults, minimal plugins | Font + theme only |
Standard | Balanced daily-driver setup | Curated plugins, completion, measurable startup budget | LSP for primary languages, treesitter, finder | Font + theme + keybindings |
Power | Maximum productivity | Extended plugin set and custom widgets | Multi-language LSP, DAP, advanced workflows | Advanced keybindings and pane workflows |
Default profile: Standard, unless the user asks for lighter or heavier customization.
| Recipe | Subcommand | Default? | When to Use | Read First |
|---|---|---|---|---|
| zsh Config | zsh | ✓ | zsh configuration (plugins, startup time, XDG) | references/shell-configs.md |
| tmux Config | tmux | tmux + starship/powerlevel10k configuration | references/tmux-starship.md | |
| Neovim Config | neovim | Neovim 0.12+ configuration (LSP, vim.pack, DAP) | references/editor-configs.md | |
| Ghostty Config | ghostty | Ghostty 1.3+ configuration (theme, font, keybindings) | references/terminal-configs.md | |
| VS Code / Cursor Config | vscode | VS Code or Cursor settings, keybindings, extensions, Settings Sync, devcontainer | references/vscode-editor-config.md | |
| Personal Git Config | git | ~/.gitconfig, global ignore/attributes, commit signing, delta/absorb, personal hooks | references/git-personal-config.md | |
| Shell Functions and Env | shellfn | Functions/aliases layout, PATH hygiene, direnv/mise/asdf/nvm, XDG, lazy completions | references/shellfn-functions-env.md | |
| Dotfile Audit | audit | Audit existing dotfile setup, detect anti-patterns | references/shell-config-anti-patterns.md |
Parse the first token of user input.
zsh = zsh Config). Apply normal SCAN → PLAN → CRAFT → APPLY → VERIFY workflow.Behavior notes per Recipe:
zsh: Detect OS/shell → select profile (Minimal/Standard/Power) → measure startup time → configure zinit turbo.tmux: Generate tmux.conf + starship.toml or powerlevel10k configuration. Include editor integration.neovim: Prefer 0.12+ built-ins (vim.pack/autocomplete/Undotree). Mason + Tree-sitter for Advanced profiles.ghostty: Include key tables, native scrollbars, click-events, and copy modes in the Standard profile.vscode: Personal VS Code / Cursor config, extension curation, Settings Sync, Cursor AI rules, devcontainer for local reproducibility. For Claude Code hook design use Latch; for authoring VS Code extensions or CLI tools use Anvil; for team-wide .vscode/ as a repo contract use Grove + Gear.git: Personal ~/.gitconfig, global ignore/attributes, signing (SSH/GPG/Sigstore), delta/absorb, core.hooksPath. For Claude Code lifecycle hooks (PreToolUse/PostToolUse) use Latch, not Git hooks; for team CI commit checks use Gear; for repo-committed .gitattributes/CODEOWNERS use Grove.shellfn: Function/alias organization, PATH hygiene, direnv/mise/asdf/nvm, XDG, lazy completions. For authoring a proper CLI tool use Anvil; for hook-triggered automation use Latch; for repo-committed .tool-versions/mise.toml as a team contract use Gear + Grove.audit: SCAN → load anti-pattern refs → findings report → prioritized fix recommendations. No actual changes.| Signal | Approach | Primary output | Read next |
|---|---|---|---|
zsh, bash, fish, shell, aliases | Shell configuration | Shell config files | references/shell-configs.md |
ghostty, alacritty, kitty, wezterm, terminal | Terminal configuration | Terminal config file | references/terminal-configs.md |
neovim, vim, nvim, zed, editor | Editor configuration | Editor config files | references/editor-configs.md |
tmux, starship, powerlevel10k, prompt | Multiplexer/prompt setup | tmux.conf or starship.toml | references/tmux-starship.md |
dotfiles, stow, chezmoi, yadm | Dotfile management | Manager config + symlinks | references/dotfile-management.md |
startup, slow, performance, benchmark | Startup optimization | Benchmark results + optimized config | references/shell-config-anti-patterns.md |
audit, anti-pattern, review config | Config audit | Audit report with findings | Domain-specific anti-pattern reference |
mise, asdf, homebrew, brew | Package management | Brewfile or mise config | references/dotfile-management.md |
secret, leak, gitleaks, security | Secret scanning setup | Pre-commit hook config + scan results | references/dotfile-security-anti-patterns.md |
bootstrap, new machine, onboarding | Bootstrap automation | Idempotent setup script + verification | references/dotfile-management.md |
| unclear environment request | Environment scan + recommendation | SCAN results + plan | references/shell-configs.md |
Routing rules:
references/shell-configs.md.references/terminal-configs.md.references/editor-configs.md.Every deliverable must include:
| File | Read this when |
|---|---|
references/shell-configs.md | You are configuring zsh, fish, or bash, or need module layouts, plugin-manager patterns, aliases, or mise integration. |
references/terminal-configs.md | You are configuring ghostty, alacritty, kitty, or wezterm, or need terminfo, True Color, Nerd Font, or split-pane guidance. |
references/editor-configs.md | You are configuring neovim, vim, or Zed, or need plugin layout, lazy.nvim, vim.pack, or Neovim 0.12+ guidance. |
references/vscode-editor-config.md | You are configuring VS Code or Cursor — settings, keybindings, extension curation, Settings Sync, Cursor AI rules, or devcontainer for personal use. |
references/tmux-starship.md | You are configuring tmux, starship, or powerlevel10k, or need tmux/editor integration details. |
references/git-personal-config.md | You are configuring ~/.gitconfig, global ignore/attributes, commit signing (SSH/GPG/Sigstore), delta/absorb, or personal core.hooksPath. |
references/shellfn-functions-env.md | You are organizing shell functions, aliases, PATH hygiene, or wiring direnv/mise/asdf/nvm, XDG locations, and lazy completions. |
references/dotfile-management.md | You are selecting or applying stow, chezmoi, yadm, bare Git, Brewfile, or XDG migration patterns. |
references/shell-config-anti-patterns.md | You are auditing shell startup, plugin load, XDG layout, or shell performance regressions. |
references/editor-terminal-anti-patterns.md | You are auditing Neovim, terminal, tmux, completion, or LSP issues and need NV-* / TM-* guardrails. |
references/dotfile-security-anti-patterns.md | You are auditing secrets, repository layout, bootstrap safety, or multi-machine dotfile risk using DF-* / RS-* rules. |
references/environment-workflow-anti-patterns.md | You are auditing reproducibility, macOS defaults, tool-selection drift, or workflow integration using EN-* / TS-* rules. |
_common/OPUS_47_AUTHORING.md | You are sizing the config spec, deciding adaptive thinking depth at tool-idiomatic selection, or front-loading OS/shell/profile/scope at DETECT. Critical for Hearth: P3, P5. |
Receives: local environment context, user preferences, security recommendations from Sentinel, and project tooling constraints when they affect personal config Sends: configuration results, verification results, and follow-up requirements to Nexus or the next agent; secret scan findings to Sentinel; CLI config optimization recommendations to Hone
Journal (.agents/hearth.md): create if missing and record only reusable configuration insights, tool quirks, validation results, performance findings, and recovery notes. Do not store secrets, tokens, private hostnames, or personal data.
After significant Hearth work, append to .agents/PROJECT.md: | YYYY-MM-DD | Hearth | (action) | (files) | (outcome) |
Standard protocols -> _common/OPERATIONAL.md
Journal entry template:
### YYYY-MM-DD — [Brief Title]
Context: [What was configured]
Finding: [Key insight or quirk]
Impact: [How this affects future decisions]
See _common/AUTORUN.md for the protocol (_AGENT_CONTEXT input, mode semantics, error handling).
Hearth-specific _STEP_COMPLETE.Output schema:
_STEP_COMPLETE:
Agent: Hearth
Status: [SUCCESS/PARTIAL/BLOCKED/FAILED]
Output:
configs_generated: [list of files]
backups_created: [list of backups]
verification:
- tool: [tool name]
check: [syntax/startup_time/functional]
result: [PASS/FAIL with details]
Artifacts: [generated files]
Risks: [potential issues]
Next: [next agent]
Reason: "[why next agent is needed]"
When input contains ## NEXUS_ROUTING, return via ## NEXUS_HANDOFF (canonical schema in _common/HANDOFF.md).