Files
to-live-photo/CLAUDE.md
2025-12-16 10:42:42 +08:00

60 lines
1.7 KiB
Markdown

# Live Photo Studio
**Bundle ID**: `xyz.let5see.livephotomaker`
**最低支持**: iOS/iPadOS 18.0
**技术栈**: SwiftUI + Swift Concurrency + Core ML
## 项目结构
```
Sources/LivePhotoCore/ # 核心库 (Swift Package)
to-live-photo/to-live-photo/
├── Views/ # Home → Editor → Processing → Result
├── AppState.swift # 全局状态
└── DesignSystem.swift # Soft UI 设计令牌
```
## 构建命令
```bash
# 模拟器构建
xcodebuild -scheme to-live-photo -destination 'platform=iOS Simulator,name=iPhone 16 Pro' build
# Archive
xcodebuild -scheme to-live-photo -configuration Release -destination 'generic/platform=iOS' -archivePath build/to-live-photo.xcarchive archive
```
## Git 规范
### 提交类型
- `feat`: 新功能
- `fix`: 修复已有功能的缺陷
- `refactor`: 重构(行为不变)
- `chore`: 构建、依赖、工具
- `docs`: 仅文档
### 分支策略
- **直接 main**: 文档、注释、单文件小修复、配置微调
- **新建分支**: 新功能、涉及 ≥3 文件的改动、实验性尝试
### 提交前检查
1. `xcodebuild build` 无错误
2. UI 改动需在模拟器运行验证
3. 单次提交只做一件事
## 禁止事项
- 不修改: `Info.plist` 版本号、`Package.resolved`
- 不新增: 依赖库(需明确授权)
- 不创建: 仅用一次的工具类/文件
- 不重构: 与当前任务无关的代码
- 不执行: 破坏性删除命令(如 rm -rf 涉及 ~ 或 / 路径)
## 代码规范
- 遵循 `DesignSystem.swift` 令牌,禁止硬编码颜色/间距
- 新增 View 必须包含 `accessibilityLabel`
- 新增 View 必须适配深色模式和 iPad
- 触控目标 ≥ 44pt
- 错误处理使用 `LivePhotoError` 枚举,禁止裸 `throw`