R/tools.R

Defines functions netboostTmpCleanup mcupgma_exec

Documented in mcupgma_exec netboostTmpCleanup

#' Execute a program/script from the installed MCUPGMA suite.
#'
#' @param exec    Name of the file of the executable.
#' @param console Logical. Print output to R console or fetch for return to
#'   caller
#' @param ...  Arguments passed to mcupgma executable in order required by
#'   program
#' @return console=TRUE: exit code (0: no error). console=FALSE: STDOUT/STDERR
#'   output
#' @examples
#'   mcupgma_exec(exec="cluster.pl", "--help")
#' @export
mcupgma_exec <- function(exec=NULL, ..., console=TRUE) {
    if (is.null(exec)) stop("mcupgma_exec: call without executable")

    exec_abs_path <- file.path(netboostMCUPGMAPath(), exec)

    if (!file.exists(exec_abs_path))
        stop(paste("mcupgma_exec: file does not exist:", exec, exec_abs_path))

    # Types may become mixed giving many parameters, so ensure boolean.
    console <- isTRUE(as.logical(console))

    # Arguments must be bundled in character vector
    call_args <- as.character(unlist(list(...), use.names=FALSE))
    
    # Default: STDOUT/STDERR to R console
    std <- ""

    # If console is not set, write output to temporary file.
    if (!console) std <- tempfile()

    ret <- system2(command = exec_abs_path,
                   stdout = std, stderr = std,
                   wait=TRUE,
                   args=call_args,
                   env=c(paste0("TMP_PATH=", netboostTmpPath())))

    #  flush.console()

    # If execution returned error, always throw warning.
    # Also, save copy of output.
    if (ret != 0) {
        preserve <- file.path(netboostTmpPath(), paste0("output_", exec))
        file.copy(std, preserve)
        warning(paste("Execution of", exec, "returned no success:", ret,
                      "(this may be an real error or not).",
                      "STDOUT/ERR output saved in:", preserve),
                call. = FALSE)
        #    file.show(std)
    }
    
    # If STDIN/STDERR was printed on console, return exit code.
    # Else, read output from temporary file and return as text.
    if (console) {
        return(ret)
    } else {
        std_output <- readChar(std, file.info(std)$size)
        unlink(std)
        return(std_output)
    }
}

#' Cleans the netboost temporary folder. This can be useful during the session
#' as mcupgma creates vast directory structures (for iterations).
#' Creates the own folder (all netboost temporary data is stored in
#' netboostTmpPath(), which is equal to tempdir()/netboost).
#' Also used for first time setup of folder.
#'
#' @param verbose Flag verbose
#' @return none
netboostTmpCleanup <- function(verbose = FALSE) {
    folder <- netboostTmpPath()

    if (dir.exists(folder)) {
        if (verbose)
            message(paste("Netboost: cleaning temporary folder:", folder))

        ## Delete and recreate more convenient than globbing through the folders
        unlink(folder, recursive = TRUE)
    }

    # Create or recreate folder.
    dir.create(folder)
}

Try the netboost package in your browser

Any scripts or data that you put into this service are public.

netboost documentation built on Nov. 8, 2020, 4:58 p.m.