local-only server
The server can only run on the client’s local machine because it depends on local resources.
Integrations
Integration for code coverage reporting, as indicated by the codecov badge in the README.
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:
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: null
para agregar contenido al final del archivo- La 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 operaciones de entrada o 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.
This server cannot be installed
Tools
Un editor de archivos de texto orientado a líneas. Optimizado para herramientas LLM con acceso parcial eficiente a archivos para minimizar el uso de tokens.