2021-02-28 12:23:30 -08:00
|
|
|
|
|
|
|
extern crate bindgen;
|
|
|
|
|
|
|
|
use std::env;
|
|
|
|
use std::path::PathBuf;
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
// Tell cargo to invalidate the built crate whenever the wrapper changes
|
|
|
|
println!("cargo:rerun-if-changed=radio.h");
|
|
|
|
|
|
|
|
// The bindgen::Builder is the main entry point
|
|
|
|
// to bindgen, and lets you build up options for
|
|
|
|
// the resulting bindings.
|
|
|
|
let bindings = bindgen::Builder::default()
|
|
|
|
// The input header we would like to generate
|
|
|
|
// bindings for.
|
|
|
|
.header("radio.h")
|
|
|
|
// Tell cargo to invalidate the built crate whenever any of the
|
|
|
|
// included header files changed.
|
|
|
|
.parse_callbacks(Box::new(bindgen::CargoCallbacks))
|
|
|
|
.whitelist_type("radio_device_t")
|
2021-03-01 02:29:53 -08:00
|
|
|
.whitelist_var("radio_md380")
|
|
|
|
.whitelist_var("radio_md390")
|
|
|
|
.whitelist_var("radio_md201")
|
|
|
|
.whitelist_var("radio_uv380")
|
|
|
|
.whitelist_var("radio_uv390")
|
|
|
|
.whitelist_var("radio_md960")
|
|
|
|
.whitelist_var("radio_d900;")
|
|
|
|
.whitelist_var("radio_dp8")
|
|
|
|
.whitelist_var("radio_rt27d")
|
|
|
|
.whitelist_var("radio_rd5")
|
|
|
|
.whitelist_var("radio_gd77;")
|
|
|
|
.whitelist_var("radio_dm180")
|
|
|
|
.whitelist_var("radio_d868u")
|
|
|
|
.whitelist_var("radio_d878u")
|
|
|
|
.whitelist_var("radio_dmr6x")
|
|
|
|
.whitelist_var("radio_rt84")
|
2021-03-01 01:52:37 -08:00
|
|
|
.blacklist_type("FILE")
|
2021-02-28 12:23:30 -08:00
|
|
|
// Finish the builder and generate the bindings.
|
|
|
|
.generate()
|
|
|
|
// Unwrap the Result and panic on failure.
|
|
|
|
.expect("Unable to generate bindings for radio.h");
|
|
|
|
|
|
|
|
// Write the bindings to the $OUT_DIR/bindings.rs file.
|
|
|
|
let out_path = PathBuf::from(env::var("OUT_DIR").unwrap());
|
|
|
|
bindings
|
|
|
|
.write_to_file(out_path.join("bindings.rs"))
|
|
|
|
.expect("Couldn't write bindings!");
|
|
|
|
}
|