| Crates.io | yek |
| lib.rs | yek |
| version | 0.22.1 |
| created_at | 2025-01-29 09:32:42.908734+00 |
| updated_at | 2025-09-17 08:45:25.317064+00 |
| description | A tool to serialize a repository into chunks of text files |
| homepage | |
| repository | https://github.com/bodo-run/yek |
| max_upload_size | |
| id | 1534534 |
| size | 403,919 |
yekA fast Rust based tool to serialize text-based files in a repository or directory for LLM consumption.1
By default:
.gitignore rules to skip unwanted files.yek.yaml file.Yek يک means "One" in Farsi/Persian.
Consider having a simple repo like this:
.
├── README.md
├── src
│ ├── main.rs
│ └── utils.rs
└── tests
└── test.rs
Running yek in this directory will produce a single file and write it to the temp directory with the following content:
>>>> README.md
... content ...
>>>> tests/test.rs
... content ...
>>>> src/utils.rs
... content ...
>>>> src/main.rs
... content ...
[!NOTE]
yekwill prioritize more important files to come last in the output. This is useful for LLM consumption since LLMs tend to pay more attention to content that appears later in the context.
Choose the installation method for your platform:
curl -fsSL https://bodo.run/yek.sh | bash
For Windows (PowerShell):
irm https://bodo.run/yek.ps1 | iex
git clone https://github.com/bodo-run/yek
cd yek
cargo install --path .
yek has sensible defaults, you can simply run yek in a directory to serialize the entire repository. It will serialize all files in the repository and write them into a temporary file. The path to the file will be printed to the console.
Process current directory and write to temp directory:
yek
Pipe output to clipboard (macOS):
yek src/ | pbcopy
Cap the max output size to 128K tokens:
yek --tokens 128k
[!NOTE]
yekwill remove any files that won't fit in the capped context size. It will try to fit in more important files
yek --max-size 100KB --output-dir /tmp/yek src/
Process multiple directories:
yek src/ tests/
Process multiple files
yek file1.txt file2.txt file3.txt
Use glob patterns:
yek "src/**/*.ts"
yek "src/main.rs" "tests/*.rs" "docs/README.md"
[!NOTE] When using glob patterns, make sure to quote them to prevent shell expansion.
yek --help
Usage: yek [OPTIONS] [input-dirs]...
Arguments:
[input-dirs]...
Options:
--no-config
--config-file <CONFIG_FILE>
--max-size <MAX_SIZE> [default: 10MB]
--tokens <TOKENS>
--json
--debug
--output-dir [<OUTPUT_DIR>]
--output-template <OUTPUT_TEMPLATE> [default: ">>>> FILE_PATH\nFILE_CONTENT"]
--ignore-patterns <IGNORE_PATTERNS>...
--unignore-patterns <UNIGNORE_PATTERNS>...
-h, --help Print help
You can place a file called yek.yaml at your project root or pass a custom path via --config. The configuration file allows you to:
yek.yamlYou can also use yek.toml or yek.json instead of yek.yaml.
This is optional, you can configure the yek.yaml file at the root of your project.
# Add patterns to ignore (in addition to .gitignore)
ignore_patterns:
- "ai-promots/**"
- "__generated__/**"
# Configure Git-based priority boost (optional)
git_boost_max: 50 # Maximum score boost based on Git history (default: 100)
# Define priority rules for processing order
# Higher scores are processed first
priority_rules:
- score: 100
pattern: "^src/lib/"
- score: 90
pattern: "^src/"
- score: 80
pattern: "^docs/"
# Add additional binary file extensions to ignore
# These extend the built-in list (.jpg, .png, .exe, etc.)
binary_extensions:
- ".blend" # Blender files
- ".fbx" # 3D model files
- ".max" # 3ds Max files
- ".psd" # Photoshop files
# Define output directory
output_dir: /tmp/yek
# Define output template.
# FILE_PATH and FILE_CONTENT are expected to be present in the template.
output_template: "{{{FILE_PATH}}}\n\nFILE_CONTENT"
All configuration keys are optional. By default:
.gitignore are used.yek is fast. It's written in Rust and does many things in parallel to speed up processing.
Here is a benchmark comparing it to Repomix serializing the Next.js project:
time yek
Executed in 5.19 secs fish external
usr time 2.85 secs 54.00 micros 2.85 secs
sys time 6.31 secs 629.00 micros 6.31 secs
time repomix
Executed in 22.24 mins fish external
usr time 21.99 mins 0.18 millis 21.99 mins
sys time 0.23 mins 1.72 millis 0.23 mins
yek is 230x faster than repomix.
See proposed features. I am open to accepting new feature requests. Please write a detailed proposal to discuss new features.
yek.yek is not "blazingly" fast. It's just fast, as fast as your computer can be. ↩