Skip to content

Configuração

O Repomix pode ser configurado usando um arquivo de configuração (repomix.config.json) ou opções de linha de comando. O arquivo de configuração permite que você personalize vários aspectos de como seu código-fonte é processado e gerado.

Início rápido

Crie um arquivo de configuração no diretório do seu projeto:

bash
repomix --init

Isso criará um arquivo repomix.config.json com as configurações padrão. Você também pode criar um arquivo de configuração global que será usado como fallback quando nenhuma configuração local for encontrada:

bash
repomix --init --global

Opções de configuração

OpçãoDescriçãoPadrão
input.maxFileSizeTamanho máximo do arquivo em bytes para processar. Arquivos maiores serão ignorados. Útil para excluir arquivos binários grandes ou arquivos de dados50000000
output.filePathNome do arquivo de saída. Suporta formatos XML, Markdown e texto simples"repomix-output.xml"
output.styleEstilo de saída (xml, markdown, plain). Cada formato tem suas próprias vantagens para diferentes ferramentas de IA"xml"
output.parsableStyleIndica se a saída deve ser escapada de acordo com o esquema de estilo escolhido. Permite melhor análise mas pode aumentar a contagem de tokensfalse
output.compressIndica se deve realizar extração inteligente de código usando Tree-sitter para reduzir a contagem de tokens enquanto preserva a estruturafalse
output.headerTextTexto personalizado para incluir no cabeçalho do arquivo. Útil para fornecer contexto ou instruções para ferramentas de IAnull
output.instructionFilePathCaminho para um arquivo contendo instruções personalizadas detalhadas para processamento de IAnull
output.fileSummaryIndica se deve incluir uma seção de resumo no início mostrando contagens de arquivos, tamanhos e outras métricastrue
output.directoryStructureIndica se deve incluir a estrutura de diretórios na saída. Ajuda a IA a entender a organização do projetotrue
output.filesIndica se deve incluir o conteúdo dos arquivos na saída. Defina como false para incluir apenas estrutura e metadadostrue
output.removeCommentsIndica se deve remover comentários dos tipos de arquivos suportados. Pode reduzir ruído e contagem de tokensfalse
output.removeEmptyLinesIndica se deve remover linhas vazias da saída para reduzir a contagem de tokensfalse
output.showLineNumbersIndica se deve adicionar números de linha a cada linha. Útil para referenciar partes específicas do códigofalse
output.copyToClipboardIndica se deve copiar a saída para a área de transferência do sistema além de salvar o arquivofalse
output.topFilesLengthNúmero de arquivos principais para exibir no resumo. Se definido como 0, nenhum resumo será exibido5
output.includeEmptyDirectoriesIndica se deve incluir diretórios vazios na estrutura do repositóriofalse
output.git.sortByChangesIndica se deve ordenar arquivos por número de alterações git. Arquivos com mais alterações aparecem no finaltrue
output.git.sortByChangesMaxCommitsNúmero máximo de commits para analisar ao contar alterações git. Limita a profundidade do histórico por desempenho100
output.git.includeDiffsIndica se deve incluir as diferenças git na saída. Mostra separadamente as alterações da árvore de trabalho e as alterações preparadasfalse
includePadrões de arquivos para incluir usando padrões glob[]
ignore.useGitignoreIndica se deve usar os padrões do arquivo .gitignore do projetotrue
ignore.useDefaultPatternsIndica se deve usar os padrões de ignorar padrão (node_modules, .git, etc.)true
ignore.customPatternsPadrões adicionais para ignorar usando padrões glob[]
security.enableSecurityCheckIndica se deve realizar verificações de segurança usando Secretlint para detectar informações sensíveistrue
tokenCount.encodingCodificação de contagem de tokens usada pelo tokenizador tiktoken da OpenAI. Use o200k_base para GPT-4o, cl100k_base para GPT-4/3.5. Veja tiktoken model.py para mais detalhes."o200k_base"

O arquivo de configuração suporta a sintaxe JSON5, que permite:

  • Comentários (tanto de uma linha quanto multilinha)
  • Vírgulas finais em objetos e arrays
  • Nomes de propriedades sem aspas
  • Sintaxe de string mais flexível

Validação de esquema

Você pode habilitar a validação de esquema para seu arquivo de configuração adicionando a propriedade $schema:

json
{
  "$schema": "https://repomix.com/schemas/latest/schema.json",
  "output": {
    "filePath": "repomix-output.md",
    "style": "markdown"
  }
}

Isso fornece autocompletar e validação em editores que suportam esquema JSON.

Exemplo de arquivo de configuração

Aqui está um exemplo de um arquivo de configuração completo (repomix.config.json):

