I do understand that generally global variables are evil and I should avoid them, but if my package does need to have a global variable, which of these two approaches are better? And are there any other recommended approaches?
Using an environment visible to the package
pkgEnv <- new.env() pkgEnv$sessionId <- "xyz123"
Using
options
options("pkgEnv.sessionId" = "xyz123")
I know there are some other threads that ask about how to achieve global variables, but I haven't seen a discussion on which one is recommended
Some packages use hidden variables (variables that begin with a
.
), like.Random.seed
and.Last.value
do in base R. In your package you could doBut in your package you don't need to assign
e
. You can use a.onLoad()
hook to assign the variable upon loading the package.See this question and its answers for some good explanation on package variables.
When most people say you should avoid 'global' variables, they mean you should not assign to the global environment (
.GlobalEnv
,GlobalEnv
, oras.environment(1)
) or that you should not pass information between internal functions by any method other than passing such data as the arguments of a function call.Caching is another matter entirely. I often caching results that I don't want to re-calculate (memoization) or re-query. A pattern I use a lot in packages is the following:
The call to
local
creates a new environment where I can store results using the scoping assignment operator<<-
without having to worry about the fact that the package was already sealed, and the last expression (the function definition) is returned as the value of the call tolocal()
and is bound to the namemyFunction
.