Arguments pkgs character vector of the names of packages whosecurrent versions should be downloaded from the repositories.If repos = NULL, a character vector of file paths ofwindows.zip files containing binary builds of packages. Sourcedirectories or .tar.gz archives may also be installed, butsome packages need suitable tools installed (see theDetails section).unix.tar.gz files.
These can be source archives or binarypackage archive files (as created by R CMD build -binary).On a CRAN build of R for OS X these can be .tgz filescontaining binary package archives.Tilde-expansion will be done on the file paths.If this is missing or a zero-length character vector, a listbox ofavailable packages is presented where possible in an interactive Rsession.libcharacter vector giving the library directories where toinstall the packages. Recycled as needed. If missing, defaults tothe first element of.reposcharacter vector, the base URL(s) of the repositoriesto use, e.g., the URL of a CRAN mirror such as'For more details onsupported URL schemes see.Can be NULL to install from local files(with extension .tar.gz for source packages).contriburlURL(s) of the contrib sections of the repositories. Use thisargument if your repository mirror is incomplete, e.g., becauseyou burned only the contrib section on a CD, or only havebinary packages.
Overrides argument repos. As withrepos, can also be NULL to install from local files.methoddownload method, see.availablean object as returned bylisting packages available at the repositories, or NULL whenthe function makes an internal call to available.packages.destdirdirectory where downloaded packages are stored. If it isNULL (the default) a subdirectorydownloadedpackages of the session temporarydirectory will be used (and the files will be deletedat the end of the session).dependencies logical indicating to also install uninstalledpackages which these packages depend on/link to/import/suggest(and so on recursively). Not used if repos = NULL.Can also be a character vector, a subset ofc('Depends', 'Imports', 'LinkingTo', 'Suggests', 'Enhances').Only supported if lib is of length one (or missing),so it is unambiguous where to install the dependent packages.
DetailsR packages are primarily distributed as source packages, butbinary packages (a packaging up of the installed package) arealso supported, and the type most commonly used on Windows and fromthe CRAN distribution for OS X. This function can install eithertype where supported, either by downloading a file from a repositoryor from a local file. The default type is given by('pkgType'): this defaults to 'source'apart from under Windows or a CRAN binary distribution for OS X.This is the main function to install packages. It takes a vector ofnames and a destination library, downloads the packages from therepositories and installs them. LockingThere are various options for locking: these differ between source andbinary installs. By default for a source install, the library directory islocked by creating a directory 00LOCK within it. Thishas two purposes: it prevents any other process installing into thatlibrary concurrently, and is used to store any previous version of thepackage to restore on error.
A finer-grained locking is provided bythe option -pkglock which creates a separate lock for eachpackage: this allows enough freedom for parallelinstallation. Per-package locking is the default when installing asingle package, and for multiple packages when Ncpus 1L.Finally locking (and restoration on error) can be suppressed by-no-lock. For an OS X or Windows binary install, no locking is done bydefault. Setting argument lock to TRUE (it defaults tothe value of ('install.lock', FALSE)) will useper-directory locking as described for source installs: if the valueis 'pkglock' per-package locking will be used.
If package locking is used on Windows with libsonly = TRUE andthe installation fails, the package will be restored to its previousstate. Note that it is possible for the package installation to fail so badlythat the lock directory is not removed: this inhibits any furtherinstalls to the library directory (or for -pkglock, of thepackage) until the lock directory is removed manually. Parallel installsParallel installs are attempted if pkgs has length greater thanone and Ncpus 1.
It makes use of a parallel make,so the make specified (default make) when R wasbuilt must be capable of supporting make -j n: GNU makeand dmake do, but FreeBSD and Solaris make do not:if necessary environment variable MAKE can be set for thecurrent session to select a suitable make. Install.packages needs to be able to compute all thedependencies of pkgs from available, including if oneelement of pkgs depends indirectly on another. This means thatif for example you are installing CRAN packages which dependon Bioconductor packages which in turn depend on CRANpackages, available needs to cover both CRAN andBioconductor packages.