This is the notes for myself on creating R packages in 6 steps, following Jeff Leeks's guide and Hadley Wickham's guide.
Step 1: Loading necessary packages
library("devtools")
library("roxygen2")
Step 2: Create package folder
create('packagename')
This will create a folder with packagename in your working directory with the following files:
- DESCRIPTION
- NAMESPACE
- R (folder)
- Man (folder)
- packagename.Rproj (file)
Open packagename.Rproj with Rstudio, this will bring you to the package directory
Step 3: Add functions
In the R folder, write your desire functions in to files, one function per file.
Remeber to add the following lines (started with #')on the top of each function.
#' Title
#'
#' Description..........
#' ...................
#'
#' @param x1: \code{inputParameter1}
#' @param x2: \code{inputParameter2}
#'
#' @return y1: what is it
#'
#' @keywords keywords
#'
#' @export
#'
#' @examples
#' R code here showing how your function works
try <- function(x1,x2){
y1 <- x1 + x2
return(y1)
}
@export is needed if this function is intended to be used by the users.
Step 4: Add manuals for functions
As the header lines for each function is written in the desired format, it can be automatically translate into manual page by devtools and roxygen2.
document("packagename")
This writes the manual for each functions in to the man folder.
Step 5: Add informations into DESCRIPTION
The DESCRIPTION is automatically generated as:
Package: packagename
Title: What the Package Does (one line, title case)
Version: 0.0.0.9000
Authors@R: person("First", "Last", email = "first.last@example.com", role = c("aut", "cre"))
Description: What the package does (one paragraph).
Depends: R (>= 3.2.2)
License: What license is it under?
LazyData: true
Fill up the infomation without messing with the format, and add the following:
Imports:
dplyr,
stringi
Suggests:
dplyr,
stringi
This will tells R
to install everything under Imports when this package is installed, whereas everything under suggests will not.
Step 6: Push to github
On github, create a repository naming it packagename
echo "# packagename" >> README.md
git init
git add *
git commit -m "first commit"
git remote add origin https://github.com/username/packagename.git
git push -u origin master
Now, the package can be install using the command:
library(devtools)
install_github('packagename',username='username')
Rcpp add on
So in the project Directory, the folder tree should be like:
.
├── DESCRIPTION
├── NAMESPACE
├── R
│ └── function1.R
│ └── function2.R
├── README.md
├── man
│ └── function1.Rd
│ └── function2.Rd
└── packagename.Rproj
Do the following:
mkdir src
mkdir -p inst/include
Put the .cpp files in the src and .hpp files in inst/include.
And do:
echo "PKG_CPPFLAGS += -I../inst/include/
PKG_CXXFLAGS = $(CXX1XSTD)" >> src/Makevars
For every cpp functions that needed to be export into R space,
Add the following before defining the function, no comments are allowed between this phrase and the funciton:
// [[Rcpp::export]]
void function(int x, int y){
}