Skip to content

Configuración

Repomix puede configurarse mediante un archivo de configuración (repomix.config.json) o opciones de línea de comandos. El archivo de configuración le permite personalizar varios aspectos de cómo se procesa y genera la salida de su base de código.

Inicio rápido

Cree un archivo de configuración en el directorio de su proyecto:

bash
repomix --init

Esto creará un archivo repomix.config.json con la configuración predeterminada. También puede crear un archivo de configuración global que se utilizará como respaldo cuando no se encuentre una configuración local:

bash
repomix --init --global

Opciones de configuración

OpciónDescripciónPredeterminado
input.maxFileSizeTamaño máximo de archivo en bytes para procesar. Los archivos más grandes serán ignorados. Útil para excluir archivos binarios grandes o archivos de datos50000000
output.filePathNombre del archivo de salida. Admite formatos XML, Markdown y texto plano"repomix-output.xml"
output.styleEstilo de salida (xml, markdown, plain). Cada formato tiene sus propias ventajas para diferentes herramientas de IA"xml"
output.parsableStyleIndica si se debe escapar la salida según el esquema de estilo elegido. Permite un mejor análisis pero puede aumentar el recuento de tokensfalse
output.compressIndica si se debe realizar una extracción inteligente de código usando Tree-sitter para reducir el recuento de tokens mientras se preserva la estructurafalse
output.headerTextTexto personalizado para incluir en el encabezado del archivo. Útil para proporcionar contexto o instrucciones a las herramientas de IAnull
output.instructionFilePathRuta a un archivo que contiene instrucciones personalizadas detalladas para el procesamiento de IAnull
output.fileSummaryIndica si se debe incluir una sección de resumen al principio mostrando recuentos de archivos, tamaños y otras métricastrue
output.directoryStructureIndica si se debe incluir la estructura de directorios en la salida. Ayuda a la IA a entender la organización del proyectotrue
output.filesIndica si se debe incluir el contenido de los archivos en la salida. Establecer en false para incluir solo estructura y metadatostrue
output.removeCommentsIndica si se deben eliminar los comentarios de los tipos de archivos soportados. Puede reducir el ruido y el recuento de tokensfalse
output.removeEmptyLinesIndica si se deben eliminar las líneas vacías de la salida para reducir el recuento de tokensfalse
output.showLineNumbersIndica si se deben agregar números de línea a cada línea. Útil para referenciar partes específicas del códigofalse
output.copyToClipboardIndica si se debe copiar la salida al portapapeles del sistema además de guardar el archivofalse
output.topFilesLengthNúmero de archivos principales para mostrar en el resumen. Si se establece en 0, no se mostrará ningún resumen5
output.includeEmptyDirectoriesIndica si se deben incluir directorios vacíos en la estructura del repositoriofalse
output.git.sortByChangesIndica si se deben ordenar los archivos por número de cambios git. Los archivos con más cambios aparecen al finaltrue
output.git.sortByChangesMaxCommitsNúmero máximo de commits para analizar al contar cambios git. Limita la profundidad del historial por rendimiento100
output.git.includeDiffsIndica si se deben incluir las diferencias git en la salida. Muestra por separado los cambios del árbol de trabajo y los cambios preparadosfalse
includePatrones de archivos a incluir usando patrones glob[]
ignore.useGitignoreIndica si se deben usar los patrones del archivo .gitignore del proyectotrue
ignore.useDefaultPatternsIndica si se deben usar los patrones de ignorar predeterminados (node_modules, .git, etc.)true
ignore.customPatternsPatrones adicionales para ignorar usando patrones glob[]
security.enableSecurityCheckIndica si se deben realizar comprobaciones de seguridad usando Secretlint para detectar información sensibletrue
tokenCount.encodingCodificación de recuento de tokens utilizada por el tokenizador tiktoken de OpenAI. Use o200k_base para GPT-4o, cl100k_base para GPT-4/3.5. Ver tiktoken model.py para más detalles."o200k_base"

El archivo de configuración admite la sintaxis JSON5, que permite:

  • Comentarios (tanto de una línea como multilínea)
  • Comas finales en objetos y arrays
  • Nombres de propiedades sin comillas
  • Sintaxis de cadena más flexible

