This package provides R with access to Boost header files. Boost provides free peer-reviewed portable C++ source libraries. A large part of Boost is provided as C++ template code which is resolved entirely at compile-time without linking.
This package aims to provide the most useful subset of Boost libraries for template use among CRAN packages. By placing these libraries in this package, we offer a more efficient distribution system for CRAN as replication of this code in the sources of other packages is avoided.
It can be used via the
LinkingTo: field in the
DESCRIPTION field of an R package — and the R package infrastructure tools will then know how to set include flags correctly on all architectures supported by R.
Note that this can be used solely by headers-only Boost libraries. This covers most of Boost, but excludes some libraries which require linking for parts or all of their functionality.
As of release 1.72.0-3, the following Boost libraries are included:
accumulators algorithm align any atomic bimap bind circular_buffer compute concept config container date_time detail dynamic_bitset exception flyweight foreach functional fusion geometry graph heap icl integer interprocess intrusive io iostreams iterator math move mp11 mpl multiprecision numeric pending phoenix polygon preprocessor propery_tree random range scope_exit smart_ptr sort spirit tuple type_traits typeof unordered utility uuid
The Rcpp Gallery contains several examples under its
boost tag including the introductory first and second. From the first, a simple example to compute the greatest common demoninator of two integers follows:
Saving it as
boostExample.cpp and simple sourcing this
Rcpp::sourceCpp("boostExample.cpp") produces the function
computeGCD(). See the Rcpp Gallery for more examples.
We aim to maintain this package in a somewhat conservative fashion and do not always immediately jump the newest Boost releases. Rather, we (used to) start from the Debian sources for Boost to ensure that we work with a version that is at the same time current yet mature. But on occassion, and as needed, and more recently, we will also go directly to Boost releases.
In general, we plan to keep the package up-to-date with Boost upstream, but will not necessarily follow each and every new release as we also value the merits of relative release stability.
If needed, the script
local/script/CreateBoost.sh can be used to update a forked version to a newer version of Boost.
That used to be a concern, and we wrote:
The repo has a large footprint. We know. We erroneously thought that committing the Boost tarballs would be a good idea. It wasn’t. First attempts at pruning the history using bfg were not that successful. If someone has a script doing this well we would take another look.
Otherwise we recommend to just start from CreateBoost.sh.
Dirk Eddelbuettel, Jay Emerson and Michael Kane
This package is provided under the same license as Boost itself, the BSL-1.0