fn main() {
println!("cargo::rustc-check-cfg=cfg(libcrun_stub)");
#[cfg(not(target_os = "linux"))]
{
println!("cargo:warning=libcrun is Linux-only, building stub module");
return;
}
#[cfg(target_os = "linux")]
linux_build();
}
#[cfg(target_os = "linux")]
fn linux_build() {
use std::env;
use std::path::PathBuf;
let libcrun = match pkg_config::Config::new()
.atleast_version("1.8")
.probe("libcrun")
{
Ok(lib) => lib,
Err(e) => {
println!("cargo:warning=pkg-config failed to find libcrun: {}", e);
println!("cargo:warning=Building with stub module (no libcrun functionality)");
println!("cargo:rustc-cfg=libcrun_stub");
return;
}
};
for lib in &libcrun.libs {
println!("cargo:rustc-link-lib={}", lib);
}
for path in &libcrun.link_paths {
println!("cargo:rustc-link-search=native={}", path.display());
}
let mut builder = bindgen::Builder::default()
.header("wrapper.h")
.parse_callbacks(Box::new(bindgen::CargoCallbacks::new()))
.allowlist_function("libcrun_.*")
.allowlist_function("crun_.*")
.allowlist_type("libcrun_.*")
.allowlist_type("crun_.*")
.allowlist_type("runtime_spec_schema_.*")
.allowlist_var("LIBCRUN_.*")
.generate_comments(true)
.derive_debug(true)
.derive_default(true)
.size_t_is_usize(true);
for path in &libcrun.include_paths {
builder = builder.clang_arg(format!("-I{}", path.display()));
}
let bindings = builder
.generate()
.expect("Unable to generate bindings for libcrun");
let out_path = PathBuf::from(env::var("OUT_DIR").unwrap());
bindings
.write_to_file(out_path.join("bindings.rs"))
.expect("Couldn't write bindings!");
println!("cargo:rerun-if-changed=wrapper.h");
println!("cargo:rerun-if-env-changed=PKG_CONFIG_PATH");
println!("cargo:rerun-if-env-changed=LIBRARY_PATH");
println!("cargo:rerun-if-env-changed=C_INCLUDE_PATH");
}