#! /usr/bin/Rscript --default-packages=NULL ### -*- R -*- R_scripts_dir <- file.path(normalizePath("~"), "lib", "R", "Scripts") ## ## Ideally the default flavor could be set in one place. flavor <- "gcc" ## flavor <- "clang" ## args <- commandArgs(trailingOnly = TRUE) .flavor_from_f_arg <- function(flavor) { if(flavor == "g") return("gcc") if(startsWith(flavor, "g/")) { version <- substring(flavor, 3L) return(sprintf("gcc-%s", version)) } if(flavor == "c") return("clang") if(startsWith(flavor, "c/")) { ## Also handle old-style c/x/y: no longer used any more ... version <- unlist(strsplit(flavor, "/", fixed = TRUE))[2L] return(sprintf("clang-%s", version)) } flavor } if(any(ind <- startsWith(args, "-f="))) { flavor <- .flavor_from_f_arg(substring(args[ind][1L], 4L)) args <- args[!ind] } if(any(ind <- startsWith(args, "-f"))) { flavor <- .flavor_from_f_arg(substring(args[ind][1L], 3L)) args <- args[!ind] } R_exe <- file.path(normalizePath("~"), "tmp", sprintf("R-d-%s", flavor), "bin", "R") flavor <- sub("-.*", "", flavor) pos <- which(args == "--exe") if(length(pos)) { R_exe <- normalizePath(args[pos + 1L]) args <- args[-c(pos, pos + 1L)] flavor <- NULL } pos <- which(startsWith(args, "-x=")) if(length(pos)) { R_exe <- normalizePath(substring(args[pos[1L]]), 4L) args <- args[-pos] flavor <- NULL } ## Avoid 'WARNING: ignoring environment value of R_HOME' ... Sys.unsetenv("R_HOME") ## Make sure that R_LIBS and R_LIBS_SITE are not set. Sys.unsetenv(c("R_LIBS", "R_LIBS_SITE")) ## Re-set R_LIBS_USER to force re-expansion if(Sys.getenv("R_LIBS_USER") != "NULL") Sys.setenv("R_LIBS_USER" = file.path(Sys.getenv("HOME"), "lib/R/Library/%v/%a-%o")) ## Set R_MAKEVARS_USER according to flavor. if(!is.null(flavor)) { suffix <- flavor ## ## This looks a bit strange: perhaps we could simply use ## R_MAKEVARS_USER directly? Sys.setenv("R_MAKEVARS_USER" = Sys.getenv("_R_CHECK_MAKEVARS_USER_", file.path(Sys.getenv("HOME"), ".R", sprintf("Makevars-%s", suffix)))) ## } ## Use the KH default profile for now. Sys.setenv("R_PROFILE_USER" = file.path(Sys.getenv("HOME"), ".R", "Rprofile")) ## ## Setting this in check_CRAN_incoming.R should be good enough ...? ## Sys.setenv("OMP_NUM_THREADS" = 4, ## "OMP_THREAD_LIMIT" = 4, ## "RCPP_PARALLEL_NUM_THREADS" = 4) ## status <- system2(R_exe, c("--no-save", "--no-restore", "--slave", "--args", args), stdin = file.path(R_scripts_dir, "check_CRAN_incoming.R")) ## Getting the usage with '-h' gives status 0 ... if((status == 0L) && !is.null(flavor) && !any(args == "-h")) { ## Setting the check dir via -d= is mostly handled by the script, ## but also needs to be done here ... pos <- which(startsWith(args, "-d=")) new <- if(length(pos)) substring(args[pos[1L]], 4L) else file.path(normalizePath("~"), "tmp", "CRAN") old <- tools:::CRAN_check_details(paste0("r-devel-linux-x86_64-debian-", flavor)) changes <- tools:::check_packages_in_dir_changes(new, old) if(NROW(changes)) { writeLines("\nCheck results changes:") print(changes) } }