json
{
  "$schema": "https://repomix.com/schemas/latest/schema.json",
  "input": {
    "maxFileSize": 50000000
  },
  "output": {
    "filePath": "repomix-output.xml",
    "style": "xml",
    "parsableStyle": false,
    "compress": false,
    "headerText": "Informações de cabeçalho personalizadas para o arquivo empacotado.",
    "fileSummary": true,
    "directoryStructure": true,
    "files": true,
    "removeComments": false,
    "removeEmptyLines": false,
    "topFilesLength": 5,
    "showLineNumbers": false,
    "copyToClipboard": false,
    "includeEmptyDirectories": false,
    "git": {
      "sortByChanges": true,
      "sortByChangesMaxCommits": 100,
      "includeDiffs": false
    }
  },
  "include": ["**/*"],
  "ignore": {
    "useGitignore": true,
    "useDefaultPatterns": true,
    // Os padrões também podem ser especificados em .repomixignore
    "customPatterns": [
      "additional-folder",
      "**/*.log"
    ],
  },
  "security": {
    "enableSecurityCheck": true
  },
  "tokenCount": {
    "encoding": "o200k_base"
  }
}

Locais dos arquivos de configuração

O Repomix procura os arquivos de configuração na seguinte ordem:

  1. Arquivo de configuração local (repomix.config.json) no diretório atual
  2. Arquivo de configuração global:
    • Windows: %LOCALAPPDATA%\Repomix\repomix.config.json
    • macOS/Linux: ~/.config/repomix/repomix.config.json

As opções de linha de comando têm precedência sobre as configurações do arquivo.

Padrões de ignorar

O Repomix fornece múltiplas formas de especificar quais arquivos devem ser ignorados. Os padrões são processados na seguinte ordem de prioridade:

  1. Opções de CLI (--ignore)
  2. Arquivo .repomixignore no diretório do projeto
  3. .gitignore e .git/info/exclude (se ignore.useGitignore for verdadeiro)
  4. Padrões padrão (se ignore.useDefaultPatterns for verdadeiro)

Exemplo de .repomixignore:

text
# Diretórios de cache
.cache/
tmp/

# Saídas de compilação
dist/
build/

# Registros
*.log

Padrões de ignorar padrão

Quando ignore.useDefaultPatterns é verdadeiro, o Repomix ignora automaticamente padrões comuns:

text
node_modules/**
.git/**
coverage/**
dist/**

Para a lista completa, veja defaultIgnore.ts

Recursos avançados

Compressão de código

O recurso de compressão de código, habilitado com output.compress: true, usa Tree-sitter para extrair inteligentemente estruturas de código essenciais enquanto remove detalhes de implementação. Isso ajuda a reduzir a contagem de tokens enquanto mantém informações estruturais importantes.

Benefícios principais:

  • Reduz significativamente a contagem de tokens
  • Preserva as assinaturas de classes e funções
  • Mantém importações e exportações
  • Conserva definições de tipos e interfaces
  • Remove corpos de funções e detalhes de implementação

Para mais detalhes e exemplos, consulte o Guia de compressão de código.

Integração com Git

A configuração output.git fornece recursos poderosos relacionados ao Git:

  • sortByChanges: Quando verdadeiro, os arquivos são ordenados por número de alterações Git (commits que modificaram o arquivo). Arquivos com mais alterações aparecem no final da saída. Isso ajuda a priorizar os arquivos mais ativamente desenvolvidos. Padrão: true
  • sortByChangesMaxCommits: O número máximo de commits para analisar ao contar alterações de arquivos. Padrão: 100
  • includeDiffs: Quando verdadeiro, inclui as diferenças Git na saída (inclui separadamente as alterações da árvore de trabalho e as alterações preparadas). Isso permite que o leitor veja as alterações pendentes no repositório. Padrão: false

Exemplo de configuração:

json
{
  "output": {
    "git": {
      "sortByChanges": true,
      "sortByChangesMaxCommits": 100,
      "includeDiffs": true
    }
  }
}

Verificações de segurança

Quando security.enableSecurityCheck está habilitado, o Repomix usa Secretlint para detectar informações sensíveis em seu código-fonte antes de incluí-las na saída. Isso ajuda a prevenir a exposição acidental de:

  • Chaves de API
  • Tokens de acesso
  • Chaves privadas
  • Senhas
  • Outras credenciais sensíveis

Remoção de comentários

Quando output.removeComments é definido como true, os comentários são removidos dos tipos de arquivos suportados para reduzir o tamanho da saída e focar no conteúdo essencial do código. Isso pode ser particularmente útil quando:

  • Você está trabalhando com código altamente documentado
  • Você está tentando reduzir a contagem de tokens
  • Você está focando na estrutura e lógica do código

Para os idiomas suportados e exemplos detalhados, consulte o Guia de remoção de comentários.

Released under the MIT License.