lenson78's picture
initial upload: v2026.3.23 with HF Spaces deployment
9aa5185 verified
metadata
sidebar_position: 1
title: CLI Interface
description: >-
  Master the Hermes Agent terminal interface โ€” commands, keybindings,
  personalities, and more

CLI Interface

Hermes Agent's CLI is a full terminal user interface (TUI) โ€” not a web UI. It features multiline editing, slash-command autocomplete, conversation history, interrupt-and-redirect, and streaming tool output. Built for people who live in the terminal.

Running the CLI

# Start an interactive session (default)
hermes

# Single query mode (non-interactive)
hermes chat -q "Hello"

# With a specific model
hermes chat --model "anthropic/claude-sonnet-4"

# With a specific provider
hermes chat --provider nous        # Use Nous Portal
hermes chat --provider openrouter  # Force OpenRouter

# With specific toolsets
hermes chat --toolsets "web,terminal,skills"

# Start with one or more skills preloaded
hermes -s hermes-agent-dev,github-auth
hermes chat -s github-pr-workflow -q "open a draft PR"

# Resume previous sessions
hermes --continue             # Resume the most recent CLI session (-c)
hermes --resume <session_id>  # Resume a specific session by ID (-r)

# Verbose mode (debug output)
hermes chat --verbose

# Isolated git worktree (for running multiple agents in parallel)
hermes -w                         # Interactive mode in worktree
hermes -w -q "Fix issue #123"     # Single query in worktree

Interface Layout

Stylized preview of the Hermes CLI layout showing the banner, conversation area, and fixed input prompt.

The Hermes CLI banner, conversation stream, and fixed input prompt rendered as a stable docs figure instead of fragile text art.

The welcome banner shows your model, terminal backend, working directory, available tools, and installed skills at a glance.

Status Bar

A persistent status bar sits above the input area, updating in real time:

 โš• claude-sonnet-4-20250514 โ”‚ 12.4K/200K โ”‚ [โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–‘โ–‘โ–‘โ–‘] 6% โ”‚ $0.06 โ”‚ 15m
Element Description
Model name Current model (truncated if longer than 26 chars)
Token count Context tokens used / max context window
Context bar Visual fill indicator with color-coded thresholds
Cost Estimated session cost (or n/a for unknown/zero-priced models)
Duration Elapsed session time

The bar adapts to terminal width โ€” full layout at โ‰ฅ 76 columns, compact at 52โ€“75, minimal (model + duration only) below 52.

Context color coding:

Color Threshold Meaning
Green < 50% Plenty of room
Yellow 50โ€“80% Getting full
Orange 80โ€“95% Approaching limit
Red โ‰ฅ 95% Near overflow โ€” consider /compress

Use /usage for a detailed breakdown including per-category costs (input vs output tokens).

Session Resume Display

When resuming a previous session (hermes -c or hermes --resume <id>), a "Previous Conversation" panel appears between the banner and the input prompt, showing a compact recap of the conversation history. See Sessions โ€” Conversation Recap on Resume for details and configuration.

Keybindings

Key Action
Enter Send message
Alt+Enter or Ctrl+J New line (multi-line input)
Alt+V Paste an image from the clipboard when supported by the terminal
Ctrl+V Paste text and opportunistically attach clipboard images
Ctrl+B Start/stop voice recording when voice mode is enabled (voice.record_key, default: ctrl+b)
Ctrl+C Interrupt agent (double-press within 2s to force exit)
Ctrl+D Exit
Tab Accept auto-suggestion (ghost text) or autocomplete slash commands

Slash Commands

Type / to see the autocomplete dropdown. Hermes supports a large set of CLI slash commands, dynamic skill commands, and user-defined quick commands.

Common examples:

Command Description
/help Show command help
/model Show or change the current model
/tools List currently available tools
/skills browse Browse the skills hub and official optional skills
/background <prompt> Run a prompt in a separate background session
/skin Show or switch the active CLI skin
/voice on Enable CLI voice mode (press Ctrl+B to record)
/voice tts Toggle spoken playback for Hermes replies
/reasoning high Increase reasoning effort
/title My Session Name the current session

For the full built-in CLI and messaging lists, see Slash Commands Reference.

For setup, providers, silence tuning, and messaging/Discord voice usage, see Voice Mode.

:::tip Commands are case-insensitive โ€” /HELP works the same as /help. Installed skills also become slash commands automatically. :::

Quick Commands

You can define custom commands that run shell commands instantly without invoking the LLM. These work in both the CLI and messaging platforms (Telegram, Discord, etc.).

# ~/.hermes/config.yaml
quick_commands:
  status:
    type: exec
    command: systemctl status hermes-agent
  gpu:
    type: exec
    command: nvidia-smi --query-gpu=utilization.gpu,memory.used --format=csv,noheader

Then type /status or /gpu in any chat. See the Configuration guide for more examples.

Preloading Skills at Launch

If you already know which skills you want active for the session, pass them at launch time:

hermes -s hermes-agent-dev,github-auth
hermes chat -s github-pr-workflow -s github-auth

Hermes loads each named skill into the session prompt before the first turn. The same flag works in interactive mode and single-query mode.

Skill Slash Commands

Every installed skill in ~/.hermes/skills/ is automatically registered as a slash command. The skill name becomes the command:

/gif-search funny cats
/axolotl help me fine-tune Llama 3 on my dataset
/github-pr-workflow create a PR for the auth refactor

# Just the skill name loads it and lets the agent ask what you need:
/excalidraw

Personalities

Set a predefined personality to change the agent's tone:

/personality pirate
/personality kawaii
/personality concise

Built-in personalities include: helpful, concise, technical, creative, teacher, kawaii, catgirl, pirate, shakespeare, surfer, noir, uwu, philosopher, hype.

