返回技能列表

apply-semantic-versioning

pjt222
更新于 6 days ago
31 次查看
17
2
17
在 GitHub 上查看
designdata

关于

This skill analyzes code changes to automatically determine the correct semantic version bump (major/minor/patch) following SemVer 2.0.0. It handles breaking change detection, pre-release identifiers, and build metadata for release preparation. Use it after merging changes to resolve version disagreements or to ensure proper tagging before a release.

快速安装

Claude Code

推荐
主要方式
npx skills add pjt222/agent-almanac -a claude-code
插件命令备选方式
/plugin add https://github.com/pjt222/agent-almanac
Git 克隆备选方式
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/apply-semantic-versioning

在 Claude Code 中复制并粘贴此命令以安装该技能

技能文档

施語義版控

依變析定正版升。此技讀版檔、分變為破(主)、功(次)、修(補)、算新版、更諸檔。循 SemVer 2.0.0 規。

用時

  • 備新發而須定正版乃用
  • 合變後、標前乃用
  • 察變為破否乃用
  • 加預發標(alpha、beta、rc)乃用
  • 解何升宜之爭乃用

  • 必要:含版檔(DESCRIPTION、package.json、Cargo.toml、pyproject.toml、或 VERSION)之項根
  • 必要:上發後之 git 史(標或提交)
  • 可選:用之提交約(Conventional Commits、自由式)
  • 可選:將施之預發標(alpha、beta、rc)
  • 可選:若檔不可讀則前版

第一步:讀當前版

覓項根之版檔而讀之。

# R packages
grep "^Version:" DESCRIPTION

# Node.js
grep '"version"' package.json

# Rust
grep '^version' Cargo.toml

# Python
grep 'version' pyproject.toml

# Plain file
cat VERSION

析當前版為 major.minor.patch 諸分。若版含預發後綴(如 1.2.0-beta.1),別記。

得: 當前版識為 MAJOR.MINOR.PATCH[-PRERELEASE]

敗則: 若無版檔,察 VERSION 或 git 標(git describe --tags --abbrev=0)。若全無版,初發以 0.1.0 始,若項有穩之公 API 則以 1.0.0 始。

第二步:析上發後之變

取上標發後諸變。

# Find the last version tag
git describe --tags --abbrev=0

# List commits since that tag
git log --oneline v1.2.3..HEAD

# If using Conventional Commits, filter by type
git log --oneline v1.2.3..HEAD | grep -E "^[a-f0-9]+ (feat|fix|BREAKING)"

若無標,對初提交或已知基線比。

得: 可按變類分之提交列。

敗則: 若 git 史不可得或標闕,請開發手述變。依其述分類。

第三步:分變

施 SemVer 分類則:

Change TypeVersion BumpExamples
Breaking (incompatible API change)MAJORRenamed/removed public function, changed return type, removed parameter, changed default behavior
Feature (new backwards-compatible functionality)MINORNew exported function, new parameter with default, new file format support
Fix (backwards-compatible bug fix)PATCHBug fix, documentation correction, performance improvement with same API

分類則:

  1. 若任一變破,升為 MAJOR(重次與補為零)
  2. 若無破而任新功,升為 MINOR(重補為零)
  3. 若僅修,升為 PATCH

特例:

  • 1.0.0 前:初發中(0.x.y),次升可含破。明書
  • 棄用:棄函乃次變(仍行)。除之為主
  • 內變:重構而不變公 API 乃補

得: 諸變分為破/功/修而升級定。

敗則: 若變歧,偏高升。保守主升勝於破下游之次升。

第四步:算新版

施升於當前版:

CurrentBumpNew Version
1.2.3MAJOR2.0.0
1.2.3MINOR1.3.0
1.2.3PATCH1.2.4
0.9.5MINOR0.10.0
2.0.0-rc.1(release)2.0.0

若請預發標:

  • 1.3.0-alpha.1 為將至 1.3.0 之首 alpha
  • 1.3.0-beta.1 為首 beta
  • 1.3.0-rc.1 為首 rc

預發先後:alpha < beta < rc < (release)

