Disclaimer: This project is experimental, under heavy development, and should not be used yet.
:rs_bindings_from_cc
parses C++ headers and generates:
For convenience, :test_wrapper
is a shell script that passes all Clang command line flags from the current Bazel C++ toolchain:
bazel run //rs_bindings_from_cc:test_wrapper -- --public_headers=hello_world.h
or:
bazel build //rs_bindings_from_cc:test_wrapper bazel-bin/rs_bindings_from_cc/test_wrapper --public_headers=hello_world.h
If possible follow these recommendations:
src_code_gen
should:assert_cc_matches!/assert_rs_matches!/assert_cc_not_matches!/assert_rs_not_matches!
macrosimporter
should:ir_from_cc_test.rs
) so they cover both AST logic and IR serialization/deserialization, but C++ tests (thanks to its nice matchers) are also OK at the moment (importer_test.cc
)rs_bindings_from_cc_test.sh
.test/golden
.rs_bindings_from_cc/test/golden/update.sh
to regenerate checked-in files.rust_test
or cc_test
on top in subpackages of test
.To run individual rust tests with bazel test
(like bazel test --test_filter=<test>
for gtest cases), give the test function name as --test_arg=<test>
.
To get Rust backtraces for rs_bindings_from_cc
when running end-to-end tests, use bazel test --action_env=RUST_BACKTRACE=1
to run the tests.
Chat room (internal): https://chat.google.com/room/AAAAImO--WA
20% starter projects list (internal): b/hotlists/3645339