Title: | A Dependency Management System for Projects and their R Package Dependencies |
---|---|
Description: | Manage the R packages your project depends on in an isolated, portable, and reproducible way. |
Authors: | Aron Atkins [aut, cre], Toph Allen [aut], Kevin Ushey [aut], Jonathan McPherson [aut], Joe Cheng [aut], JJ Allaire [aut], Posit Software, PBC [cph, fnd] |
Maintainer: | Aron Atkins <[email protected]> |
License: | GPL-2 |
Version: | 0.9.2.9000 |
Built: | 2024-11-24 05:41:30 UTC |
Source: | https://github.com/rstudio/packrat |
Packrat is a tool for managing the R packages your project depends on in an isolated, portable, and reproducible way.
Use packrat to make your R projects more:
Isolated: Installing a new or updated package for one project won't break your other projects, and vice versa. That's because packrat gives each project its own private package library.
Portable: Easily transport your projects from one computer to another, even across different platforms. Packrat makes it easy to install the packages your project depends on.
Reproducible: Packrat records the exact package versions you depend on, and ensures those exact versions are the ones that get installed wherever you go.
Use init
to create a new packrat project,
snapshot
to record changes to your project's library, and
restore
to recreate your library the way it was the last time you
(or anyone!) took a snapshot.
Using these simple functions and sharing packrat's files lets you collaborate in a shared, consistent environment with others as your project grows and changes, and provides an easy way to share your results when you're done.
A packrat project contains a few extra files and directories. The
init
function creates these files for you, if they don't
already exist.
packrat/lib/
Private package library for this project.
packrat/src/
Source packages of all the dependencies that packrat has been made aware of.
packrat/packrat.lock
Lists the precise package versions that were used to satisfy dependencies, including dependencies of dependencies. (This file should never be edited by hand!)
.Rprofile
Directs R to use the private package library (when it is started from the project directory).
Packrat is designed to work hand in hand with Git, Subversion, or any other
version control system. Be sure to check in the .Rprofile
,
packrat.lock
files, and everything under
packrat/src/
. You can tell your VCS to ignore packrat/lib/
(or
feel free to check it in if you don't mind taking up some extra space in your
repository).
Posit Software, PBC
Useful links:
## Not run: # Create a new packrat project from an existing directory of \R code init() # Install a package and take a snapshot of the new state of the library install.packages("TTR") snapshot() # Accidentally remove a package and restore to add it back remove.packages("TTR") restore() ## End(Not run)
## Not run: # Create a new packrat project from an existing directory of \R code init() # Install a package and take a snapshot of the new state of the library install.packages("TTR") snapshot() # Accidentally remove a package and restore to add it back remove.packages("TTR") restore() ## End(Not run)
Bundle a packrat project, for easy sharing.
bundle( project = NULL, file = NULL, include.src = TRUE, include.lib = FALSE, include.bundles = TRUE, include.vcs.history = FALSE, overwrite = FALSE, omit.cran.src = FALSE, ... )
bundle( project = NULL, file = NULL, include.src = TRUE, include.lib = FALSE, include.bundles = TRUE, include.vcs.history = FALSE, overwrite = FALSE, omit.cran.src = FALSE, ... )
project |
The project directory. Defaults to the currently activate
project. By default, the current project active under |
file |
The path to write the bundle. By default, we write
the bundle to |
include.src |
Include the packrat sources? |
include.lib |
Include the packrat private library? |
include.bundles |
Include other packrat bundle tarballs
(as in |
include.vcs.history |
Include version control history (ie, |
overwrite |
Boolean; overwrite the file at |
omit.cran.src |
Boolean; when |
... |
Optional arguments passed to |
The project is bundled as a gzipped tarball (.tar.gz
), which can
be unbundled either with packrat::unbundle
(which
restores the project as well), R's own utils::untar
, or
through most system tar
implementations.
The tar binary is selected using the same heuristic as restore
.
The path (invisibly) to the bundled project.
Remove packages from the given library.
clean( packages = NULL, project = NULL, lib.loc = libDir(project), dry.run = FALSE, force = FALSE )
clean( packages = NULL, project = NULL, lib.loc = libDir(project), dry.run = FALSE, force = FALSE )
packages |
A set of package names to remove from the project. When
|
project |
The project directory. Defaults to current working directory. |
lib.loc |
The library to clean. Defaults to the private package library associated with the project directory. |
dry.run |
Perform a dry run, returning records on which packages would have been moved by the current clean action. |
force |
Force package removal, even if they are still in use within the project? |
## Not run: # Get unused package records unused_packages() # Clean all unused packages clean() # Clean specific packages clean("foo") ## End(Not run)
## Not run: # Get unused package records unused_packages() # Clean all unused packages clean() # Clean specific packages clean("foo") ## End(Not run)
Disable packrat within a project, reverting to the use of standard user package libraries.
disable(project = NULL, restart = TRUE)
disable(project = NULL, restart = TRUE)
project |
The directory in which packrat will be disabled (defaults to the current working directory) |
restart |
If |
Disabling packrat for a project removes the packrat initialization code
from the .Rprofile file, resulting in the use of standard user package
libraries. Note that the packrat
directory is not deleted, but remains
unused.
To re-enable the use of packrat for a project you can call the
init
function.
The restart
parameter will only result in a restart of R when the R
environment packrat is running within makes available a restart function via
getOption("restart")
.
Given a project directory, makes a new packrat project in the directory.
init( project = ".", options = NULL, enter = TRUE, restart = enter, infer.dependencies = TRUE )
init( project = ".", options = NULL, enter = TRUE, restart = enter, infer.dependencies = TRUE )
project |
The directory that contains the R project. |
options |
An R |
enter |
Boolean, enter packrat mode for this project after finishing a init? |
restart |
If |
infer.dependencies |
If |
init
works as follows:
Application dependencies are computed by examining the R code
throughout the project for library
and require
calls. You can
opt out of this behavior by setting infer.dependencies
to
FALSE
.
A snapshot is taken of the version of each package currently used by
the project as described in snapshot
, and each package's
sources are downloaded.
A private library is created in the directory.
The snapshot is applied to the directory as described in
restore
.
When init
is finished, all the packages
on which the project depends are installed in a new, private library located
inside the project directory.
You must restart your R session in the given project directory after
running init
in order for the changes to take effect!
When R is started in the directory, it will use the new, private library.
Calls to require
and library
will load packages
from the private library (except for 'base' or 'recommended' R packages,
which are found in the system library), and functions such as install.packages
will modify that private library. You can sync this private library with
packrat using snapshot
and restore
.
The restart
parameter will only result in a restart of R when the
R environment packrat is running within makes available a restart function
via getOption("restart")
.
packrat for a description of the files created by
init
.
## Not run: ## initialize a project using a local repository of packages packrat::init(options = list(local.repos = "~/projects/R")) ## End(Not run)
## Not run: ## initialize a project using a local repository of packages packrat::init(options = list(local.repos = "~/projects/R")) ## End(Not run)
Uses R CMD INSTALL
to install the package. Will also try to install
dependencies of the package from CRAN, if they're not already installed.
install( pkg = ".", reload = TRUE, quick = FALSE, local = TRUE, args = getOption("devtools.install.args"), quiet = FALSE, dependencies = NA, build_vignettes = !quick, keep_source = getOption("keep.source.pkgs") )
install( pkg = ".", reload = TRUE, quick = FALSE, local = TRUE, args = getOption("devtools.install.args"), quiet = FALSE, dependencies = NA, build_vignettes = !quick, keep_source = getOption("keep.source.pkgs") )
pkg |
package description, can be path or package name. |
reload |
if |
quick |
if |
local |
if |
args |
An optional character vector of additional command line
arguments to be passed to |
quiet |
if |
dependencies |
|
build_vignettes |
if |
keep_source |
If |
By default, installation takes place using the current package directory.
If you have compiled code, this means that artefacts of compilation will be
created in the src/
directory. If you want to avoid this, you can
use local = FALSE
to first build a package bundle and then install
it from a temporary directory. This is slower, but keeps the source
directory pristine.
If the package is loaded, it will be reloaded after installation.
This function can be used to install a package from a local 'repository'; i.e., a directory containing package tarballs and sources.
install_local(pkgs, ..., lib = .libPaths()[1], repos = get_opts("local.repos"))
install_local(pkgs, ..., lib = .libPaths()[1], repos = get_opts("local.repos"))
pkgs |
A character vector of package names. |
... |
Optional arguments passed to |
lib |
The library in which the package should be installed. |
repos |
The local repositories to search for the package names specified. |
Get and set metadata in the current packrat-managed project lockfile packrat.lock
set_lockfile_metadata(repos = NULL, r_version = NULL, project = NULL) get_lockfile_metadata(metadata = NULL, simplify = TRUE, project = NULL)
set_lockfile_metadata(repos = NULL, r_version = NULL, project = NULL) get_lockfile_metadata(metadata = NULL, simplify = TRUE, project = NULL)
repos |
A named character vector of the form |
r_version |
A length-one character vector with suitable numeric version
string. See |
project |
The project directory. When in packrat mode, defaults to the current project; otherwise, defaults to the current working directory. |
metadata |
The lockfile field name(s) to draw from. |
simplify |
Boolean; if |
Project's packrat.lock
contains some metadata before packages
dependencies informations. The project's lockfile is created and updated
programmatically by snapshot
. However it could be necessary sometimes to
modify manually some of those values. For example, it could be useful to set another repository
CRAN url when deploying to a offline environnement.
r_version
: R version the project depends on
repos
: Name of repos and their url recorded packages can be
retrieve from. Only url is recommended to change if need. Name of repos is
used in package records and must be identical
## Not run: # changes repos url repos <- old_repos <- get_lockfile_metadata("repos") repos repos["CRAN"] <- "https://cran.r-project.org/" set_lockfile_metadata(repos = repos) get_lockfile_metadata("repos") # setting back old state # set_lockfile_metadata(repos = old_repos) # changes R version rver <- old_rver <- get_lockfile_metadata("r_version") rver rver <- "3.4.1" set_lockfile_metadata(r_version = rver) get_lockfile_metadata("r_version") # Setting back old state # set_lockfile_metadata(r_version = old_rver) ## End(Not run)
## Not run: # changes repos url repos <- old_repos <- get_lockfile_metadata("repos") repos repos["CRAN"] <- "https://cran.r-project.org/" set_lockfile_metadata(repos = repos) get_lockfile_metadata("repos") # setting back old state # set_lockfile_metadata(repos = old_repos) # changes R version rver <- old_rver <- get_lockfile_metadata("r_version") rver rver <- "3.4.1" set_lockfile_metadata(r_version = rver) get_lockfile_metadata("r_version") # Setting back old state # set_lockfile_metadata(r_version = old_rver) ## End(Not run)
Install/augment the .Rprofile
in a project, so that all R sessions
started in this directory enter packrat mode
, and use the local
project library.
packify(project = NULL, quiet = FALSE)
packify(project = NULL, quiet = FALSE)
project |
The directory in which to install the |
quiet |
Be chatty? |
It is not normally necessary to call packify
directly; these files are
normally installed by init
. packify
can be used to
restore the files if they are missing (for instance, if they were not added to
source control, or were accidentally removed).
You'll need to restart R in the specified directory after running
packify
in order to start using the private package library.
These functions provide a mechanism for (temporarily) using packages outside of the packrat private library. The packages are searched within the 'default' libraries; that is, the libraries that would be available upon launching a new R session.
with_extlib(packages = NULL, expr, envir = parent.frame()) extlib(packages) user_lib() packrat_lib()
with_extlib(packages = NULL, expr, envir = parent.frame()) extlib(packages) user_lib() packrat_lib()
packages |
An optional set of package names (as a character
vector) to load for the duration of evaluation of |
expr |
An R expression. |
envir |
An environment in which the expression is evaluated. |
## Not run: with_extlib("lattice", xyplot(1 ~ 1)) with_extlib(expr = packageVersion("lattice")) # since devtools requires roxygen2 >= 5.0.0 for this step, this # should fail unless roxygen2 is available in the packrat lib.loc with_extlib("devtools", load_all("path/to/project")) # this method will work given roxygen2 is installed in the # non-packrat lib.loc with devtools with_extlib(expr = devtools::load_all("path/to/project")) ## End(Not run)
## Not run: with_extlib("lattice", xyplot(1 ~ 1)) with_extlib(expr = packageVersion("lattice")) # since devtools requires roxygen2 >= 5.0.0 for this step, this # should fail unless roxygen2 is available in the packrat lib.loc with_extlib("devtools", load_all("path/to/project")) # this method will work given roxygen2 is installed in the # non-packrat lib.loc with devtools with_extlib(expr = devtools::load_all("path/to/project")) ## End(Not run)
Use these functions to switch packrat
mode on and off. When within
packrat
mode, the R session will use the private library generated
for the current project.
packrat_mode( on = NULL, project = NULL, auto.snapshot = get_opts("auto.snapshot"), clean.search.path = FALSE ) on( project = NULL, auto.snapshot = get_opts("auto.snapshot"), clean.search.path = TRUE, print.banner = TRUE ) off(project = NULL, print.banner = TRUE)
packrat_mode( on = NULL, project = NULL, auto.snapshot = get_opts("auto.snapshot"), clean.search.path = FALSE ) on( project = NULL, auto.snapshot = get_opts("auto.snapshot"), clean.search.path = TRUE, print.banner = TRUE ) off(project = NULL, print.banner = TRUE)
on |
Turn packrat mode on ( |
project |
The directory in which packrat mode is launched – this is where local libraries will be used and updated. |
auto.snapshot |
Perform automatic, asynchronous snapshots? |
clean.search.path |
Detach and unload any packages loaded from non-system libraries before entering packrat mode? |
print.banner |
Print the packrat banner when entering / exiting packrat mode? The packrat banner informs you of the new packrat mode state, as well as the library path in use. |
Get and set options for the current packrat-managed project.
get_opts(options = NULL, simplify = TRUE, project = NULL) set_opts(..., project = NULL, persist = TRUE) opts
get_opts(options = NULL, simplify = TRUE, project = NULL) set_opts(..., project = NULL, persist = TRUE) opts
options |
A character vector of valid option names. |
simplify |
Boolean; |
project |
The project directory. When in packrat mode, defaults to the current project; otherwise, defaults to the current working directory. |
... |
Entries of the form |
persist |
Boolean; persist these options for future sessions? |
auto.snapshot
: Perform automatic, asynchronous snapshots when running interactively?
(logical; defaults to FALSE
)
use.cache
:
Install packages into a global cache, which is then shared across projects? The
directory to use is read through Sys.getenv("R_PACKRAT_CACHE_DIR")
.
Windows support is currently experimental.
(logical; defaults to FALSE
)
print.banner.on.startup
:
Print the banner on startup? Can be one of TRUE
(always print),
FALSE
(never print), and 'auto'
(do the right thing)
(defaults to "auto"
)
vcs.ignore.lib
:
If TRUE, version control configuration is modified to ignore packrat private libraries.
(logical; defaults to TRUE
)
vcs.ignore.src
:
If TRUE, version control configuration is modified to ignore packrat private sources.
(logical; defaults to FALSE
)
external.packages
:
Packages which should be loaded from the user library. This can be useful for
very large packages which you don't want duplicated across multiple projects,
e.g. BioConductor annotation packages, or for package development scenarios
wherein you want to use e.g. devtools
and roxygen2
for package
development, but do not want your package to depend on these packages.
(character; defaults to Sys.getenv("R_PACKRAT_EXTERNAL_PACKAGES")
)
local.repos
:
Ad-hoc local 'repositories'; i.e., directories containing package sources within
sub-directories.
(character; empty by default)
load.external.packages.on.startup
:
Load any packages specified within external.packages
on startup?
(logical; defaults to TRUE
)
ignored.packages
:
Prevent packrat from tracking certain packages. Dependencies of these packages
will also not be tracked (unless these packages are encountered as dependencies
in a separate context from the ignored package).
(character; empty by default)
ignored.directories
:
Prevent packrat from looking for dependencies inside certain directories of your
workspace. For example, if you have set your "local.repos" to be inside your local
workspace so that you can track custom packages as git submodules.
Each item should be the relative path to a directory in the workspace, e.g. "data",
"lib/gitsubmodule". Note that packrat already ignores any "invisible" files and
directories, such as those whose names start with a "." character.
(character; empty by default)
quiet.package.installation
:
Emit output during package installation?
(logical; defaults to TRUE
)
snapshot.recommended.packages
:
Should 'recommended' packages discovered in the system library be
snapshotted? See the Priority
field of available.packages()
for more information – 'recommended' packages are those normally bundled
with CRAN releases of R on OS X and Windows, but new releases are also
available on the CRAN server.
(logical; defaults to FALSE
)
snapshot.fields
:
What fields of a package's DESCRIPTION file should be used when discovering
dependencies?
(character, defaults to c("Imports", "Depends", "LinkingTo")
)
symlink.system.packages
:
Symlink base R packages into a private packrat/lib-R
directory?
This is done to further encapsulate the project from user packages that
have been installed into the R system library.
(boolean, defaults to TRUE
)
## Not run: ## use 'devtools' and 'knitr' from the user library packrat::set_opts(external.packages = c("devtools", "knitr")) ## set local repository packrat::set_opts(local.repos = c("~/projects/R")) ## get the set of 'external packages' packrat::opts$external.packages() ## set the external packages packrat::opts$external.packages(c("devtools", "knitr")) ## End(Not run)
## Not run: ## use 'devtools' and 'knitr' from the user library packrat::set_opts(external.packages = c("devtools", "knitr")) ## set local repository packrat::set_opts(local.repos = c("~/projects/R")) ## get the set of 'external packages' packrat::opts$external.packages() ## set the external packages packrat::opts$external.packages(c("devtools", "knitr")) ## End(Not run)
These functions provide a mechanism for retrieving the paths to Packrat resource directories. Each of these directories can be overridden by setting either an environment variable, or an R option.
project_dir(project = NULL) src_dir(project = NULL) lib_dir(project = NULL) bundles_dir(project = NULL)
project_dir(project = NULL) src_dir(project = NULL) lib_dir(project = NULL) bundles_dir(project = NULL)
project |
The project directory. |
project_dir()
is special – the R_PACKRAT_PROJECT_DIR
environment variable is set and unset by on
and
off
, respectively, and generally should not be
overridden by the user.
The following table shows the order in which resource directories are discovered (from left to right). The first non-empty result is used.
API | Environment Variable | R Option | Default Value |
project_dir() |
R_PACKRAT_PROJECT_DIR |
packrat.project.dir |
getwd() |
src_dir() |
R_PACKRAT_SRC_DIR |
packrat.src.dir |
"packrat/src" |
lib_dir() |
R_PACKRAT_LIB_DIR |
packrat.lib.dir |
"packrat/lib" |
bundles_dir() |
R_PACKRAT_BUNDLES_DIR |
packrat.bundles.dir |
"packrat/bundles" |
(none) | R_PACKRAT_LIB_R_DIR |
packrat.lib-r.dir |
"packrat/lib-R" |
(none) | R_PACKRAT_LIB_EXT_DIR |
packrat.lib-ext.dir |
"packrat/lib-ext" |
Generate a local CRAN-like repository which can be used to store and distribute R packages.
repos_create(path, name = basename(path), add = TRUE)
repos_create(path, name = basename(path), add = TRUE)
path |
Path to a local CRAN-like repository. |
name |
The name to assign to the repository. Defaults to the directory name in which the reopsitory is created. |
add |
Add this new repository to the current set of repositories? |
Upload a Package to a Local CRAN-like Repository
repos_upload(package, to, ...)
repos_upload(package, to, ...)
package |
Path to a package tarball. The tarball should be
created by |
to |
The name of the CRAN-like repository. It (currently) must be a local (on-disk) CRAN repository. |
... |
Optional arguments passed to |
Add a repository to the set of currently available repositories. This is
effectively an easier-to-use wrapper over interacting with the
"repos"
option, which is otherwise set with options(repos = ...)
.
repos_add(..., overwrite = FALSE) repos_add_local(..., overwrite = FALSE) repos_set(...) repos_set_local(...) repos_remove(names) repos_list()
repos_add(..., overwrite = FALSE) repos_add_local(..., overwrite = FALSE) repos_set(...) repos_set_local(...) repos_remove(names) repos_list()
... |
Named arguments of the form |
overwrite |
Boolean; overwrite if a repository with the given name already exists? |
names |
The names of repositories (as exist in e.g.
|
repos_add_local
is used for adding file-based repositories; that is,
CRAN repositories that live locally on disk and not on the internet / local network.
Applies the most recent snapshot to the project's private library.
restore( project = NULL, overwrite.dirty = FALSE, prompt = interactive(), dry.run = FALSE, restart = !dry.run )
restore( project = NULL, overwrite.dirty = FALSE, prompt = interactive(), dry.run = FALSE, restart = !dry.run )
project |
The project directory. When in packrat mode, if this is
|
overwrite.dirty |
A dirty package is one that has been changed since the
last snapshot or restore. Packrat will leave these alone by default. If you
want to guarantee that |
prompt |
|
dry.run |
If |
restart |
If |
restore
works by adding, removing, and changing packages so that the
set of installed packages and their versions matches the snapshot exactly.
There are three common use cases for restore
:
Hydrate: Use restore
after copying a project to a new machine
to populate the library on that machine.
Sync: Use restore
to apply library changes made by a
collaborator to your own library. (In general, you want to run restore
whenever you pick up a change to packrat.lock
)
Rollback: Use restore
to undo accidental changes made
to the library since the last snapshot.
restore
cannot make changes to packages that are currently loaded. If
changes are necessary to currently loaded packages, you will need to restart
R to apply the changes (restore
will let you know when this is
necessary). It is recommended that you do this as soon as possible, because
any library changes made between running restore
and restarting R
will be lost.
restore
can be destructive; it will remove packages that were
not in the snapshot, and it will replace newer packages with older versions
if that's what the snapshot indicates. restore
will warn you before
attempting to remove or downgrade a package (if prompt
is
TRUE
), but will always perform upgrades and new installations
without prompting.
restore
works only on the private package library created by
packrat; if you have other libraries on your path, they will be unaffected.
The restart
parameter will only result in a restart of R when the R
environment packrat is running within makes available a restart function
via getOption("restart")
.
To install packages hosted in private repositories on GitHub, GitLab, and
Bitbucket, you must either set the option
packrat.authenticated.downloads.use.renv
to TRUE
and ensure
that curl
is available on your system, or ensure that the
httr
package is available in your R library.
In addition, you must make credentials for your provider available in the
appropriate environment variable(s): GITHUB_PAT
, GITLAB_PAT
,
and/or BITBUCKET_USERNAME
and BITBUCKET_PASSWORD
. These
environment variables are hidden from package installation subprocesses.
Packrat does not support installation from enterprise instances of GitHub, GitLab, or Bitbucket.
Packrat selects a tar
binary with the following heuristic: If a
TAR
environment variable exists, Packrat will use that. Otherwise,
it will either look for a tar
binary on the PATH
on Unix, or
look for the system tar
on Windows. If no binary is found in those
locations, it will use R's internal tar
implementation, which may
cause errors with long filenames.
snapshot
, the command that creates the snapshots
applied with restore
.
status
to view the differences between the most recent
snapshot and the library.
Retrieve the packages on the search path, as well as the associated library location.
search_path()
search_path()
Finds the packages in use in the project, and stores a list of those packages, their sources, and their current versions in packrat.
snapshot( project = NULL, available = NULL, lib.loc = libDir(project), ignore.stale = FALSE, dry.run = FALSE, prompt = interactive(), snapshot.sources = TRUE, infer.dependencies = TRUE )
snapshot( project = NULL, available = NULL, lib.loc = libDir(project), ignore.stale = FALSE, dry.run = FALSE, prompt = interactive(), snapshot.sources = TRUE, infer.dependencies = TRUE )
project |
The project directory. Defaults to current working directory. |
available |
A database of available packages. |
lib.loc |
The library to snapshot. Defaults to the private library associated with the given directory. |
ignore.stale |
Stale packages are packages that are different from the
last snapshot, but were installed by packrat. Typically, packages become
stale when a new snapshot is available, but you haven't applied it yet with
|
dry.run |
Computes the changes to your packrat state that would be made if a snapshot were performed, and prints them to the console. |
prompt |
|
snapshot.sources |
Boolean; should package sources be downloaded during snapshot? |
infer.dependencies |
If |
snapshot
modifies the project's packrat.lock
file, and
the sources stored in the project's packrat/src
directory. If you
are working with a version control system, your collaborators can sync the
changes to these files and then use restore
to apply your
snapshot.
restore
to apply a snapshot.
status
to view the differences between the most recent snapshot
and the library.
## Not run: # Take a snapshot of the current project snapshot() # See what changes would be included in a snapshot snapshot(dry.run = TRUE) ## End(Not run)
## Not run: # Take a snapshot of the current project snapshot() # See what changes would be included in a snapshot snapshot(dry.run = TRUE) ## End(Not run)
Shows the differences between the project's packrat dependencies, its private package library, and its R scripts.
status(project = NULL, lib.loc = libDir(project), quiet = FALSE)
status(project = NULL, lib.loc = libDir(project), quiet = FALSE)
project |
The directory that contains the R project. |
lib.loc |
The library to examine. Defaults to the private library associated with the project directory. |
quiet |
Print detailed information about the packrat status to the console? |
These differences are created when you use the normal R package management
commands like install.packages
, update.packages
,
and remove.packages
. To bring these differences into packrat, you
can use snapshot
.
Differences can also arise if one of your collaborators adds or removes
packages from the packrat dependencies. In this case, you simply need to tell
packrat to update your private package library using restore
.
Either NULL
if a packrat
project has not yet been
initialized, or a (invisibly) a data.frame
with components:
package |
The package name, |
packrat.version |
The package version used in the last snapshot, |
packrat.source |
The location from which the package was obtained, |
library.version |
The package version available in the local library, |
currently.used |
Whether the package is used in any of the R code in the current project. |
Unbundle a previously bundle
d project.
unbundle(bundle, where, ..., restore = TRUE)
unbundle(bundle, where, ..., restore = TRUE)
bundle |
Path to the bundled file. |
where |
The directory where we will unbundle the project. |
... |
Optional arguments passed to |
restore |
Boolean; should we |
Unused packages are those still contained within your project library, but are unused in your project.
unused_packages(project = NULL, lib.loc = libDir(project))
unused_packages(project = NULL, lib.loc = libDir(project))
project |
The project directory. |
lib.loc |
The library to check. |