得: 新版依 SemVer 則算。

敗則: 若當前版不合式或非 SemVer,先歸一。如 1.21.2.0

第五步:更版檔

書新版於宜檔。

# R: Update DESCRIPTION
# Change "Version: 1.2.3" to "Version: 1.3.0"
// Node.js: Update package.json
// Change "version": "1.2.3" to "version": "1.3.0"
// Also update package-lock.json if present
# Rust: Update Cargo.toml
# Change version = "1.2.3" to version = "1.3.0"

若項有多檔引版(如 _pkgdown.ymlCITATIONcodemeta.json),皆更。

得: 諸版檔一致更至新版。

敗則: 若某檔更敗,撤諸變守一致。勿留版檔於半更之狀。

第六步:建版標

更版提交後,建 git 標。

# Annotated tag (preferred)
git tag -a v1.3.0 -m "Release v1.3.0"

# Lightweight tag (acceptable)
git tag v1.3.0

循項既立標式:

得: git 標合新版。

敗則: 若標已存,版未正升。以 git tag -l "v1.3*" 察重標解之而進。

  • 當前版自正版檔讀
  • 上發後諸提交皆析
  • 每變分為破、功、或修
  • 升級合最重變(破 > 功 > 修)
  • 新版循 SemVer 2.0.0 式:MAJOR.MINOR.PATCH[-PRERELEASE][+BUILD]
  • 項中諸版檔一致更
  • 無版跳(如 1.2.3 直至 1.4.0 而 1.3.0 未發)
  • git 標合新版與項約
  • 預發後綴若用,循正先後(alpha < beta < rc)

  • 跳次:自 1.2.3 直至 1.4.0 因「加二功」。每發一升;功數非定版
  • 視棄用為破:棄函(加警)乃次變。僅除之為破
  • 忘 1.0.0 前則:1.0.0 前,API 視不穩。諸項於此階以次升破變,然當書
  • 版檔不一:更 package.json 而不更 package-lock.json、或更 DESCRIPTION 而不更 CITATION。諸版引須同步
  • 建元混:建元(+build.123)不影版先後。1.0.0+build.11.0.0+build.2 先後同
  • 不標發:無 git 標,後升不能定變析之基

  • manage-changelog — 守配版升之更記
  • plan-release-cycle — 謀發里程以定何時升
  • release-package-version — R 特之發流含版升
  • commit-changes — 以正辭提交版升
  • create-github-release — 自版標建 GitHub 發

GitHub 仓库

pjt222/agent-almanac
路径: i18n/wenyan/skills/apply-semantic-versioning
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

相关推荐技能

content-collections

Content Collections 是一个 TypeScript 优先的构建工具,可将本地 Markdown/MDX 文件转换为类型安全的数据集合。它专为构建博客、文档站和内容密集型 Vite+React 应用而设计,提供基于 Zod 的自动模式验证。该工具涵盖从 Vite 插件配置、MDX 编译到生产环境部署的完整工作流。

查看技能

polymarket

这个Claude Skill为开发者提供完整的Polymarket预测市场开发支持,涵盖API调用、交易执行和市场数据分析。关键特性包括实时WebSocket数据流,可监控实时交易、订单和市场动态。开发者可用它构建预测市场应用、实施交易策略并集成实时市场预测功能。

查看技能

creating-opencode-plugins

该Skill帮助开发者创建OpenCode插件,用于接入命令、文件、LSP等25+种事件。它提供了插件结构、事件API规范和JavaScript/TypeScript实现模式,适合需要拦截操作、扩展功能或自定义事件处理的场景。开发者可通过它快速构建响应式模块来增强OpenCode AI助手的能力。

查看技能

sglang

SGLang是一个专为LLM设计的高性能推理框架,特别适用于需要结构化输出的场景。它通过RadixAttention前缀缓存技术,在处理JSON、正则表达式、工具调用等具有重复前缀的复杂工作流时,能实现极速生成。如果你正在构建智能体或多轮对话系统,并追求远超vLLM的推理性能,SGLang是理想选择。

查看技能