Global Variables in R Packages

[This article was first published on R on datawookie, and kindly contributed to R-bloggers]. (You can report issue about the content on this page here)
Want to share your content on R-bloggers? click here if you have a blog, or here if you don't.

I know that global variables are from the Devil, but sometimes you just can’t get around them.

I’m building a small package for a client that relies on a data file. For various reasons that file is not part of the package and can reside in different locations on users’ machines. Furthermore there are users on both Windows and Linux machines.

I decided to set up a global variable to store the data file path and a function to modify it.

Naive Implementation

This is what my initial implementation looked like:

data_path = "data"

set_data_path <- function(path) {
  data_path <<- path
}

It seems perfectly reasonable. And, in fact, would work… were in not in a package. However, building the package and giving a try yielded an error.

> set_data_path("/tmp")
Error in set_data_path("/tmp") : 
  cannot change value of locked binding for 'data_path'

While investigating the problem I learned about unlockBinding(), which is good to know.

Improved Implementation

It turns out that you need to use an environment to get this to work. Here is the revised (working) code:

pkg.globals <- new.env()

pkg.globals$data_path <- "data"

set_data_path <- function(path) {
  pkg.globals$data_path <- path
}

It’s slightly more verbose, but it works!

To leave a comment for the author, please follow the link and comment on their blog: R on datawookie.

R-bloggers.com offers daily e-mail updates about R news and tutorials about learning R and many other topics. Click here if you're looking to post or find an R/data-science job.
Want to share your content on R-bloggers? click here if you have a blog, or here if you don't.

Never miss an update!
Subscribe to R-bloggers to receive
e-mails with the latest R posts.
(You will not see this message again.)

Click here to close (This popup will not appear again)