MCP HubMCP Hub
스킬 목록으로 돌아가기

release-package-version

pjt222
업데이트됨 Yesterday
17
2
17
GitHub에서 보기
메타general

정보

이 스킬은 R 패키지의 전체 릴리스 주기를 자동화하여 버전 업데이트, NEWS.md 갱신, git 태그 지정, GitHub 릴리스 생성을 처리합니다. 패치, 마이너 또는 메이저 릴리스가 준비된 경우나 CRAN 승인 후 해당 GitHub 릴리스를 생성할 때 사용하세요. 또한 릴리스 후 개발 버전 증분 설정도 수행합니다.

빠른 설치

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에서 이 명령을 복사하여 붙여넣어 스킬을 설치하세요

문서

發布套件版本

執行 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 技能)

步驟

步驟一:定版本變更

依語意化版本:

變更類型版本變更
僅修錯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 變更。

步驟二:更新版本

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 單獨不推標籤。用 --tagsgit 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 저장소

pjt222/agent-almanac
경로: i18n/wenyan-lite/skills/release-package-version
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

연관 스킬

content-collections

메타

이 스킬은 콘텐츠 콜렉션(Content Collections)을 위한 프로덕션 검증된 설정을 제공합니다. 콘텐츠 콜렉션은 Markdown/MDX 파일을 Zod 검증이 포함된 타입 안전한 데이터 콜렉션으로 변환해주는 TypeScript 최우선 도구입니다. 블로그, 문서 사이트 또는 콘텐츠 중심의 Vite + React 애플리케이션을 구축할 때 타입 안전성과 자동 콘텐츠 검증을 보장하기 위해 사용하세요. Vite 플러그인 구성과 MDX 컴파일부터 배포 최적화 및 스키마 검증에 이르기까지 모든 것을 다룹니다.

스킬 보기

polymarket

메타

이 스킬은 개발자들이 Polymarket 예측 시장 플랫폼을 활용한 애플리케이션을 구축할 수 있도록 지원하며, 거래 및 시장 데이터를 위한 API 통합 기능을 포함합니다. 또한 WebSocket을 통한 실시간 데이터 스트리밍을 제공하여 실시간 거래와 시장 활동을 모니터링할 수 있습니다. 이를 통해 거래 전략을 구현하거나 실시간 시장 업데이트를 처리하는 도구를 생성하는 데 활용할 수 있습니다.

스킬 보기

creating-opencode-plugins

메타

이 스킬은 개발자들이 명령어, 파일, LSP 작업 등 25개 이상의 이벤트 유형에 연결되는 OpenCode 플러그인을 만들 수 있도록 돕습니다. JavaScript/TypeScript 모듈을 위한 플러그인 구조, 이벤트 API 명세, 구현 패턴을 제공합니다. OpenCode AI 어시스턴트의 라이프사이클을 사용자 정의 이벤트 기반 로직으로 가로채거나, 모니터링하거나, 확장해야 할 때 사용하세요.

스킬 보기

sglang

메타

SGLang은 RadixAttention 프리픽스 캐싱을 활용하여 JSON, 정규식, 에이전트 워크플로우를 위한 고속 구조화 생성에 특화된 고성능 LLM 서빙 프레임워크입니다. 특히 반복되는 프리픽스가 있는 작업에서 상당히 빠른 추론 속도를 제공하여 복잡한 구조화 출력 및 다중 턴 대화에 이상적입니다. 제약 디코딩이 필요하거나 광범위한 프리픽스 공유가 있는 애플리케이션을 구축할 때는 vLLM과 같은 대안보다 SGLang을 선택하십시오.

스킬 보기