submit-to-cran
О программе
Этот навык Claude автоматизирует полный рабочий процесс отправки R-пакета в CRAN, включая предварительные проверки и подготовку необходимого файла `cran-comments.md`. Он обрабатывает первоначальные выпуски, обновления существующих пакетов и повторные отправки после отзывов рецензентов. Разработчикам следует использовать его, когда их пакет проходит локальные проверки без ошибок и предупреждений и имеет обновлённый номер версии.
Быстрая установка
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/submit-to-cranСкопируйте и вставьте эту команду в Claude Code для установки этого навыка
Документация
Submit to CRAN
Full CRAN sub workflow: pre-flight checks → submission.
Use When
- Pkg ready for initial CRAN release
- Sub updated ver of existing CRAN pkg
- Re-sub after CRAN reviewer feedback
In
- Required: R pkg passing local
R CMD checkw/ 0 err + 0 warn - Required: Updated ver # in DESCRIPTION
- Required: Updated NEWS.md w/ ver changes
- Optional: Prev CRAN reviewer comments (re-subs)
Do
Step 1: Ver + NEWS Check
Verify DESCRIPTION ver:
desc::desc_get_version()
Verify NEWS.md has entry. Summarize user-facing changes.
Got: Ver follows semver. NEWS.md has matching entry.
If err: Update ver usethis::use_version() (major/minor/patch). Add NEWS.md entry.
Step 2: Local R CMD Check
devtools::check()
Got: 0 err, 0 warn, 0 notes (1 note OK new sub: "New submission").
If err: Fix all err+warn before. Read log <pkg>.Rcheck/00check.log. Notes → explain in cran-comments.md.
Step 3: Spell Check
devtools::spell_check()
Add legit words → inst/WORDLIST (one per line, sorted).
Got: No unexpected misspellings. All flagged corrected | added.
If err: Fix genuine misspellings. Tech terms → inst/WORDLIST sorted.
Step 4: URL Check
urlchecker::url_check()
Got: All URLs HTTP 200. No broken/redirected.
If err: Replace broken. \doi{} for DOI links not raw URLs. Remove dead links.
Step 5: Win-Builder
devtools::check_win_devel()
devtools::check_win_release()
Wait email (~15-30 min).
Got: 0 err + 0 warn on both release + devel. Email in 15-30 min.
If err: Address platform-specific. Common: diff compiler warns, missing sys deps, path sep diffs. Fix local + re-sub.
Step 6: R-hub Check
rhub::rhub_check()
Multi-platform (Ubuntu, Windows, macOS).
Got: All platforms pass 0 err + 0 warn.
If err: Specific platform fails → check R-hub log. Use testthat::skip_on_os() | conditional code for platform-dep behavior.
Step 7: Prep cran-comments.md
Create | update in pkg root:
## R CMD check results
0 errors | 0 warnings | 1 note
* This is a new release.
## Test environments
* local: Windows 11, R 4.5.0
* win-builder: R-release, R-devel
* R-hub: ubuntu-latest (R-release), windows-latest (R-release), macos-latest (R-release)
## Downstream dependencies
There are currently no downstream dependencies for this package.
Updates → include:
- What changed (brief)
- Response to prev reviewer feedback
- Reverse dep check results if applicable
Got: Accurate summary across all envs, explains notes.
If err: Results differ across platforms → doc all variations. CRAN reviewers check vs own tests.
Step 8: Final Pre-flight
# One last check
devtools::check()
# Verify the built tarball
devtools::build()
Got: Final check passes clean. .tar.gz built in parent dir.
If err: Last-min issue → fix + re-run all from Step 2. Don't sub w/ known fails.
Step 9: Submit
devtools::release()
Interactive checks + sub. Answer honest.
Alt: manual at https://cran.r-project.org/submit.html, upload tarball.
Got: Confirmation email from CRAN in min. Click link → finalize.
If err: Check email for rejection reasons. Common: examples too slow, missing \value tags, non-portable code. Fix + re-sub, note in cran-comments.md what changed.
Step 10: Post-Submission
Post-acceptance:
# Tag the release
usethis::use_github_release()
# Bump to development version
usethis::use_dev_version()
Got: GitHub release created w/ accepted ver tag. DESCRIPTION bumped to dev (x.y.z.9000).
If err: GH release fails → manual gh release create. CRAN acceptance delayed → wait email before tag.
Check
-
R CMD check0 err + 0 warn local - Win-builder passes (release + devel)
- R-hub passes all platforms
-
cran-comments.mdaccurate - All URLs valid
- No spelling errors
- Ver # correct + incremented
- NEWS.md current
- DESCRIPTION metadata complete + accurate
Traps
- Examples too slow: Wrap expensive in
\donttest{}. CRAN enforces time limits. - Non-std file/dir names: Avoid files triggering CRAN notes (check
.Rbuildignore) - Missing
\valuein docs: All exported fns need@returntag - Vignette build fails: Vignettes must build in clean env w/o your
.Renviron - DESCRIPTION Title: Title Case, no period at end, no "A Package for..."
- Forget rev dep checks: Updates → run
revdepcheck::revdep_check()
Examples
# Full pre-submission workflow
devtools::spell_check()
urlchecker::url_check()
devtools::check()
devtools::check_win_devel()
rhub::rhub_check()
# Wait for results...
devtools::release()
→
release-package-version— ver bumping + git taggingwrite-roxygen-docs— docs meet CRAN standardssetup-github-actions-ci— CI mirroring CRAN expectationsbuild-pkgdown-site— docs site for accepted pkgs
GitHub репозиторий
Похожие навыки
content-collections
МетаЭтот навык предоставляет проверенную в продакшене настройку для Content Collections — TypeScript-ориентированного инструмента, который преобразует файлы Markdown/MDX в типобезопасные коллекции данных с валидацией Zod. Используйте его при создании блогов, сайтов документации или контентных приложений на Vite + React для обеспечения типобезопасности и автоматической проверки содержимого. Он охватывает всё: от настройки плагина Vite и компиляции MDX до оптимизации развертывания и валидации схем.
polymarket
МетаЭтот навык позволяет разработчикам создавать приложения на платформе прогнозных рынков Polymarket, включая интеграцию с API для торговли и получения рыночных данных. Он также обеспечивает потоковую передачу данных в реальном времени через WebSocket для отслеживания текущих сделок и рыночной активности. Используйте его для реализации торговых стратегий или создания инструментов, обрабатывающих обновления рынка в реальном времени.
creating-opencode-plugins
МетаЭтот навык помогает разработчикам создавать плагины OpenCode, которые подключаются к более чем 25 типам событий, таким как команды, файлы и операции LSP. Он предоставляет структуру плагина, спецификации API событий и шаблоны реализации для модулей на JavaScript/TypeScript. Используйте его, когда вам нужно перехватывать, отслеживать или расширять жизненный цикл ассистента OpenCode AI с помощью пользовательской событийно-ориентированной логики.
sglang
МетаSGLang — это высокопроизводительный фреймворк для обслуживания больших языковых моделей (LLM), специализирующийся на быстрой структурированной генерации JSON, regex и рабочих процессов агентов с использованием кэширования префиксов RadixAttention. Он обеспечивает значительно более высокую скорость вывода, особенно для задач с повторяющимися префиксами, что делает его идеальным для сложных структурированных результатов и многократных диалогов. Выбирайте SGLang вместо альтернатив, таких как vLLM, когда вам требуется ограниченное декодирование или вы создаете приложения с интенсивным совместным использованием префиксов.