You can also define custom personalities in ~/.hermes/config.yaml:

personalities:
  helpful: "You are a helpful, friendly AI assistant."
  kawaii: "You are a kawaii assistant! Use cute expressions..."
  pirate: "Arrr! Ye be talkin' to Captain Hermes..."
  # Add your own!

Multi-line Input

There are two ways to enter multi-line messages:

  1. Alt+Enter or Ctrl+J โ€” inserts a new line
  2. Backslash continuation โ€” end a line with \ to continue:
โฏ Write a function that:\
  1. Takes a list of numbers\
  2. Returns the sum

:::info Pasting multi-line text is supported โ€” use Alt+Enter or Ctrl+J to insert newlines, or simply paste content directly. :::

Interrupting the Agent

You can interrupt the agent at any point:

  • Type a new message + Enter while the agent is working โ€” it interrupts and processes your new instructions
  • Ctrl+C โ€” interrupt the current operation (press twice within 2s to force exit)
  • In-progress terminal commands are killed immediately (SIGTERM, then SIGKILL after 1s)
  • Multiple messages typed during interrupt are combined into one prompt

Tool Progress Display

The CLI shows animated feedback as the agent works:

Thinking animation (during API calls):

  โ—œ (๏ฝกโ€ขฬ๏ธฟโ€ขฬ€๏ฝก) pondering... (1.2s)
  โ—  (โŠ™_โŠ™) contemplating... (2.4s)
  โœงูฉ(หŠแ—œห‹*)ูˆโœง got it! (3.1s)

Tool execution feed:

  โ”Š ๐Ÿ’ป terminal `ls -la` (0.3s)
  โ”Š ๐Ÿ” web_search (1.2s)
  โ”Š ๐Ÿ“„ web_extract (2.1s)

Cycle through display modes with /verbose: off โ†’ new โ†’ all โ†’ verbose.

Session Management

Resuming Sessions

When you exit a CLI session, a resume command is printed:

Resume this session with:
  hermes --resume 20260225_143052_a1b2c3

Session:        20260225_143052_a1b2c3
Duration:       12m 34s
Messages:       28 (5 user, 18 tool calls)

Resume options:

hermes --continue                          # Resume the most recent CLI session
hermes -c                                  # Short form
hermes -c "my project"                     # Resume a named session (latest in lineage)
hermes --resume 20260225_143052_a1b2c3     # Resume a specific session by ID
hermes --resume "refactoring auth"         # Resume by title
hermes -r 20260225_143052_a1b2c3           # Short form

Resuming restores the full conversation history from SQLite. The agent sees all previous messages, tool calls, and responses โ€” just as if you never left.

Use /title My Session Name inside a chat to name the current session, or hermes sessions rename <id> <title> from the command line. Use hermes sessions list to browse past sessions.

Session Storage

CLI sessions are stored in Hermes's SQLite state database under ~/.hermes/state.db. The database keeps:

  • session metadata (ID, title, timestamps, token counters)
  • message history
  • lineage across compressed/resumed sessions
  • full-text search indexes used by session_search

Some messaging adapters also keep per-platform transcript files alongside the database, but the CLI itself resumes from the SQLite session store.

Context Compression

Long conversations are automatically summarized when approaching context limits:

# In ~/.hermes/config.yaml
compression:
  enabled: true
  threshold: 0.50    # Compress at 50% of context limit by default
  summary_model: "google/gemini-3-flash-preview"  # Model used for summarization

When compression triggers, middle turns are summarized while the first 3 and last 4 turns are always preserved.

Background Sessions

Run a prompt in a separate background session while continuing to use the CLI for other work:

/background Analyze the logs in /var/log and summarize any errors from today

Hermes immediately confirms the task and gives you back the prompt:

๐Ÿ”„ Background task #1 started: "Analyze the logs in /var/log and summarize..."
   Task ID: bg_143022_a1b2c3

How It Works

Each /background prompt spawns a completely separate agent session in a daemon thread:

  • Isolated conversation โ€” the background agent has no knowledge of your current session's history. It receives only the prompt you provide.
  • Same configuration โ€” the background agent inherits your model, provider, toolsets, reasoning settings, and fallback model from the current session.
  • Non-blocking โ€” your foreground session stays fully interactive. You can chat, run commands, or even start more background tasks.
  • Multiple tasks โ€” you can run several background tasks simultaneously. Each gets a numbered ID.

Results

When a background task finishes, the result appears as a panel in your terminal:

โ•ญโ”€ โš• Hermes (background #1) โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฎ
โ”‚ Found 3 errors in syslog from today:                         โ”‚
โ”‚ 1. OOM killer invoked at 03:22 โ€” killed process nginx        โ”‚
โ”‚ 2. Disk I/O error on /dev/sda1 at 07:15                      โ”‚
โ”‚ 3. Failed SSH login attempts from 192.168.1.50 at 14:30      โ”‚
โ•ฐโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ•ฏ

If the task fails, you'll see an error notification instead. If display.bell_on_complete is enabled in your config, the terminal bell rings when the task finishes.

Use Cases

  • Long-running research โ€” "/background research the latest developments in quantum error correction" while you work on code
  • File processing โ€” "/background analyze all Python files in this repo and list any security issues" while you continue a conversation
  • Parallel investigations โ€” start multiple background tasks to explore different angles simultaneously

:::info Background sessions do not appear in your main conversation history. They are standalone sessions with their own task ID (e.g., bg_143022_a1b2c3). :::

Quiet Mode

By default, the CLI runs in quiet mode which:

  • Suppresses verbose logging from tools
  • Enables kawaii-style animated feedback
  • Keeps output clean and user-friendly

For debug output:

hermes chat --verbose