diff --git a/R/update.R b/R/update.R index 8dc9666..ff3fd6f 100644 --- a/R/update.R +++ b/R/update.R @@ -22,7 +22,7 @@ update_submodules <- function(path = '.', skip = '.registry'){ withr::local_dir(path) repo <- gert::git_open(path) submodules <- gert::git_submodule_list(repo = repo) - submodules$upstream <- remote_heads_many(submodules$url, submodules$branch) + submodules$upstream <- remote_heads_in_batches(submodules$url, submodules$branch) for(i in seq_len(nrow(submodules))){ info <- as.list(submodules[i,]) if(info$path %in% skip) next @@ -46,7 +46,7 @@ submodules_up_to_date <- function(skip_broken = TRUE, path = '.'){ withr::local_dir(path) repo <- gert::git_open(path) submodules <- gert::git_submodule_list(repo = repo) - submodules$upstream <- remote_heads_many(submodules$url, submodules$branch) + submodules$upstream <- remote_heads_in_batches(submodules$url, submodules$branch) isok <- which(submodules$upstream == submodules$head) fine <- submodules$path[isok] broken <- submodules[is.na(submodules$upstream),] @@ -129,7 +129,7 @@ parse_raw_gitpack <- function(buf){ } remote_heads_many <- function(repos, refs = NULL, verbose = TRUE){ - pool <- curl::multi_set(multiplex = TRUE) # use default pool + pool <- curl::new_pool(multiplex = TRUE, host_con = 1L) len <- length(repos) out <- rep(NA_character_, len) completed <- 0 @@ -164,6 +164,23 @@ remote_heads_many <- function(repos, refs = NULL, verbose = TRUE){ }, fail = message, pool = pool) }) curl::multi_run(pool = pool) + rm(pool); gc() #close connection cat("\n", file = stderr()) out } + +# GitHub does not like too many requests at once so we wait a bit +remote_heads_in_batches <- function(repos, refs){ + ngroups <- ceiling(length(repos)/1000) + batch <- sample(seq_len(ngroups), 100, replace = TRUE) + out <- lapply(seq_len(ngroups), function(group){ + sx <- batch == group + if(group > 1) { + message("Done! Waiting for a bit for the next batch...") + Sys.sleep(60) + } + message("Starting batch: ", group) + remote_heads_many(repos[sx], refs[sx]) + }) + do.call(c, out) +}