repomix-rs: A Deep Dive into AI Code Context Infrastructure Built with Rus A developer built repomix-rs, an open-source Rust-based infrastructure for transmitting codebase structure and content in an AI-readable format. The tool addresses token budget constraints by using tiktoken-rs for tokenization, Tree-sitter for compression saving 70% tokens, and split-output to avoid exceeding context windows. It includes a CLI, MCP server, and core library for integration with AI tools like Claude and Cursor. This document is aimed at senior engineers, architects, and technical decision-makers. Open source, feel free to give a star πŸ’Ž GitHub 🫱: https://github.com/sopaco/repomix-rs Although current mainstream LLMs Deepseek, GLM have expanded their context windows, token costs grow linearly. A medium-sized project's complete source code often exceeds 100K tokens, surpassing the comfortable processing range of most models. Traditional solutions have structural flaws: | Solution | Problem | |---|---| | Manual splitting + prompt engineering | High human cost, not scalable | | RAG vector retrieval | Loses global structure; depends on embedding quality | | Copy-paste into chat | Error-prone; cannot be automated | | git archive + compression | AI cannot directly consume it | repomix solves a more fundamental problem: how to transmit a codebase's structure and content in an AI-readable format, precisely, completely, and reproducibly. The core constraint of AI engineering is the token budget. repomix-rs addresses three problems in a targeted way: tiktoken-rs OpenAI o200k base , fully aligned with GPT-4o billing. --split-output allows splitting by tokens, ensuring the context window is never exceeded. --compress Tree-sitter saves an average of 70% tokens without losing structural information. β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”‚ AI Consumer Layer β”‚ β”‚ β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”‚ β”‚ β”‚ Claude β”‚ β”‚ Cursor β”‚ β”‚ Hermes Agent β”‚ β”‚ β”‚ β”‚ Desktop β”‚ β”‚ IDE β”‚ β”‚ Custom Agents β”‚ β”‚ β”‚ β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜ β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜ β”‚ β”‚ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜ β”‚ β”‚ MCP Protocol JSON-RPC over stdio β”‚ β”‚ β–Ό β”‚ β”‚ β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”‚ β”‚ β”‚ repomix-mcp MCP Server β”‚ β”‚ β”‚ β”‚ Tools: pack codebase | pack remote repository β”‚ β”‚ β”‚ β”‚ read repomix output | grep repomix output β”‚ β”‚ β”‚ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜ β”‚ β”‚ β”‚ β”‚ β”‚ β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”‚ β”‚ β”‚repomix-cli β”‚ β”‚ repomix-core β”‚ β”‚ β”‚ β”‚ clap CLI β”‚ β”‚ Library β”‚ β”‚ β”‚ β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”˜ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜ β”‚ β”‚ β”‚ β”‚ repomix-config β”‚ β”‚ └──────────────────── Config Schema β”‚ β”‚ β”‚ β”‚ β”‚ β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”‚ β”‚ β”‚File Collectorβ”‚ β”‚ Processor β”‚ β”‚ Git Intg. β”‚ β”‚ β”‚ β”‚ rayon par. β”‚ β”‚ tree-sitter β”‚ β”‚ git CLI β”‚ β”‚ β”‚ β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”˜ β””β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”˜ β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”˜ β”‚ β”‚ β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”‚ β”‚ β”‚ β–Ό β–Ό β–Ό β”‚ β”‚ β”‚ β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”‚ β”‚ β”‚ β”‚File Systemβ”‚ β”‚ Secretlint β”‚ β”‚ tiktoken-rs β”‚ β”‚ β”‚ β”‚ β”‚ tokio fs β”‚ β”‚ Security β”‚ β”‚ Tokenize β”‚ β”‚ β”‚ β”‚ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜ β”‚ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜ repomix-rs adopts a 5-Crate Cargo Workspace architecture, aligned with Rust ecosystem best practices for layered design: repomix-rs/ β”œβ”€β”€ crates/ β”‚ β”œβ”€β”€ repomix-core/ ← Core engine public API β”‚ β”œβ”€β”€ repomix-config/ ← Config types + default modes β”‚ β”œβ”€β”€ repomix-shared/ ← Cross-crate shared types β”‚ β”œβ”€β”€ repomix-cli/ ← CLI entry point depends on core + config β”‚ └── repomix-mcp/ ← MCP Server depends on core + shared β”œβ”€β”€ Cargo.toml ← workspace root └── README.md repomix-core Core Engine This is the sole "business logic" crate, encompassing: | Module | Responsibility | |---|---| file collector | Recursive directory scanning; apply include/exclude rules | processor | File content processing compression, comment removal, AST analysis | output | Serialization for four formats XML / MD / JSON / Plain | git | Git-aware operations change frequency analysis, diff, log | metrics | Token counts, character statistics, Top-N leaderboard | security | Secretlint integration; suspicious file detection | Exposed Traits: async trait pub trait ProgressCallback: Send + Sync { fn on progress &self, msg: &str ; fn on complete &self, msg: &str ; fn on error &self, msg: &str ; } pub trait FileProcessor: Send + Sync { async fn process &self, file: &Path - Result