summaryrefslogtreecommitdiff
path: root/bindgen/rust/celeritas-sys/build.rs
blob: f0a1d36a899e8d51b6e8783139fd610814d02500 (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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
use std::env;
use std::path::PathBuf;

use bindgen::callbacks::ParseCallbacks;

const SERIALIZABLE_TYPES: &[&str] = &[
    "Vec2",
    "Vec3",
    "Vec4",
    "Mat4",
    "Quat",
    "Transform",
    "Bbox_3D",
    "OBB",
    "DirectionalLight",
    "PointLight",
];
const EQ_TYPES: &[&str] = &[
    "BufferHandle",
    "TextureHandle",
    "MeshHandle",
    "MaterialHandle",
    "ModelHandle",
];
const DEFAULT_TYPES: &[&str] = &["ShaderDataLayout"];

#[derive(Debug)]
struct AdditionalDerives;
impl ParseCallbacks for AdditionalDerives {
    fn add_derives(&self, info: &bindgen::callbacks::DeriveInfo<'_>) -> Vec<String> {
        let mut derives = vec![];
        if SERIALIZABLE_TYPES.contains(&info.name) {
            derives.extend_from_slice(&["Serialize".to_string(), "Deserialize".to_string()]);
        }
        if EQ_TYPES.contains(&info.name) {
            derives.extend_from_slice(&["PartialEq".to_string()]);
        }
        if DEFAULT_TYPES.contains(&info.name) {
            derives.push("Default".to_string());
        }
        derives
    }
}

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/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.
        .rustified_enum("GPU_TextureType")
        .rustified_enum("GPU_TextureFormat")
        .parse_callbacks(Box::new(bindgen::CargoCallbacks::new()))
        .parse_callbacks(Box::new(AdditionalDerives))
        // 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!");
}