Iain McLaughlan 10/2/2021
Make sure that a package is installed.
if(!library(<package>)){
install.packages("<package>")
library(<package>)
}
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.
Don’t like printing having a [1] in front of it?
cat("<string>")
# Create an R project
devtools::create(path = "./<PROJECT NAME>")
# 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")
Working within ./R/
DON’T use library(...)
or require(...)
# Within a packaged don't use
library(<LIBRARY NAME>)
# or
require(<LIBRARY NAME>)
Instead update the DESCRIPTION file with an Imports:
section.
# 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.
In a working file use Ctrl + Alt + Shift + R to add a Roxygen documentation template.
# With roxygen comments on functions within ./R create a manual
devtools::document()
# 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-<FILE NAME>.R
# Run all tests
devtools::test()
Test coverage.
# 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()
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