R/conda_export.R

Defines functions conda_export

Documented in conda_export

#' Conda export
#'
#' @description
#'  Get a list of installed packages within a conda environment.
#'  Generates a requirements.txt file.
#' @param name Name of conda environment.
#' @param save_path Path to save the requirements file. 
#' If the file ends with .yml or .yaml, a conda-style 
#' yaml file will be generated.
#' If the file ends with requirements.txt, a pip-style requirements.txt file
#'  will be generated.
#' @param preview Print the requirements file to the R console.
#' @param verbose Print messages. 
#' @inheritParams reticulate::conda_export
#' @source https://stackoverflow.com/a/55687210
#' @returns Path to requirements file.
#' 
#' @export 
#' @examples
#' \dontrun{
#' conda_export()
#' }
conda_export <- function(name, 
                         save_path=tempfile(fileext = "_requirements.txt"),
                         preview=FALSE,
                         verbose=TRUE,
                         ...){
  requireNamespace("reticulate")
  
  force(name)
  #### Get packages ####
  dir.create(dirname(save_path),recursive = TRUE,showWarnings = FALSE)
  if(grepl("requirements\\.txt$",save_path)){
    system(paste("conda","list -n testenv --export >",save_path))  
  } else if (grepl("\\.yml$|\\.yaml$",save_path)){
    reticulate::conda_export(envname = name,
                             file = save_path,
                             ...)  
  } 
  #### Read ####
  txt <- readLines(save_path)
  if(length(txt)==0) stopper("No packages found.")
  #### Preview ####
  if(preview) cat(paste(txt,collapse = "\n")); cat("\n");
  #### Save ####
  if(!is.null(save_path)) {
    writeLines(txt, save_path)
    messager("Saved to",save_path,v=verbose)
    return(save_path)
  } else {
    return(txt)  
  } 
}

Try the rworkflows package in your browser

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

rworkflows documentation built on May 29, 2024, 2:37 a.m.