R/installPackages.R

Defines functions installPackages.packageSum installPackages.findFn installPackages

Documented in installPackages installPackages.findFn installPackages.packageSum

installPackages <- function(x, minCount, ...){
  UseMethod('installPackages')
}

installPackages.findFn <- function(x, minCount, ...){
##
## 1.  minCount
##
  if(missing(minCount)) 
    minCount <- sqrt(x[1, 'Count'])
##
## 2.  get PackageSummary from x
##
  pkgsum <- attr(x, 'PackageSummary')
  xName <- substring(deparse(substitute(x)), 1, 25)
  if (is.null(pkgsum))
    stop('not a findFn object;  does not have ',
         'attribute PackageSummary:  ', xName)
##
## 3.  installPackages.packageSum
##
  installPackages.packageSum(pkgsum, minCount, ...)
} 

installPackages.packageSum <- function(x, minCount, 
                repos = getOption("repos"), ...){
##
## 1.  minCount
##
  if(missing(minCount)) 
    minCount <- sqrt(x[1, 'Count'])
  xName <- substring(deparse(substitute(x)), 1, 25)
##
## 2.  Confirm columns Count and Package 
##  
  if (!all(c('Count', 'Package') %in% names(x)))
      stop('Must have columns Count & Package:  ', xName)
##  
## 3.  select Count>=minCount  
##  
  sel <- (x$Count >= minCount)
  toget <- x$Package[sel]
##
## 4.  Installed pkgs?
##
  instPkgs <- .packages(TRUE)
  notInst <- toget[!(toget %in% instPkgs)]
##
## 5.  get not installed
##
  if (length(notInst) > 0){
    print(getOption('repos'))
    if(is.na(nchar(repos) | 
      (nchar(repos)<25))) 
      repos <- "https://cran.rstudio.com/" 
    utils::install.packages(notInst, repos=repos)
  }
}

Try the sos package in your browser

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

sos documentation built on June 30, 2024, 1:06 a.m.