website/docs/guides/use-soul-with-hermes.md
SOUL.md is the primary identity for your Hermes instance. It's the first thing in the system prompt — it defines who the agent is, how it speaks, and what it avoids.
If you want Hermes to feel like the same assistant every time you talk to it — or if you want to replace the Hermes persona entirely with your own — this is the file to use.
Use SOUL.md for:
In short:
SOUL.md is about who Hermes is and how Hermes speaksDo not use it for:
Those belong in AGENTS.md.
A good rule:
SOUL.mdAGENTS.mdHermes now uses only the global SOUL file for the current instance:
~/.hermes/SOUL.md
If you run Hermes with a custom home directory, it becomes:
$HERMES_HOME/SOUL.md
Hermes automatically seeds a starter SOUL.md for you if one does not already exist.
That means most users now begin with a real file they can read and edit immediately.
Important:
SOUL.md, Hermes does not overwrite itWhen Hermes starts a session, it reads SOUL.md from HERMES_HOME, scans it for prompt-injection patterns, truncates it if needed, and uses it as the agent identity — slot #1 in the system prompt. This means SOUL.md completely replaces the built-in default identity text.
If SOUL.md is missing, empty, or cannot be loaded, Hermes falls back to a built-in default identity.
No wrapper language is added around the file. The content itself matters — write the way you want your agent to think and speak.
If you do nothing else, open the file and change just a few lines so it feels like you.
For example:
You are direct, calm, and technically precise.
Prefer substance over politeness theater.
Push back clearly when an idea is weak.
Keep answers compact unless deeper detail is useful.
That alone can noticeably change how Hermes feels.
You are a pragmatic senior engineer.
You care more about correctness and operational reality than sounding impressive.
## Style
- Be direct
- Be concise unless complexity requires depth
- Say when something is a bad idea
- Prefer practical tradeoffs over idealized abstractions
## Avoid
- Sycophancy
- Hype language
- Overexplaining obvious things
You are a thoughtful research collaborator.
You are curious, honest about uncertainty, and excited by unusual ideas.
## Style
- Explore possibilities without pretending certainty
- Distinguish speculation from evidence
- Ask clarifying questions when the idea space is underspecified
- Prefer conceptual depth over shallow completeness
You are a patient technical teacher.
You care about understanding, not performance.
## Style
- Explain clearly
- Use examples when they help
- Do not assume prior knowledge unless the user signals it
- Build from intuition to details
You are a rigorous reviewer.
You are fair, but you do not soften important criticism.
## Style
- Point out weak assumptions directly
- Prioritize correctness over harmony
- Be explicit about risks and tradeoffs
- Prefer blunt clarity to vague diplomacy
A strong SOUL.md is:
A weak SOUL.md is:
Hermes already tries to be helpful and clear. SOUL.md should add real personality and style, not restate obvious defaults.
You do not need headings, but they help.
A simple structure that works well:
# Identity
Who Hermes is.
# Style
How Hermes should sound.
# Avoid
What Hermes should not do.
# Defaults
How Hermes should behave when ambiguity appears.
These are complementary.
Use SOUL.md for your durable baseline.
Use /personality for temporary mode switches.
Examples:
/personality teacherThis is the most common mistake.
frontend/.”nano ~/.hermes/SOUL.md
or
vim ~/.hermes/SOUL.md
Then restart Hermes or start a new session.
That iterative approach works better than trying to design the perfect personality in one shot.
Check:
~/.hermes/SOUL.md or $HERMES_HOME/SOUL.mdSOUL.md/personality overlay is not dominating the resultPossible causes:
Move project instructions into AGENTS.md and keep SOUL.md focused on identity and style.