Как правильно документировать методы S4 "[" и "[<-" с использованием roxygen? - программирование
Подтвердить что ты не робот

Как правильно документировать методы S4 "[" и "[<-" с использованием roxygen?

Ниже я опубликовал мини-пример, в котором я хочу написать документацию для метода "[" для класса S4. Кто-нибудь знает, как правильно документировать метод для обобщенного "[" с использованием roxygen и S4?
Я получаю предупреждение при проверке пакета после сборки (см. Ниже).

#' An S4 class that stores a string.
#' @slot a contains a string
#' @export
setClass("testClass", 
         representation(a="character"))

#' extract method for testClass
#'
#' @docType methods
#' @rdname extract-methods
setMethod("[", signature(x = "testClass", i = "ANY", j="ANY"),
         function (x, i, j, ..., drop){
             print("void function")
         }
)

Выдержка из проверки пакета:

* checking for missing documentation entries ... WARNING
Undocumented S4 methods:
  generic '[' and siglist 'testClass'
All user-level objects in a package (including S4 classes and methods)
should have documentation entries.
See the chapter 'Writing R documentation files' in manual 'Writing R Extensions'.
4b9b3361

Ответ 1

Как и в случае с roxygen2 > 3.0.0, вам больше не нужно работать и нужно только:

#' Extract parts of testClass.
#'
setMethod("[", signature(x = "testClass", i = "ANY", j="ANY"),
  function (x, i, j, ..., drop){
    print("void function")
  }
)

Ответ 2

Я, наконец, понял это более или менее. По крайней мере, теперь это работает:

#' An S4 class that stores a string.
#' @slot a contains a string
#' @export
setClass("testClass", 
     representation(a="character"))

#' extract parts of testClass
#'
#' @name [
#' @aliases [,testClass-method
#' @docType methods
#' @rdname extract-methods
#'
setMethod("[", signature(x = "testClass", i = "ANY", j="ANY"),
    function (x, i, j, ..., drop){
       print("void function")
    }
)

Ответ 3

Для чего стоит, в случае замены функции, вам нужно что-то вроде следующего:

#' An S4 class that stores a list.
#' @export
    setClass("testClass", 
      representation(a="list"))

#' extract parts of testClass
#'
#' @name [
#' @aliases [,testClass-method
#' @docType methods
#' @rdname extract-methods
setMethod("[", signature(x = "testClass", i = "ANY", j="ANY"),
  function (x, i, j, ..., drop) {
     [email protected][i]
  }
)

#' replace names of testClass
#'
#' @name [
#' @aliases [<-,testClass-method
#' @docType methods
#' @rdname extract-methods
setReplaceMethod("names", signature(x = "testClass", value = "ANY"), definition = function (x, value) {
  names([email protected]) <- value
  x
})