commit | 8b475a4b28a3dc31b83f23470d95fe60718d26c7 | [log] [tgz] |
---|---|---|
author | Lukasz Anforowicz <lukasza@google.com> | Tue Nov 29 09:33:02 2022 -0800 |
committer | Copybara-Service <copybara-worker@google.com> | Tue Nov 29 09:33:32 2022 -0800 |
tree | 1c1805eda93915b76694ebec4ffb5917be5b563a | |
parent | 841386cc4ee97b85dd426921768f5811ca8d2d40 [diff] |
Fix handling of `std::cmp::Ordering` and `Option<i8>` in `format_ty...`. Before this CL the "Cross-crate dependencies are not supported yet (b/258261328)" error had no test coverage. Adding this test coverage is the primary motivation for this CL. This CL is triggered by the realization that cross-crate test coverage can be provided by testing types from the `std` crate (earlier I thought that testing these scenarios will require modifying `test::run_compiler` to support depending on other crates). Adding tests for `std::cmp::Ordering` helped flush out an additional bug: `format_ty_for_rs` incorrectly assumed that `ty.to_string()` returns a single identifier and panicked when it returned "std::cmp::Ordering". Fixing this bug encouraged introduction of initial, minimal support for modules/namespaces and reusing `NamespaceQualifier` from `rs_bindings_from_cc`. The CL also opportunistucally adds test coverage for _generic_ types from other crates - by testing `Option<i8>`. PiperOrigin-RevId: 491660080
Extremely experimental interop tooling for C++ and Rust.
Please don‘t use, this is an experiment and we don’t yet know where will it take us. There will be breaking changes without warning. Unfortunately, we can't take contributions at this point.
$ apt install clang lld bazel $ git clone git@github.com:google/crubit.git $ cd crubit $ bazel build --linkopt=-fuse-ld=/usr/bin/ld.lld //rs_bindings_from_cc:rs_bindings_from_cc_impl
$ git clone https://github.com/llvm/llvm-project $ cd llvm-project $ CC=clang CXX=clang++ cmake -S llvm -B build -DLLVM_ENABLE_PROJECTS='clang' -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=install $ cmake --build build -j $ # wait... $ cmake --install build $ cd ../crubit $ LLVM_INSTALL_PATH=../llvm-project/install bazel build //rs_bindings_from_cc:rs_bindings_from_cc_impl