<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><title>R: User-Level Configuration of renv</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<link rel="stylesheet" type="text/css" href="R.css" />
</head><body>

<table width="100%" summary="page for config {renv}"><tr><td>config {renv}</td><td style="text-align: right;">R Documentation</td></tr></table>

<h2>User-Level Configuration of renv</h2>

<h3>Description</h3>

<p>Configure different behaviors of <code>renv</code>.
</p>


<h3>Details</h3>

<p>For a given configuration option:
</p>

<ol>
<li><p> If an <span style="font-family: Courier New, Courier; color: #666666;"><b>R</b></span> option of the form <code style="white-space: pre;">renv.config.&lt;name&gt;</code> is available,
then that option's value will be used;
</p>
</li>
<li><p> If an environment variable of the form <code style="white-space: pre;">RENV_CONFIG_&lt;NAME&gt;</code> is available,
then that option's value will be used;
</p>
</li>
<li><p> Otherwise, the default for that particular configuration value is used.
</p>
</li></ol>

<p>Any periods (<code>.</code>)s in the option name are transformed into underscores (<code style="white-space: pre;">_</code>)
in the environment variable name, and vice versa. For example, the
configuration option <code>auto.snapshot</code> could be configured as:
</p>

<ul>
<li> <p><code style="white-space: pre;">options(renv.config.auto.snapshot = &lt;...&gt;)</code>
</p>
</li>
<li> <p><code style="white-space: pre;">Sys.setenv(RENV_CONFIG_AUTO_SNAPSHOT = &lt;...&gt;)</code>
</p>
</li></ul>

<p>Note that if both the R option and the environment variable are defined, the
R option will be used instead. Environment variables can be more useful when
you want a particular configuration to be automatically inherited by child
processes; if that behavior is not desired, then the R option may be
preferred.
</p>
<p>If you want to set and persist these options across multiple projects, it is
recommended that you set them in your user startup files (e.g. in
<code style="white-space: pre;">~/.Rprofile</code> or <code style="white-space: pre;">~/.Renviron</code>).
</p>


<h3>Configuration</h3>

<p>The following <code>renv</code> configuration options are available:
</p>

<table summary="Rd table">
<tr>
 <td style="text-align: left;">
<strong>Name</strong> </td><td style="text-align: left;"> <strong>Type</strong> </td><td style="text-align: left;"> <strong>Default</strong> </td><td style="text-align: left;"> <strong>Description</strong> </td>
</tr>
<tr>
 <td style="text-align: left;">
