R/axel.R

Defines functions axel

Documented in axel

#' axel downloader
#'
#' R wrapper for axel, which enables multi-threaded download
#'  of a single large file.
#'
#' @return Path where the file has been downloaded
#'
#' @inheritParams downloader
#' @family downloaders
#' @seealso \url{https://github.com/axel-download-accelerator/axel/}
#' @keywords internal
axel <- function(input_url,
                 output_path,
                 background = FALSE,
                 nThread = 1,
                 force_overwrite = FALSE,
                 quiet = TRUE,
                 alternate = TRUE,
                 check_certificates = FALSE) {
    message("Downloading with axel.")
    dir.create(output_path, showWarnings = FALSE, recursive = TRUE)
    out_file <- file.path(output_path, basename(input_url))
    if (force_overwrite) {
        message("Overwriting pre-existing file.")
        if(file.exists(out_file)) file.remove(out_file, showWarnings = FALSE)
    }
    axel <- "axel"
    cmd <- paste(
        axel,
        input_url,
        "-n", nThread,
        ## Checking certificates can sometimes cause issues
        if (check_certificates) "" else "--insecure",
        if (force_overwrite) "" else "--no-clobber",
        "-o", out_file,
        if (quiet) "-q" else "",
        # ifelse(alternate,"-a",""),
        if (background) "& bg" else ""
    )
    # print(cmd)
    system(cmd)
    return(out_file)
}
neurogenomics/MungeSumstats documentation built on Aug. 10, 2024, 5:59 a.m.