R/view.R

Defines functions view

Documented in view

#' View a File or Directory
#'
#' Call \code{shell.exec} on windows, mimic \code{shell.exec}
#' otherwise.
#' @param path A path to a file or directory.
#' @param program A program to use.
#' @template return_invisibly_null
#' @family operating system functions
#' @export
#' @examples
#' path <- file.path(tempdir(), "foo.txt")
#' writeLines(c("abc", "xyz"), con = path)
#' view(path)
view <- function(path, program = NA) {
    qpath <- shQuote(normalizePath(path, mustWork = TRUE))
    if (interactive()) {
        if (!is.na(program) && is_installed(program)) {
            system2(program, qpath, wait = FALSE)
        } else {
            if (fritools::is_windows()) {
                shell.exec(path) # Exclude Linting: this is windows only
            } else {
                if (fritools::is_installed("thunar")) {
                    system2("thunar", qpath, wait = FALSE)
                } else {
                    if (dir.exists(qpath)) {
                        list.files(qpath, full.names = TRUE)
                    } else {
                        throw(paste0("Don't know how to open ", qpath, "."))
                    }
                }
            }
        }
    } else {
        warning("You are in batch mode.")
    }
    return(invisible(NULL))
}

Try the fritools package in your browser

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

fritools documentation built on Nov. 19, 2023, 1:06 a.m.