Quick tips

Issues installing packages

Try

options(repos = c(REPO_NAME = "https://packagemanager.rstudio.com/all/latest"))

This will make sure that the latest version of the package is being installed.

Default installing packages

Don't want to rely on the user having all of the packages installed?

if(!require("pacman")) install.packages("pacman"); library(pacman)

pacman::p_load(
    ggplot2,
    tidyr,
    ...
)

Package install

Make sure that a package is installed.

if(!library(<package>)){
    install.packages("<package>")
    library(<package>)
}

Snippets

Bored of typing too much? Use snippets. Go to Tools >> Global options >> Code >> Edit snippets. In here is a list of snippets which can be edited to match the use case that you use it most for. These can come up as auto complete suggestions but if not can be added by typing the key then Shift + Tab.

An example

snippet if
    if($1:condition){
        {2:code}
    }

Typing if then Shift + Tab the code in the snippet will be added. Hit Tab to move between editables.

Better printing

Don't like printing having a [1] in front of it?

cat("<string>")

R project

``` {r project-setup, eval=FALSE}

Create an R project

devtools::create(path = "./")

Initialise an R environment

renv::init()

Set up unit testing

usethis::use_testthat()

Build package

devtools::build(path = "./")

Setting the path = "./" will create the .tar.gz within the project dir.

If not then specify a path to your package dir.

Installing from .tar.gz

In this case path_to_file = "./Project_0.0.1.tar.gz"

path_to_file = "./Project_0.0.1.tar.gz" install.packages(path_to_file, repos = NULL, type="source")

Adding a licence to a project

usethis::use_apache_license() # Or whatever licence you want.

## External dependincies

Working within `./R/` **DON'T** use `library(...)` or `require(...)`

``` {r dependincies, eval=F, class.source="bg-danger"}
# Within a packaged don't use
library(<LIBRARY NAME>)
# or
require(<LIBRARY NAME>)

Instead update the DESCRIPTION file with an Imports: section. ``` {r imports, eval=F, class.source="bg-success"}

Within DESCRIPTION

Imports: ggplot2 (>= 3.3.3)

Adding imports in this way will install with dependencies when the package is 
installed. If using this as a pretend package that isn't installed fully then 
adding `library(...)` for the given dependency in the running file should work.

## Roxygen - documentation

In a working file use Ctrl + Alt + Shift + R to add a Roxygen documentation template.
``` {r roxygen, eval=F}
# With roxygen comments on functions within ./R create a manual
devtools::document()

Testing

Testthat - unit testing

``` {r testthat, eval=F}

Create testing file structure

usethis::use_testthat()

Create tests for the current working file

usethis::use_test() # Adds a test file in ./tests/testthat/test-.R

Run all tests

devtools::test()

### Covr - test coverage

Test coverage.

# Renv - library environments

```r
# Creating an R environment
renv::init()
# Taking a snapshot of the current dependencies and store in renv.lock.
renv::snapshot()

# Load back to the last snapshot
renv::restore()

Git

Supper basic just covering the most commonly used commands.

Create a git repo

git init

Add files, commit and push to remote repo (like github or another file store).

git add . 
git commit -m "<SHORT DESCRIPTION"> -m "<LONGER DESCRIPTION>(optional)"
git push <REMOTE NAME> <BRANCH NAME>
# example
git push origin master

Checkout new branch and add to remote.

git branch <NEW BRANCH NAME>

or

git checkout -b <NEW BRANCH NAME>

git push --set-upstream <remote> <branch>
# example
git push --set-upstream origin master

# If branch is already tracked on remote
git push

Pull data from remote

git pull <remote> <branch>
#example
git pull origin master
# If on branch
git pull

General info

git status


IainMcl/Useful-R documentation built on July 8, 2021, 6:19 p.m.