258 lines
5.0 KiB
Markdown
258 lines
5.0 KiB
Markdown
# aide env 子命令设计文档
|
||
|
||
## 一、背景
|
||
|
||
### 1.1 解决的问题
|
||
|
||
| 问题 | 影响 |
|
||
|------|------|
|
||
| 环境不一致 | 命令执行失败,打断业务流程 |
|
||
| 手动检查繁琐 | 每次都要检查 Python、虚拟环境、依赖 |
|
||
| 修复方式不统一 | 不同人有不同的修复习惯 |
|
||
|
||
### 1.2 设计目标
|
||
|
||
提供**统一的环境检测与修复**:
|
||
- 自动检测环境问题
|
||
- 能修复的自动修复
|
||
- 不能修复的给出明确建议
|
||
|
||
---
|
||
|
||
## 二、职责
|
||
|
||
### 2.1 做什么
|
||
|
||
1. 检测 Python 版本是否满足要求
|
||
2. 检测 uv 是否可用
|
||
3. 检测/创建虚拟环境
|
||
4. 安装依赖
|
||
5. 输出项目配置信息
|
||
|
||
### 2.2 不做什么
|
||
|
||
- 不修改业务代码
|
||
- 不执行业务逻辑
|
||
- 不进行流程追踪
|
||
|
||
---
|
||
|
||
## 三、接口规格
|
||
|
||
### 3.1 命令语法
|
||
|
||
```
|
||
aide env ensure [--runtime]
|
||
```
|
||
|
||
### 3.2 参数
|
||
|
||
| 参数 | 类型 | 说明 |
|
||
|------|------|------|
|
||
| `--runtime` | 可选 | 仅检查 aide 运行时环境,不依赖配置文件 |
|
||
|
||
### 3.3 输出
|
||
|
||
**成功(runtime 模式)**:
|
||
```
|
||
✓ 运行时环境就绪 (python:3.12, uv:0.4.0)
|
||
```
|
||
|
||
**成功(完整模式)**:
|
||
```
|
||
→ 任务原文档: task-now.md
|
||
→ 任务细则文档: task-spec.md
|
||
✓ 环境就绪 (python:3.12, uv:0.4.0, venv:.venv)
|
||
```
|
||
|
||
**自动修复**:
|
||
```
|
||
→ 创建虚拟环境: .venv
|
||
✓ 已创建虚拟环境
|
||
⚠ 未找到 requirements.txt,已创建空文件
|
||
→ 安装依赖(uv pip install -r requirements.txt)
|
||
✓ 环境就绪 (python:3.12, uv:0.4.0, venv:.venv)
|
||
```
|
||
|
||
**失败**:
|
||
```
|
||
✗ Python 版本不足,要求>=3.11,当前 3.9
|
||
```
|
||
|
||
```
|
||
✗ 未检测到 uv,请先安装(FileNotFoundError)
|
||
```
|
||
|
||
---
|
||
|
||
## 四、业务流程
|
||
|
||
```
|
||
@startuml
|
||
skinparam defaultFontName "PingFang SC"
|
||
|
||
start
|
||
|
||
if (--runtime 参数?) then (是)
|
||
:required_py = "3.11" (硬编码);
|
||
else (否)
|
||
:从配置文件读取 required_py;
|
||
endif
|
||
|
||
:检查 Python 版本;
|
||
if (版本满足?) then (是)
|
||
else (否)
|
||
:输出错误信息;
|
||
stop
|
||
endif
|
||
|
||
:检查 uv 可用性;
|
||
if (uv 可用?) then (是)
|
||
else (否)
|
||
:输出错误信息;
|
||
stop
|
||
endif
|
||
|
||
if (--runtime 参数?) then (是)
|
||
:输出运行时环境就绪;
|
||
stop
|
||
endif
|
||
|
||
:读取配置文件;
|
||
:确保 .gitignore 包含 .aide/;
|
||
|
||
:读取 venv 路径配置;
|
||
if (虚拟环境存在?) then (是)
|
||
else (否)
|
||
:使用 uv venv 创建;
|
||
if (创建成功?) then (是)
|
||
else (否)
|
||
:输出错误信息;
|
||
stop
|
||
endif
|
||
endif
|
||
|
||
:读取 requirements 路径配置;
|
||
if (requirements.txt 存在?) then (是)
|
||
else (否)
|
||
:创建空文件;
|
||
:输出警告;
|
||
endif
|
||
|
||
:使用 uv pip install 安装依赖;
|
||
if (安装成功?) then (是)
|
||
else (否)
|
||
:输出错误信息;
|
||
stop
|
||
endif
|
||
|
||
:输出任务文档路径配置;
|
||
:输出环境就绪;
|
||
|
||
stop
|
||
@enduml
|
||
```
|
||
|
||
---
|
||
|
||
## 五、数据结构
|
||
|
||
### 5.1 配置依赖
|
||
|
||
从 `.aide/config.toml` 读取:
|
||
|
||
```
|
||
[runtime]
|
||
python_min # Python 最低版本要求
|
||
|
||
[env]
|
||
venv # 虚拟环境路径
|
||
requirements # 依赖文件路径
|
||
|
||
[task]
|
||
source # 任务原文档路径
|
||
spec # 任务细则文档路径
|
||
```
|
||
|
||
### 5.2 方法签名原型
|
||
|
||
```
|
||
class EnvManager:
|
||
root: Path # 项目根目录
|
||
|
||
ensure(runtime_only: bool, cfg: ConfigManager) -> bool
|
||
# 主入口,返回是否成功
|
||
|
||
_get_required_python(cfg: ConfigManager, runtime_only: bool) -> str
|
||
# 获取 Python 版本要求
|
||
|
||
_parse_version(version: str) -> tuple[int, ...]
|
||
# 解析版本号字符串
|
||
|
||
_check_python_version(required: str) -> bool
|
||
# 检查 Python 版本
|
||
|
||
_check_uv() -> str | None
|
||
# 检查 uv,返回版本号或 None
|
||
|
||
_ensure_venv(venv_path: Path) -> bool
|
||
# 确保虚拟环境存在
|
||
|
||
_ensure_requirements_file(req_path: Path) -> None
|
||
# 确保 requirements.txt 存在
|
||
|
||
_install_requirements(venv_path: Path, req_path: Path) -> bool
|
||
# 安装依赖
|
||
```
|
||
|
||
---
|
||
|
||
## 六、依赖
|
||
|
||
| 依赖项 | 类型 | 说明 |
|
||
|--------|------|------|
|
||
| ConfigManager | 内部模块 | 配置读写 |
|
||
| output | 内部模块 | 输出格式化 |
|
||
| uv | 外部工具 | 虚拟环境和依赖管理 |
|
||
|
||
---
|
||
|
||
## 七、被依赖
|
||
|
||
| 依赖方 | 说明 |
|
||
|--------|------|
|
||
| /aide:init | 调用 env ensure --runtime 和 env ensure |
|
||
| aide init | 内部可能调用 env 检查 |
|
||
|
||
---
|
||
|
||
## 八、修改指南
|
||
|
||
### 8.1 修改检测逻辑
|
||
|
||
1. 更新本文档的业务流程图
|
||
2. 修改 `aide/env/ensure.py`
|
||
3. 如有新的输出,更新输出示例
|
||
|
||
### 8.2 添加新的检测项
|
||
|
||
1. 在本文档添加检测项说明
|
||
2. 在 `EnvManager` 添加对应方法
|
||
3. 在 `ensure()` 中调用
|
||
4. 更新 [aide skill 设计文档](../../../aide-marketplace/aide-plugin/docs/skill/aide.md)
|
||
|
||
### 8.3 修改配置依赖
|
||
|
||
1. 更新本文档的"配置依赖"章节
|
||
2. 修改代码实现
|
||
3. 同步更新 [配置格式文档](../formats/config.md)
|
||
|
||
---
|
||
|
||
## 九、相关文档
|
||
|
||
- [program 导览](../README.md)
|
||
- [配置格式文档](../formats/config.md)
|
||
- [aide skill 设计文档](../../../aide-marketplace/aide-plugin/docs/skill/aide.md)
|
||
- [/aide:init 命令设计](../../../aide-marketplace/aide-plugin/docs/commands/init.md)
|