Skip to content

Repomix

Pack your codebase into AI-friendly formats

Output Format

Include Patterns (using glob patterns)

Ignore Patterns

Output Format Options

File Processing Options

npm versionnpm downloadsDiscordSponsorsGitHub stars

🏆 Indicação para os Open Source Awards

Estamos honrados! O Repomix foi indicado na categoria Powered by AI no JSNation Open Source Awards 2025.

Isso não teria sido possível sem todos vocês que usam e apoiam o Repomix. Obrigado!

Se o Repomix ajudou você a analisar ou empacotar bases de código para ferramentas de IA, ficaríamos gratos pelo seu voto na categoria Powered by AI.

Você pode votar aqui: https://forms.gle/5QaYBM6pNoyWLfL2A

Obrigado pelo seu apoio!

Início Rápido

Depois de gerar um arquivo compactado (repomix-output.xml) usando o Repomix, você pode enviá-lo para um assistente de IA (como ChatGPT, Claude) com um prompt como:

Este arquivo contém todos os arquivos do repositório combinados em um.
Eu quero refatorar o código, então, por favor, revise-o primeiro.

A IA analisará todo o seu código-fonte e fornecerá insights abrangentes:

Repomix File Usage 1

Ao discutir mudanças específicas, a IA pode ajudar a gerar código. Com recursos como o Artifacts do Claude, você pode até receber vários arquivos interdependentes:

Repomix File Usage 2

Feliz codificação! 🚀

Usando a Ferramenta CLI

O Repomix pode ser usado como uma ferramenta de linha de comando, oferecendo recursos poderosos e opções de personalização.

A ferramenta CLI pode acessar repositórios privados pois utiliza o Git instalado localmente.

Início Rápido

Você pode experimentar o Repomix instantaneamente no diretório do seu projeto sem instalação:

bash
npx repomix

Ou instale globalmente para uso repetido:

bash
# Instalar com npm
npm install -g repomix

# Ou com yarn
yarn global add repomix

# Ou com bun
bun add -g repomix

# Ou com Homebrew (macOS/Linux)
brew install repomix

# Então execute em qualquer diretório de projeto
repomix

É isso! O Repomix irá gerar um arquivo repomix-output.xml no seu diretório atual, contendo todo o seu repositório em um formato amigável para IA.

Uso

Para compactar todo o seu repositório:

bash
repomix

Para compactar um diretório específico:

bash
repomix path/to/directory

Para compactar arquivos ou diretórios específicos usando glob patterns:

bash
repomix --include "src/**/*.ts,**/*.md"

Para excluir arquivos ou diretórios específicos:

bash
repomix --ignore "**/*.log,tmp/"

Para compactar um repositório remoto:

bash
# Usando formato abreviado
npx repomix --remote yamadashy/repomix

# Usando URL completa (suporta branches e caminhos específicos)
npx repomix --remote https://github.com/yamadashy/repomix
npx repomix --remote https://github.com/yamadashy/repomix/tree/main

# Usando URL do commit
npx repomix --remote https://github.com/yamadashy/repomix/commit/836abcd7335137228ad77feb28655d85712680f1

Para inicializar um novo arquivo de configuração (repomix.config.json):

bash
repomix --init

Depois de gerar o arquivo compactado, você pode usá-lo com ferramentas de IA Generativa como Claude, ChatGPT e Gemini.

Uso do Docker

Você também pode executar o Repomix usando o Docker 🐳 Isso é útil se você quiser executar o Repomix em um ambiente isolado ou preferir usar contêineres.

Uso básico (diretório atual):

bash
docker run -v .:/app -it --rm ghcr.io/yamadashy/repomix

Para compactar um diretório específico:

bash
docker run -v .:/app -it --rm ghcr.io/yamadashy/repomix path/to/directory

Processar um repositório remoto e enviar para um diretório output:

bash
docker run -v ./output:/app -it --rm ghcr.io/yamadashy/repomix --remote https://github.com/yamadashy/repomix

Formatos de Saída

Escolha seu formato de saída preferido:

bash
# Formato XML (padrão)
repomix --style xml

# Formato Markdown
repomix --style markdown

# Formato de texto simples
repomix --style plain

Customização

Crie um repomix.config.json para configurações persistentes:

json
{
  "output": {
    "style": "markdown",
    "filePath": "custom-output.md",
    "removeComments": true,
    "showLineNumbers": true,
    "topFilesLength": 10
  },
  "ignore": {
    "customPatterns": ["*.test.ts", "docs/**"]
  }
}

Mais Exemplos

Precisa de mais ajuda? 💡

Consulte nosso guia para instruções detalhadas, ou visite nosso repositório GitHub para mais exemplos e código-fonte.

Released under the MIT License.