Checkpoints and /rollback
Checkpoints and /rollback
Section titled “Checkpoints and /rollback”Hermes Agent automatically snapshots your project before destructive operations and lets you restore it with a single command. Checkpoints are enabled by default — there’s zero cost when no file-mutating tools fire.
This safety net is powered by an internal Checkpoint Manager that keeps a separate shadow git repository under ~/.hermes/checkpoints/ — your real project .git is never touched.
What Triggers a Checkpoint
Section titled “What Triggers a Checkpoint”Checkpoints are taken automatically before:
- File tools —
write_fileandpatch - Destructive terminal commands —
rm,rmdir,cp,install,mv,sed -i,truncate,dd,shred, output redirects (>), andgit reset/clean/checkout
The agent creates at most one checkpoint per directory per turn, so long-running sessions don’t spam snapshots.
Quick Reference
Section titled “Quick Reference”| Command | Description |
|---|---|
/rollback | List all checkpoints with change stats |
/rollback <N> | Restore to checkpoint N (also undoes last chat turn) |
/rollback diff <N> | Preview diff between checkpoint N and current state |
/rollback <N> <file> | Restore a single file from checkpoint N |
How Checkpoints Work
Section titled “How Checkpoints Work”At a high level:
- Hermes detects when tools are about to modify files in your working tree.
- Once per conversation turn (per directory), it:
- Resolves a reasonable project root for the file.
- Initialises or reuses a shadow git repo tied to that directory.
- Stages and commits the current state with a short, human‑readable reason.
- These commits form a checkpoint history that you can inspect and restore via
/rollback.
flowchart LR user["User command\n(hermes, gateway)"] agent["AIAgent\n(run_agent.py)"] tools["File & terminal tools"] cpMgr["CheckpointManager"] shadowRepo["Shadow git repo\n~/.hermes/checkpoints/<hash>"]
user --> agent agent -->|"tool call"| tools tools -->|"before mutate\nensure_checkpoint()"| cpMgr cpMgr -->|"git add/commit"| shadowRepo cpMgr -->|"OK / skipped"| tools tools -->|"apply changes"| agentConfiguration
Section titled “Configuration”Checkpoints are enabled by default. Configure in ~/.hermes/config.yaml:
checkpoints: enabled: true # master switch (default: true) max_snapshots: 50 # max checkpoints per directory
# Auto-maintenance (opt-in): sweep ~/.hermes/checkpoints/ at startup # and delete shadow repos whose working directory no longer exists # (orphans) or whose newest commit is older than retention_days. # Runs at most once per min_interval_hours, tracked via a # .last_prune marker inside ~/.hermes/checkpoints/. auto_prune: false # default off — enable to reclaim disk retention_days: 7 delete_orphans: true # delete repos whose workdir is gone min_interval_hours: 24To disable:
checkpoints: enabled: falseWhen disabled, the Checkpoint Manager is a no‑op and never attempts git operations.
Listing Checkpoints
Section titled “Listing Checkpoints”From a CLI session:
/rollbackHermes responds with a formatted list showing change statistics:
📸 Checkpoints for /path/to/project:
1. 4270a8c 2026-03-16 04:36 before patch (1 file, +1/-0) 2. eaf4c1f 2026-03-16 04:35 before write_file 3. b3f9d2e 2026-03-16 04:34 before terminal: sed -i s/old/new/ config.py (1 file, +1/-1)
/rollback <N> restore to checkpoint N /rollback diff <N> preview changes since checkpoint N /rollback <N> <file> restore a single file from checkpoint NEach entry shows:
- Short hash
- Timestamp
- Reason (what triggered the snapshot)
- Change summary (files changed, insertions/deletions)
Previewing Changes with /rollback diff
Section titled “Previewing Changes with /rollback diff”Before committing to a restore, preview what has changed since a checkpoint:
/rollback diff 1This shows a git diff stat summary followed by the actual diff:
test.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/test.py b/test.py--- a/test.py+++ b/test.py@@ -1 +1 @@-print('original content')+print('modified content')Long diffs are capped at 80 lines to avoid flooding the terminal.
Restoring with /rollback
Section titled “Restoring with /rollback”Restore to a checkpoint by number:
/rollback 1Behind the scenes, Hermes:
- Verifies the target commit exists in the shadow repo.
- Takes a pre‑rollback snapshot of the current state so you can “undo the undo” later.
- Restores tracked files in your working directory.
- Undoes the last conversation turn so the agent’s context matches the restored filesystem state.
On success:
✅ Restored to checkpoint 4270a8c5: before patchA pre-rollback snapshot was saved automatically.(^_^)b Undid 4 message(s). Removed: "Now update test.py to ..." 4 message(s) remaining in history. Chat turn undone to match restored file state.The conversation undo ensures the agent doesn’t “remember” changes that have been rolled back, avoiding confusion on the next turn.
Single-File Restore
Section titled “Single-File Restore”Restore just one file from a checkpoint without affecting the rest of the directory:
/rollback 1 src/broken_file.pyThis is useful when the agent made changes to multiple files but only one needs to be reverted.
Safety and Performance Guards
Section titled “Safety and Performance Guards”To keep checkpointing safe and fast, Hermes applies several guardrails:
- Git availability — if
gitis not found onPATH, checkpoints are transparently disabled. - Directory scope — Hermes skips overly broad directories (root
/, home$HOME). - Repository size — directories with more than 50,000 files are skipped to avoid slow git operations.
- No‑change snapshots — if there are no changes since the last snapshot, the checkpoint is skipped.
- Non‑fatal errors — all errors inside the Checkpoint Manager are logged at debug level; your tools continue to run.
Where Checkpoints Live
Section titled “Where Checkpoints Live”All shadow repos live under:
~/.hermes/checkpoints/ ├── <hash1>/ # shadow git repo for one working directory ├── <hash2>/ └── ...Each <hash> is derived from the absolute path of the working directory. Inside each shadow repo you’ll find:
- Standard git internals (
HEAD,refs/,objects/) - An
info/excludefile containing a curated ignore list - A
HERMES_WORKDIRfile pointing back to the original project root
You normally never need to touch these manually.
Best Practices
Section titled “Best Practices”- Leave checkpoints enabled — they’re on by default and have zero cost when no files are modified.
- Use
/rollback diffbefore restoring — preview what will change to pick the right checkpoint. - Use
/rollbackinstead ofgit resetwhen you want to undo agent-driven changes only. - Combine with Git worktrees for maximum safety — keep each Hermes session in its own worktree/branch, with checkpoints as an extra layer.
For running multiple agents in parallel on the same repo, see the guide on Git worktrees.