release-package-version
关于
This skill automates the complete release cycle for R packages, handling version bumps, NEWS.md updates, git tagging, and GitHub release creation. Use it when a package is ready for a patch, minor, or major release, or after CRAN acceptance to create the corresponding GitHub release. It also sets up the post-release development version increment.
快速安装
Claude Code
推荐npx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/release-package-version在 Claude Code 中复制并粘贴此命令以安装该技能
技能文档
發布套件版本
執行 R 套件之完整版本發布週期。
適用時機
- 已備發布新版本(修錯、功能或破壞性變更)
- CRAN 接受之後,建立對應之 GitHub 發布
- 設置發布後之開發版本
輸入
- 必要:含已備發布變更之套件
- 必要:發布類型:patch(0.1.0 -> 0.1.1)、minor(0.1.0 -> 0.2.0)或 major(0.1.0 -> 1.0.0)
- 選擇性:是否提交 CRAN(預設:否,宜獨用
submit-to-cran技能)
步驟
步驟一:定版本變更
依語意化版本:
| 變更類型 | 版本變更 | 例 |
|---|---|---|
| 僅修錯 | Patch | 0.1.0 -> 0.1.1 |
| 新功能(向後相容) | Minor | 0.1.0 -> 0.2.0 |
| 破壞性變更 | Major | 0.1.0 -> 1.0.0 |
預期: 依上次發布以來變更之性質,確定正確之變更類型(patch、minor 或 major)。
失敗時: 若不確,檢視上次標籤以來之 git log 並對每變更分類。任何破壞性 API 變更皆須 major 變更。
步驟二:更新版本
usethis::use_version("minor") # or "patch" or "major"
此將更新 DESCRIPTION 中之 Version 欄並於 NEWS.md 加標題。
預期: DESCRIPTION 之版本已更新。NEWS.md 有發布版本之新段標題。
失敗時: 若 usethis::use_version() 不可用,手動更新 DESCRIPTION 之 Version 欄並加 # packagename x.y.z 標題至 NEWS.md。
步驟三:更新 NEWS.md
於新版本標題下填入發布筆記:
# packagename 0.2.0
## New Features
- Added `new_function()` for processing data (#42)
- Support for custom themes in `plot_results()` (#45)
## Bug Fixes
- Fixed crash when input contains all NAs (#38)
- Corrected off-by-one error in `window_calc()` (#41)
## Minor Improvements
- Improved error messages for invalid input types
- Updated documentation examples
用議題/PR 編號以資追蹤。
預期: NEWS.md 含按類組織之面向用戶變更之完整摘要,附議題/PR 編號以資追蹤。
失敗時: 若變更難以重建,用 git log --oneline v<previous>..HEAD 列上次發布以來之所有提交並分類之。
步驟四:最終檢查
devtools::check()
devtools::spell_check()
urlchecker::url_check()
預期: devtools::check() 返 0 錯誤、0 警告、0 注。拼寫檢查與 URL 檢查無問題。
失敗時: 發布前修所有錯誤與警告。將誤報詞加入 inst/WORDLIST 供拼寫檢查器。替換失效之 URL。
步驟五:提交發布
git add DESCRIPTION NEWS.md
git commit -m "Release packagename v0.2.0"
預期: 含 DESCRIPTION 之版本變更與更新後 NEWS.md 之單一提交。
失敗時: 若有他未提交變更,僅暫存 DESCRIPTION 與 NEWS.md。發布提交應僅含版本相關變更。
步驟六:標記發布
git tag -a v0.2.0 -m "Release v0.2.0"
git push origin main --tags
預期: 註解標籤 v0.2.0 已建並推至遠端。git tag -l 於本地顯示標籤;git ls-remote --tags origin 於遠端確認之。
失敗時: 若推送失敗,檢查是否有寫入權。若標籤已存在,以 git show v0.2.0 確認其指向正確提交。
步驟七:建立 GitHub 發布
gh release create v0.2.0 \
--title "packagename v0.2.0" \
--notes-file NEWS.md
或用:
usethis::use_github_release()
預期: GitHub 發布已建,發布筆記可見於倉庫之 Releases 頁。
失敗時: 若 gh release create 失敗,確認 gh CLI 已認證(gh auth status)。若 usethis::use_github_release() 失敗,於 GitHub 手動建發布。
步驟八:設開發版本
發布後,變更至開發版本:
usethis::use_dev_version()
此將版本改為 0.2.0.9000 表示開發中。
git add DESCRIPTION NEWS.md
git commit -m "Begin development for next version"
git push
預期: DESCRIPTION 之版本現為 0.2.0.9000(開發版本)。NEWS.md 有開發版本之新標題。變更已推至遠端。
失敗時: 若 usethis::use_dev_version() 不可用,手動將版本改為 DESCRIPTION 中之 x.y.z.9000 並加 # packagename (development version) 標題至 NEWS.md。
驗證
- DESCRIPTION 中之版本與擬發布相符
- NEWS.md 有完整準確之發布筆記
-
R CMD check通過 - Git 標籤與版本相符(如
v0.2.0) - GitHub 發布已存在,附發布筆記
- 發布後開發版本已設(x.y.z.9000)
常見陷阱
- 遺忘推送標籤:
git push單獨不推標籤。用--tags或git push origin v0.2.0 - NEWS.md 格式:用合 pkgdown/CRAN 預期格式之 markdown 標題
- 標錯提交:務於版本變更提交之後標籤,勿之前
- CRAN 版本已存在:CRAN 不接受已發布之版本。務遞增
- 開發版本入發布:永勿提交
.9000版本至 CRAN
相關技能
submit-to-cran— 版本發布後 CRAN 之提交create-github-release— 通用 GitHub 發布建立setup-github-actions-ci— 發布時觸發 pkgdown 重建build-pkgdown-site— 文件站反映新版本
GitHub 仓库
相关推荐技能
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是理想选择。
