スキル一覧に戻る

write-roxygen-docs

pjt222
更新日 6 days ago
16 閲覧
17
2
17
GitHubで表示
メタworddata

について

このスキルは、関数、データセット、クラスを含むRパッケージコンポーネントのroxygen2ドキュメントを生成します。tidyverseスタイル規約に従い、標準タグ、相互参照、例、NAMESPACEエントリを扱います。新規エクスポート、内部ヘルパー、S3/S4/R6メソッドのドキュメント作成時、またはR CMD checkのドキュメント問題修正時にご利用ください。

クイックインストール

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/write-roxygen-docs

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

ドキュメント

撰寫 Roxygen 文檔

為 R 套件之函式、資料集與類別建立完整之 roxygen2 文檔。

適用時機

  • 為新匯出函式加文檔
  • 為內部輔助函式加文檔
  • 為套件資料集加文檔
  • 為 S3/S4/R6 類別與方法加文檔
  • 修復文檔相關之 R CMD check

輸入

  • 必要:欲文檔化之 R 函式、資料集或類別
  • 選擇性:交叉引用之相關函式(@family@seealso
  • 選擇性:函式是否應匯出

步驟

步驟一:撰寫函式文檔

將 roxygen 註解直接置於函式上方:

#' Compute the weighted mean of a numeric vector
#'
#' Calculates the arithmetic mean of `x` weighted by `w`. Missing values
#' in either `x` or `w` are handled according to the `na.rm` parameter.
#'
#' @param x A numeric vector of values.
#' @param w A numeric vector of weights, same length as `x`.
#' @param na.rm Logical. Should missing values be removed? Default `FALSE`.
#'
#' @return A single numeric value representing the weighted mean.
#'
#' @examples
#' weighted_mean(1:5, rep(1, 5))
#' weighted_mean(c(1, 2, NA, 4), c(1, 1, 1, 1), na.rm = TRUE)
#'
#' @export
#' @family summary functions
#' @seealso [stats::weighted.mean()] for the base R equivalent
weighted_mean <- function(x, w, na.rm = FALSE) {
  # implementation
}

預期: 完整之 roxygen 區塊,含標題、描述、各參數之 @param@return@examples@export

失敗時: 若不確某標籤,查 ?roxygen2::rd_roclet。常見遺漏為 @return,CRAN 要求所有匯出函式皆需。

步驟二:必要標籤參考

標籤用途匯出時必要?
#' Title首行,一句
#' Description空白行後之段落
@param參數文檔
@return返回值描述是(CRAN)
@examples用法範例強烈建議
@export加至 NAMESPACE是,對公共 API
@family將相關函式分組建議
@seealso交叉引用選擇性
@keywords internal標為內部對非匯出文檔

預期: 函式類型所需之所有標籤皆已辨識。匯出函式至少有 @param@return@examples@export

失敗時: 若不熟某標籤,參 roxygen2 文檔 之用法與語法。

步驟三:文檔化資料集

建立 R/data.R

#' Example dataset of city temperatures
#'
#' A dataset containing daily temperature readings for major cities.
#'
#' @format A data frame with 365 rows and 4 variables:
#' \describe{
#'   \item{date}{Date of observation}
#'   \item{city}{City name}
#'   \item{temp_c}{Temperature in Celsius}
#'   \item{humidity}{Relative humidity percentage}
#' }
#' @source \url{https://example.com/data}
"city_temperatures"

預期: R/data.R 含各資料集之 roxygen 區塊,以 @format 描述結構,以 @source 提供資料來源。

失敗時:R CMD check 警告未文檔化之資料集,確保引號中之字串(如 "city_temperatures")精確匹配以 usethis::use_data() 儲存之物件名。

步驟四:文檔化套件

建立 R/packagename-package.R

#' @keywords internal
"_PACKAGE"

## usethis namespace: start
## usethis namespace: end
NULL

預期: R/packagename-package.R 存在,含 @keywords internal"_PACKAGE" 標記。執行 devtools::document() 生成 man/packagename-package.Rd

失敗時:R CMD check 報缺套件文檔頁,驗證文件名為 R/<packagename>-package.R 且含 "_PACKAGE" 字串。

步驟五:處理特殊情況

含點之函式名(S3 方法):

#' @export
#' @rdname process
process.myclass <- function(x, ...) {
  # S3 method
}

@inheritParams 重用文檔

#' @inheritParams weighted_mean
#' @param trim Fraction of observations to trim.
trimmed_mean <- function(x, w, na.rm = FALSE, trim = 0.1) {
  # implementation
}

.data 代詞之 no visible binding 修復

#' @importFrom rlang .data
my_function <- function(df) {
  dplyr::filter(df, .data$column > 5)
}

預期: 特殊情況(S3 方法、繼承參數、.data 代詞)得正確文檔化。@rdname 將 S3 方法分組。@inheritParams 重用參數文檔而不重複。

失敗時:R CMD check 警告「no visible binding for global variable」,加 #' @importFrom rlang .data 或最後手段用 utils::globalVariables()

步驟六:生成文檔

devtools::document()

預期: man/ 目錄已更新,各文檔化物件有 .Rd 文件。NAMESPACE 已重新生成,含正確之匯出與匯入。

失敗時: 檢查 roxygen 語法錯誤。常見問題:\describe{} 中未閉之括號、行上缺 #' 前綴或無效標籤名。修復後再跑 devtools::document()

驗證

  • 每匯出函式皆有 @param@return@examples
  • devtools::document() 運行無錯誤
  • devtools::check() 無文檔警告
  • @family 標籤正確將相關函式分組
  • 範例運行無錯誤(以 devtools::run_examples() 測試)

常見陷阱

  • @return:CRAN 要求所有匯出函式皆文檔化其返回值
  • 需網路/認證之範例:以 \dontrun{} 包裹,並加註說明原因
  • 慢範例:對可運行但對 CRAN 太慢者用 \donttest{}
  • roxygen 中之 markdown:於 DESCRIPTION 中以 Roxygen: list(markdown = TRUE) 啟用
  • 忘跑 devtools::document():man 頁為生成,非手寫

相關技能

  • create-r-package — 含 roxygen 配置之初始套件設置
  • write-testthat-tests — 測試所文檔化之函式
  • write-vignette — 函式參考之外之長篇文檔
  • submit-to-cran — CRAN 之文檔要求

GitHub リポジトリ

pjt222/agent-almanac
パス: i18n/wenyan-lite/skills/write-roxygen-docs
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

関連スキル

content-collections

メタ

このスキルは、Content Collections(Markdown/MDXファイルを型安全なデータコレクションに変換するTypeScriptファーストのツール)の本番環境でテストされた設定を提供します。Zodバリデーションによる型安全性を実現し、ブログ、ドキュメントサイト、コンテンツ重視のVite + Reactアプリケーション構築時にご利用ください。Viteプラグインの設定、MDXコンパイルから、デプロイ最適化、スキーマバリデーションまで、すべてを網羅しています。

スキルを見る

polymarket

メタ

このスキルは、開発者がPolymarket予測市場プラットフォームを活用したアプリケーション構築を可能にします。API統合による取引や市場データの取得に加え、WebSocketを介したリアルタイムデータストリーミングにより、ライブ取引や市場活動を監視できます。取引戦略の実装や、ライブ市場更新を処理するツールの作成にご利用ください。

スキルを見る

creating-opencode-plugins

メタ

このスキルは、開発者がコマンド、ファイル、LSP操作など25種類以上のイベントタイプにフックするOpenCodeプラグインを作成することを支援します。JavaScript/TypeScriptモジュール向けに、プラグイン構造、イベントAPI仕様、および実装パターンを提供します。カスタムイベント駆動ロジックでOpenCode AIアシスタントのライフサイクルをインターセプト、監視、または拡張する必要がある場合にご利用ください。

スキルを見る

sglang

メタ

SGLangは、高性能なLLMサービングフレームワークであり、RadixAttentionプレフィックスキャッシュを活用したJSON、正規表現、エージェントワークフロー向けの高速で構造化された生成を特長とします。特にプレフィックスが繰り返されるタスクにおいて、大幅に高速な推論を実現し、複雑な構造化出力やマルチターン対話に最適です。制約付きデコードが必要な場合や、広範なプレフィックス共有を伴うアプリケーションを構築する場合は、vLLMなどの代替案ではなくSGLangを選択してください。

スキルを見る