blob: 924a98cace12ab99b117ff5a9cf33abfdfa95f31 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
|
use std::env;
use std::path::PathBuf;
use bindgen::callbacks::ParseCallbacks;
const SERIALIZABLE_TYPES: &[&'static str] = &[
"Vec2",
"Vec3",
"Vec4",
"Mat4",
"Quat",
"Transform",
"DirectionalLight",
"PointLight",
];
#[derive(Debug)]
struct DeriveSerialize;
impl ParseCallbacks for DeriveSerialize {
fn add_derives(&self, info: &bindgen::callbacks::DeriveInfo<'_>) -> Vec<String> {
if SERIALIZABLE_TYPES.contains(&info.name) {
vec!["Serialize".to_string(), "Deserialize".to_string()]
} else {
vec![]
}
}
}
fn main() {
/* */
// Tell cargo to look for shared libraries in the specified directory
// TODO: we need to look based on OS
// println!("cargo:rustc-link-search=../../build/windows/x64/debug");
let static_lib_path =
"/Users/josh/code/CodenameVentus/deps/celeritas-core/build/macosx/arm64/debug".to_string();
// let static_lib_path = std::env::var("CELERITAS_CORE_LIB")
// .unwrap_or("../../../build/macosx/arm64/debug".to_string());
println!("cargo:rustc-link-search={static_lib_path}");
// Tell cargo to tell rustc to link the system bzip2
// shared library.
println!("cargo:rustc-link-lib=core_static");
println!("cargo:rustc-link-lib=glfw3");
// TODO: ^ use our locally compiled glfw
// The bindgen::Builder is the main entry point
// to bindgen, and lets you build up options for
// the resulting bindings.
let bindings = bindgen::Builder::default()
// The input header we would like to generate
// bindings for.
.header("../../../include/amalgamation.h")
// -- our code
.clang_arg("-I../../../src")
.clang_arg("-I../../../src/core")
.clang_arg("-I../../../src/maths")
.clang_arg("-I../../../src/new_render")
.clang_arg("-I../../../src/platform")
.clang_arg("-I../../../src/ral")
.clang_arg("-I../../../src/ral/backends/opengl")
.clang_arg("-I../../../src/resources")
.clang_arg("-I../../../src/std")
.clang_arg("-I../../../src/std/containers")
.clang_arg("-I../../../src/systems")
// -- dependencies
.clang_arg("-I../../../deps/cgltf")
.clang_arg("-I../../../deps/glfw-3.3.8/include/GLFW")
.clang_arg("-I../../../deps/glad/include")
.clang_arg("-I../../../deps/stb_image")
.clang_arg("-I../../../deps/stb_image_write")
.clang_arg("-I../../../deps/stb_truetype")
.generate_inline_functions(true)
// Tell cargo to invalidate the built crate whenever any of the
// included header files changed.
.parse_callbacks(Box::new(bindgen::CargoCallbacks::new()))
.parse_callbacks(Box::new(DeriveSerialize))
// Finish the builder and generate the bindings.
.generate()
// Unwrap the Result and panic on failure.
.expect("Unable to generate bindings");
// Write the bindings to the $OUT_DIR/bindings.rs file.
let out_path = PathBuf::from(env::var("OUT_DIR").unwrap());
bindings
.write_to_file(out_path.join("bindings.rs"))
.expect("Couldn't write bindings!");
}
|