R/infer_biocviews.R

Defines functions infer_biocviews

Documented in infer_biocviews

#' Infer biocViews
#' 
#' Infer the best terms to fill the \code{biocViews} field in
#'  your \emph{DESCRIPTION} file based on the code within your R package.
#'  By default, also includes any \code{biocViews} that are already present in 
#'  the \emph{DESCRIPTION} file.
#' Please see the 
#' \href{https://www.bioconductor.org/packages/release/BiocViews.html}{
#' Bioconductor website} for more details.
#' @param type Which element of the \link[biocViews]{recommendBiocViews} 
#' results list to return.
#' If a vector is supplied, only the first value will be used.
#' @param include_branch Whether to include the \code{branch} argument as one 
#' of the returned \code{biocViews}.
#' @param biocviews User-supplied \code{biocViews} terms to include in
#' addition to the automated recommendations. 
#' @param keep_current Keep any \code{biocViews} terms that are already 
#' included in the \emph{DESCRIPTION} file.
#' @param verbose Print messages.
#' @inheritParams infer_deps
#' @inheritParams biocViews::recommendBiocViews
#' @returns A character vector of biocviews.
#' 
#' @export
#' @importFrom here here
#' @examples 
#' ## Don't run simply bc biocViews::recommendBiocViews is unable 
#' ## to find the DESCRIPTION file when running examples.
#' \dontrun{
#' biocviews <- infer_biocviews()
#' }
infer_biocviews <- function(pkgdir=here::here(),
                            branch = c("Software", 
                                       "AnnotationData", 
                                       "ExperimentData")[1],
                            type = c("recommended",
                                     "current",
                                     "remove"),
                            keep_current = TRUE,
                            include_branch = TRUE,
                            biocviews = NULL,
                            add_newlines = FALSE,
                            verbose = TRUE){
  # devoptera::args2vars(infer_biocviews)
  
  requireNamespace("biocViews")
  branch <- branch[1]
  type <- type[1] 
  #### Check args ####
  ## branch_opts
  branch_opts <- eval(formals(biocViews::recommendBiocViews)$branch)
  if(!branch %in% branch_opts){
    stp1 <- paste("branch must be one of:",
                  paste("\n -",shQuote(branch_opts),collapse = ""))
    stop(stp1)
  }
  ## type_opts
  type_opts <- eval(formals(infer_biocviews)$type)
  if(!type %in% type_opts){
    stp2 <- paste("type must be one of:",
                  paste("\n -",shQuote(type_opts),collapse = ""))
    stop(stp2)
  } 
  #### Infer biocViews ####
  messager("Inferring biocViews.",v=verbose)
  bioc_recc <- biocViews::recommendBiocViews(
    pkgdir = pkgdir,
    branch = branch
  )
  #### Remove any newlines or trailing spaces ####
  bioc_recc <- lapply(bioc_recc, function(x){
    if(nchar(x)==0) return(x)
    trimws(gsub("\n","",strsplit(x,",")[[1]]))
  })
  out <- unique(c(biocviews,bioc_recc[[type]]))
  if(isTRUE(keep_current)) {
    out <- unique(c(out,bioc_recc$current))
  }
  #### Add the name of the branch itself ####
  if(isTRUE(include_branch)){
    out <- unique(c(branch,out))
  }
  out <- out[nchar(out)>0]
  #### Report ####
  if(length(out)==0) {
    messager("0 biocViews inferred. Returning NULL.",v=verbose)
    return(NULL)
  } else {
    messager(length(out),"biocViews inferred:",
             paste("\n -",out,collapse = ""),
             v=verbose)
    if(isTRUE(add_newlines)) out <- paste0("\n  ",out)
    return(out)
  }
}

Try the rworkflows package in your browser

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

rworkflows documentation built on Sept. 23, 2024, 1:08 a.m.