Starting with R 4.0.0 (released April 2020), R for Windows uses a toolchain bundle called rtools4. This version of Rtools is based on msys2, which makes easier to build and maintain R itself as well as the system libraries needed by R packages on Windows. The latest builds of rtools4 contain 3 toolchains:
C:\rtools40\mingw32
: the 32-bit gcc-8-3.0 toolchain for R 4.0 - 4.1C:\rtools40\mingw64
: the 64-bit gcc-8-3.0 toolchain for R 4.0 - 4.1C:\rtools40\ucrt64
: a 64-bit gcc-10.3.0 ucrt toolchain for R 4.2 1
The msys2 documentation gives an overview of the supported environments in msys2 and a comparison of MSVCRT and UCRT. The main difference between upstream msys2 and rtools4 is that our toolchains and libraries are configured for static linking, whereas upstream msys2 prefers dynamic linking. The references at the bottom of this document contain more information.
The current version of Rtools is maintained by Jeroen Ooms. Older editions were put together by Prof. Brian Ripley and Duncan Murdoch. The best place for reporting bugs is via the r-windows organization on GitHub.
Note that Rtools is only needed build R packages with C/C++/Fortran code from source. By default, R for Windows installs the precompiled "binary packages" from CRAN, for which you do not need Rtools.
To use rtools, download the installer from CRAN:
- On Windows 64-bit: rtools40-x86_64.exe (includes both i386 and x64 compilers). Permanent url: rtools40-x86_64.exe.
- On Windows 32-bit: rtools40-i686.exe (i386 compilers only). Permanent url: rtools40-i686.exe.
Note for RStudio users: you need at least RStudio version 1.2.5042
to work with rtools4.
After installation is complete, you need to perform one more step to be able to compile R packages: we put the location of the Rtools make utilities (bash
, make
, etc) on the PATH
. The easiest way to do so is by creating a text file .Renviron
in your Documents folder which contains the following line:
PATH="${RTOOLS40_HOME}\usr\bin;${PATH}"
You can do this with a text editor, or from R like so (note that in R code you need to escape backslashes):
write('PATH="${RTOOLS40_HOME}\\usr\\bin;${PATH}"', file = "~/.Renviron", append = TRUE)
Restart R, and verify that make
can be found, which should show the path to your Rtools installation.
Sys.which("make")
## "C:\\rtools40\\usr\\bin\\make.exe"
Now try to install an R package from source:
install.packages("jsonlite", type = "source")
If this succeeds, you're good to go! See the links below to learn more about rtools4 and the Windows build infrastructure.
More documentation about using rtools4 for R users and package authors:
- Using pacman: the new rtools package manager to build and install C/C++ system libraries.
- Installing R packages: Some older R packages that need extra help to compile.
- Testing packages with ucrt64: Instructions for building and testing using the experimental UCRT toolchains.
- FAQ: Common questions about Rtools40 and R on Windows.
Advanced information about building R base and building system libraries:
- r-base: Scripts for building R for Windows using rtools4.
- rtools-packages: Toolchains and static libraries for rtools4 (GCC 8+)
- rtools-backports: Backported C/C++ libraries for the gcc-4.9.3 legacy toolchain (for R 3.3 - 3.6)
- rtools-installer: Builds the rtools4 installer bundle.