README.md•26.5 kB
# Persistent Terminal MCP Server
[English](README.en.md)
一个功能强大的 Model Context Protocol (MCP) 服务器,基于 TypeScript 和 [`node-pty`](https://github.com/microsoft/node-pty) 实现持久化终端会话管理。即使客户端断开连接,终端命令也会继续运行,特别适合 Claude、Cursor、Cline 等 AI 助手执行长时间任务。
油管视频地址:https://youtu.be/nfLi1IZxhJs
b站视频地址:https://www.bilibili.com/video/BV14ksPzqEbM/
Windows 配置mcp 视频教程地址:https://youtu.be/WYEKwTQCAnc
## ✨ 核心特性
### 🔥 持久化终端会话
- **长期运行**:创建、复用、管理长期运行的 Shell 会话
- **断线续传**:客户端断开后终端继续运行,重连后可继续操作
- **多会话管理**:同时管理多个独立的终端会话
- **自动清理**:超时会话自动清理,避免资源泄漏
### 🧠 智能输出管理
- **循环缓冲区**:可配置大小(默认 10,000 行),自动管理内存
- **多种读取模式**:
  - `full`:完整输出
  - `head`:只读取开头 N 行
  - `tail`:只读取末尾 N 行
  - `head-tail`:同时读取开头和末尾
- **增量读取**:使用 `since` 参数只读取新增内容
- **Token 估算**:自动估算输出的 token 数量,方便 AI 控制上下文
### 🎨 Spinner 动画压缩
- **自动检测**:识别常见的进度动画字符(⠋⠙⠹⠸⠼⠴⠦⠧⠇⠏, ◐◓◑◒ 等)
- **智能节流**:减少 `npm install`、`yarn`、`pnpm` 等命令的噪音输出
- **保留关键信息**:压缩动画的同时保留真实日志
- **灵活配置**:可通过环境变量或参数控制开关
### 🌐 Web 可视化管理界面
- **实时终端**:基于 xterm.js 的终端渲染,支持完整 ANSI 颜色
- **WebSocket 推送**:终端输出实时显示,无需刷新
- **交互操作**:直接在浏览器中发送命令、查看输出
- **多实例支持**:自动端口分配,支持多个 AI 客户端同时使用
- **VS Code 风格**:暗色主题,简洁美观的界面设计
### 🤖 Codex 自动修复 Bug
- **完全自动化**:集成 OpenAI Codex CLI,自动修复代码 Bug
- **文档驱动**:AI 描述保存为 MD 文档,Codex 读取并修复
- **详细报告**:生成完整的修复报告,包含修改前后对比
- **智能等待**:自动检测 Codex 执行完成,默认超时 10 分钟
- **历史记录**:所有 Bug 描述和修复报告永久保存在 docs/ 目录
### 🔌 多种集成方式
- **MCP 协议**:原生支持 Claude Desktop、Claude Code、Cursor、Cline 等客户端
- **REST API**:提供 HTTP 接口,方便非 MCP 场景集成
- **严格兼容**:完全符合 MCP stdio 协议规范,stdout 纯净无污染
### 🛡️ 稳定性保障
- **输出稳定检测**:`wait_for_output` 工具确保获取完整输出
- **交互式应用支持**:完美支持 vim、npm create 等交互式程序
- **ANSI 转义序列**:正确处理终端控制字符
- **错误恢复**:自动重连、异常处理机制
## 🚀 安装方式
### ✅ 快速运行(推荐)
无需安装,直接使用 `npx` 启动:
```bash
npx persistent-terminal-mcp
```
REST 版本同样支持:
```bash
npx persistent-terminal-mcp-rest
```
### 📦 引入到现有项目
```bash
npm install persistent-terminal-mcp
```
安装后即可在代码中引用所有核心类与类型:
```ts
import { PersistentTerminalMcpServer } from "persistent-terminal-mcp";
```
### 🌐 全局安装(可选)
```bash
npm install --global persistent-terminal-mcp
persistent-terminal-mcp
```
## 🧪 本地开发
适合想要修改源码或深入调试的场景:
```bash
npm install          # 安装依赖
npm run build        # 编译 TypeScript → dist/
npm start            # 通过 stdio 启动 MCP 服务器
```
开发阶段也可直接运行 TypeScript 源码:
```bash
npm run dev          # MCP 服务器 (tsx)
npm run dev:rest     # REST 服务器 (tsx)
```
### 🐞 调试模式
启用调试日志(输出到 stderr,不会干扰 MCP 通信):
```bash
MCP_DEBUG=true persistent-terminal-mcp
```
### 📚 示例脚本
```bash
npm run example:basic        # 基础操作:创建 → 写入 → 读取 → 终止
npm run example:smart        # 智能读取:head/tail/head-tail 模式演示
npm run example:spinner      # Spinner 压缩功能演示
npm run example:webui        # Web UI 功能演示
npm run test:tools           # 全量验证所有 MCP 工具
npm run test:fixes           # 关键修复的回归测试
```
## ⚙️ MCP 客户端配置
### Claude Desktop
#### macOS / Linux
**配置文件位置**: `~/Library/Application Support/Claude/claude_desktop_config.json`
在配置文件中添加以下内容:
```json
{
  "mcpServers": {
    "persistent-terminal": {
      "command": "npx",
      "args": ["-y", "persistent-terminal-mcp"],
      "env": {
        "MAX_BUFFER_SIZE": "10000",
        "SESSION_TIMEOUT": "86400000",
        "COMPACT_ANIMATIONS": "true",
        "ANIMATION_THROTTLE_MS": "100"
      }
    }
  }
}
```
**说明**:
- `-y` 参数会自动确认 npx 的下载提示
- 若已全局安装(`npm install -g persistent-terminal-mcp`),可将 `command` 改为 `"persistent-terminal-mcp"` 并移除 `args` 中的 `-y`
#### Windows
**配置文件位置**: `%APPDATA%\Claude\claude_desktop_config.json`
```json
{
  "mcpServers": {
    "persistent-terminal": {
      "command": "cmd",
      "args": ["/c", "npx", "-y", "persistent-terminal-mcp"],
      "env": {
        "MAX_BUFFER_SIZE": "10000",
        "SESSION_TIMEOUT": "86400000",
        "COMPACT_ANIMATIONS": "true",
        "ANIMATION_THROTTLE_MS": "100"
      }
    }
  }
}
```
**说明**:
- Windows 需要通过 `cmd /c` 来调用 `npx`
- 若已全局安装,可将 `args` 改为 `["/c", "persistent-terminal-mcp"]`
---
### Claude Code
#### macOS / Linux
使用命令行快速添加:
```bash
claude mcp add persistent-terminal \
  --env MAX_BUFFER_SIZE=10000 \
  --env SESSION_TIMEOUT=86400000 \
  --env COMPACT_ANIMATIONS=true \
  --env ANIMATION_THROTTLE_MS=100 \
  -- npx -y persistent-terminal-mcp
```
**或者**编辑配置文件 `~/.claude.json`:
```json
{
  "mcpServers": {
    "persistent-terminal": {
      "command": "npx",
      "args": ["-y", "persistent-terminal-mcp"],
      "env": {
        "MAX_BUFFER_SIZE": "10000",
        "SESSION_TIMEOUT": "86400000",
        "COMPACT_ANIMATIONS": "true",
        "ANIMATION_THROTTLE_MS": "100"
      }
    }
  }
}
```
#### Windows
> # ⚠️ **Windows 用户请注意**
>
> ## **Claude Code** 在 Windows 下 `claude mcp add` 命令存在参数解析问题
>
> ### **🚫 不推荐使用命令行方式**
>
> 请参考专门的配置文档:
>
> ### 📖 [《Windows 下配置 persistent-terminal MCP》](docs/clients/claude-code-windows.md)
>
> 该文档提供了两种推荐方案:
>
> - ✅ **项目级配置**(推荐):在项目根目录创建 `.mcp.json` 文件
> - ✅ **全局配置**:使用 Python 脚本修改 `~/.claude.json`
---
### Cursor / Cline
配置方式与 Claude Desktop 类似,请参考各客户端的 MCP 配置文档。
### Codex
#### macOS / Linux
在 `.codex/config.toml` 文件中添加以下配置:
```toml
# MCP Server Configuration (TOML Format)
# 用于配置 persistent-terminal MCP 服务器
[mcp_servers.persistent-terminal]
command = "npx"
args = ["-y", "persistent-terminal-mcp"]
[mcp_servers.persistent-terminal.env]
MAX_BUFFER_SIZE = "10000"
SESSION_TIMEOUT = "86400000"
COMPACT_ANIMATIONS = "true"
ANIMATION_THROTTLE_MS = "100"
```
#### Windows
在 `.codex/config.toml` 文件中添加以下配置:
```toml
# MCP Server Configuration (TOML Format)
# 用于配置 persistent-terminal MCP 服务器
[mcp_servers.persistent-terminal]
command = "cmd"
args = ["/c", "npx", "-y", "persistent-terminal-mcp"]
[mcp_servers.persistent-terminal.env]
MAX_BUFFER_SIZE = "10000"
SESSION_TIMEOUT = "86400000"
COMPACT_ANIMATIONS = "true"
ANIMATION_THROTTLE_MS = "100"
```
**说明**:Windows 需要通过 `cmd /c` 来调用 `npx`
---
### 环境变量说明
| 变量                     | 说明                           | 默认值            |
| ------------------------ | ------------------------------ | ----------------- |
| `MAX_BUFFER_SIZE`        | 缓冲区最大行数                 | 10000             |
| `SESSION_TIMEOUT`        | 会话超时时间(毫秒)           | 86400000 (24小时) |
| `COMPACT_ANIMATIONS`     | 是否启用 Spinner 压缩          | true              |
| `ANIMATION_THROTTLE_MS`  | 动画节流时间(毫秒)           | 100               |
| `MCP_DEBUG`              | 是否启用调试日志               | false             |
| `AUTO_START_REST_SERVER` | MCP 启动时自动启动 REST 服务器 | false             |
| `REST_HOST`              | REST 服务器监听地址            | localhost         |
| `REST_PORT`              | REST 服务器端口                | 3001              |
| `AUTO_START_TERMINAL_UI` | REST 启动时自动启动 Web UI     | true              |
| `WEB_UI_HOST`            | Web UI 服务器监听地址          | localhost         |
| `AUTO_OPEN_BROWSER`      | 是否自动打开浏览器访问 Web UI  | false             |
| `WEB_UI_PORT`             | Web UI 服务器端口              | 3000              |
### 🚀 自动启动服务器配置
通过环境变量可以实现服务器的自动启动和网络访问配置:
#### 外部访问配置
要让 REST API 和 Web UI 支持外部网络访问,设置以下环境变量:
```bash
# 自动启动 REST API 服务器
AUTO_START_REST_SERVER=true
# REST API 监听所有网络接口(允许外部访问)
REST_HOST=0.0.0.0
# 自动启动 Web UI 界面
AUTO_START_TERMINAL_UI=true
# Web UI 监听所有网络接口(允许外部访问)
WEB_UI_HOST=0.0.0.0
# REST API 端口(可选)
REST_PORT=3001
# Web UI 端口(可选)
WEB_UI_PORT=3000
# 是否自动打开浏览器(可选)
AUTO_OPEN_BROWSER=false
```
#### 使用效果
设置上述环境变量后,启动 MCP 服务器时会:
1. ✅ REST API 服务器自动启动在 `http://0.0.0.0:3001`
2. ✅ Web UI 自动启动在 `http://0.0.0.0:3000`
3. ✅ 两个服务都可以从外部网络访问
4. ✅ 可选择是否自动打开浏览器
#### 客户端配置示例
将环境变量添加到 MCP 客户端配置中:
**Claude Desktop 配置**:
```json
{
  "mcpServers": {
    "persistent-terminal": {
      "command": "npx",
      "args": ["-y", "persistent-terminal-mcp"],
      "env": {
        "AUTO_START_REST_SERVER": "true",
        "REST_HOST": "0.0.0.0",
        "AUTO_START_TERMINAL_UI": "true",
        "WEB_UI_HOST": "0.0.0.0",
        "WEB_UI_PORT": "3000",
        "AUTO_OPEN_BROWSER": "false",
        "MAX_BUFFER_SIZE": "10000",
        "SESSION_TIMEOUT": "86400000"
      }
    }
  }
}
```
**Claude Code 配置**:
```bash
claude mcp add persistent-terminal \
  --env AUTO_START_REST_SERVER=true \
  --env REST_HOST=0.0.0.0 \
  --env AUTO_START_TERMINAL_UI=true \
  --env WEB_UI_HOST=0.0.0.0 \
  --env WEB_UI_PORT=3000 \
  --env AUTO_OPEN_BROWSER=false \
  -- npx -y persistent-terminal-mcp
```
## 🧱 TypeScript 程序化使用
```ts
import {
  PersistentTerminalMcpServer,
  TerminalManager,
  RestApiServer,
} from "persistent-terminal-mcp";
const manager = new TerminalManager();
const rest = new RestApiServer(manager);
await rest.start(3001);
const mcpServer = new PersistentTerminalMcpServer();
const server = mcpServer.getServer();
await server.connect(/* 自定义 transport */);
```
所有核心类和类型在包的根入口即可获取,详情可参考 `src/index.ts`。
## 🛠️ MCP 工具一览
| 工具                    | 作用                    | 主要参数                                      |
| ----------------------- | ----------------------- | --------------------------------------------- |
| `create_terminal`       | 创建持久终端会话        | `shell`, `cwd`, `env`, `cols`, `rows`         |
| `create_terminal_basic` | 精简版创建入口          | `shell`, `cwd`                                |
| `write_terminal`        | 向终端写入命令          | `terminalId`, `input`, `appendNewline`        |
| `read_terminal`         | 读取缓冲输出            | `terminalId`, `mode`, `since`, `stripSpinner` |
| `wait_for_output`       | 等待输出稳定            | `terminalId`, `timeout`, `stableTime`         |
| `get_terminal_stats`    | 查看统计信息            | `terminalId`                                  |
| `list_terminals`        | 列出所有活跃终端        | 无                                            |
| `kill_terminal`         | 终止会话                | `terminalId`, `signal`                        |
| `open_terminal_ui`      | 打开 Web 管理界面       | `port`, `autoOpen`                            |
| `fix_bug_with_codex` 🆕 | 使用 Codex 自动修复 Bug | `description`, `cwd`, `timeout`               |
### 工具详细说明
#### `create_terminal` - 创建终端
创建一个新的持久化终端会话。
**参数**:
- `shell` (可选): Shell 类型,如 `/bin/bash`、`/bin/zsh`
- `cwd` (可选): 工作目录
- `env` (可选): 环境变量对象
- `cols` (可选): 终端列数,默认 80
- `rows` (可选): 终端行数,默认 24
**返回**:
- `terminalId`: 终端 ID
- `status`: 状态
- `pid`: 进程 ID
- `shell`: Shell 类型
- `cwd`: 工作目录
#### `write_terminal` - 写入命令
向终端发送命令或输入。
**参数**:
- `terminalId`: 终端 ID
- `input`: 要发送的内容
- `appendNewline` (可选): 是否自动添加换行符,默认 true
**提示**:默认会自动添加换行符执行命令,如需发送原始控制字符(如方向键),请设置 `appendNewline: false`。
#### `read_terminal` - 读取输出
读取终端的缓冲输出,支持多种智能截断模式。
**参数**:
- `terminalId`: 终端 ID
- `mode` (可选): 读取模式
  - `full`: 完整输出(默认)
  - `head`: 只读取开头
  - `tail`: 只读取末尾
  - `head-tail`: 同时读取开头和末尾
- `since` (可选): 从第 N 行开始读取(增量读取)
- `maxLines` (可选): 最大行数,默认 1000
- `headLines` (可选): head 模式的行数,默认 50
- `tailLines` (可选): tail 模式的行数,默认 50
- `stripSpinner` (可选): 是否压缩 Spinner 动画
**返回**:
- `output`: 输出内容
- `totalLines`: 总行数
- `lineRange`: 实际返回的行范围
- `estimatedTokens`: 估算的 token 数量
- `truncated`: 是否被截断
- `spinnerCompacted`: 是否进行了 Spinner 压缩
#### `wait_for_output` - 等待输出稳定
等待终端输出稳定后再读取,确保获取完整输出。
**参数**:
- `terminalId`: 终端 ID
- `timeout` (可选): 最大等待时间(毫秒),默认 5000
- `stableTime` (可选): 稳定时间(毫秒),默认 500
**使用场景**:
- 执行命令后确保获取完整输出
- 等待交互式应用启动完成
#### `fix_bug_with_codex` 🆕 - 自动修复 Bug
使用 OpenAI Codex CLI 自动分析和修复代码中的 Bug。
**参数**:
- `description` (必需): 详细的 Bug 描述,必须包含:
  - 问题症状(具体的错误行为)
  - 期望行为(应该如何工作)
  - 问题位置(文件路径、行号、函数名)
  - 相关代码(有问题的代码片段)
  - 根本原因(为什么会出现这个问题)
  - 修复建议(如何修复)
  - 影响范围(还会影响什么)
  - 相关文件(所有相关的文件路径)
  - 测试用例(如何验证修复是否有效)
  - 上下文信息(有助于理解问题的背景)
- `cwd` (可选): 工作目录,默认为当前目录
- `timeout` (可选): 超时时间(毫秒),默认 600000(10 分钟)
**返回**:
- `terminalId`: 执行 Codex 的终端 ID
- `reportPath`: 修复报告路径
- `reportExists`: 报告是否存在
- `workingDir`: 工作目录
- `executionTime`: 执行时间(秒)
- `timedOut`: 是否超时
- `output`: 终端输出
- `reportPreview`: 报告预览
**工作流程**:
1. AI 提供详细的 Bug 描述
2. 工具将描述保存到 `docs/codex-bug-description-TIMESTAMP.md`
3. Codex 读取文档并分析问题
4. Codex 修复 Bug 并生成报告 `docs/codex-fix-TIMESTAMP.md`
5. AI 读取报告并总结给用户
**重要提示**:
- ⚠️ 此工具具有完全系统访问权限(`danger-full-access`)
- ⚠️ Codex 可以修改任何文件,建议在 Git 仓库中使用
- ✅ 只使用英文描述(避免 UTF-8 编码问题)
- ✅ 描述越详细,修复质量越高
**示例**:
```javascript
fix_bug_with_codex({
  description: `Username validation bug in auth.js file.
PROBLEM:
- File: src/auth/login.ts, line 45
- Code: const usernameRegex = /^[a-zA-Z0-9]{3,20}$/
- Symptom: Username 'user_name' is rejected with 'Invalid username' error
- Expected: Should accept usernames with underscores and hyphens
ROOT CAUSE:
- Regex [a-zA-Z0-9] only allows letters and numbers
- Missing support for underscore and hyphen characters
SUGGESTED FIX:
- Change regex to: /^[a-zA-Z0-9_-]{3,20}$/
VERIFICATION:
- Run: npm test
- Expected: all tests pass`,
  cwd: "/path/to/project",
  timeout: 600000,
});
```
**详细文档**:
- [Codex Bug Fix Tool 功能文档](docs/features/CODEX_BUG_FIX_TOOL.md)
- [Codex Bug Fix Tool 测试报告](docs/features/CODEX_BUG_FIX_TEST_REPORT.md)
> **💡 提示**:Codex CLI 需要 OpenAI API 访问权限。如果你在国内或遇到访问问题,可以考虑使用 [Codex CLI 镜像服务](https://www.codex-cli.top)(¥99/月,每日 $90 额度),让 AI 编程更流畅。
#### `open_terminal_ui` - 打开 Web 管理界面
启动一个基于浏览器的可视化终端管理界面。
**参数**:
- `port` (可选): 端口号,默认从 3002 开始自动查找
- `autoOpen` (可选): 是否自动打开浏览器,默认 true
**返回**:
- `url`: Web UI 地址
- `port`: 实际使用的端口
- `mode`: 启动模式(new/existing)
- `autoOpened`: 是否自动打开了浏览器
#### `fix_bug_with_codex` 🆕 - 使用 Codex 自动修复 Bug
调用 OpenAI Codex CLI 自动分析和修复代码中的 bug,并生成详细的修复报告。
**⚠️ 重要提示**:
- 此工具使用 **完全权限模式**(`--sandbox danger-full-access --ask-for-approval never`)
- Codex 可以完全控制代码库,请谨慎使用
- 建议在使用前备份代码或使用版本控制
**参数**:
- `description` (必填): **详细的** bug 描述,必须包含:
  - 问题现象(具体的错误表现)
  - 预期行为(应该如何工作)
  - 问题位置(文件路径、行号)
  - 相关代码片段
  - 根本原因(如果知道)
  - 修复建议(如果有)
  - 影响范围(可能影响的功能)
  - 相关文件(所有相关文件路径)
  - 测试用例(如何验证修复)
  - 上下文信息(背景资料)
- `cwd` (可选): 工作目录,默认当前目录
- `timeout` (可选): 超时时间(毫秒),默认 600000(10分钟)
**返回**:
- `terminalId`: 执行 Codex 的终端 ID
- `reportPath`: 修复报告的路径(`docs/codex-fix-TIMESTAMP.md`)
- `reportExists`: 报告是否成功生成
- `executionTime`: 执行时间
- `output`: Codex 的终端输出
**工作流程**:
1. AI 助手收集详细的 bug 信息
2. 调用此工具,传入详细描述
3. Codex 分析问题并修复代码
4. Codex 在 `docs/` 目录生成详细报告
5. AI 助手读取报告并向用户汇报
**报告内容**:
- 问题描述
- 修改的文件列表
- 每个文件的具体修改(修改前/修改后对比)
- 修改原因说明
- 测试建议
- 注意事项
**使用示例**:
```
用户:登录功能有 bug,用户名验证总是失败
AI 助手:
1. [查看相关文件,理解问题]
2. [调用 fix_bug_with_codex]
   {
     "description": "登录功能用户名验证存在 bug,具体表现:
     1. 问题现象:用户输入 'user_name' 时被拒绝
     2. 预期行为:应该接受包含下划线的用户名
     3. 问题位置:src/auth/login.ts 第 45 行
     4. 相关代码:const usernameRegex = /^[a-zA-Z0-9]{3,20}$/
     5. 根本原因:正则表达式不允许下划线
     ..."
   }
3. [等待 Codex 完成]
4. [读取报告] view("docs/codex-fix-2025-10-18T00-35-12.md")
5. [向用户汇报修复结果]
```
**前置要求**:
- 已安装 Codex CLI:`npm install -g @openai/codex-cli`
- 已配置 Codex 认证
- 项目中存在 `docs/` 目录
**最佳实践**:
- 提供尽可能详细的 bug 描述(描述越详细,修复质量越高)
- 在调用前先查看相关文件,理解问题
- 修复后务必运行测试验证
- 查看生成的报告了解具体修改
- 使用版本控制,便于回滚
## 🌐 Web 管理界面
### 功能特性
- 📊 **终端列表**:查看所有终端的状态、PID、Shell、工作目录等信息
- 🖥️ **实时终端**:使用 xterm.js 渲染终端输出,支持 ANSI 颜色
- ⚡ **实时更新**:WebSocket 推送,终端输出实时显示
- ⌨️ **交互操作**:直接在浏览器中发送命令
- 🎨 **VS Code 风格**:暗色主题,简洁美观
- 🔄 **自动端口**:支持多实例,自动避免端口冲突
### 快速使用
在 Claude 或其他 MCP 客户端中说:
```
请打开终端管理界面
```
或者直接运行测试脚本:
```bash
npm run test:webui
```
详细使用说明见 [Web UI 使用指南](docs/guides/WEB_UI_USAGE.md)。
## 🔌 REST API(可选)
如果需要 HTTP 接口,可启动 REST 版本:
```bash
npx persistent-terminal-mcp-rest
```
服务器默认监听 `3001` 端口(可配置),端点与 MCP 工具一一对应:
| 端点                        | 方法   | 说明         |
| --------------------------- | ------ | ------------ |
| `/api/terminals`            | POST   | 创建终端     |
| `/api/terminals`            | GET    | 列出所有终端 |
| `/api/terminals/:id`        | GET    | 获取终端详情 |
| `/api/terminals/:id`        | DELETE | 终止终端     |
| `/api/terminals/:id/input`  | POST   | 发送命令     |
| `/api/terminals/:id/output` | GET    | 读取输出     |
| `/api/terminals/:id/stats`  | GET    | 获取统计信息 |
## 📁 项目结构
```
persistent-terminal-mcp/
├── src/                    # TypeScript 源码
│   ├── index.ts           # MCP 服务器入口
│   ├── mcp-server.ts      # MCP 服务器实现
│   ├── terminal-manager.ts # 终端管理器
│   ├── output-buffer.ts   # 输出缓冲区
│   ├── web-ui-manager.ts  # Web UI 管理器
│   ├── web-ui-server.ts   # Web UI 服务器
│   ├── rest-server.ts     # REST API 服务器
│   ├── types.ts           # 类型定义
│   ├── __tests__/         # 单元测试
│   └── examples/          # 示例脚本
├── dist/                   # 编译后的 JavaScript
├── public/                 # Web UI 静态文件
├── docs/                   # 文档
│   ├── guides/            # 使用指南
│   ├── reference/         # 技术参考
│   ├── clients/           # 客户端配置
│   └── zh/                # 中文文档
├── tests/                  # 测试套件
│   └── integration/       # 集成测试
└── scripts/                # 辅助脚本
```
## 📚 文档导航
### 快速访问
- 📖 [完整文档索引](docs/README.md)
- 🚨 [修复文档索引](docs/reference/fixes/README.md)
- 🧪 [集成测试说明](tests/integration/README.md)
- 🌐 [Web UI 使用指南](docs/guides/WEB_UI_USAGE.md)
### 按分类
- **使用指南**:[使用说明](docs/guides/usage.md) | [故障排查](docs/guides/troubleshooting.md) | [MCP 配置](docs/guides/mcp-config.md)
- **技术参考**:[技术细节](docs/reference/technical-details.md) | [工具总结](docs/reference/tools-summary.md)
- **修复文档**:[Stdio 修复](docs/reference/fixes/STDIO_FIX.md) | [Cursor 修复](docs/reference/fixes/CURSOR_FIX_SUMMARY.md) | [终端修复](docs/reference/fixes/TERMINAL_FIXES.md)
- **客户端配置**:[Claude Desktop/Code](docs/clients/claude-code-setup.md)
## 🔍 重要说明
### Stdio 纯净性
本 MCP 服务器严格遵循 MCP 协议,确保 stdout 只包含 JSON-RPC 消息,所有日志输出到 stderr。这保证了与 Cursor 等严格客户端的完全兼容。详见 [Stdio 修复文档](docs/reference/fixes/STDIO_FIX.md)。
### Cursor 兼容性
完全兼容 Cursor 及其他要求严格 JSON-RPC 通信的 MCP 客户端。快速设置见 [快速修复指南](docs/reference/fixes/QUICK_FIX_GUIDE.md)。
### 终端交互
支持交互式应用(vim、npm create 等),正确处理 ANSI 转义序列。详见 [终端修复文档](docs/reference/fixes/TERMINAL_FIXES.md)。
### 输出稳定性
使用 `wait_for_output` 工具确保命令执行后获取完整输出,避免读取不完整的数据。
## 🧪 测试
### 运行测试
```bash
npm test                     # 运行所有单元测试
npm run test:integration     # 运行所有集成测试
npm run test:all            # 运行所有测试
```
### 集成测试
```bash
npm run test:integration:stdio      # Stdio 纯净性测试
npm run test:integration:cursor     # Cursor 场景测试
npm run test:integration:terminal   # 终端功能测试
```
## 🤝 贡献指南
欢迎提 Issue 或 PR!详细流程与代码规范见 [CONTRIBUTING.md](CONTRIBUTING.md)。
### 贡献方式
1. Fork 本仓库
2. 创建特性分支 (`git checkout -b feature/AmazingFeature`)
3. 提交更改 (`git commit -m 'Add some AmazingFeature'`)
4. 推送到分支 (`git push origin feature/AmazingFeature`)
5. 开启 Pull Request
## 📄 开源许可
本项目以 [MIT 许可证](LICENSE) 发布。
## 🙏 致谢
- [node-pty](https://github.com/microsoft/node-pty) - 强大的 PTY 库
- [Model Context Protocol](https://modelcontextprotocol.io/) - MCP 协议规范
- [xterm.js](https://xtermjs.org/) - 优秀的终端模拟器
## 📞 支持
- 📖 查看 [文档](docs/README.md)
- 🐛 提交 [Issue](https://github.com/yourusername/node-pty/issues)
- 💬 参与 [讨论](https://github.com/yourusername/node-pty/discussions)
---
**最后更新**: 2025-10-22
**版本**: 1.0.2