-
-
Notifications
You must be signed in to change notification settings - Fork 85
Roxygen Guide
Michel Lang edited this page Dec 23, 2018
·
21 revisions
- Document
NULL
instead of the class itself to get more flexibility. Note that you must provide@name
. - Documentation contains the following elements:
- Each documentation starts with an
@title
section (explicitly declaring it as title), followed by a newline. - Next comes an
@description
which describes the general purpose of the class. - The "Usage" section must be manually created with
@section Usage
. It should contain the following information:- If the class inherits from another class, this should be the first information.
- The construction of the class, with assignment to an examplary variable.
- All members, in alphabetical order. This includes active bindings. If the member is intendend to be set by the user, include an extra line with an assignment.
- All methods (except
clone()
,print()
andformat()
), in alphabetical order. Include all arguments and defaults. - All S3 methods defined for the class.
- Section "Arguments". Describe each argument used in the construtctor, as right-hand side of an assignment or as an argument in a method. Include the expected class / type of each argument. If you have trouble describing an argument because it has a different type in different places, try to find better names to distinguish these variables.
- Section "Details". A short description for each member and each method, in the same order as listed in "Usage". Make sure to document the type or return value for members and methods, respectively.
- Each documentation starts with an
- Use
@keywords internal
for classes which are mostly used internally. - Use
@family
for all classes which belong to a common parent class, including the parent class. - Remember to
@include TheBaseClass.R
if the parent class lives in another file in the same package to make sure that the collation order is set correctly inDESCRIPTION
.
#' @title ClassFoo
#'
#' @name ClassFoo
#' @description
#' This is the description of class foo. Its only purpose is this
#' documentation example.
#'
#' @section Usage:
#' Inherits from [TheBaseClass].
#'
#' ```
#' # Construction
#' f = ClassFoo$new(argument1)
#'
#' # Members
#' f$id
#' f$id = id
#' f$member
#'
#' # Methods
#' f$method1(argument2 = 123)
#' f$method2()
#' ```
#'
#' @section Arguments:
#' * `argument1` ([R6 class] or `type`):
#' Description of argument1
#' * `argument2` (`integer()`):
#' Description of argument1
#' * `id` (`character(1)`):
#' Identifier for the instance.
#’
#' @section Details:
#' * `id`: A short descriptive identifier.
#' * `member`: Description of member.
#' * `method1()` ([data.table::data.table()]): Description of method1. The returned data table has two columns: ...
#' * `method2()` (`logical(1)`): Description of method2. Return `TRUE` if some condition holds.
#'
#' @family TheBaseClass
#'
#' @examples
#' f = ClassFoo$new("hello", 123)
#' f$method1(10)
NULL
#' @export
ClassFoo = R6Class("ClassFoo", inherit = TheBaseClass)
CI
Roxygen (Documentation)
Style
Misc