commit | ce17f3f2a9afe3f56183e80470d91728ff119ba6 | [log] [tgz] |
---|---|---|
author | Lukasz Anforowicz <lukasza@google.com> | Mon Feb 27 11:32:14 2023 -0800 |
committer | Copybara-Service <copybara-worker@google.com> | Mon Feb 27 11:33:04 2023 -0800 |
tree | 5d524d49a06c0713b5313a7fae4d0a44117b43a3 | |
parent | 77d270a1326c21fdd1cff28a8b86eefc583f8af2 [diff] |
Prevent panics when processing re-imports (i.e. `use` items). Some callers of `FullyQualifiedName` expect to only work with named items (e.g. `format_fn` expects that all functions it works with are named; and `format_ty_for_cc` expects that all ADTs it works with are named). Before this CL `FullyQualifiedName::new` would panic when called for a `def_id` without an associated name. This panic would be a problem for callers of `FullyQualifiedName` that only need the `mod_path` (e.g. when `format_crate` emits unsupported-item comments and uses `mod_path` to reorder them into the right location in relation to other topo-sorted bindings). This CL makes `FullyQualifiedName::name` an `Option` and tweaks `FullyQualifiedName::new` so that it no longer panics when called with an unnamed item. This CL also opportunistically replaces the custom `get_symbol` function with more-or-less equivalent calls to [`DefPathData::get_opt_name`](https://doc.rust-lang.org/beta/nightly-rustc/rustc_hir/definitions/enum.DefPathData.html#method.get_opt_name). PiperOrigin-RevId: 512684397
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