use std::env; use std::fs; use std::path::Path; fn main() { println!("cargo:rerun-if-changed=build.rs"); if env::var("CARGO_FEATURE_CUDA").is_ok() { println!("cargo:rustc-cfg=cuda"); let perf_libs_dir = { let manifest_dir = env::var("CARGO_MANIFEST_DIR").unwrap(); let mut path = Path::new(&manifest_dir); path = path.parent().unwrap(); path.join(Path::new("target/perf-libs")) }; let perf_libs_dir = perf_libs_dir.to_str().unwrap(); // Ensure `perf_libs_dir` exists. It's been observed that // a cargo:rerun-if-changed= directive with a non-existent // directory triggers a rebuild on every |cargo build| invocation fs::create_dir_all(&perf_libs_dir).unwrap_or_else(|err| { if err.kind() != std::io::ErrorKind::AlreadyExists { panic!("Unable to create {}: {:?}", perf_libs_dir, err); } }); println!("cargo:rerun-if-changed={}", perf_libs_dir); println!("cargo:rustc-link-search=native={}", perf_libs_dir); println!("cargo:rerun-if-changed={}/libcuda-crypt.a", perf_libs_dir); println!("cargo:rustc-link-lib=static=cuda-crypt"); let cuda_home = match env::var("CUDA_HOME") { Ok(cuda_home) => cuda_home, Err(_) => String::from("/usr/local/cuda"), }; println!("cargo:rustc-link-search=native={}/lib64", cuda_home); println!("cargo:rustc-link-lib=dylib=cudart"); println!("cargo:rustc-link-lib=dylib=cuda"); println!("cargo:rustc-link-lib=dylib=cudadevrt"); } }