use std::path::PathBuf;
fn compile_raylib(raylib_path: &str) {
let mut cmake_config = cmake::Config::new(raylib_path);
let mut cmake_config = cmake_config
.define("BUILD_EXAMPLES", "OFF")
.define("CMAKE_BUILD_TYPE", "Release");
#[cfg(debug_assertions)]
{
cmake_config = cmake_config.profile("Debug");
}
#[cfg(not(debug_assertions))]
{
cmake_config = cmake_config.profile("Release");
}
let destination = cmake_config.build();
println!("cargo:rustc-link-search=native={}", destination.join("lib").display());
println!("cargo:rustc-link-search=native={}", destination.join("lib32").display());
println!("cargo:rustc-link-search=native={}", destination.join("lib64").display());
}
fn link_libs() {
if cfg!(windows) {
println!("cargo:rustc-link-lib=dylib=winmm");
println!("cargo:rustc-link-lib=dylib=gdi32");
println!("cargo:rustc-link-lib=dylib=user32");
println!("cargo:rustc-link-lib=dylib=shell32");
}
else if cfg!(target_os = "macos") {
println!("cargo:rustc-link-search=native=/usr/local/lib");
println!("cargo:rustc-link-lib=framework=OpenGL");
println!("cargo:rustc-link-lib=framework=Cocoa");
println!("cargo:rustc-link-lib=framework=IOKit");
println!("cargo:rustc-link-lib=framework=CoreFoundation");
println!("cargo:rustc-link-lib=framework=CoreVideo");
}
else if cfg!(unix) {
println!("cargo:rustc-link-search=/usr/local/lib");
println!("cargo:rustc-link-lib=X11");
}
else {
panic!("Unsupported platform");
}
println!("cargo:rustc-link-lib=static=raylib");
}
fn generate_bindings(header_file: &str) {
let bindings = bindgen::Builder::default()
.header(header_file)
.parse_callbacks(Box::new(bindgen::CargoCallbacks))
.generate()
.expect("Unable to generate bindings");
let out_path = PathBuf::from(std::env::var("OUT_DIR").unwrap());
bindings
.write_to_file(out_path.join("bindings.rs"))
.expect("Couldn't write bindings!");
}
pub fn main() {
println!("cargo:rerun-if-changed=src/wrapper.h");
compile_raylib("third_party/raylib");
link_libs();
generate_bindings("src/wrapper.h");
}