From 12f9e299f345a8d7ea8a370b264e72131b0d929e Mon Sep 17 00:00:00 2001 From: Josiah Parry Date: Sun, 31 Mar 2024 14:36:26 -0400 Subject: [PATCH] Add extendr to R type mapping (#14) * add data types doc * add listsxp nextto pairlist * fix: add `data-types.qmd` to the mix * additional types written --------- Co-authored-by: Mossa --- _quarto.yml | 1 + data-types.qmd | 47 +++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 48 insertions(+) create mode 100644 data-types.qmd diff --git a/_quarto.yml b/_quarto.yml index 8309ca6..982c8d9 100644 --- a/_quarto.yml +++ b/_quarto.yml @@ -17,6 +17,7 @@ website: - hello-world.qmd - project-structure.qmd - conversion.qmd + - data-types.qmd style: "docked" search: true navbar: diff --git a/data-types.qmd b/data-types.qmd new file mode 100644 index 0000000..f630418 --- /dev/null +++ b/data-types.qmd @@ -0,0 +1,47 @@ +--- +title: R to Rust type mapping +--- + +extendr is allows us to create a bridge between R and Rust. When writing a function in Rust that is intended to be called from R, it is important that the input types be R types. There are many types of objects in R (almost) all of which are available in extendr via a wrapper struct. + +The below lists the extendr structs that wrap R object types. These types can be used as function arguments or return values. + +## Scalar types + +| R type | extendr type | Rust type | +| ------| -----------| ----------| +| `integer(1)` | `Rint` | `i32` | +| `double(1)` | `Rfloat` | `f64` | +| `logical(1)` | `Rbool` | `bool` | +| `complex(1)` | `Rcplx` | `Complex` | +| `character(1)` | `Rstr` | `String` | + +## Vector types + +| R type | extendr type | extendr scalar type | C API Type | +|-------------|------------|-------------------|----------| +| `integer()` | `Integers` | `Rint` | `INTSXP` | +| `double()` | `Doubles` | `Rfloat` | `REALSXP` | +| `logical()` | `Logicals` | `Rbool` | `LGLSXP` | +| `complex()` | `Complexes` | `Rcplx` | `CPLXSXP` | +| `character()` | `Strings` | `Rstr` | `STRSXP` | +| `raw()` | `Raw` | `&[u8]` | `RAWSXP` | +| `list()` | `List` | `Robj` | `VECSXP` | + + +## Other types + + +- [`Environment`](https://extendr.github.io/extendr/extendr_api/wrapper/environment/struct.Environment.html) (`ENVSXP`) +- [`Expressions`](https://extendr.github.io/extendr/extendr_api/wrapper/expr/struct.Expressions.html) (`EXPRSXP`) +- [`ExternalPtr`](https://extendr.github.io/extendr/extendr_api/wrapper/externalptr/struct.ExternalPtr.html) (`EXTPTRSXP`) +- [`Function`](https://extendr.github.io/extendr/extendr_api/wrapper/function/struct.Function.html) (`CLOSSXP`) +- [`Language`](https://extendr.github.io/extendr/extendr_api/wrapper/lang/struct.Language.html) (`LANGSXP`) +- [`RArray`](https://extendr.github.io/extendr/extendr_api/wrapper/matrix/struct.RArray.html) +- [`Pairlist`](https://extendr.github.io/extendr/extendr_api/wrapper/pairlist/struct.Pairlist.html) (`LISTSXP`) +- [`Promise`](https://extendr.github.io/extendr/extendr_api/wrapper/promise/struct.Promise.html) (`PROMSXP`) +- [`S4`](https://extendr.github.io/extendr/extendr_api/wrapper/s4/struct.S4.html) (`S4SXP`) + +## Using Rust library types vs R-native types + +## Returning Rust values to R \ No newline at end of file