SuperPM super-pm-upgrade
install
source · Clone the upstream repo
git clone https://github.com/konglong87/superPM
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/konglong87/superPM "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/super-pm-upgrade" ~/.claude/skills/konglong87-superpm-super-pm-upgrade && rm -rf "$T"
manifest:
skills/super-pm-upgrade/SKILL.mdsource content
Preamble (run first)
# 检测当前版本 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