docs: 移除 pyproject.toml,改为 uv run --with 依赖管理方式

- 移除 pyproject.toml 和 uv.lock
- 更新 SKILL.md:使用 uv run --with 按需加载依赖
- 更新 README.md:添加多行格式的测试命令
- 更新项目规范文档
- 修复脚本:支持从任意位置执行
- 新增 uv-with-dependency-management 规范
This commit is contained in:
2026-03-09 14:14:33 +08:00
parent dfe6904f4c
commit c140bda66b
7 changed files with 267 additions and 292 deletions

View File

@@ -7,7 +7,7 @@ context: |
- 依赖: pyproject.toml声明,使用uv安装
- 主机环境: 禁止污染配置,需操作须请求用户
- 开发文档: README.md,每次迭代按需更新开发文档; 禁emoji/特殊字符
- skill文档: SKILL.md,每次迭代按需更新skill文档(面向AI且需按无uv环境的前提编写)
- skill文档: SKILL.md,每次迭代按需更新skill文档
- 测试: 所有需求必须设计全面测试
- 任务: 禁止创建git变更任务(push/commit等); git读取允许(status/log/diff等)
- 代码: 模块文件150-300行; 错误需自定义异常+清晰信息+位置上下文

View File

@@ -2,45 +2,31 @@
## Purpose
为不同平台提供特定的依赖配置,解决平台特定的依赖兼容性问题(如 macOS x86_64 的 docling-parse 版本限制)。通过强制用户选择平台特定的 extras确保依赖在不同平台上都能正常安装和运行
为不同平台提供特定的依赖配置,解决平台特定的依赖兼容性问题(如 macOS x86_64 的 docling-parse 版本限制)。通过 `uv run --with` 方式按需加载依赖,在文档中提供平台特定的命令示例
## Requirements
### Requirement: 平台特定的依赖配置
系统必须在 `pyproject.toml` 中为不同平台提供特定的依赖 extras
### Requirement: 平台检测文档
系统必须在 SKILL.md 中提供平台检测方法和平台特定的 `uv run --with` 命令示例
#### Scenario: PDF 解析的平台特定 extras
- **WHEN** 用户查看 `pyproject.toml` 中的 `[project.optional-dependencies]` 配置
- **THEN** 系统必须提供以下 PDF 解析 extras
- `pdf-win`: Windows x86_64 平台的 PDF 解析依赖
- `pdf-macos-intel`: macOS x86_64 (Intel) 平台的 PDF 解析依赖
- `pdf-macos-arm`: macOS arm64 (Apple Silicon) 平台的 PDF 解析依赖
- `pdf-linux`: Linux 平台的 PDF 解析依赖
#### Scenario: 平台检测命令
- **WHEN** 用户阅读 SKILL.md 中的多平台依赖安装指南
- **THEN** 系统必须提供以下平台的检测命令
- macOS / Linux: `uname -m``uname -s`
- Windows: PowerShell 环境变量检测
- Python 跨平台检测: `import platform; print(f'{platform.system()}-{platform.machine()}')`
#### Scenario: macOS x86_64 特殊版本约束
- **WHEN** 用户安装 `pdf-macos-intel` extra
- **THEN** 系统必须使用以下硬编码版本
- `docling==2.40.0`
- `docling-parse==4.0.0`
#### Scenario: macOS x86_64 特殊说明
- **WHEN** 用户在 macOS x86_64 平台阅读 PDF 解析依赖的安装说明
- **THEN** 系统必须明确说明以下特殊要求
- 必须使用 Python 3.12
- `docling-parse` 5.x 无 x86_64 wheel必须使用 4.0.0
- 提供完整的 `uv run --python 3.12 --with "docling==2.40.0" --with "docling-parse==4.0.0" --with "numpy<2" ...` 命令示例
#### Scenario: Office 文档的平台特定 extras
- **WHEN** 用户查看 `pyproject.toml` 中的 Office 文档 extras
- **THEN** 系统必须提供以下组合 extras
- `office-win`: Windows x86_64 平台的完整 Office 文档依赖
- `office-macos-intel`: macOS x86_64 (Intel) 平台的完整 Office 文档依赖
- `office-macos-arm`: macOS arm64 (Apple Silicon) 平台的完整 Office 文档依赖
- `office-linux`: Linux 平台的完整 Office 文档依赖
### Requirement: 移除通用平台 extras
系统必须移除通用的平台无关 extras强制用户明确选择平台。
#### Scenario: PDF extra 不存在
- **WHEN** 用户尝试安装 `lyxy-document[pdf]` extra
- **THEN** 系统必须报错或提示用户选择平台特定的 extra
#### Scenario: Office extra 不存在
- **WHEN** 用户尝试安装 `lyxy-document[office]` extra
- **THEN** 系统必须报错或提示用户选择平台特定的 extra
#### Scenario: 每个平台的运行命令
- **WHEN** 用户阅读 SKILL.md
- **THEN** 系统必须为每个平台Windows/macOS Intel/macOS ARM/Linux和每种文档格式提供清晰的 `uv run --with` 命令示例
- **AND** 命令必须包含所有必需的依赖
### Requirement: 平台检测文档
系统必须在 `SKILL.md` 中提供平台检测方法和平台特定的安装指南。
@@ -63,24 +49,13 @@
- **THEN** 系统必须为每个平台Windows/macOS Intel/macOS ARM/Linux提供清晰的 `uv run` 命令示例
### Requirement: Lock 文件管理
系统必须忽略 `uv.lock` 文件,不将其提交到版本控制
系统必须移除 `uv.lock` 文件,每次 `uv run` 都是全新的依赖解析
#### Scenario: gitignore 配置
#### Scenario: 移除 uv.lock 文件
- **WHEN** 用户查看项目根目录
- **THEN** 系统必须不包含 uv.lock 文件
- **AND** 依赖版本由文档中的版本约束说明
#### Scenario: gitignore 配置(可选)
- **WHEN** 用户查看项目的 `.gitignore` 文件
- **THEN** 系统必须在文件中包含 `uv.lock` 条目
#### Scenario: 依赖安装灵活性
- **WHEN** 用户使用 `uv run --with` 安装依赖
- **THEN** 系统必须能够根据当前平台动态解析依赖,而不依赖预先锁定的 lock 文件
### Requirement: 依赖重复但清晰
系统允许在多个平台 extras 中重复声明相同的依赖,以保持清晰和简单。
#### Scenario: 重复声明基础依赖
- **WHEN** 用户查看不同的平台 extras
- **THEN** 系统可以在每个 extra 中重复声明基础依赖(如 `markitdown[pdf]``pypdf``markdownify`
- **AND** 这些重复声明必须版本一致
#### Scenario: 维护简单性优先
- **WHEN** 开发者需要修改依赖版本
- **THEN** 系统优先选择简单清晰的重复声明,而不是复杂的依赖引用或约束文件
- **THEN** 系统可以包含 `uv.lock` 条目以确保不会误提交(如果用户重新创建了 lock 文件)

View File

@@ -0,0 +1,77 @@
# UV --with 依赖管理
## Purpose
基于文档的依赖管理方式,使用 `uv run --with` 按需加载依赖。移除 pyproject.toml 和 uv.lock通过 SKILL.md 和 README.md 提供完整的依赖说明和命令示例。
## Requirements
### Requirement: 文档驱动的依赖声明
系统必须在 SKILL.md 和 README.md 中明确说明每种文档格式和平台所需的依赖包。
#### Scenario: SKILL.md 包含完整的依赖命令
- **WHEN** AI 或用户阅读 SKILL.md
- **THEN** 文档必须为每种文档格式DOCX/XLSX/PPTX/PDF/HTML和平台提供完整的 `uv run --with` 命令示例
- **AND** 命令必须包含所有必需的依赖包
#### Scenario: README.md 包含开发依赖速查表
- **WHEN** 开发者阅读 README.md
- **THEN** 文档必须提供测试每种格式的 `uv run --with` 命令示例
- **AND** 必须包含特殊平台的版本约束说明(如 macOS Intel
### Requirement: 按需加载依赖
系统必须使用 `uv run --with` 方式按需加载依赖,无需预先安装 extras 组合。
#### Scenario: 运行 PDF 解析
- **WHEN** 用户执行 `uv run --with docling --with pypdf --with chardet scripts/lyxy_document_reader.py file.pdf`
- **THEN** 系统必须自动安装这些依赖(如果尚未安装)
- **AND** 必须成功执行脚本
#### Scenario: 测试 DOCX reader
- **WHEN** 开发者执行 `uv run --with docling --with python-docx ... pytest tests/test_readers/test_docx/`
- **THEN** 系统必须只安装指定的依赖
- **AND** 必须成功运行测试
### Requirement: 平台特定版本约束
系统必须在文档和命令中明确说明特殊平台的版本约束。
#### Scenario: macOS Intel 的 PDF 解析
- **WHEN** 用户在 macOS x86_64 平台阅读 PDF 解析说明
- **THEN** 文档必须明确说明需要 Python 3.12
- **AND** 命令必须包含版本约束:`--with "docling==2.40.0" --with "docling-parse==4.0.0" --with "numpy<2"`
- **AND** 必须说明原因docling-parse 5.x 无 x86_64 wheel
#### Scenario: 其他平台使用最新版本
- **WHEN** 用户在 macOS ARM 或 Linux 平台
- **THEN** 命令可以省略版本号,使用最新兼容版本
- **AND** 文档必须说明这是可行的
### Requirement: 移除 pyproject.toml
系统必须移除 pyproject.toml 文件,不再使用 extras 声明依赖。
#### Scenario: 项目根目录不包含 pyproject.toml
- **WHEN** 用户查看项目根目录
- **THEN** 系统必须不包含 pyproject.toml 文件
#### Scenario: 依赖说明不在 pyproject.toml
- **WHEN** 用户尝试查找依赖声明
- **THEN** 系统必须引导用户查阅 SKILL.md 或 README.md
### Requirement: 移除 uv.lock
系统必须移除 uv.lock 文件,每次 `uv run` 都是全新的依赖解析。
#### Scenario: 项目不包含 uv.lock
- **WHEN** 用户查看项目根目录
- **THEN** 系统必须不包含 uv.lock 文件
#### Scenario: 依赖版本由文档说明
- **WHEN** 用户需要了解依赖版本约束
- **THEN** 系统必须在 SKILL.md 或 README.md 中说明
- **AND** 不依赖 uv.lock 锁定版本
### Requirement: 核心 chardet 依赖
系统必须在所有 `uv run --with` 命令中包含 chardet 依赖。
#### Scenario: 所有格式都包含 chardet
- **WHEN** 用户查阅任何格式的依赖命令
- **THEN** 命令必须包含 `--with chardet`