<code>auto.snapshot</code> </td><td style="text-align: left;"> <code>logical[1]</code> </td><td style="text-align: left;"> <code>FALSE</code> </td><td style="text-align: left;"> Automatically snapshot changes to the project library after a new package is installed with <code>renv::install()</code>, or removed with <code>renv::remove()</code>?
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>bitbucket.host</code> </td><td style="text-align: left;"> <code>character[1]</code> </td><td style="text-align: left;"> <code>"api.bitbucket.org/2.0"</code> </td><td style="text-align: left;"> The default Bitbucket host to be used during package retrieval.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>copy.method</code> </td><td style="text-align: left;"> <code>*</code> </td><td style="text-align: left;"> <code>"auto"</code> </td><td style="text-align: left;"> The method to use when attempting to copy directories. See <strong>Copy Methods</strong> for more information.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>connect.timeout</code> </td><td style="text-align: left;"> <code>integer[1]</code> </td><td style="text-align: left;"> <code>20L</code> </td><td style="text-align: left;"> The amount of time to spend (in seconds) when attempting to download a file. Only used when the <code>curl</code> downloader is used.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>connect.retry</code> </td><td style="text-align: left;"> <code>integer[1]</code> </td><td style="text-align: left;"> <code>3L</code> </td><td style="text-align: left;"> The number of times to attempt re-downloading a file, when transient errors occur. Only used when the <code>curl</code> downloader is used.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>dependency.errors</code> </td><td style="text-align: left;"> <code>character[1]</code> </td><td style="text-align: left;"> <code>"reported"</code> </td><td style="text-align: left;"> Many <code>renv</code> APIs require the enumeration of your project's <span style="font-family: Courier New, Courier; color: #666666;"><b>R</b></span> package dependencies. This option controls how errors that occur during this enumeration are handled. By default, errors are reported but are non-fatal. Set this to <code>"fatal"</code> to force errors to be fatal, and <code>"ignored"</code> to ignore errors altogether. See <a href="dependencies.html">dependencies</a> for more details.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>external.libraries</code> </td><td style="text-align: left;"> <code style="white-space: pre;">character[*]</code> </td><td style="text-align: left;"> <code>NULL</code> </td><td style="text-align: left;"> A character vector of external libraries, to be used in tandem with your projects. Be careful when using external libraries: it's possible that things can break within a project if the version(s) of packages used in your project library happen to be incompatible with packages in your external libraries; for example, if your project required <code style="white-space: pre;">xyz 1.0</code> but <code style="white-space: pre;">xyz 1.1</code> was present and loaded from an external library. Can also be an <span style="font-family: Courier New, Courier; color: #666666;"><b>R</b></span> function that provides the paths to external libraries. Library paths will be expanded through <a href="../../base/html/libPaths.html">.expand_R_libs_env_var</a> as necessary.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>filebacked.cache</code> </td><td style="text-align: left;"> <code>logical[1]</code> </td><td style="text-align: left;"> <code>TRUE</code> </td><td style="text-align: left;"> Enable the <code>renv</code> file-backed cache? When enabled, <code>renv</code> will cache the contents of files that are read (e.g. DESCRIPTION files) in memory, thereby avoiding re-reading the file contents from the filesystem if the file has not changed. <code>renv</code> uses the file <code>mtime</code> to determine if the file has changed; consider disabling this if <code>mtime</code> is unreliable on your system.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>github.host</code> </td><td style="text-align: left;"> <code>character[1]</code> </td><td style="text-align: left;"> <code>"api.github.com"</code> </td><td style="text-align: left;"> The default GitHub host to be used during package retrieval.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>gitlab.host</code> </td><td style="text-align: left;"> <code>character[1]</code> </td><td style="text-align: left;"> <code>"gitlab.com"</code> </td><td style="text-align: left;"> The default GitLab host to be used during package retrieval.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>hydrate.libpaths</code> </td><td style="text-align: left;"> <code style="white-space: pre;">character[*]</code> </td><td style="text-align: left;"> <code>NULL</code> </td><td style="text-align: left;"> A character vector of library paths, to be used by <code>renv::hydrate()</code> when attempting to hydrate projects. When empty, the default set of library paths (as specified in <code>?hydrate</code>) are used instead. See <code><a href="hydrate.html">hydrate</a></code> for more details.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>install.staged</code> </td><td style="text-align: left;"> <code>logical[1]</code> </td><td style="text-align: left;"> <code>TRUE</code> </td><td style="text-align: left;"> DEPRECATED: Please use <code>install.transactional</code> instead.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>install.transactional</code> </td><td style="text-align: left;"> <code>logical[1]</code> </td><td style="text-align: left;"> <code>TRUE</code> </td><td style="text-align: left;"> Perform a transactional install of packages during install and restore? When enabled, <code>renv</code> will first install packages into a temporary library, and later copy or move those packages back into the project library only if all packages were successfully downloaded and installed. This can be useful if you'd like to avoid mutating your project library if installation of one or more packages fails.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>mran.enabled</code> </td><td style="text-align: left;"> <code>logical[1]</code> </td><td style="text-align: left;"> <code>TRUE</code> </td><td style="text-align: left;"> Attempt to download binaries from <a href="https://mran.microsoft.com/">MRAN</a> during restore? See <code>vignette("mran", package = "renv")</code> for more details.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>repos.override</code> </td><td style="text-align: left;"> <code style="white-space: pre;">character[*]</code> </td><td style="text-align: left;"> <code>NULL</code> </td><td style="text-align: left;"> Override the R package repositories used during <code><a href="restore.html">restore</a></code>. Primarily useful for deployment / continuous integration, where you might want to enforce the usage of some set of repositories over what is defined in <code>renv.lock</code> or otherwise set by the R session.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>rspm.enabled</code> </td><td style="text-align: left;"> <code>logical[1]</code> </td><td style="text-align: left;"> <code>TRUE</code> </td><td style="text-align: left;"> Boolean; enable RSPM integration for <code>renv</code> projects? When <code>TRUE</code>, <code>renv</code> will attempt to transform the repository URLs used by RSPM into binary URLs as appropriate for the current platform. Set this to <code>FALSE</code> if you'd like to continue using source-only RSPM URLs, or if you find that <code>renv</code> is improperly transforming your repository URLs.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>sandbox.enabled</code> </td><td style="text-align: left;"> <code>logical[1]</code> </td><td style="text-align: left;"> <code>TRUE</code> </td><td style="text-align: left;"> Enable sandboxing for <code>renv</code> projects? When active, <code>renv</code> will attempt to sandbox the system library, preventing non-system packages installed in the system library from becoming available in <code>renv</code> projects. (That is, only packages with priority <code>"base"</code> or <code>"recommended"</code>, as reported by <code>installed.packages()</code>, are made available.)
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>shims.enabled</code> </td><td style="text-align: left;"> <code>logical[1]</code> </td><td style="text-align: left;"> <code>TRUE</code> </td><td style="text-align: left;"> Should <code>renv</code> shims be installed on package load? When enabled, <code>renv</code> will install its own shims over the functions <code>install.packages()</code>, <code>update.packages()</code> and <code>remove.packages()</code>, delegating these functions to <code>renv::install()</code>, <code>renv::update()</code> and <code>renv::remove()</code> as appropriate.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>snapshot.validate</code> </td><td style="text-align: left;"> <code>logical[1]</code> </td><td style="text-align: left;"> <code>TRUE</code> </td><td style="text-align: left;"> Validate <span style="font-family: Courier New, Courier; color: #666666;"><b>R</b></span> package dependencies when calling snapshot? When <code>TRUE</code>, <code>renv</code> will attempt to diagnose potential issues in the project library before creating <code>renv.lock</code> -- for example, if a package installed in the project library depends on a package which is not currently installed.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>synchronized.check</code> </td><td style="text-align: left;"> <code>logical[1]</code> </td><td style="text-align: left;"> <code>FALSE</code> </td><td style="text-align: left;"> Check that the project library is synchronized with the lockfile on load?
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>updates.check</code> </td><td style="text-align: left;"> <code>logical[1]</code> </td><td style="text-align: left;"> <code>FALSE</code> </td><td style="text-align: left;"> Check for package updates when the session is initialized? This can be useful if you'd like to ensure that your project lockfile remains up-to-date with packages as they are released on CRAN.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>updates.parallel</code> </td><td style="text-align: left;"> <code>*</code> </td><td style="text-align: left;"> <code>2L</code> </td><td style="text-align: left;"> Check for package updates in parallel? This can be useful when a large number of packages installed from non-CRAN remotes are installed, as these packages can then be checked for updates in parallel.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>user.library</code> </td><td style="text-align: left;"> <code>logical[1]</code> </td><td style="text-align: left;"> <code>FALSE</code> </td><td style="text-align: left;"> Include the user library on the library paths for your projects? Note that this risks breaking project encapsulation and is not recommended for projects which you intend to share or collaborate on with other users. See also the caveats for the <code>external.libraries</code> option.
</td>
</tr>
<tr>
 <td style="text-align: left;">
