Add bindgen.sh for genrule modules

* bindgen required environment variables are set in bindgen.sh,
  which also adds dependencies of those tool paths into the
  output dependent file.

Bug: 157666974
Bug: 152884384
Test: make
Change-Id: I4164492466b9c0e1e7297307470ac985a63382e6
2 files changed
tree: 2adea7775c05a0ee2ee40ed1d52fe8a1479509e9
  1. android/
  2. csmith-fuzzing/
  3. out/
  4. src/
  5. .cargo_vcs_info.json
  6. Android.bp
  7. build.rs
  8. Cargo.lock
  9. Cargo.toml
  10. Cargo.toml.orig
  11. LICENSE
  12. METADATA
  13. MODULE_LICENSE_BSD_LIKE
  14. OWNERS
  15. README.md
README.md

crates.io docs.rs

bindgen

bindgen automatically generates Rust FFI bindings to C (and some C++) libraries.

For example, given the C header doggo.h:

typedef struct Doggo {
    int many;
    char wow;
} Doggo;

void eleven_out_of_ten_majestic_af(Doggo* pupper);

bindgen produces Rust FFI code allowing you to call into the doggo library's functions and use its types:

/* automatically generated by rust-bindgen */

#[repr(C)]
pub struct Doggo {
    pub many: ::std::os::raw::c_int,
    pub wow: ::std::os::raw::c_char,
}

extern "C" {
    pub fn eleven_out_of_ten_majestic_af(pupper: *mut Doggo);
}

Users Guide

📚 Read the bindgen users guide here! 📚

MSRV

The minimum supported Rust version is 1.34.

No MSRV bump policy has been established yet, so MSRV may increase in any release.

API Reference

API reference documentation is on docs.rs

Contributing

See CONTRIBUTING.md for hacking on bindgen!