changes: simpler version control from R

build status

What does changes do?

changes allows beginners with minimal programming experience to use version control. Version control is a framework that saves previous versions of your work as you develop your projects (Like 'Track changes' in MS Word). You can then easily look at previous versions, merge changes, and collaborate with others, but without the headache!

changes uses git under the hood. Git is a popular version control system used by projects such as Android and ggplot2. Don't worry, you don't need to know any git to use changes!

How do I use it?

Here's a quick demo of how to use changes:

unlink("~/Desktop/myproject", recursive = TRUE)
dir.create("~/Desktop/myproject")
knitr::opts_knit$set(root.dir = '~/Desktop/myproject/')
knitr::opts_chunk$set(comment = "  ")

First, we need to create a new project (we only need to do this the first time we work with the project).

library(changes)
create_repo("~/Desktop/myproject")

We can tell the repository if there are files (e.g. large data output files) we don't want to keep records of

ignore("output/results.csv")

and we can always change our minds later.

unignore("output/results.csv")

With the project set up, we can work on our project as normal.

# write some words to a file
cat("this is fun!\n", file = "README.md", append = TRUE)

We can then see which files have changed and make a record of the project, with a message to say what we did

changes()
record("added stuff to readme")

Now we can keep working on and adding files in this folder, and recording our changes regularly with record().

It's easy to forget to record, so changes will automatically remind us if we have unrecorded changes and it's been some time since we last used changes. By default we'll be reminded after 60 minutes, but we can change that:

remind_me(after = 30)

If we make a change we don't want to keep or record, we can undo it and go back to our last record

cat("I could do this all day.\n", file = "README.md", append = TRUE)
changes()
scrub()
changes()

We can look at all the records we've made so far

timeline()

and go back in time to recover the project at any one of those records - all of the files will be changed back to how they were at the time of that record

go_to(2)
timeline()

but don't worry, we can always go back to the future to recover our subsequent work.

go_to(3)

If we want to start again from a previous record, we can bring that record to the end of our timeline. changes will change all of the files to how they were at the time of the record, but all the work we recorded since then will still be stored, just in case we need it later.

retrieve(2)
timeline()

Installation

changes isn't on CRAN yet, but it can be installed from github

# install.packages("remotes")
remotes::install_github("ropenscilabs/changes")


ropenscilabs/ozrepro documentation built on May 20, 2022, 10:43 a.m.