knitr::opts_chunk$set( collapse = TRUE, comment = "#>" )
This vignette describes interactive use of environments built with {rix}
using
an IDE (GUI editor) like RStudio. Depending on your operating system and the
editor you wish to use, different settings must be configured.
It is also possible to evaluate single functions inside a dedicated, separate,
environment from another, main, interactive R session. For more details
regarding this, refer to the vignette vignette("z-advanced-topic-running-r-or-shell-code-in-nix-from-r")
.
The following are the setups we recommend you use to work using an IDE and Nix environments. To be recommended, a setup should:
Regardless of your operating system, a general-purpose editor such as VS Code (or Codium), Emacs, or Neovim meets the above requirements. Recent releases of Positron also work quite well. (Note: Neovim is not covered here due to lack of experience—PRs welcome!) However, some editors perform better on certain platforms.
Also, we recommend you uninstall R if it's installed system-wide and also remove your local library of packages and instead only use dedicated Nix shells to manage your projects. While we made our possible for Nix shells to not interfere with a system-installed R, we recommend users go into the habit of taking some minutes at the start of a project to properly set up their development environment.
On macOS, RStudio will only be available through Nix and only for versions 4.4.3 or more recent, or after the 2025-02-28 if you're using dates. For older versions of R or dates, RStudio is not available for macOS through Nix so you cannot use it. As such, we recommend either VS Code (or Codium) or Positron for older dates or versions. Emacs or Neovim are also good options. See the relevant sections below to set up any of these editors. We also recommend to install the editor on macOS directly, and configure it to interact with Nix shells, instead of using Nix to install the editor, even though it does take some more effort to configure.
On Windows, since you have to use Nix through WSL, your options are limited to editors that either:
We recommend to use an editor you can install directly on Windows and configure to interact nicely with WSL, and it turns out that this is mostly only VS Code (or Codium) or Positron. See this section to learn how to configure VS Code (or Codium) or Positron.
If you want to use RStudio, this is also possible but:
You should also be aware that there is currently a bug in the RStudio Nix
package that makes RStudio ignore project-specific .Rprofile
files, which can
be an issue if you also have a system-level library of packages. Instead, you
can sure the .Rprofile
generated by rix()
yourself or you can uninstall the
system-level R and library of packages.
Furthermore, be aware that there is a bug in WSLg that prevents modifier keys like Alt Gr from working properly.
If you prefer Emacs or Neovim, then we recommend to install it in WSL and use
it in command line mode, not through WSLg (so starting Emacs with the - nw
argument).
On Linux distributions, the only real limitation is that RStudio cannot interact with Nix shells (just like on the other operating systems), so if you want to use RStudio then you need to install it using Nix.
You should also be aware that there is currently a bug in the RStudio Nix
package that makes RStudio ignore project-specific .Rprofile
files, which can
be an issue if you also have a system-level library of packages. Instead, you
can sure the .Rprofile
generated by rix()
yourself or you can uninstall the
system-level R and library of packages.
If you use another editor, just follow the relevant instructions below; the question you need to think about is whether you want to use Nix to install the editor inside of the development shell or if you prefer to install your editor yourself using your distribution's package manager, and configure it to interact with Nix shells. We recommend the latter option, regardless of the editor you choose.
RStudio must be installed by Nix in order to see and use Nix shells. So
you cannot use the RStudio already installed on your computer to work with Nix
shells. This means you need to set ide = "rstudio"
if you wish to use RStudio.
You should also be aware that there is currently a bug in the RStudio Nix
package that makes RStudio ignore project-specific .Rprofile
files, which can
be an issue if you also have a system-level library of packages. Instead, you
can sure the .Rprofile
generated by rix()
yourself or you can uninstall the
system-level R and library of packages.
To use RStudio on macOS simply use ide = "rstudio"
, but be aware that this
will only work for R version 4.4.3 at least, or for a date on or after the
2025-02-28. If you don't need to work with older versions of R or older date,
RStudio is an appropriate choice. Then, build the environment using nix-build
and drop into the shell using nix-shell
. Then, type rstudio
to start
RStudio. If you wish, you can even put the rstudio
command in the shell hook to start it immediately as you run nix-shell
.
To use RStudio on Linux or Windows simply use ide = "rstudio"
. Then, build the
environment using nix-build
and drop into the shell using nix-shell
. Then,
type rstudio
to start RStudio.
If you plan to use RStudio on Ubuntu, then you need further configuration to make it work, because of newly introduced sandboxing features in Ubuntu 24.04. You will need to create an RStudio-specific AppArmor profile. To do so create this apparmor profile:
sudo nano /etc/apparmor.d/nix.rstudio
Populate it with:
profile nix.rstudio /nix/store/*-RStudio-*-wrapper/bin/rstudio flags=(unconfined) { userns, }
Save it, load the profile and start RStudio:
sudo apparmor_parser -r /etc/apparmor.d/nix.rstudio sudo systemctl reload apparmor
You can now start RStudio from the activated Nix shell.
On Windows, you need to have WSLg
enabled, which should be the case on the
latest versions of Windows. If you wish, you can even put the rstudio
command
in the shell hook to start it immediately as you run nix-shell
.
On Linux and WSL, depending on your desktop environment, and for older versions of RStudio, you might see the following error message when trying to launch RStudio:
qt.glx: qglx_findConfig: Failed to finding matching FBConfig for QSurfaceFormat(version 2.0, options QFlags<QSurfaceFormat::FormatOption>(), depthBufferSize -1, redBufferSize 1, greenBufferSize 1, blueBufferSize 1, alphaBufferSize -1, stencilBufferSize -1, samples -1, swapBehavior QSurfaceFormat::SingleBuffer, swapInterval 1, colorSpace QSurfaceFormat::DefaultColorSpace, profile QSurfaceFormat::NoProfile) Could not initialize GLX Aborted (core dumped)
in this case, run the following before running RStudio:
export QT_XCB_GL_INTEGRATION=none
The same instructions apply whether your host operating system is Linux, macOS or Windows. The first step is of course to install Positron on your operating system using the usual means of installing software.
If you're on Windows, install Positron on Windows, not in WSL. Positron on Windows is able to interact with WSL seamlessly and before continuing here, please follow these instructions (it’s mostly about installing the right extensions after having installed Positron).
On macOS, start by installing Positron using the official .dmg
installer. Start
Positron, and then the command palette using COMMAND-SHIFT-P
. In the search
bar, type "Install 'positron' command in PATH"
and click on it: this will make
it possible to start Positron from a terminal.
Once Positron is installed, you need to install a piece of software called direnv
:
direnv
will automatically load Nix shells when you open a project that contains a
default.nix
file in an editor. It works on any operating system and many
editors support it, including Positron. Follow the instructions for your operating
system here but if you're using
Windows, install direnv
in WSL (even though you’ve just installed Positron
for Windows), so follow the instructions for whatever Linux
distribution you're using there (likely Ubuntu), or use Nix to install direnv
if you prefer (this is the way I recommend to install it on macOS, unless you
already use brew
):
nix-env -f '<nixpkgs>' -iA direnv
This will install direnv
and make it available even outside of Nix shells!
Then, we highly recommend to install the nix-direnv
extension:
nix-env -f '<nixpkgs>' -iA nix-direnv
It is not mandatory to use nix-direnv
if you already have direnv
, but it'll
make loading environments much faster and seamless. Finally, if you haven't used
direnv
before, don't forget this last step.
Then, in Positron, install the
direnv extension (and also the
WSL extension if you're on Windows, as explained in the official documentation
linked above!). Finally, add a file called .envrc
and simply write the
following two lines in it:
use nix mkdir $TMP
in it. Now, remotely connect to WSL and open the project's folder using File > Open Folder...
and you will
see a pop-up stating direnv: /PATH/TO/PROJECT/.envrc is blocked
and a button
to allow it. Click Allow
and then open an R script. You might get another
pop-up asking you to restart the extension, so click Restart
. Be aware that at
this point, direnv
will run nix-shell
and so will start building the
environment. If that particular environment hasn't been built and cached yet, it
might take some time before Positron will be able to interact with it. You might get
yet another popup, this time from the R Code extension complaining that R can't
be found. In this case, simply restart Code and open the project folder again:
now it should work every time. For a new project, simply repeat this process:
default.nix
file;nix-build
;.envrc
and write the two lines from above in it;Another option is to create the .envrc
file and write use nix
in it, then
open a terminal, navigate to the project's folder, and run direnv allow
. Doing
this before opening Positron should not prompt you anymore.
If you're on Windows, using Positron like this is particularly interesting, because it allows you to install Positron on Windows as usual, and then you can configure it to interact with a Nix shell, even if it's running from WSL. This is a very seamless experience.
If you want to install Positron with Nix, you need a call that looks like this:
rix( date = ..., r_pkgs = c(...), # whatever packages you need ide = "positron", ... )
If you plan to use Positron on Ubuntu, then you need further configuration to make it work, because of newly introduced sandboxing features in Ubuntu 24.04. You will need to create an Positron-specific AppArmor profile. To do so create this apparmor profile:
sudo nano /etc/apparmor.d/nix.positron
Populate it with:
profile nix.positron /nix/store/*-positron-bin-*/bin/positron flags=(unconfined) { userns, }
Save it, load the profile and start Positron:
sudo apparmor_parser -r /etc/apparmor.d/nix.positron sudo systemctl reload apparmor
You can now start Positron from the activated Nix shell.
The advantage of letting Nix handle Positron is that you don't need to configure
anything else. Simply build your environment using nix-build
, then activate
the shell using nix-shell
and run positron
to start using Positron in the
right environment (you can even put the positron
command in the shell hook to
start it immediately as you run nix-shell
). Settings and extensions are shared
between all the different Positrons of all your different shells so you don't
need to waste time reconfiguring different instances of Positron, and Nix shells
that use the same version of Positron will not install it twice, but simply
reuse it. However, if the version is slightly different, then a new version will
be installed.
To avoid having different versions of Positron installed on your system, you can instead opt for the option where you install a single Positron instance on your system and use it with all the Nix shells.
You can use VS Code or Codium (henceforth, I'll refer to both these editors
simply as "Code") with Nix shells by either installing it through Nix (so by
setting ide = "code"
or ide = "codium"
) or by installing it on your
operating system and then configure it to be able to interact with Nix shells.
In any case, you will need to install the {languageserver}
R package for Code
to interact properly with the R console.
Settings and extensions are shared between all the different Codes of all your different shells so you don't need to waste time reconfiguring different instances of Code, and Nix shells that use the same version of Code will not install it twice, but simply reuse it. However, if the version is slightly different, then a new version will be installed.
To avoid having different versions of Code installed on your system, you can instead opt for the option where you install Code for your system using the usual installation method (so an installer for Windows or macOS, through your operating system's package manager for any Linux distribution), and instead configure it to interact with Nix shells.
If you're on Windows, using Code like this is particularly interesting, because it allows you to install Code on Windows as usual, and then you can configure it to interact with a Nix shell, even if it's running from WSL. This is a very seamless experience.
The same instructions apply whether your host operating system is Linux, macOS or Windows. The first step is of course to install Code on your operating system using the usual means of installing software.
If you're on Windows, install Code on Windows, not in WSL. Code on Windows is able to interact with WSL seamlessly and before continuing here, please follow these instructions.
Then, you need to install a piece of software called direnv
: direnv
will
automatically load Nix shells when you open a project that contains a
default.nix
file in an editor. It works on any operating system and many
editors support it, including Code. Follow the instructions for your operating
system here but if you're using
Windows, install direnv
in WSL, so follow the instructions for whatever Linux
distribution you're using there (likely Ubuntu), or use Nix to install direnv
if you prefer (this is the way I recommend to install it on macOS, unless you
already use brew
):
nix-env -f '<nixpkgs>' -iA direnv
This will install direnv
and make it available even outside of Nix shells!
Then, we highly recommend to install the nix-direnv
extension:
nix-env -f '<nixpkgs>' -iA nix-direnv
It is not mandatory to use nix-direnv
if you already have direnv
, but it'll
make loading environments much faster and seamless. Finally, if you haven't used
direnv
before, don't forget this last
step.
Then, in Code, install the
direnv extension (and also the
WSL extension if you're on Windows, as explained in the official documentation
linked above!). Finally, add a file called .envrc
and simply write the
following two lines in it:
use nix mkdir $TMP
Now, remotely connect to WSL and open the project's folder using File > Open Folder...
and you will
see a pop-up stating direnv: /PATH/TO/PROJECT/.envrc is blocked
and a button
to allow it. Click Allow
and then open an R script. You might get another
pop-up asking you to restart the extension, so click Restart
. Be aware that at
this point, direnv
will run nix-shell
and so will start building the
environment. If that particular environment hasn't been built and cached yet, it
might take some time before Code will be able to interact with it. You might get
yet another popup, this time from the R Code extension complaining that R can't
be found. In this case, simply restart Code and open the project folder again:
now it should work every time. For a new project, simply repeat this process:
default.nix
file;nix-build
;.envrc
and write the two lines from above in it;Another option is to create the .envrc
file and write the two lines from above in it, then
open a terminal, navigate to the project's folder, and run direnv allow
. Doing
this before open Code should not prompt you anymore.
So, concretely, if you want to install Code with Nix, you need a call that looks like this:
rix( date = ..., r_pkgs = ..., ide = "code", # or "codium" ... )
But if you prefer to use the Code you have installed system-wide, then you
need to add the {languageserver}
package and use ide = "none"
:
rix( date = ..., r_pkgs = c("languageserver", ...), # languageserver is needed ide = "none", ... )
The advantage of letting Nix handle Code is that you don't need to configure
anything else. Simply build your environment using nix-build
, then activate
the shell using nix-shell
and run code
(for VS Code) or codium
(for
Codium). You can even put the code
(or codium
) command in the shell hook
argument to have it start as soon as you drop in the development shell using
nix-shell
.
You can install Emacs on Linux and macOS and configure it to interact with Nix shells. Install Emacs using the usual means of installing software on your operating system. On Windows you cannot use the native Emacs installed on Windows to interact with WSL, so you will need to install Emacs on WSL. If your WSL distribution is Ubuntu (which it likely is), you can install Emacs with:
sudo apt update sudo apt install -y emacs
Because you’re using the Emacs from your operating system, generate default.nix
shells by setting ide = "other"
:
rix( date = ..., r_pkgs = c(...), # whatever packages you need ide = "other", ... )
Then, you need to install a piece of software called direnv
: direnv
will
automatically load Nix shells when you open a project that contains a
default.nix
file in an editor. It works on any operating system and many
editors support it, including Emacs. Follow the instructions for your operating
system here but if you're using
Windows, install direnv
in WSL, so follow the instructions for whatever Linux
distribution you're using there (likely Ubuntu), or use Nix to install direnv
if you prefer (this is the way I recommend to install it on macOS, unless you
already use brew
):
nix-env -f '<nixpkgs>' -iA direnv
This will install direnv
and make it available even outside of Nix shells!
Then, we highly recommend to install the nix-direnv
extension:
nix-env -f '<nixpkgs>' -iA nix-direnv
It is not mandatory to use nix-direnv
if you already have direnv
, but it'll
make loading environments much faster and seamless. Finally, if you haven't used
direnv
before, don't forget this last
step.
Then install the Emacs direnv
package. Finally,
add a file called .envrc
and simply write the following two lines in it:
use nix mkdir $TMP
Now, open the project's folder in a
terminal and type direnv allow
. Be aware that at this point, direnv
will run
nix-shell
and so will start building the environment. If that particular
environment hasn't been built and cached yet, it might take some time. Starting
Emacs and loading a script from that folder will now load the environment for
you automatically. On Windows, starting Emacs from WSL will start the Linux GUI
version using WSLg. As mentioned in the introduction, be aware that there is a
bug in WSLg that prevents modifier keys like Alt
Gr from working properly. This is
quite problematic with Emacs, so we recommend using it in cli mode using emacs
-nw
.
For a new project, simply repeat this process:
default.nix
file;nix-build
;.envrc
and write the two lines from above in it;direnv allow
.Emacs can be installed through Nix, but is not an option of the ide
argument.
This is because there are several versions of Emacs available through Nix (find
these versions
here)
so install whatever version you want by putting it in system_pkgs
like so:
rix( date = ..., r_pkgs = c(...), # whatever packages you need system_pkgs = "emacs", ... )
This doesn't require any further configuration to use. Simply drop in the Nix
shell using nix-shell
and type emacs
. You can set the emacs
command as the
shell hook so Emacs starts automatically upon entering the shell. On Windows, if
WSLg is enabled, it'll start Emacs from WSL, if not, it'll start it as a
terminal application. we recommend using Emacs as a terminal application instead
of through WSLg, as there is a bug in WSLg that prevents modifier keys like
AltGr from working properly. This is
quite problematic with Emacs, so we recommend using it in cli mode using emacs
-nw
.
If you don't use direnv
to automatically load the Nix shell with your editor,
you can also create a launcher using rix::make_launcher("rstudio")
(change
"rstudio"
to whichever command starts your editor). This will create a script
called start-EDITOR.sh
where EDITOR
will be replaced by what you used before.
The contents of the script are the following:
1 2 3 | #!/usr/bin/env nix-shell #!nix-shell default.nix -i bash EDITOR |
Give this script execution rights (by using chmod +x start-EDITOR.sh
in a
terminal) and you’ll be able to start your editor in the right environment by
either clicking on it, or by running ./start-EDITOR.sh
in the terminal.
(On Linux, if you use RStudio, and only if needed, add the export
QT_XCB_GL_INTEGRATION=none
line before rstudio
).
You can also define a shortcut to a project that will take care of activating the environment and launching your editor. This way, you don't need to start a terminal in that folder and drop into the Nix environment each time you want to work on this project. For example, you could define a bash alias like this:
alias kmeans='nix-shell ~/Documents/kmeans/default.nix --run rstudio
which would then execute RStudio in the right project by simply typing kmeans
in a terminal for your project that uses the K-means algorithm.
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.