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.md
source 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

注意事项

  1. 备份重要:升级前自动创建备份分支
  2. 网络依赖:需要访问Git远程仓库
  3. 版本号格式:遵循语义化版本(v1.0.0)
  4. 回退支持:任何时候都可以回退到旧版本
  5. Git依赖:需要Git仓库环境

版本历史

  • v1.0.0 (2026-03-25): 初始版本,包含需求洞察模块8个skill
  • v1.1.0 (计划中): 方案设计模块
  • v1.2.0 (计划中): 增长迭代模块
  • v2.0.0 (计划中): 完整27个skill