Validación de esquema

Puede habilitar la validación de esquema para su archivo de configuración agregando la propiedad $schema:

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

Esto proporciona autocompletado y validación en editores que admiten esquemas JSON.

Ejemplo de archivo de configuración

Aquí hay un ejemplo de un archivo de configuración 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": "Información de encabezado personalizada para el archivo empaquetado.",
    "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,
    // Los patrones también se pueden especificar en .repomixignore
    "customPatterns": [
      "additional-folder",
      "**/*.log"
    ],
  },
  "security": {
    "enableSecurityCheck": true
  },
  "tokenCount": {
    "encoding": "o200k_base"
  }
}

Ubicaciones de los archivos de configuración

Repomix busca los archivos de configuración en el siguiente orden:

  1. Archivo de configuración local (repomix.config.json) en el directorio actual
  2. Archivo de configuración global:
    • Windows: %LOCALAPPDATA%\Repomix\repomix.config.json
    • macOS/Linux: ~/.config/repomix/repomix.config.json

Las opciones de línea de comandos tienen prioridad sobre la configuración del archivo.

Patrones de ignorar

Repomix proporciona múltiples formas de especificar qué archivos deben ignorarse. Los patrones se procesan en el siguiente orden de prioridad:

  1. Opciones de CLI (--ignore)
  2. Archivo .repomixignore en el directorio del proyecto
  3. .gitignore y .git/info/exclude (si ignore.useGitignore es verdadero)
  4. Patrones predeterminados (si ignore.useDefaultPatterns es verdadero)

Ejemplo de .repomixignore:

text
# Directorios de caché
.cache/
tmp/

# Salidas de compilación
dist/
build/

# Registros
*.log

Patrones de ignorar predeterminados

Cuando ignore.useDefaultPatterns es verdadero, Repomix ignora automáticamente patrones comunes:

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

Para la lista completa, vea defaultIgnore.ts

Características avanzadas

Compresión de código

La función de compresión de código, habilitada con output.compress: true, utiliza Tree-sitter para extraer inteligentemente estructuras de código esenciales mientras elimina detalles de implementación. Esto ayuda a reducir el recuento de tokens mientras mantiene información estructural importante.

Beneficios principales:

  • Reduce significativamente el recuento de tokens
  • Preserva las firmas de clases y funciones
  • Mantiene importaciones y exportaciones
  • Conserva definiciones de tipos e interfaces
  • Elimina cuerpos de funciones y detalles de implementación

Para más detalles y ejemplos, consulte la Guía de compresión de código.

Integración con Git

La configuración output.git proporciona potentes características relacionadas con Git:

  • sortByChanges: Cuando es verdadero, los archivos se ordenan por número de cambios Git (commits que modificaron el archivo). Los archivos con más cambios aparecen al final de la salida. Esto ayuda a priorizar los archivos más activamente desarrollados. Predeterminado: true
  • sortByChangesMaxCommits: El número máximo de commits para analizar al contar cambios de archivos. Predeterminado: 100
  • includeDiffs: Cuando es verdadero, incluye las diferencias Git en la salida (incluye por separado los cambios del árbol de trabajo y los cambios preparados). Esto permite al lector ver los cambios pendientes en el repositorio. Predeterminado: false

Ejemplo de configuración:

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

Comprobaciones de seguridad

Cuando security.enableSecurityCheck está habilitado, Repomix utiliza Secretlint para detectar información sensible en su base de código antes de incluirla en la salida. Esto ayuda a prevenir la exposición accidental de:

  • Claves de API
  • Tokens de acceso
  • Claves privadas
  • Contraseñas
  • Otras credenciales sensibles

Eliminación de comentarios

Cuando output.removeComments se establece en true, los comentarios se eliminan de los tipos de archivos soportados para reducir el tamaño de salida y enfocarse en el contenido esencial del código. Esto puede ser particularmente útil cuando:

  • Está trabajando con código muy documentado
  • Está tratando de reducir el recuento de tokens
  • Se está enfocando en la estructura y lógica del código

Para los lenguajes soportados y ejemplos detallados, consulte la Guía de eliminación de comentarios.

Released under the MIT License.