MCP HubMCP Hub
Volver a habilidades

submit-to-cran

pjt222
Actualizado 2 days ago
3 vistas
17
2
17
Ver en GitHub
Metadesign

Acerca de

Esta Habilidad de Claude automatiza el flujo de trabajo completo para enviar un paquete R a CRAN, incluyendo las comprobaciones previas al envío y la preparación del archivo requerido `cran-comments.md`. Maneja lanzamientos iniciales, actualizaciones de paquetes existentes y reenvíos tras los comentarios de los revisores. Los desarrolladores deben usarla cuando su paquete supere las comprobaciones locales sin errores ni advertencias y tenga un número de versión actualizado.

Instalación rápida

Claude Code

Recomendado
Principal
npx skills add pjt222/agent-almanac -a claude-code
Comando PluginAlternativo
/plugin add https://github.com/pjt222/agent-almanac
Git CloneAlternativo
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/submit-to-cran

Copia y pega este comando en Claude Code para instalar esta habilidad

Documentación

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 check w/ 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 check 0 err + 0 warn local
  • Win-builder passes (release + devel)
  • R-hub passes all platforms
  • cran-comments.md accurate
  • 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 \value in docs: All exported fns need @return tag
  • 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 tagging
  • write-roxygen-docs — docs meet CRAN standards
  • setup-github-actions-ci — CI mirroring CRAN expectations
  • build-pkgdown-site — docs site for accepted pkgs

Repositorio GitHub

pjt222/agent-almanac
Ruta: i18n/caveman-ultra/skills/submit-to-cran
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

Habilidades relacionadas

content-collections

Meta

Esta habilidad proporciona una configuración probada en producción para Content Collections, una herramienta centrada en TypeScript que transforma archivos Markdown/MDX en colecciones de datos con tipado seguro mediante validación Zod. Úsala al construir blogs, sitios de documentación o aplicaciones Vite + React con mucho contenido para garantizar seguridad de tipos y validación automática de contenido. Abarca todo, desde la configuración del plugin de Vite y compilación MDX hasta la optimización de despliegue y validación de esquemas.

Ver habilidad

polymarket

Meta

Esta habilidad permite a los desarrolladores crear aplicaciones con la plataforma de mercados de predicción Polymarket, incluyendo la integración de API para operaciones y datos de mercado. También proporciona transmisión de datos en tiempo real a través de WebSocket para monitorear operaciones en vivo y actividad del mercado. Úsela para implementar estrategias de trading o crear herramientas que procesen actualizaciones de mercado en tiempo real.

Ver habilidad

creating-opencode-plugins

Meta

Esta habilidad ayuda a los desarrolladores a crear complementos de OpenCode que se conectan a más de 25 tipos de eventos, como comandos, archivos y operaciones LSP. Proporciona la estructura del complemento, las especificaciones de la API de eventos y los patrones de implementación para módulos en JavaScript/TypeScript. Úsala cuando necesites interceptar, monitorear o extender el ciclo de vida del asistente de IA de OpenCode con lógica personalizada basada en eventos.

Ver habilidad

sglang

Meta

SGLang es un framework de alto rendimiento para el servicio de LLM que se especializa en generación rápida y estructurada para JSON, expresiones regulares y flujos de trabajo de agentes utilizando su caché de prefijos RadixAttention. Ofrece una inferencia significativamente más rápida, especialmente para tareas con prefijos repetidos, lo que lo hace ideal para salidas complejas y estructuradas, y conversaciones multiturno. Elige SGLang sobre alternativas como vLLM cuando necesites decodificación restringida o estés construyendo aplicaciones con uso extensivo de prefijos compartidos.

Ver habilidad