1
raylib-ffi/build/bind.rs

111 lines
3.3 KiB
Rust

use std::path::PathBuf;
use crate::wrap::enums::get_blocked_enum_names;
/// Compiles raylib
pub fn compile_raylib(raylib_path: &str) {
// Construct a config for running cmake
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");
}
// Set the correct build profile
#[cfg(debug_assertions)]
{
cmake_config = cmake_config.profile("Debug");
}
#[cfg(not(debug_assertions))]
{
cmake_config = cmake_config.profile("Release");
}
// Build the cmake project
let destination = cmake_config.build();
// Tell cargo where the libraries might be
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()
);
}
/// Links libraries
pub fn link_libs() {
// Handle windows 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");
}
// Handle MacOS
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");
}
// Handle UNIX
else if cfg!(unix) {
println!("cargo:rustc-link-search=/usr/local/lib");
println!("cargo:rustc-link-lib=X11");
}
// Fail on other platforms
else {
panic!("Unsupported platform");
}
// Link raylib itself
if cfg!(feature = "dylib") {
println!("cargo:rustc-link-lib=dylib=raylib");
}
else {
println!("cargo:rustc-link-lib=static=raylib");
}
}
/// Generates `bindings.rs` file
pub fn generate_bindings(header_file: &str) {
// Construct a builder for generating bindings
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_");
// Deny all blocked enums
for enum_name in get_blocked_enum_names() {
builder = builder.blocklist_type(format!("{}.*", enum_name));
}
// Generate the bindings
let bindings = builder.generate().expect("Unable to generate bindings");
// Write `src/bindings.rs`
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!");
}