devtools roxygen package creation and rd documentation

前端 未结 2 1208
鱼传尺愫
鱼传尺愫 2020-12-28 21:57

I am new to roxygen and am struggling to see how to be able to use it to quickly create a new/custom package.

I.e. I would like to know the minimum requirements are

相关标签:
2条回答
  • 2020-12-28 22:38

    Much later - You could let RoxygenReady prepare your functions with the minimal Roxygen annotation skeleton. It basically brings you from your 2 input functions to GSee's answer, which is the input of Roxygen2.

    0 讨论(0)
  • 2020-12-28 22:46

    I'm surprised @hadley says to not use package.skeleton in his comment. I would use package.skeleton, add roxygen comment blocks, then delete all the files in the "man" directory and run roxygenize. However, since Hadley says "Noooooooooo", here's the minimum you need to be able to build a package that passes R CMD check and exports your functions.

    Create directory called "package1". Under that directory, create a file called DESCRIPTION and put this in it (edit it appropriately if you like):

    DESCRIPTION

    Package: package1
    Type: Package
    Title: What the package does (short line)
    Version: 0.0.1
    Date: 2012-11-12
    Author: Who wrote it
    Maintainer: Who to complain to <yourfault@somewhere.net>
    Description: More about what it does (maybe more than one line)
    License: GPL
    

    Now create a directory called "R" and add a file for each function (or, you can put both of your functions in the same file if you want). I created 2 files: fun1.R and fun2.R

    fun1.R

    #' fun1
    #' @param x numeric
    #' @export
    fun1 <- function(x){
        rnorm(100*x)
    }
    

    fun2.R

    #' fun2
    #' @param y numeric
    #' @export
    fun2 <- function(y){
        rnorm(200*y)
    }
    

    Now you can roxygenize your package

    R> library(roxygen2)
    Loading required package: digest
    R> list.files()
    [1] "package1"
    R> roxygenize("package1")
    Updating collate directive in  /home/garrett/tmp/package1/DESCRIPTION 
    Updating namespace directives
    Writing fun1.Rd
    Writing fun2.Rd
    

    Since you mentioned devtools in the title of your Q, you could use the build and install functions from devtools

    build('package1')
    install('package1')
    

    Or you can exit R and use the tools that come with R to build/check/install.

    $ R CMD build package1
    $ R CMD check package1_0.0.1.tar.gz
    $ R CMD INSTALL package1_0.0.1.tar.gz 
    

    Now, fire up R again to use your new package.

    $ R --vanilla -q
    
    library(package1)
    fun1(20)
    fun2(20)
    

    But, figuring out the minimum requirements is unlikely to help you (or the users of your package) much. You'd be much better off studying one of the many, many packages that use roxgen2.

    Here's a better version of the fun1.R file which still doesn't use all the roxygen tags that it could, but is much better than the bare minimum

    Modified fun1.R

    #' fun1
    #'
    #' This is the Description section
    #'
    #' This is the Details section
    #'
    #' @param x numeric. this is multiplied by 100 to determine the length of the returned vector
    #' @return a numeric vector of random deviates of length \code{100 * x}
    #' @author your name
    #' @seealso \code{\link{fun2}}
    #' @examples
    #' fun1(2)
    #' length(fun1(20))
    #' @export
    fun1 <- function(x){
        rnorm(100*x)
    }
    
    0 讨论(0)
提交回复
热议问题