use std::path::PathBuf;
use crate::wrap::enums::get_blocked_enum_names;
pub 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");
if cfg!(feature = "dylib") {
cmake_config.define("BUILD_SHARED_LIBS", "ON");
}
#[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()
);
}
pub 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");
}
if cfg!(feature = "dylib") {
println!("cargo:rustc-link-lib=dylib=raylib");
}
else {
println!("cargo:rustc-link-lib=static=raylib");
}
}
pub fn generate_bindings(header_file: &str) {
let mut builder = bindgen::Builder::default()
.header(header_file)
.parse_callbacks(Box::new(bindgen::CargoCallbacks::new()))
.blocklist_item("DEG2RAD")
.blocklist_item("PI")
.blocklist_item("RAD2DEG")
.blocklist_item("__GNUC_VA_LIST")
.blocklist_item("__bool_true_false_are_defined")
.blocklist_item("false_")
.blocklist_item("true_");
for enum_name in get_blocked_enum_names() {
builder = builder.blocklist_type(format!("{}.*", enum_name));
}
let bindings = builder.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!");
}