<code>user.profile</code> </td><td style="text-align: left;"> <code>logical[1]</code> </td><td style="text-align: left;"> <code>FALSE</code> </td><td style="text-align: left;"> Load the user R profile (typically located at <code style="white-space: pre;">~/.Rprofile</code>) when <code>renv</code> is loaded? Consider disabling this if you require extra encapsulation in your projects; e.g. if your <code>.Rprofile</code> attempts to load packages that you might not install in your projects. </td>
</tr>
<tr>
 <td style="text-align: left;">
</td>
</tr>

</table>



<h3>Copy Methods</h3>

<p>If you find that <code>renv</code> is unable to copy some directories in your
environment, you may want to try setting the <code>copy.method</code> option. By
default, <code>renv</code> will try to choose a system tool that is likely to succeed in
copying files on your system &ndash; <code>robocopy</code> on Windows, and <code>cp</code> on Unix.
<code>renv</code> will also instruct these tools to preserve timestamps and attributes
when copying files. However, you can select a different method as
appropriate.
</p>
<p>The following methods are supported:
</p>

<table summary="Rd table">
<tr>
 <td style="text-align: left;">
<code>R</code>        </td><td style="text-align: left;"> Use <span style="font-family: Courier New, Courier; color: #666666;"><b>R</b></span>'s built-in <code>file.copy()</code> function. </td>
</tr>
<tr>
 <td style="text-align: left;">
<code>cp</code>       </td><td style="text-align: left;"> Use <code>cp</code> to copy files. </td>
</tr>
<tr>
 <td style="text-align: left;">
<code>robocopy</code> </td><td style="text-align: left;"> Use <code>robocopy</code> to copy files. (Only available on Windows.) </td>
</tr>
<tr>
 <td style="text-align: left;">
<code>rsync</code>    </td><td style="text-align: left;"> Use <code>rsync</code> to copy files. </td>
</tr>
<tr>
 <td style="text-align: left;">
</td>
</tr>

</table>

<p>You can also provide a custom copy method if required; e.g.</p>
<pre>options(renv.config.copy.method = function(src, dst) {
  # copy a file from 'src' to 'dst'
})
</pre>
<p>Note that <code>renv</code> will always first attempt to copy a directory first to a
temporary path within the target folder, and then rename that temporary path
to the final target destination. This helps avoid issues where a failed
attempt to copy a directory could leave a half-copied directory behind
in the final location.
</p>


<h3>Project-Local Settings</h3>

<p>For settings that should persist alongside a particular project, the
various settings available in <a href="settings.html">settings</a> can be used.
</p>


<h3>Examples</h3>

<pre>

# disable automatic snapshots
options(renv.config.auto.snapshot = FALSE)

# disable with environment variable
Sys.setenv(RENV_CONFIG_AUTO_SNAPSHOT = "FALSE")

</pre>

<hr /><div style="text-align: center;">[Package <em>renv</em> version 0.11.0 <a href="00Index.html">Index</a>]</div>
</body></html>
