const fn target_arch() -> Option<&'static str> {
#[cfg(not(target_os="windows"))]
{ None }
#[cfg(target_os="windows")] {
#[cfg(target_arch="x86")] {Some("x86")}
#[cfg(target_arch="x86_64")] {Some("x64")}
#[cfg(target_arch="aarch64")] {Some("arm64")}
#[cfg(target_arch="arm")] {Some("arm")}
}
}
#[cfg(feature = "bindgen")]
fn gen_bindings() {
let bindings = bindgen::Builder::default()
.header("wrapper.h")
.parse_callbacks(Box::new(bindgen::CargoCallbacks));
let bindings = [
"PrjMarkDirectoryAsPlaceholder",
"PrjStartVirtualizing",
"PrjStopVirtualizing",
"PrjFillDirEntryBuffer",
"PrjFileNameMatch",
"PrjWritePlaceholderInfo",
"PrjWriteFileData",
"PrjAllocateAlignedBuffer",
"PrjFreeAlignedBuffer",
].iter().fold(bindings, |b, s| b.whitelist_function(s));
let bindings = bindings
.whitelist_type("IO_ERROR")
.generate()
.expect("Unable to generate bindings");
let out_path = std::path::PathBuf::from(std::env::var("OUT_DIR").unwrap());
bindings
.write_to_file(out_path.join("bindings.rs"))
.expect("Couldn't write bindings!");
}
#[cfg(not(feature = "bindgen"))]
fn gen_bindings() { }
fn main() {
println!("cargo:rustc-link-lib=ProjectedFSLib");
if let Some(arch) = target_arch() {
let manifest_dir = std::env::var("CARGO_MANIFEST_DIR").unwrap();
println!("cargo:rustc-link-search={}/lib/{}", manifest_dir, arch);
}
println!("cargo:rerun-if-changed=wrapper.h");
println!("cargo:rerun-if-changed=projectedfslib.h");
gen_bindings()
}