-
Notifications
You must be signed in to change notification settings - Fork 67
/
Copy pathneeds.R
61 lines (60 loc) · 2.06 KB
/
needs.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
tryCatch(needs(), error = function(e) {
while (".needs" %in% search()) detach(.needs)
.needs <- new.env(parent = .GlobalEnv)
.needs$needs <- function(...)
{
needs_ <- function(...) {
pkgs <- unlist(...)
if (length(pkgs)) {
loaded <- suppressMessages(suppressWarnings(sapply(pkgs,
library, character = T, logical = T)))
if (any(!loaded)) {
missing <- pkgs[!loaded]
cat("installing packages:n")
cat(missing, sep = "n")
utils::install.packages(missing, repos = "http://cran.rstudio.com/",
quiet = T)
}
suppressMessages(suppressWarnings(sapply(pkgs, library,
character = T)))
}
}
packageInfo <- utils::installed.packages()
if (missing(...))
return(invisible())
pkgs <- match.call()[-1]
parsed <- if (is.null(names(pkgs))) {
as.character(pkgs)
}
else {
mapply(paste, names(pkgs), as.character(pkgs), MoreArgs = list(sep = ":"))
}
parts <- lapply(strsplit(parsed, "[:=(, ]+"), function(d) {
d[d != ""]
})
grouped <- split(parts, sapply(parts, length))
needs_(grouped$`1`)
toCheck <- grouped$`2`
if (length(toCheck)) {
installedPackages <- packageInfo[, "Package"]
needsPackage <- sapply(toCheck, `[`, 1)
needsVersion <- sapply(toCheck, function(x) {
gsub("[^0-9.-]+", "", x[2])
})
installed <- needsPackage %in% installedPackages
needs_(needsPackage[!installed])
compared <- mapply(utils::compareVersion, needsVersion[installed],
packageInfo[needsPackage[installed], "Version"])
if (any(compared == 1)) {
toUpdate <- needsPackage[installed][compared == 1]
cat("updating packages:n")
cat(toUpdate, sep = "n")
utils::update.packages(oldPkgs = toUpdate, ask = F)
}
needs_(needsPackage[installed])
}
invisible()
}
# attach to the search path
attach(.needs)
})