Servidor editor de texto MCP
Un servidor de Protocolo de Contexto de Modelo (MCP) que ofrece funciones de edición de archivos de texto orientados a líneas mediante una API estandarizada. Optimizado para herramientas LLM con acceso parcial eficiente a archivos para minimizar el uso de tokens.
Inicio rápido para usuarios de Claude.app
Para utilizar este editor con Claude.app, agregue la siguiente configuración a su mensaje:
o con docker:
Related MCP server: Serena MCP Server
Descripción general
El Servidor del Editor de Texto MCP está diseñado para facilitar operaciones seguras y eficientes con archivos de texto basados en líneas en una arquitectura cliente-servidor. Implementa el Protocolo de Contexto de Modelo, lo que garantiza una edición de archivos fiable con una robusta detección y resolución de conflictos. Su enfoque orientado a líneas lo hace ideal para aplicaciones que requieren acceso sincronizado a archivos, como herramientas de edición colaborativa, sistemas de procesamiento de texto automatizado o cualquier escenario donde varios procesos necesiten modificar archivos de texto de forma segura. La capacidad de acceso parcial a archivos es especialmente valiosa para herramientas basadas en LLM, ya que ayuda a reducir el consumo de tokens al cargar solo las partes necesarias de los archivos.
Beneficios clave
Operaciones de edición basadas en líneas
Acceso parcial a archivos con uso eficiente de tokens y especificaciones de rango de línea
Optimizado para la integración de herramientas LLM
Edición concurrente segura con validación basada en hash
Operaciones atómicas de múltiples archivos
Manejo robusto de errores con tipos de errores personalizados
Soporte de codificación completo (utf-8, shift_jis, latin1, etc.)
Características
Edición y lectura de archivos de texto orientados a líneas
Acceso parcial inteligente a archivos para minimizar el uso de tokens en aplicaciones LLM
Obtener el contenido del archivo de texto con la especificación del rango de líneas
Leer múltiples rangos de múltiples archivos en una sola operación
Aplicación de parches basada en líneas con manejo correcto de cambios de número de línea
Editar el contenido de archivos de texto con detección de conflictos
Soporte de codificación de caracteres flexible (utf-8, shift_jis, latin1, etc.)
Soporte para múltiples operaciones con archivos
Manejo adecuado de ediciones concurrentes con validación basada en hash
Procesamiento de archivos grandes con uso eficiente de la memoria
Requisitos
Python 3.11 o superior
Sistema operativo compatible con POSIX (Linux, macOS, etc.) o Windows
Suficiente espacio en disco para operaciones con archivos de texto
Permisos del sistema de archivos para operaciones de lectura y escritura
Instalar Python 3.11+
Instalar uv (recomendado) o pip
Crear entorno virtual e instalar dependencias
Requisitos
Python 3.13+
Sistema operativo compatible con POSIX (Linux, macOS, etc.) o Windows
Permisos del sistema de archivos para operaciones de lectura y escritura
Instalación
Ejecutar a través de uvx
Instalación mediante herrería
Para instalar Text Editor Server para Claude Desktop automáticamente a través de Smithery :
Instalación manual
Instalar Python 3.13+
Instalación de Docker
Instalar uv (recomendado) o pip
Crear entorno virtual e instalar dependencias
Uso
Iniciar el servidor:
Inicie el servidor con Docker:
con el inspector:
Herramientas MCP
El servidor proporciona varias herramientas para la manipulación de archivos de texto:
obtener_el_contenido_del_archivo_de_texto
Obtenga el contenido de uno o más archivos de texto con especificación de rango de línea.
Solicitud de rango único:
Solicitud de rangos múltiples:
Parámetros:
file_path: Ruta al archivo de textoline_start/start: Número de línea desde el que comenzar (basado en 1)line_end/end: Número de línea donde finalizar (inclusive, nulo para el final del archivo)encoding: Codificación del archivo (predeterminado: "utf-8"). Especifique la codificación del archivo de texto (p. ej., "shift_jis", "latin1").
Respuesta de rango único:
Respuesta de rangos múltiples:
contenido del archivo de texto del parche
Aplique parches a archivos de texto con gestión robusta de errores y detección de conflictos. Admite la edición de varios archivos en una sola operación.
Formato de solicitud:
Notas importantes:
Obtenga siempre el hash actual y range_hash usando get_text_file_contents antes de editar
Los parches se aplican de abajo a arriba para manejar correctamente los cambios de número de línea
Los parches no deben superponerse dentro del mismo archivo
Los números de línea se basan en 1
end: nullpara agregar contenido al final del archivoLa codificación del archivo debe coincidir con la codificación utilizada en get_text_file_contents
Respuesta de éxito:
Respuesta de error con sugerencias:
} }
Editar el contenido del archivo:
Manejar conflictos:
Manejo de errores
El servidor maneja varios casos de error:
Archivo no encontrado
Errores de permisos
Desajustes de hash (detección de edición concurrente)
Rangos de parches no válidos
Parches superpuestos
Errores de codificación (cuando el archivo no se puede decodificar con la codificación especificada)
Número de línea fuera de límites
Consideraciones de seguridad
Validación de ruta de archivo: el servidor valida todas las rutas de archivo para evitar ataques de recorrido de directorio
Control de acceso: se deben configurar los permisos adecuados del sistema de archivos para restringir el acceso a los directorios autorizados
Validación de hash: todas las modificaciones de archivos se validan utilizando hashes SHA-256 para evitar condiciones de carrera
Sanitización de entrada: todas las entradas del usuario se desinfectan y validan adecuadamente
Manejo de errores: La información confidencial no se expone en los mensajes de error
Solución de problemas
Problemas comunes
Permiso denegado
Comprobar permisos de archivos y directorios
Asegúrese de que el proceso del servidor tenga el acceso de lectura y escritura necesario
Errores de hash de rango y desajuste de hash
El archivo fue modificado por otro proceso
El contenido que se está reemplazando ha cambiado
Ejecute get_text_file_contents para obtener hashes nuevos
Problemas de codificación
Verificar que la codificación del archivo coincida con la codificación especificada
Utilice utf-8 para archivos nuevos
Comprobar marcadores de lista de materiales en los archivos
Problemas de conexión
Verifique que el servidor esté en ejecución y sea accesible
Compruebe la configuración de la red y la configuración del firewall
Problemas de rendimiento
Considere usar rangos de líneas más pequeños para archivos grandes
Monitorear los recursos del sistema (memoria, espacio en disco)
Utilice la codificación adecuada para el tipo de archivo
Desarrollo
Configuración
Clonar el repositorio
Crear y activar un entorno virtual de Python
Instalar dependencias de desarrollo:
uv pip install -e ".[dev]"Ejecutar pruebas:
make all
Herramientas de calidad del código
Ruff para pelusa
Negro para formato de código
isort para la clasificación de importaciones
mypy para verificación de tipos
pytest-cov para la cobertura de pruebas
Pruebas
Las pruebas se encuentran en el directorio tests y se pueden ejecutar con pytest:
Cobertura de prueba actual: 90%
Estructura del proyecto
Licencia
Instituto Tecnológico de Massachusetts (MIT)
Contribuyendo
Bifurcar el repositorio
Crear una rama de características
Realiza tus cambios
Ejecutar pruebas y controles de calidad del código
Enviar una solicitud de extracción
Sugerencias de tipo
Este proyecto utiliza sugerencias de tipo de Python en todo el código. Por favor, asegúrese de que todas las contribuciones las mantengan.
Manejo de errores
Todos los casos de error deben gestionarse adecuadamente y devolver mensajes de error significativos. El servidor nunca debe bloquearse debido a entradas o operaciones de archivo no válidas.
Pruebas
Las nuevas funciones deben incluir pruebas adecuadas. Intente mantener o mejorar la cobertura de pruebas actual.
Estilo de código
Todo el código debe estar formateado con Black y pasar el control de linting de Ruff. La ordenación de las importaciones debe ser gestionada por isort.