% File src/library/utils/man/INSTALL.Rd % Part of the R package, http://www.R-project.org % Copyright 1995-2013 R Core Team % Distributed under GPL 2 or later \name{INSTALL} \alias{INSTALL} \title{Install Add-on Packages} \description{Utility for installing add-on packages.} \usage{ \special{R CMD INSTALL [options] [-l lib] pkgs} } \arguments{ \item{pkgs}{a space-separated list with the path names of the packages to be installed. See \sQuote{Details}.} \item{lib}{the path name of the \R library tree to install to. Also accepted in the form \samp{--library=lib}. Paths including spaces should be quoted, using the conventions for the shell in use.} \item{options}{a space-separated list of options through which in particular the process for building the help files can be controlled. Use \command{R CMD INSTALL --help} for the full current list of options.} } \details{ This will stop at the first error, so if you want all the \code{pkgs} to be tried, call this via a shell loop. If used as \command{R CMD INSTALL pkgs} without explicitly specifying \code{lib}, packages are installed into the library tree rooted at the first directory in the library path which would be used by \R run in the current environment. To install into the library tree \code{\var{lib}}, use \command{R CMD INSTALL -l \var{lib} \var{pkgs}}. This prepends \code{lib} to the library path for duration of the install, so required packages in the installation directory will be found (and used in preference to those in other libraries). #ifdef windows It is possible that environment variable \env{TMPDIR} will need to be set (although \command{R CMD} tries to set it suitably otherwise): use forward slashes and no spaces for the path to a writable directory. #endif Both \code{lib} and the elements of \code{pkgs} may be absolute or relative path names of directories. \code{pkgs} may also contain names of package archive files: these are then extracted to a temporary directory. These are tarballs containing a single directory, optionally compressed by \command{gzip}, \command{bzip2}, \command{xz} or \command{compress}. #ifdef unix Finally, binary package archive files (as created by \command{R CMD INSTALL --build}) can be supplied. #endif #ifdef windows Finally, zipped binary packages (as created by \command{R CMD INSTALL --build}) can be supplied. #endif Tarballs are by default unpackaged by the internal \code{\link{untar}} function: if needed an external \command{tar} command can be specified by the environment variable \env{R_INSTALL_TAR}: please ensure that it can handle the type of compression used on the tarball. (This is sometimes needed for tarballs containing invalid or unsupported sections, and can be faster on very large tarballs. Setting \env{R_INSTALL_TAR} to \samp{tar.exe} has been needed to overcome permissions issues on some Windows systems.) The package sources can be cleaned up prior to installation by \option{--preclean} or after by \option{--clean}: cleaning is essential if the sources are to be used with more than one architecture or platform. #ifdef unix Some package sources contain a \file{configure} script that can be passed arguments or variables via the option \option{--configure-args} and \option{--configure-vars}, respectively, if necessary. The latter is useful in particular if libraries or header files needed for the package are in non-system directories. In this case, one can use the configure variables \code{LIBS} and \code{CPPFLAGS} to specify these locations (and set these via \option{--configure-vars}), see section \dQuote{Configuration variables} in \dQuote{R Installation and Administration} for more information. (If these are used more than once on the command line they are concatenated.) The configure mechanism can be bypassed using the option \option{--no-configure}. #endif If the attempt to install the package fails, leftovers are removed. If the package was already installed, the old version is restored. This happens either if a command encounters an error or if the install is interrupted from the keyboard: after cleaning up the script terminates. For details of the locking which is done, see the section \sQuote{Locking} in the help for \code{\link{install.packages}}. #ifdef windows Option \option{--build} can be used to zip up the installed package for distribution. #endif #ifdef unix Option \option{--build} can be used to tar up the installed package for distribution as a binary package (as used on OS X). This is done by \code{utils::tar} unless environment variable \env{R_INSTALL_TAR} is set. Some platforms (notably Windows) make use of sub-architectures in which binaries for different CPUs are installed within the same library tree. For such installations, the default behaviour is to try to build packages for all installed sub-architectures unless the package has a configure script or a \file{src/Makefile}, when only the sub-architecture running \command{R CMD INSTALL} is used. To use only that sub-architecture, use \option{--no-multiarch}. To install just the compiled code for another sub-architecture, use \option{--libs-only}. #endif By default a package is installed with static HTML help pages if and only if \R was: use options \option{--html} and \option{--no-html} to override this. Packages are not by default installed keeping the source formatting (see the \code{keep.source} argument to \code{\link{source}}): this can be enabled by the option \option{--with-keep.source} or by setting environment variable \env{R_KEEP_PKG_SOURCE} to \code{yes}. Use \command{R CMD INSTALL --help} for concise usage information, including all the available options. } \note{ The options do not have to precede \samp{pkgs} on the command line, although it will be more legible if they do. All the options are processed before any packages, and where options have conflicting effects the last one will win. #ifdef unix Some parts of the operation of \code{INSTALL} depend on the \R temporary directory (see \code{\link{tempdir}}, usually under \file{/tmp}) having both write and execution access to the account running \R. This is usually the case, but if \file{/tmp} has been mounted as \code{noexec}, environment variable \env{TMPDIR} may need to be set to a directory from which execution is allowed. #endif } \seealso{ \code{\link{REMOVE}} and \code{\link{library}} for information on using several library trees; \code{\link{update.packages}} for automatic update of packages using the internet (or other \R level installation of packages, such as by \code{install.packages}). The section on \dQuote{Add-on packages} in \dQuote{R Installation and Administration} and the chapter on \dQuote{Creating R packages} in \dQuote{Writing \R Extensions} #ifdef windows (on the Help menu in \code{RGui}), #endif \code{\link{RShowDoc}} and the \file{doc/manual} subdirectory of the \R source tree). } \keyword{utilities}