forked from andreytkachenko/onnxruntime-rs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
build.rs
90 lines (74 loc) · 2.65 KB
/
build.rs
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 bindgen::callbacks::{EnumVariantValue, ParseCallbacks};
use heck::CamelCase;
use std::env;
use std::path::PathBuf;
fn main() {
println!("cargo:rerun-if-env-changed=ONNXRUNTIME_LIB_DIR");
println!("cargo:rerun-if-env-changed=ONNXRUNTIME_INCLUDE_DIR");
if let Ok(dirs) = std::env::var("ONNXRUNTIME_LIB_DIR") {
for dir in dirs.split(':') {
println!("cargo:rustc-link-search={}", dir);
}
};
let mut clang_args = Vec::new();
if let Ok(dirs) = std::env::var("ONNXRUNTIME_INCLUDE_DIR") {
for dir in dirs.split(':') {
clang_args.push(format!("-I{}", dir));
}
};
println!("cargo:rustc-link-lib=onnxruntime");
let bindings = bindgen::Builder::default()
.header("cbits/ort.h")
.clang_args(clang_args)
.parse_callbacks(Box::new(bindgen::CargoCallbacks))
.whitelist_function("OrtGetApiBase")
.whitelist_function("OrtSessionOptionsAppendExecutionProvider_CPU")
.whitelist_function("OrtSessionOptionsAppendExecutionProvider_Tensorrt")
.whitelist_var("ORT_.*")
.whitelist_recursively(true)
.blacklist_type("__int64_t")
.blacklist_type("__uint32_t")
.rustified_non_exhaustive_enum("*")
.parse_callbacks(Box::new(CustomEnums))
.no_copy(".*")
.layout_tests(false)
.generate()
.expect("Unable to generate bindings");
let out_path = PathBuf::from(env::var("OUT_DIR").unwrap());
bindings
.write_to_file(out_path.join("bindings.rs"))
.expect("Couldn't write bindings!");
}
#[derive(Debug)]
struct CustomEnums;
impl ParseCallbacks for CustomEnums {
fn item_name(&self, name: &str) -> Option<String> {
if name.starts_with("Ort") {
return Some(name.replace("Ort", ""));
}
if name.starts_with("ONNX") {
return Some(name.replace("ONNX", "Onnx"));
}
None
}
fn enum_variant_name(
&self,
enum_name: Option<&str>,
variant_name: &str,
_variant_value: EnumVariantValue,
) -> Option<String> {
let mut variant_name = variant_name.to_camel_case();
if let Some(enum_name) = enum_name {
let enum_name = enum_name.replace("enum ", "").to_camel_case();
if variant_name.starts_with(&enum_name) {
variant_name = variant_name.replace(&enum_name, "");
}
}
if variant_name.starts_with("Ort") {
variant_name = variant_name.replace("Ort", "");
}
//Special case BFloat16
variant_name = variant_name.replace("Bfloat16", "BFloat16");
Some(variant_name)
}
}