extern crate cc;
extern crate bindgen;
use std::path::PathBuf;
macro_rules! pathbufstr {
($pb:expr, $s:expr) => { format!("{}", $pb.to_str().expect($s)) };
}
fn main() {
if std::env::var("DOCS_RS").is_ok() { return; }
let s_path: String = if cfg!(docsrs) {
std::env::var("OUT_DIR").unwrap()
}else{
".".to_string()
}; let o_path: &str = s_path.as_str();
let c_opt = if o_path == "." { "-std:c11" }else{ "-std=c++11" };
let mut dxsdk_include = ".".to_string();
let mut dxsdk_lib = ".".to_string();
if o_path == "." {
let dxsdk_dir = PathBuf::from(std::env::var("DXSDK_DIR").expect("dxskd"));
dxsdk_include = pathbufstr!(dxsdk_dir.join("Include"), "Include");
dxsdk_lib = pathbufstr!(dxsdk_dir.join("Lib").join("x64"), "Lib");
}
let mk_cc = |dname: &str, sname: &str, iname: &str, oname: &str| {
let sd = PathBuf::from(dname);
let fname = pathbufstr!(sd.join(sname), "invalid path");
println!("cargo:rerun-if-changed={}", fname);
cc::Build::new()
.file(fname)
.flag(c_opt)
.include(iname)
.include(dxsdk_include) .compile(oname)
};
if o_path == "." {
mk_cc("./ext/bridge", "bridge.cpp", "./include", "bridge");
}
let mk_bindings = |hdd: &str, header: &str, rsd: &str, rsfile: &str,
binl: bool, bcmt: bool| { let hd = PathBuf::from(hdd);
let hf = pathbufstr!(hd.join(header), "invalid path");
println!("cargo:rerun-if-changed={}", hf);
let bindings = bindgen::Builder::default()
.header(hf)
.generate_inline_functions(binl) .generate_comments(bcmt) .parse_callbacks(Box::new(bindgen::CargoCallbacks::new())) .generate()
.expect("Unable to generate bindings");
let rs = PathBuf::from(rsd);
bindings
.write_to_file(rs.join(rsfile))
.expect("Could not write bindings!");
};
if o_path == "." {
mk_bindings("./include", "bridge.hpp", "./include", "bridge_bindings.rs",
false, true); }
println!("cargo:rustc-link-search={}", dxsdk_lib);
println!("cargo:rustc-link-lib=d3d9");
println!("cargo:rustc-link-lib=d3dx9");
}