# llmgrep
[](https://crates.io/crates/llmgrep)
[](https://docs.rs/llmgrep)
**Version:** 3.1.0
Pattern-based code search for Magellan databases. Fast, deterministic symbol search with LLM-optimized JSON output.
**Positioning:** Read-only query tool for codebases indexed by Magellan. Use to find symbols, references, and call relationships. Emits structured JSON for AI-assisted code understanding.
## Purpose
**llmgrep queries Magellan databases.** Built for:
- **AI Assistants** — Structured JSON output designed for LLM consumption
- **Developers** — Fast symbol search without IDE overhead
- **Tooling** — Scriptable code analysis with precise byte spans
## Features
- **Symbol search** — Find functions, structs, traits by name or regex
- **Reference lookup** — Find all callers/callees of a function
- **Call graph traversal** — Navigate caller → callee relationships
- **AST filtering** — Filter by node kind, nesting depth, complexity
- **Geometric backend** — Native .geo file support with chunk retrieval
- **Path normalization** — Consistent path handling across platforms
- **Explicit ambiguity handling** — Structured results for disambiguation
## Quick Start
```bash
# Install
cargo install llmgrep
# Create Geometric database (recommended)
magellan watch --root ./src --db code.geo
# Search symbols
llmgrep --db code.geo search --query "parse"
# Find references
llmgrep --db code.geo search --query "MyType" --mode references
```
## Installation
```bash
cargo install llmgrep
```
## Backends
| **Geometric** | `.geo` | Full search + chunk retrieval + path normalization | **Default** |
| **SQLite** | `.db` | Full search | Legacy (always available) |
| **Native-V3** | `.v3` | O(1) KV operations + autocomplete | Reserved (disabled) |
**Geometric (.geo) features:**
- Path normalization before queries
- Explicit ambiguity error handling
- Code chunk retrieval (no file I/O)
- No SQLite dependencies
**Backend detection is automatic** — no flags needed. Detects by file extension (`.geo`) and header bytes.
## Requirements
- **[Magellan](https://github.com/oldnordic/magellan)** 3.0.0+ — Required for indexing
- **[sqlitegraph](https://crates.io/crates/sqlitegraph)** 2.0.7+ — Included automatically
## Documentation
- **[MANUAL.md](MANUAL.md)** — Complete command reference and examples
- **[CHANGELOG.md](CHANGELOG.md)** — Version history
- **[API_INTEGRATION.md](API_INTEGRATION.md)** — Magellan contract details
- **[INVARIANTS.md](INVARIANTS.md)** — Behavior guarantees
## What llmgrep Does NOT Do
- ❌ Index code (use [Magellan](https://github.com/oldnordic/magellan))
- ❌ Type checking or semantic analysis
- ❌ Background file watching
- ❌ Code editing (use [splice](https://github.com/oldnordic/splice))
- ❌ CFG analysis (use [Mirage](https://github.com/oldnordic/mirage))
## License
GPL-3.0-only. See [LICENSE](LICENSE).