スキル一覧に戻る

release-package-version

pjt222
更新日 Yesterday
4 閲覧
17
2
17
GitHubで表示
その他general

について

このスキルは、Rパッケージの完全なリリースサイクルを自動化します。バージョン番号の増加、NEWS.mdの更新、gitタグとGitHubリリースの作成を含みます。パッケージが新しいパッチ、マイナー、またはメジャーバージョンを公開する準備ができたとき、またはCRAN受理後に使用するように設計されています。主な機能は、セマンティックバージョニングに基づくバージョン更新と、リリース後の開発バージョン設定を処理します。

クイックインストール

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/release-package-version

このコマンドをClaude Codeにコピー&ペーストしてスキルをインストールします

ドキュメント


name: release-package-version description: > 发布 R 包新版本,包括版本号递增、NEWS.md 更新、git 标签创建、 GitHub release 创建及发布后开发版本设置。适用于包已准备好发布 新的补丁、次要或主要版本、CRAN 接受后创建对应的 GitHub release, 或在发布后立即设置开发版本递增的场景。 locale: zh-CN source_locale: en source_commit: 6f65f316 translator: claude-opus-4-6 translation_date: 2026-03-16 license: MIT allowed-tools: Read Write Edit Bash Grep Glob metadata: author: Philipp Thoss version: "1.0" domain: r-packages complexity: intermediate language: R tags: r, versioning, release, git-tags, changelog

发布包版本

执行 R 包版本发布的完整周期。

适用场景

  • 准备好发布新版本(缺陷修复、功能或破坏性变更)
  • CRAN 接受后,创建对应的 GitHub release
  • 设置发布后的开发版本

输入

  • 必需:已准备好发布变更的包
  • 必需:发布类型: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 技能)

步骤

第 1 步:确定版本递增类型

遵循语义化版本规范:

变更类型版本递增示例
仅缺陷修复Patch0.1.0 -> 0.1.1
新功能(向后兼容)Minor0.1.0 -> 0.2.0
破坏性变更Major0.1.0 -> 1.0.0

预期结果: 根据自上次发布以来的变更性质,确定正确的递增类型(patch、minor 或 major)。

失败处理: 若不确定,查看自上次标签以来的 git log 并对每个变更分类。任何破坏性 API 变更都需要 major 递增。

第 2 步:更新版本

usethis::use_version("minor")  # 或 "patch" 或 "major"

此命令更新 DESCRIPTION 中的 Version 字段并在 NEWS.md 中添加标题。

预期结果: DESCRIPTION 版本已更新。NEWS.md 有该发布版本的新章节标题。

失败处理:usethis::use_version() 不可用,手动更新 DESCRIPTION 中的 Version 字段,并在 NEWS.md 中添加 # packagename x.y.z 标题。

第 3 步:更新 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

使用 issue/PR 编号以便追溯。

预期结果: NEWS.md 包含按类别组织的完整面向用户变更摘要,并附有 issue/PR 编号以便追溯。

失败处理: 若难以重建变更记录,使用 git log --oneline v<previous>..HEAD 列出自上次发布以来的所有提交,并对其分类。

第 4 步:最终检查

devtools::check()
devtools::spell_check()
urlchecker::url_check()

预期结果: devtools::check() 返回 0 个错误、0 个警告、0 个注记。拼写检查和 URL 检查未发现问题。

失败处理: 发布前修复所有错误和警告。将误报词汇添加至 inst/WORDLIST 供拼写检查器使用。替换失效的 URL。

第 5 步:提交发布版本

git add DESCRIPTION NEWS.md
git commit -m "Release packagename v0.2.0"

预期结果: 单个提交包含 DESCRIPTION 中的版本递增和更新后的 NEWS.md。

失败处理: 若存在其他未提交的变更,仅暂存 DESCRIPTION 和 NEWS.md。发布提交应只包含版本相关的变更。

第 6 步:打标签

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 确认它指向正确的提交。

第 7 步:创建 GitHub Release

gh release create v0.2.0 \
  --title "packagename v0.2.0" \
  --notes-file NEWS.md

或使用:

usethis::use_github_release()

预期结果: GitHub release 已创建,发布说明在仓库的 Releases 页面上可见。

失败处理:gh release create 失败,确认 gh CLI 已通过身份验证(gh auth status)。若 usethis::use_github_release() 失败,在 GitHub 上手动创建 release。

第 8 步:设置开发版本

发布后,切换至开发版本:

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,并在 NEWS.md 中添加 # packagename (development version) 标题。

验证清单

  • DESCRIPTION 中的版本与预期发布版本匹配
  • NEWS.md 有完整、准确的发布说明
  • R CMD check 通过
  • Git 标签与版本匹配(如 v0.2.0
  • GitHub release 存在且含发布说明
  • 已设置发布后开发版本(x.y.z.9000)

常见问题

  • 忘记推送标签git push 单独不推送标签,使用 --tagsgit push origin v0.2.0
  • NEWS.md 格式:使用与 pkgdown/CRAN 期望格式匹配的 markdown 标题
  • 对错误的提交打标签:始终在版本递增提交之后打标签,而非之前
  • CRAN 版本已存在:CRAN 不接受已发布的版本,始终递增版本号
  • 发布版本中包含开发版本:切勿将 .9000 版本提交至 CRAN

相关技能

  • submit-to-cran — 版本发布后的 CRAN 提交
  • create-github-release — 通用 GitHub release 创建
  • setup-github-actions-ci — 发布版本时触发 pkgdown 重建
  • build-pkgdown-site — 文档站点反映新版本

GitHub リポジトリ

pjt222/agent-almanac
パス: i18n/zh-CN/skills/release-package-version
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

関連スキル

llamaguard

その他

LlamaGuardは、暴力やヘイトスピーチなど6つの安全性カテゴリーにおいて、LLMの入力と出力をモデレートするMetaの70-80億パラメータモデルです。94〜95%の精度を提供し、vLLM、Hugging Face、Amazon SageMakerを使用してデプロイ可能です。このスキルを使用して、AIアプリケーションにコンテンツフィルタリングと安全策を簡単に統合できます。

スキルを見る

cost-optimization

その他

このClaudeスキルは、リソースの適正サイジング、タグ付け戦略、支出分析を通じて、開発者がクラウドコストを最適化することを支援します。AWS、Azure、GCPにわたるクラウド支出の削減とコストガバナンスの実施のためのフレームワークを提供します。インフラコストの分析、リソースの適正サイジング、または予算制約への対応が必要な際にご利用ください。

スキルを見る

quantizing-models-bitsandbytes

その他

このスキルは、bitsandbytesを使用してLLMを8ビットまたは4ビット精度に量子化し、精度の低下を最小限に抑えつつ50〜75%のメモリ削減を実現します。限られたGPUメモリでより大規模なモデルを実行したり、推論を高速化するのに理想的で、INT8、NF4、FP4などのフォーマットをサポートしています。HuggingFace Transformersと統合され、QLoRAトレーニングや8ビットオプティマイザーを可能にします。

スキルを見る

dispatching-parallel-agents

その他

このClaudeスキルは、複数のエージェントを配備し、3つ以上の独立した問題を並行して調査・修正します。共有状態や依存関係がなく解決可能な、無関係な障害が発生するシナリオ向けに設計されています。中核となる機能は並列問題解決であり、効率を最大化するために独立した問題領域ごとに1つのエージェントを割り当てます。

スキルを見る