Refactor `AnalyzeSingleFunctionBody()`.

Now that we can analyze defaulted functions, the name of
`AnalyzeSingleFunctionBody()` is no longer appropriate, as it also analyzes
functions without a body.

Rename to `AnalyzeSingleFunction()` and factor out a function
`AnalyzeFunctionBody()` that deals only with function bodies.

An additional effect is that we now do additional things for defaulted functions
that we used to do only for functions with bodies, namely emitting debug info
and, importantly, propagating static lifetimes to pointees. (Strictly speaking,
this makes this change more than a refactor.)

PiperOrigin-RevId: 458209309
1 file changed
tree: 3a22aaa09f030f4f846583cbbf4cf9d3bf32a3d0
  1. .bazelci/
  2. bazel/
  3. cc_template/
  4. common/
  5. docs/
  6. lifetime_analysis/
  7. lifetime_annotations/
  8. migrator/
  9. nullability_verification/
  10. rs_bindings_from_cc/
  11. .bazelrc
  12. .gitignore
  13. BUILD
  14. Cargo.Bazel.lock
  15. CODE_OF_CONDUCT
  16. CONTRIBUTING
  17. LICENSE
  18. README.md
  19. WORKSPACE
README.md

Crubit: C++/Rust Bidirectional Interop Tool

Build status

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.

Building Crubit

$ 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

Using a prebuilt LLVM tree

$ 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