--- sidebar_position: 8 title: "Context Files" description: "Project context files — AGENTS.md, global SOUL.md, and .cursorrules — automatically injected into every conversation" --- # Context Files Hermes Agent automatically discovers and loads context files that shape how it behaves. Some are project-local and discovered from your working directory. `SOUL.md` is now global to the Hermes instance and is loaded from `HERMES_HOME` only. ## Supported Context Files | File | Purpose | Discovery | |------|---------|-----------| | **AGENTS.md** | Project instructions, conventions, architecture | Recursive (walks subdirectories) | | **SOUL.md** | Global personality and tone customization for this Hermes instance | `HERMES_HOME/SOUL.md` only | | **.cursorrules** | Cursor IDE coding conventions | CWD only | | **.cursor/rules/*.mdc** | Cursor IDE rule modules | CWD only | ## AGENTS.md `AGENTS.md` is the primary project context file. It tells the agent how your project is structured, what conventions to follow, and any special instructions. ### Hierarchical Discovery Hermes walks the directory tree starting from the working directory and loads **all** `AGENTS.md` files found, sorted by depth. This supports monorepo-style setups: ``` my-project/ ├── AGENTS.md ← Top-level project context ├── frontend/ │ └── AGENTS.md ← Frontend-specific instructions ├── backend/ │ └── AGENTS.md ← Backend-specific instructions └── shared/ └── AGENTS.md ← Shared library conventions ``` All four files are concatenated into a single context block with relative path headers. :::info Directories that are skipped during the walk: `.`-prefixed dirs, `node_modules`, `__pycache__`, `venv`, `.venv`. ::: ### Example AGENTS.md ```markdown # Project Context This is a Next.js 14 web application with a Python FastAPI backend. ## Architecture - Frontend: Next.js 14 with App Router in `/frontend` - Backend: FastAPI in `/backend`, uses SQLAlchemy ORM - Database: PostgreSQL 16 - Deployment: Docker Compose on a Hetzner VPS ## Conventions - Use TypeScript strict mode for all frontend code - Python code follows PEP 8, use type hints everywhere - All API endpoints return JSON with `{data, error, meta}` shape - Tests go in `__tests__/` directories (frontend) or `tests/` (backend) ## Important Notes - Never modify migration files directly — use Alembic commands - The `.env.local` file has real API keys, don't commit it - Frontend port is 3000, backend is 8000, DB is 5432 ``` ## SOUL.md `SOUL.md` controls the agent's personality, tone, and communication style. See the [Personality](/docs/user-guide/features/personality) page for full details. **Location:** - `~/.hermes/SOUL.md` - or `$HERMES_HOME/SOUL.md` if you run Hermes with a custom home directory Important details: - Hermes seeds a default `SOUL.md` automatically if one does not exist yet - Hermes loads `SOUL.md` only from `HERMES_HOME` - Hermes does not probe the working directory for `SOUL.md` - If the file is empty, nothing from `SOUL.md` is added to the prompt - If the file has content, the content is injected verbatim after scanning and truncation ## .cursorrules Hermes is compatible with Cursor IDE's `.cursorrules` file and `.cursor/rules/*.mdc` rule modules. If these files exist in your project root, they're loaded alongside AGENTS.md. This means your existing Cursor conventions automatically apply when using Hermes. ## How Context Files Are Loaded Context files are loaded by `build_context_files_prompt()` in `agent/prompt_builder.py`: 1. **At session start** — the function scans the working directory 2. **Content is read** — each file is read as UTF-8 text 3. **Security scan** — content is checked for prompt injection patterns 4. **Truncation** — files exceeding 20,000 characters are head/tail truncated (70% head, 20% tail, with a marker in the middle) 5. **Assembly** — all sections are combined under a `# Project Context` header 6. **Injection** — the assembled content is added to the system prompt The final prompt section looks roughly like: ```text # Project Context The following project context files have been loaded and should be followed: ## AGENTS.md [Your AGENTS.md content here] ## .cursorrules [Your .cursorrules content here] [Your SOUL.md content here] ``` Notice that SOUL content is inserted directly, without extra wrapper text. ## Security: Prompt Injection Protection All context files are scanned for potential prompt injection before being included. The scanner checks for: - **Instruction override attempts**: "ignore previous instructions", "disregard your rules" - **Deception patterns**: "do not tell the user" - **System prompt overrides**: "system prompt override" - **Hidden HTML comments**: `` - **Hidden div elements**: `