Are we Crubit Yet?
NOTE: The bug links below, of the form b/123456
, are for Google-internal tracking purposes.
What follows is an overview of the major features Crubit does and does not support. The list is necessarily incomplete, because there exist more features and types than could be feasibly listed in anything readable, but it should give a rough idea.
This page should evolve over time:
- If the status of a given feature is not listed, and not clear based on what is here, we should add it.
- Some features may not have bug IDs attached. If a feature is actively requested, it should be listed with a given bug that updates will be posted to.
- This page may fall out of date, since the set of features supported by Crubit is documented in many places. Sorry! Please update it if you notice any problems.
Types
Types come in three flavors:
- ABI-compatible: the type can be used by value or by pointer, in fields, functions, function pointers
- Layout-compatible: the type can be used anywhere an ABI-compatible type can be except:
- not by-value in manual FFI that does not use Crubit
- not by-value in function pointers
- Bridged: the type can only be passed or returned directly by value. It cannot be used by pointer, in struct fields, or in function pointers in any way.
Unless otherwise specified, the below types are supported and ABI-compatible (see /cpp/fundamental_types, /cpp/pointer_types):
- integer types (except 128-bit integers)
- floating point types
- user-defined types
- These are either layout-compatible (usually) or ABI-compatible (rarely – if all member types are supported, and it's nonempty, and it uses no obscure attributes)
- function pointers, where the parameters and return type are in this list and are ABI-compatible
- raw pointers to anything in this list
We have experimental unreleased support for the following types:
- (2024H2) b/333737717: ABI-compatible
std::string_view
/ absl::string_view
We have planned support for the following types:
- (2024H2) b/308406733: bridged protocol buffers
- (2024H2) b/351976622: bridged
std::string
- (2024H2) b/356221625: bridged
absl::Status
, absl::StatusOr
- (2024H2) b/271016831: layout-compatible
*const [T]
, *mut [T]
- (2025) b/356221873: bridged
std::vector
- (2025) b/262580415 layout-compatible
&str
The following types are not yet supported, among many others:
- b/254507801: Rust
!
- b/260128806: Arrays (
std::array<T, N>
, [T; N]
) - b/254094650:
i128
and u128
- Rust
String
Option<T>
(except in some narrow circumstances) and std::optional<T>
.- Specifically the type alias
ffi::c_char
. Result<T, E>
- b/254099023:
()
as anything but a return type. - b/213960614:
std::byte
C++
For C++ libraries, used from Rust, we have support for the following language features, used in public interfaces:
- trivially-relocatable structs. (Either trivially copyable, or
[[clang::trivial_abi]]
) - trivially relocatable unions.
- enums
- type aliases
- non-overloaded functions (which are not member functions)
- inline or non-inline
- extern “C” or non-extern “C”
We have experimental unreleased support for the following language features:
- forward declarations
- non-trivial types
- b/356224404: non-overloaded member functions, (overloaded) constructors and assignment operators
- Operator overloading
- templated types, bridged to a non-generic concrete type.
- e.g.
vector<int>
becomes struct __crubit_mangled_vector_i
, not struct vector<T>(...)
- specialization
- operator overloading
- nullability annotations
- lifetime annotations, mapped unsafely to references
- Some object-orientation:
- types with non-virtual base classes
- upcasting
- downcasting
- inherited methods
The following features are not supported yet, among many others:
- b/213280424: overloading
- b/313733992: Object-Oriented Programming more generally
- e.g., cannot derive from a C++ class and override its virtual methods
- safe support for references
- template-generic bridging, so that a C++ template becomes a Rust generic
- non-type
using
aliases- using enum
- using namespace
- constants
- macros
Rust
The following section is “aspirational”, not yet true but will be true at end of Q3
For Rust libraries, used from C++, we have support for the following language features, used in public interfaces:
- structs which are copyable or movable (see notes)
- repr(C) unions which are copyable or movable (see notes)
- opaque representations of other user-defined types which are copyable or movable (see notes):
- aliases (via
use
, type
) - functions
- inherent methods
- taking
self
by value - taking
self: *const Self
or self: *mut Self
- static methods
- but not
&self
, &mut self
, or others
- Specific known traits with equivalents in C++:
Notes: to receive bindings, a user-defined type must be C++-movable, and therefore must either be copyable (implement Clone
), or implement Default
so that a default instance can be left in place.
We have experimental unreleased support for the following language features:
- unsafe use of references,
&self
, etc. - non-opaque enums
- non-opaque non-repr(C) unions
The following features are not supported yet, among others:
- traits and trait methods in general
- defining C++ abstractions from Rust
- inheriting from a C++ class
- defining a C++ base class
- defining a C++ enum
- statics and constants
- macros
Build System
We currently only support Bazel.
TODO:
- (2025) Cargo support, build scripts, etc.
- (2025) Stable command-line interface
- (not planned) Buck2
- (not planned) CMake