cpp4r helps you to interact with R objects using C++ code. It is a fork of the cpp11 package with identical syntax and similar goals.
cpp4r can be used as a replacement for cpp11 in existing or new packages. Think of cpp11 and cpp4r as MySQL and MariaDB: they are almost identical, but cpp4r has some extra features.
After discussing some pull requests with Hadley Wickham from Posit, it was mentioned that I should create my own fork to add the following features:
- Convert ordered and unordered C++ maps to R lists.
- Roxygen support on C++ side.
-  Allow dimnamesattribute with matrices on C++ side.
-  Support nullable external_ptr<>.
-  Use values added to a vector with push_back()immediately.
- Support bidirectional passing of complex numbers/vectors.
-  Provide flexibility with data types (e.g., cpp4r’s as_integers()andas_doubles()accept logical inputs while cpp11’s do not).
- Some internal optimizations for better speed (e.g., r-lib/cpp11#463 and r-lib/cpp11#430).
Check the documentation to get started using cpp4r in your scripts, particularly if you are new to C++ programming.
You can install cpp4r from CRAN:
install.packages("cpp4r", repos = "https://cloud.r-project.org")Or the development version from GitHub:
install.packages("remotes")
remotes::install_github("pachadotdev/cpp4r")Create a new package with cpp4r::pkg_template("~/path/to/mypkg") and
then edit the generated files.
To add cpp4r to an existing package, put your C++ files in the src/
directory and add the following to your DESCRIPTION file:
LinkingTo: cpp4r
Then add a roxygen header, for example, to R/mypkg-package.R:
#' @useDynLib mypkg, .registration = TRUE
#' @keywords internal
"_PACKAGE"Then decorate C++ functions you want to expose to R with
[[cpp4r::register]].
cpp4r is a header only library with no hard dependencies and does not use a shared library. It is straightforward and reliable to use in packages without fear of compile-time and run-time mismatches.
You can vendor the
current installed version of cpp4r headers into your package with
cpp4r::vendor().
The cpp4rvendor package shows an example of vendoring cpp4r headers.
Vendoring ensures the headers will remain unchanged until you explicitly update them. The advantage is that your package will not break if there are breaking changes in future versions of cpp4r. The disadvantage is that you will not get bug fixes and new features unless you update the vendored headers.
Please open an issue or email me. I will do my best to respond before 48 hours.
Contributions are welcome! Please see the internals vignette for details about design choices and coding style.
Please note that the cpp4r project is released with a Contributor Code of Conduct. By contributing to this project, you agree to abide by its terms.