Skip to content

Commit

Permalink
Updates renv
Browse files Browse the repository at this point in the history
  • Loading branch information
cimentadaj committed Apr 13, 2023
1 parent b78e736 commit 8e2d35a
Show file tree
Hide file tree
Showing 6 changed files with 73 additions and 32 deletions.
1 change: 0 additions & 1 deletion book/.Rprofile
Original file line number Diff line number Diff line change
@@ -1,2 +1 @@
source("renv/activate.R")
renv::settings$snapshot.type("all")
7 changes: 2 additions & 5 deletions book/renv.lock
Original file line number Diff line number Diff line change
Expand Up @@ -2233,11 +2233,8 @@
},
"renv": {
"Package": "renv",
"Version": "0.16.0",
"Source": "Repository",
"Repository": "CRAN",
"Hash": "c9e8442ab69bc21c9697ecf856c1e6c7",
"Requirements": []
"Version": "0.17.3",
"Source": "Repository"
},
"reprex": {
"Package": "reprex",
Expand Down
2 changes: 1 addition & 1 deletion book/renv/.gitignore
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
sandbox/
library/
local/
cellar/
lock/
python/
sandbox/
staging/
68 changes: 53 additions & 15 deletions book/renv/activate.R
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
local({

# the requested version of renv
version <- "0.16.0"
version <- "0.17.3"

# the project directory
project <- getwd()
Expand Down Expand Up @@ -63,6 +63,10 @@ local({
if (is.environment(x) || length(x)) x else y
}

`%??%` <- function(x, y) {
if (is.null(x)) y else x
}

bootstrap <- function(version, library) {

# attempt to download renv
Expand All @@ -83,28 +87,39 @@ local({

renv_bootstrap_repos <- function() {

# get CRAN repository
cran <- getOption("renv.repos.cran", "https://cloud.r-project.org")

# check for repos override
repos <- Sys.getenv("RENV_CONFIG_REPOS_OVERRIDE", unset = NA)
if (!is.na(repos))
if (!is.na(repos)) {

# check for RSPM; if set, use a fallback repository for renv
rspm <- Sys.getenv("RSPM", unset = NA)
if (identical(rspm, repos))
repos <- c(RSPM = rspm, CRAN = cran)

return(repos)

}

# check for lockfile repositories
repos <- tryCatch(renv_bootstrap_repos_lockfile(), error = identity)
if (!inherits(repos, "error") && length(repos))
return(repos)

# if we're testing, re-use the test repositories
if (renv_bootstrap_tests_running())
return(getOption("renv.tests.repos"))
if (renv_bootstrap_tests_running()) {
repos <- getOption("renv.tests.repos")
if (!is.null(repos))
return(repos)
}

# retrieve current repos
repos <- getOption("repos")

# ensure @CRAN@ entries are resolved
repos[repos == "@CRAN@"] <- getOption(
"renv.repos.cran",
"https://cloud.r-project.org"
)
repos[repos == "@CRAN@"] <- cran

# add in renv.bootstrap.repos if set
default <- c(FALLBACK = "https://cloud.r-project.org")
Expand Down Expand Up @@ -344,8 +359,7 @@ local({
return()

# allow directories
info <- file.info(tarball, extra_cols = FALSE)
if (identical(info$isdir, TRUE)) {
if (dir.exists(tarball)) {
name <- sprintf("renv_%s.tar.gz", version)
tarball <- file.path(tarball, name)
}
Expand Down Expand Up @@ -659,8 +673,8 @@ local({
if (version == loadedversion)
return(TRUE)

# assume four-component versions are from GitHub; three-component
# versions are from CRAN
# assume four-component versions are from GitHub;
# three-component versions are from CRAN
components <- strsplit(loadedversion, "[.-]")[[1]]
remote <- if (length(components) == 4L)
paste("rstudio/renv", loadedversion, sep = "@")
Expand Down Expand Up @@ -700,6 +714,12 @@ local({
# warn if the version of renv loaded does not match
renv_bootstrap_validate_version(version)

# execute renv load hooks, if any
hooks <- getHook("renv::autoload")
for (hook in hooks)
if (is.function(hook))
tryCatch(hook(), error = warning)

# load the project
renv::load(project)

Expand Down Expand Up @@ -842,11 +862,29 @@ local({

renv_json_read <- function(file = NULL, text = NULL) {

jlerr <- NULL

# if jsonlite is loaded, use that instead
if ("jsonlite" %in% loadedNamespaces())
renv_json_read_jsonlite(file, text)
if ("jsonlite" %in% loadedNamespaces()) {

json <- catch(renv_json_read_jsonlite(file, text))
if (!inherits(json, "error"))
return(json)

jlerr <- json

}

# otherwise, fall back to the default JSON reader
json <- catch(renv_json_read_default(file, text))
if (!inherits(json, "error"))
return(json)

# report an error
if (!is.null(jlerr))
stop(jlerr)
else
renv_json_read_default(file, text)
stop(json)

}

Expand Down
10 changes: 0 additions & 10 deletions book/renv/settings.dcf

This file was deleted.

17 changes: 17 additions & 0 deletions book/renv/settings.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
{
"bioconductor.version": null,
"external.libraries": [],
"ignored.packages": [],
"package.dependency.fields": [
"Imports",
"Depends",
"LinkingTo"
],
"r.version": null,
"snapshot.type": "implicit",
"use.cache": true,
"vcs.ignore.cellar": true,
"vcs.ignore.library": true,
"vcs.ignore.local": true,
"vcs.manage.ignores": true
}

0 comments on commit 8e2d35a

Please sign in to comment.