Servidor MCP
O Repomix suporta o Model Context Protocol (MCP), permitindo que assistentes de IA interajam diretamente com sua base de código. Quando executado como um servidor MCP, o Repomix fornece ferramentas que permitem aos assistentes de IA empacotar repositórios locais ou remotos para análise sem necessidade de preparação manual de arquivos.
NOTE
Este é um recurso experimental que estaremos melhorando ativamente com base no feedback dos usuários e no uso no mundo real
Executando o Repomix como um Servidor MCP
Para executar o Repomix como um servidor MCP, use a flag --mcp
:
bash
repomix --mcp
Isso inicia o Repomix no modo servidor MCP, tornando-o disponível para assistentes de IA que suportam o Model Context Protocol.
Configurando Servidores MCP
Para usar o Repomix como um servidor MCP com assistentes de IA como o Claude, você precisa configurar as definições do MCP:
Para VS Code
Você pode instalar o servidor MCP do Repomix no VS Code usando um destes métodos:
- Usando o distintivo de instalação:
- Usando a linha de comando:
bash
code --add-mcp '{"name":"repomix","command":"npx","args":["-y","repomix","--mcp"]}'
Para VS Code Insiders:
bash
code-insiders --add-mcp '{"name":"repomix","command":"npx","args":["-y","repomix","--mcp"]}'
Para o Cline (extensão do VS Code)
Edite o arquivo cline_mcp_settings.json
:
json
{
"mcpServers": {
"repomix": {
"command": "npx",
"args": [
"-y",
"repomix",
"--mcp"
]
}
}
}
Para o Cursor
No Cursor, adicione um novo servidor MCP a partir de Cursor Settings
> MCP
> + Add new global MCP server
com uma configuração similar à do Cline.
Para o Claude Desktop
Edite o arquivo claude_desktop_config.json
com uma configuração similar à do Cline.
Para o Claude Code
Para configurar o Repomix como servidor MCP no Claude Code, use o seguinte comando:
bash
claude mcp add repomix -- npx -y repomix --mcp
Usando Docker em vez de npx
Em vez de usar npx, você pode usar o Docker para executar o Repomix como um servidor MCP:
json
{
"mcpServers": {
"repomix-docker": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"ghcr.io/yamadashy/repomix",
"--mcp"
]
}
}
}
Ferramentas MCP Disponíveis
Quando executado como um servidor MCP, o Repomix fornece as seguintes ferramentas:
pack_codebase
Esta ferramenta empacota um diretório de código local em um arquivo XML para análise de IA. Ela analisa a estrutura da base de código, extrai conteúdo de código relevante e gera um relatório abrangente incluindo métricas, árvore de arquivos e conteúdo de código formatado.
Parâmetros:
directory
: (Obrigatório) Caminho absoluto para o diretório a ser empacotadocompress
: (Opcional, padrão: false) Habilita compressão Tree-sitter para extrair assinaturas de código essenciais e estrutura enquanto remove detalhes de implementação. Reduz o uso de tokens em ~70% mantendo o significado semântico. Geralmente não é necessário já que grep_repomix_output permite recuperação incremental de conteúdo. Use apenas quando você especificamente precisar do conteúdo completo da base de código para repositórios grandes.includePatterns
: (Opcional) Especifica arquivos para incluir usando padrões fast-glob. Múltiplos padrões podem ser separados por vírgula (ex: "/*.{js,ts}", "src/,docs/**"). Apenas arquivos correspondentes serão processados.ignorePatterns
: (Opcional) Especifica arquivos adicionais para excluir usando padrões fast-glob. Múltiplos padrões podem ser separados por vírgula (ex: "test/,*.spec.js", "node_modules/,dist/**"). Estes padrões complementam .gitignore e exclusões integradas.topFilesLength
: (Opcional, padrão: 10) Número de maiores arquivos por tamanho para exibir no resumo de métricas para análise da base de código.
Exemplo:
json
{
"directory": "/path/to/your/project",
"compress": false,
"includePatterns": "src/**/*.ts,**/*.md",
"ignorePatterns": "**/*.log,tmp/",
"topFilesLength": 10
}
pack_remote_repository
Esta ferramenta busca, clona e empacota um repositório GitHub em um arquivo XML para análise de IA. Ela automaticamente clona o repositório remoto, analisa sua estrutura e gera um relatório abrangente.
Parâmetros:
remote
: (Obrigatório) URL do repositório GitHub ou formato usuário/repo (ex: "yamadashy/repomix", "https://github.com/user/repo", ou "https://github.com/user/repo/tree/branch")compress
: (Opcional, padrão: false) Habilita compressão Tree-sitter para extrair assinaturas de código essenciais e estrutura enquanto remove detalhes de implementação. Reduz o uso de tokens em ~70% mantendo o significado semântico. Geralmente não é necessário já que grep_repomix_output permite recuperação incremental de conteúdo. Use apenas quando você especificamente precisar do conteúdo completo da base de código para repositórios grandes.includePatterns
: (Opcional) Especifica arquivos para incluir usando padrões fast-glob. Múltiplos padrões podem ser separados por vírgula (ex: "/*.{js,ts}", "src/,docs/**"). Apenas arquivos correspondentes serão processados.ignorePatterns
: (Opcional) Especifica arquivos adicionais para excluir usando padrões fast-glob. Múltiplos padrões podem ser separados por vírgula (ex: "test/,*.spec.js", "node_modules/,dist/**"). Estes padrões complementam .gitignore e exclusões integradas.topFilesLength
: (Opcional, padrão: 10) Número de maiores arquivos por tamanho para exibir no resumo de métricas para análise da base de código.
Exemplo:
json
{
"remote": "yamadashy/repomix",
"compress": false,
"includePatterns": "src/**/*.ts,**/*.md",
"ignorePatterns": "**/*.log,tmp/",
"topFilesLength": 10
}
read_repomix_output
Esta ferramenta lê o conteúdo de um arquivo de saída gerado pelo Repomix. Suporta leitura parcial com especificação de intervalo de linhas para arquivos grandes. Esta ferramenta é projetada para ambientes onde o acesso direto ao sistema de arquivos é limitado.
Parâmetros:
outputId
: (Obrigatório) ID do arquivo de saída do Repomix a ser lidostartLine
: (Opcional) Número da linha inicial (baseado em 1, inclusivo). Se não especificado, lê desde o início.endLine
: (Opcional) Número da linha final (baseado em 1, inclusivo). Se não especificado, lê até o final.
Funcionalidades:
- Projetado especificamente para ambientes baseados na web ou aplicações em sandbox
- Recupera o conteúdo de saídas geradas anteriormente usando seu ID
- Fornece acesso seguro à base de código empacotada sem requerer acesso ao sistema de arquivos
- Suporta leitura parcial para arquivos grandes
Exemplo:
json
{
"outputId": "8f7d3b1e2a9c6054",
"startLine": 100,
"endLine": 200
}
grep_repomix_output
Esta ferramenta busca padrões em um arquivo de saída do Repomix usando funcionalidade similar ao grep com sintaxe JavaScript RegExp. Retorna linhas correspondentes com linhas de contexto opcionais ao redor das correspondências.
Parâmetros:
outputId
: (Obrigatório) ID do arquivo de saída do Repomix para buscarpattern
: (Obrigatório) Padrão de busca (sintaxe de expressão regular JavaScript RegExp)contextLines
: (Opcional, padrão: 0) Número de linhas de contexto para mostrar antes e depois de cada correspondência. Sobrescrito por beforeLines/afterLines se especificado.beforeLines
: (Opcional) Número de linhas de contexto para mostrar antes de cada correspondência (como grep -B). Tem precedência sobre contextLines.afterLines
: (Opcional) Número de linhas de contexto para mostrar depois de cada correspondência (como grep -A). Tem precedência sobre contextLines.ignoreCase
: (Opcional, padrão: false) Realizar correspondência insensível a maiúsculas e minúsculas
Funcionalidades:
- Usa sintaxe JavaScript RegExp para correspondência de padrões poderosa
- Suporta linhas de contexto para melhor compreensão das correspondências
- Permite controle separado de linhas de contexto antes/depois
- Opções de busca sensível e insensível a maiúsculas e minúsculas
Exemplo:
json
{
"outputId": "8f7d3b1e2a9c6054",
"pattern": "function\\s+\\w+\\(",
"contextLines": 3,
"ignoreCase": false
}
file_system_read_file e file_system_read_directory
O servidor MCP do Repomix fornece duas ferramentas de sistema de arquivos que permitem que os assistentes de IA interajam com segurança com o sistema de arquivos local:
file_system_read_file
- Lê conteúdo de arquivos do sistema de arquivos local usando caminhos absolutos
- Inclui validação de segurança integrada para detectar e prevenir acesso a arquivos contendo informações sensíveis
- Implementa validação de segurança usando Secretlint
- Previne acesso a arquivos contendo informações sensíveis (chaves de API, senhas, segredos)
- Valida caminhos absolutos para prevenir ataques de travessia de diretórios
- Retorna mensagens de erro claras para caminhos inválidos e problemas de segurança
file_system_read_directory
- Lista conteúdos de um diretório usando um caminho absoluto
- Retorna uma lista formatada mostrando arquivos e subdiretórios com indicadores claros
- Mostra arquivos e diretórios com indicadores claros (
[FILE]
ou[DIR]
) - Fornece navegação segura de diretórios com tratamento apropriado de erros
- Valida caminhos e garante que sejam absolutos
- Útil para explorar estrutura de projetos e compreender organização da base de código
Ambas as ferramentas incorporam medidas de segurança robustas:
- Validação de caminhos absolutos para prevenir ataques de travessia de diretórios
- Verificações de permissões para garantir direitos de acesso apropriados
- Integração com Secretlint para detecção de informações sensíveis
- Mensagens de erro claras para depuração e consciência de segurança
Exemplo:
typescript
// Ler um arquivo
const fileContent = await tools.file_system_read_file({
path: '/absolute/path/to/file.txt'
});
// Listar conteúdo do diretório
const dirContent = await tools.file_system_read_directory({
path: '/absolute/path/to/directory'
});
Essas ferramentas são particularmente úteis quando os assistentes de IA precisam:
- Analisar arquivos específicos na base de código
- Navegar estruturas de diretórios
- Verificar existência e acessibilidade de arquivos
- Garantir operações seguras do sistema de arquivos
Benefícios de Usar o Repomix como um Servidor MCP
Usar o Repomix como um servidor MCP oferece várias vantagens:
- Integração Direta: Assistentes de IA podem analisar sua base de código diretamente sem preparação manual de arquivos.
- Fluxo de Trabalho Eficiente: Otimiza o processo de análise de código eliminando a necessidade de gerar e carregar arquivos manualmente.
- Saída Consistente: Garante que o assistente de IA receba a base de código em um formato consistente e otimizado.
- Recursos Avançados: Aproveita todos os recursos do Repomix como compressão de código, contagem de tokens e verificações de segurança.
Uma vez configurado, seu assistente de IA pode usar diretamente as capacidades do Repomix para analisar bases de código, tornando os fluxos de trabalho de análise de código mais eficientes.