A tool to pack repository contents to single file for AI consumption
npm install repomix
Use Repomix online! š repomix.com
Need discussion? Join us on Discord!
Share your experience and tips
Stay updated on new features
Get help with configuration and usage







š¦ Repomix is a powerful tool that packs your entire repository into a single, AI-friendly file.
It is perfect for when you need to feed your codebase to Large Language Models (LLMs) or other AI tools like Claude,
ChatGPT, DeepSeek, Perplexity, Gemini, Gemma, Llama, Grok, and more.
Please consider sponsoring me.


We're honored! Repomix has been nominated for the Powered by AI category at the JSNation Open Source Awards 2025.
This wouldn't have been possible without all of you using and supporting Repomix. Thank you!
- Try Repomix in your browser at repomix.com
- Join our Discord Server for support and discussion
We look forward to seeing you there!
- AI-Optimized: Formats your codebase in a way that's easy for AI to understand and process.
- Token Counting: Provides token counts for each file and the entire repository, useful for LLM context limits.
- Simple to Use: You need just one command to pack your entire repository.
- Customizable: Easily configure what to include or exclude.
- Git-Aware: Automatically respects your .gitignore, .ignore, and .repomixignore files.
- Security-Focused: Incorporates Secretlint for robust security checks to detect and prevent inclusion of sensitive information.
- Code Compression: The --compress option uses Tree-sitter to extract key code elements, reducing token count while preserving structure.
You can try Repomix instantly in your project directory without installation:
``bash`
npx repomix@latest
Or install globally for repeated use:
`bashInstall using npm
npm install -g repomix
That's it! Repomix will generate a
repomix-output.xml file in your current directory, containing your entire
repository in an AI-friendly format.You can then send this file to an AI assistant with a prompt like:
`
This file contains all the files in the repository combined into one.
I want to refactor the code, so please review it first.
`When you propose specific changes, the AI might be able to generate code accordingly. With features like Claude's
Artifacts, you could potentially output multiple files, allowing for the generation of multiple interdependent pieces of
code.
Happy coding! š
$3
Want to try it quickly? Visit the official website at repomix.com. Simply enter your repository
name, fill in any optional details, and click the Pack button to see your generated output.
#### Available Options
The website offers several convenient features:
- Customizable output format (XML, Markdown, or Plain Text)
- Instant token count estimation
- Much more!
$3
Get instant access to Repomix directly from any GitHub repository! Our Chrome extension adds a convenient "Repomix" button to GitHub repository pages.
#### Install
- Chrome Extension: Repomix - Chrome Web Store
- Firefox Add-on: Repomix - Firefox Add-ons
#### Features
- One-click access to Repomix for any GitHub repository
- More exciting features coming soon!
$3
A community-maintained VSCode extension called Repomix Runner (created by massdo) lets you run Repomix right inside your editor with just a few clicks. Run it on any folder, manage outputs seamlessly, and control everything through VSCode's intuitive interface.
Want your output as a file or just the content? Need automatic cleanup? This extension has you covered. Plus, it works smoothly with your existing repomix.config.json.
Try it now on the VSCode Marketplace!
Source code is available on GitHub.
$3
If you're using Python, you might want to check out
Gitingest, which is better suited for Python ecosystem and data
science workflows:
https://github.com/cyclotruc/gitingestš Usage
To pack your entire repository:
`bash
repomix
`To pack a specific directory:
`bash
repomix path/to/directory
`To pack specific files or directories
using glob patterns:
`bash
repomix --include "src//.ts,/.md"
`To exclude specific files or directories:
`bash
repomix --ignore "*/.log,tmp/"
`To pack a remote repository:
`bash
repomix --remote https://github.com/yamadashy/repomixYou can also use GitHub shorthand:
repomix --remote yamadashy/repomixYou can specify the branch name, tag, or commit hash:
repomix --remote https://github.com/yamadashy/repomix --remote-branch mainOr use a specific commit hash:
repomix --remote https://github.com/yamadashy/repomix --remote-branch 935b695Another convenient way is specifying the branch's URL
repomix --remote https://github.com/yamadashy/repomix/tree/mainCommit's URL is also supported
repomix --remote https://github.com/yamadashy/repomix/commit/836abcd7335137228ad77feb28655d85712680f1`To pack files from a file list (pipe via stdin):
`bash
Using find command
find src -name "*.ts" -type f | repomix --stdinUsing git to get tracked files
git ls-files "*.ts" | repomix --stdinUsing grep to find files containing specific content
grep -l "TODO" */.ts | repomix --stdinUsing ripgrep to find files with specific content
rg -l "TODO|FIXME" --type ts | repomix --stdinUsing ripgrep (rg) to find files
rg --files --type ts | repomix --stdinUsing sharkdp/fd to find files
fd -e ts | repomix --stdinUsing fzf to select from all files
fzf -m | repomix --stdinInteractive file selection with fzf
find . -name "*.ts" -type f | fzf -m | repomix --stdinUsing ls with glob patterns
ls src/*/.ts | repomix --stdinFrom a file containing file paths
cat file-list.txt | repomix --stdinDirect input with echo
echo -e "src/index.ts\nsrc/utils.ts" | repomix --stdin
`The
--stdin option allows you to pipe a list of file paths to Repomix, giving you ultimate flexibility in selecting which files to pack.When using
--stdin, the specified files are effectively added to the include patterns. This means that the normal include and ignore behavior still applies - files specified via stdin will still be excluded if they match ignore patterns.> [!NOTE]
> When using
--stdin, file paths can be relative or absolute, and Repomix will automatically handle path resolution and deduplication.To include git logs in the output:
`bash
Include git logs with default count (50 commits)
repomix --include-logsInclude git logs with specific commit count
repomix --include-logs --include-logs-count 10Combine with diffs for comprehensive git context
repomix --include-logs --include-diffs
`The git logs include commit dates, messages, and file paths for each commit, providing valuable context for AI analysis of code evolution and development patterns.
To compress the output:
`bash
repomix --compressYou can also use it with remote repositories:
repomix --remote yamadashy/repomix --compress
`To initialize a new configuration file (
repomix.config.json):`bash
repomix --init
`Once you have generated the packed file, you can use it with Generative AI tools like ChatGPT, DeepSeek, Perplexity, Gemini, Gemma, Llama, Grok, and more.
$3
You can also run Repomix using Docker.
This is useful if you want to run Repomix in an isolated environment or prefer using containers.
Basic usage (current directory):
`bash
docker run -v .:/app -it --rm ghcr.io/yamadashy/repomix
`To pack a specific directory:
`bash
docker run -v .:/app -it --rm ghcr.io/yamadashy/repomix path/to/directory
`Process a remote repository and output to a
output directory:`bash
docker run -v ./output:/app -it --rm ghcr.io/yamadashy/repomix --remote https://github.com/yamadashy/repomix
`$3
Once you have generated the packed file with Repomix, you can use it with AI tools like ChatGPT, DeepSeek, Perplexity, Gemini, Gemma, Llama, Grok, and more.
Here are some example prompts to get you started:
#### Code Review and Refactoring
For a comprehensive code review and refactoring suggestions:
`
This file contains my entire codebase. Please review the overall structure and suggest any improvements or refactoring opportunities, focusing on maintainability and scalability.
`#### Documentation Generation
To generate project documentation:
`
Based on the codebase in this file, please generate a detailed README.md that includes an overview of the project, its main features, setup instructions, and usage examples.
`#### Test Case Generation
For generating test cases:
`
Analyze the code in this file and suggest a comprehensive set of unit tests for the main functions and classes. Include edge cases and potential error scenarios.
`#### Code Quality Assessment
Evaluate code quality and adherence to best practices:
`
Review the codebase for adherence to coding best practices and industry standards. Identify areas where the code could be improved in terms of readability, maintainability, and efficiency. Suggest specific changes to align the code with best practices.
`#### Library Overview
Get a high-level understanding of the library
`
This file contains the entire codebase of library. Please provide a comprehensive overview of the library, including its main purpose, key features, and overall architecture.
`Feel free to modify these prompts based on your specific needs and the capabilities of the AI tool you're using.
$3
Check out our community discussion where users share:
- Which AI tools they're using with Repomix
- Effective prompts they've discovered
- How Repomix has helped them
- Tips and tricks for getting the most out of AI code analysis
Feel free to join the discussion and share your own experiences! Your insights could help others make better use of
Repomix.
$3
Repomix generates a single file with clear separators between different parts of your codebase.
To enhance AI comprehension, the output file begins with an AI-oriented explanation, making it easier for AI models to
understand the context and structure of the packed repository.
#### XML Format (default)
The XML format structures the content in a hierarchical manner:
`xml
This file is a merged representation of the entire codebase, combining all repository files into a single document.
(Metadata and usage AI instructions)
src/
cli/
cliOutput.ts
index.ts
(...remaining directories)
// File contents here
(...remaining files)
(Custom instructions from
output.instructionFilePath)
`For those interested in the potential of XML tags in AI contexts:
https://docs.anthropic.com/en/docs/build-with-claude/prompt-engineering/use-xml-tags
> When your prompts involve multiple components like context, instructions, and examples, XML tags can be a
> game-changer. They help Claude parse your prompts more accurately, leading to higher-quality outputs.
This means that the XML output from Repomix is not just a different format, but potentially a more effective way to feed
your codebase into AI systems for analysis, code review, or other tasks.
#### Markdown Format
To generate output in Markdown format, use the
--style markdown option:`bash
repomix --style markdown
`The Markdown format structures the content in a hierarchical manner:
``markdown
This file is a merged representation of the entire codebase, combining all repository files into a single document.File Summary
(Metadata and usage AI instructions)
Repository Structure
`
src/
cli/
cliOutput.ts
index.ts
`(...remaining directories)
Repository Files
File: src/index.js
`
// File contents here
`(...remaining files)
Instruction
(Custom instructions from
output.instructionFilePath)
``This format provides a clean, readable structure that is both human-friendly and easily parseable by AI systems.
#### JSON Format
To generate output in JSON format, use the
--style json option:`bash
repomix --style json
`The JSON format structures the content as a hierarchical JSON object with camelCase property names:
`json
{
"fileSummary": {
"generationHeader": "This file is a merged representation of the entire codebase, combined into a single document by Repomix.",
"purpose": "This file contains a packed representation of the entire repository's contents...",
"fileFormat": "The content is organized as follows...",
"usageGuidelines": "- This file should be treated as read-only...",
"notes": "- Some files may have been excluded based on .gitignore, .ignore, and .repomixignore rules..."
},
"userProvidedHeader": "Custom header text if specified",
"directoryStructure": "src/\n cli/\n cliOutput.ts\n index.ts\n config/\n configLoader.ts",
"files": {
"src/index.js": "// File contents here",
"src/utils.js": "// File contents here"
},
"instruction": "Custom instructions from instructionFilePath"
}
`This format is ideal for:
- Programmatic processing: Easy to parse and manipulate with JSON libraries
- API integration: Direct consumption by web services and applications
- AI tool compatibility: Structured format for machine learning and AI systems
- Data analysis: Straightforward extraction of specific information using tools like
jq##### Working with JSON Output Using
jqThe JSON format makes it easy to extract specific information programmatically:
`bash
List all file paths
cat repomix-output.json | jq -r '.files | keys[]'Count total number of files
cat repomix-output.json | jq '.files | keys | length'Extract specific file content
cat repomix-output.json | jq -r '.files["README.md"]'
cat repomix-output.json | jq -r '.files["src/index.js"]'Find files by extension
cat repomix-output.json | jq -r '.files | keys[] | select(endswith(".ts"))'Get files containing specific text
cat repomix-output.json | jq -r '.files | to_entries[] | select(.value | contains("function")) | .key'Extract directory structure
cat repomix-output.json | jq -r '.directoryStructure'Get file summary information
cat repomix-output.json | jq '.fileSummary.purpose'
cat repomix-output.json | jq -r '.fileSummary.generationHeader'Extract user-provided header (if exists)
cat repomix-output.json | jq -r '.userProvidedHeader // "No header provided"'Create a file list with sizes
cat repomix-output.json | jq -r '.files | to_entries[] | "\(.key): \(.value | length) characters"'
`#### Plain Text Format
To generate output in plain text format, use the
--style plain option:`bash
repomix --style plain
``text
This file is a merged representation of the entire codebase, combining all repository files into a single document.================================================================
File Summary
================================================================
(Metadata and usage AI instructions)
================================================================
Directory Structure
================================================================
src/
cli/
cliOutput.ts
index.ts
config/
configLoader.ts
(...remaining directories)
================================================================
Files
================================================================
================
File: src/index.js
================
// File contents here
================
File: src/utils.js
================
// File contents here
(...remaining files)
================================================================
Instruction
================================================================
(Custom instructions from
output.instructionFilePath)
`$3
#### Basic Options
-
-v, --version: Show version information and exit#### CLI Input/Output Options
-
--verbose: Enable detailed debug logging (shows file processing, token counts, and configuration details)
- --quiet: Suppress all console output except errors (useful for scripting)
- --stdout: Write packed output directly to stdout instead of a file (suppresses all logging)
- --stdin: Read file paths from stdin, one per line (specified files are processed directly)
- --copy: Copy the generated output to system clipboard after processing
- --token-count-tree [threshold]: Show file tree with token counts; optional threshold to show only files with ā„N tokens (e.g., --token-count-tree 100)
- --top-files-len : Number of largest files to show in summary (default: 5, e.g., --top-files-len 20)#### Repomix Output Options
-
-o, --output : Output file path (default: repomix-output.xml, use "-" for stdout)
- --style