Preamble (run first)
bash "$(dirname "${BASH_SOURCE[0]}")"/check-update.sh 2>/dev/null || true
# 检测当前版本
if [ -f "VERSION" ]; then
CURRENT_VERSION=$(cat VERSION)
echo "📦 当前版本: $CURRENT_VERSION"
else
echo "⚠️ 未找到VERSION文件"
CURRENT_VERSION="unknown"
fi
# 检测Git仓库
if [ -d ".git" ]; then
echo "✅ Git仓库检测成功"
else
echo "❌ 未检测到Git仓库,无法升级"
exit 1
fi
执行流程
步骤 1: 检测当前版本
使用 Read 工具读取 VERSION 文件。
记录当前版本到变量 CURRENT_VERSION
步骤 2: 查询最新版本
使用 Bash 工具执行:
# 获取远程仓库最新版本标签
git fetch --tags
# 获取最新标签
LATEST_TAG=$(git tag --sort=-v:refname | head -n 1)
echo "🏷️ 最新版本: $LATEST_TAG"
记录最新版本到变量 LATEST_VERSION
步骤 3: 对比版本
AI 对比 CURRENT_VERSION 和 LATEST_VERSION:
如果当前版本 = 最新版本:
✅ 您已在最新版本!
当前版本: {CURRENT_VERSION} 最新版本: {LATEST_VERSION}
无需升级。
结束流程。
如果当前版本 < 最新版本:
🎉 发现新版本!
当前版本: {CURRENT_VERSION} 最新版本: {LATEST_VERSION}
是否查看更新日志?
用户选择后,继续。
步骤 4: 查看更新日志
使用 Bash 工具:
# 查看最新版本的更新日志
git log --pretty=format:"- %s" $CURRENT_VERSION..$LATEST_TAG
显示更新内容:
📋 更新日志 ({LATEST_VERSION}):
{更新内容}
询问用户:
是否升级到 {LATEST_VERSION}?
A) 是的,立即升级(推荐) B) 查看完整变更日志后再决定 C) 暂不升级
步骤 5: 执行升级
如果用户选择升级:
5.1 备份当前版本
使用 Bash 工具:
# 创建备份分支
BACKUP_BRANCH="backup/$(date +%Y%m%d_%H%M%S)"
git checkout -b $BACKUP_BRANCH
echo "✅ 已创建备份分支: $BACKUP_BRANCH"
5.2 切换到最新版本
# 切换到最新标签
git checkout $LATEST_TAG
# 验证VERSION文件
NEW_VERSION=$(cat VERSION)
echo "✅ 已切换到版本: $NEW_VERSION"
5.3 验证升级
使用 Read 工具验证 VERSION 文件内容。
确认版本号已更新。
步骤 6: 输出完成提示
✅ 升级成功!
原版本: {CURRENT_VERSION} 新版本: {LATEST_VERSION}
备份分支: {BACKUP_BRANCH}
如需回退,执行:
git checkout {BACKUP_BRANCH}
回退流程
步骤 1: 查看备份分支
如果用户需要回退:
使用 Bash 工具:
# 列出所有备份分支
git branch | grep "backup/"
显示备份分支列表:
📂 可回退的版本:
A) backup/20260325_154500 (v1.0.0) B) backup/20260324_120000 (v0.9.0) ...
步骤 2: 选择回退版本
使用 AskUserQuestion:
选择要回退的版本:
用户选择后,执行回退:
# 切换到备份分支
git checkout {BACKUP_BRANCH}
# 验证版本
cat VERSION
步骤 3: 验证回退
确认版本号正确。
输出:
✅ 已回退到版本 {VERSION}
兜底机制
场景 1: 网络问题
如果无法获取远程版本:
git fetch --tags 2>&1
if [ $? -ne 0 ]; then
echo "❌ 无法连接到远程仓库"
echo "请检查网络连接或稍后重试"
fi
场景 2: 未提交的更改
如果有未提交的更改:
git status --porcelain
if [ $? -ne 0 ]; then
echo "⚠️ 检测到未提交的更改"
echo ""
echo "建议先提交或暂存更改后再升级"
echo ""
echo "您可以选择:"
echo "A) 暂存更改(git stash)"
echo "B) 提交更改"
echo "C) 放弃升级"
fi
场景 3: 版本号格式错误
如果VERSION文件格式不正确:
if ! [[ "$CURRENT_VERSION" =~ ^v[0-9]+\.[0-9]+\.[0-9]+$ ]]; then
echo "⚠️ VERSION文件格式不正确: $CURRENT_VERSION"
echo "期望格式: v1.0.0"
fi
注意事项
- 备份重要:升级前自动创建备份分支
- 网络依赖:需要访问Git远程仓库
- 版本号格式:遵循语义化版本(v1.0.0)
- 回退支持:任何时候都可以回退到旧版本
- Git依赖:需要Git仓库环境
版本历史
- v1.0.0 (2026-03-25): 初始版本,包含需求洞察模块8个skill
- v1.1.0 (计划中): 方案设计模块
- v1.2.0 (计划中): 增长迭代模块
- v2.0.0 (计划中): 完整27个skill
产出质量检查 / Verification Checklist
- 版本号已确认(当前版本 vs 目标版本)
- 升级脚本已验证
- 回退方案已准备
- VERSION 文件已更新
⚠️ 任何一项未通过 → 不要执行升级。
常见误区 / Red Flags — STOP
出现以下情况立即停止并回溯:
| 误区 | 正确做法 |
|---|---|
| 使用"应该"、"大概"、"看起来"做结论 | 必须基于实际数据和验证 |
| 未运行检查就声称已完成 | 先验证,再陈述 |
| 跳过备份直接升级 | 先备份,再升级 |