From 46c5150db4b9ba3f644247470fa4b7b307320fc2 Mon Sep 17 00:00:00 2001 From: Alex Gaynor Date: Sun, 26 Nov 2023 17:44:15 -0500 Subject: [PATCH] update bindgen and no longer rely on `-include` also make path seperator windows friendly fixes #2087 fixes #2086 closes #2089 --- openssl-sys/Cargo.toml | 2 +- openssl-sys/build/run_bindgen.rs | 36 +++++++++++++------------------- 2 files changed, 15 insertions(+), 23 deletions(-) diff --git a/openssl-sys/Cargo.toml b/openssl-sys/Cargo.toml index 95d920adb6..5ae1dfc7b8 100644 --- a/openssl-sys/Cargo.toml +++ b/openssl-sys/Cargo.toml @@ -23,7 +23,7 @@ libc = "0.2" bssl-sys = { version = "0.1.0", optional = true } [build-dependencies] -bindgen = { version = "0.64.0", optional = true, features = ["experimental"] } +bindgen = { version = "0.65.0", optional = true, features = ["experimental"] } cc = "1.0.61" openssl-src = { version = "300.1.2", optional = true, features = ["legacy"] } pkg-config = "0.3.9" diff --git a/openssl-sys/build/run_bindgen.rs b/openssl-sys/build/run_bindgen.rs index 1eeaad225d..5e62237f35 100644 --- a/openssl-sys/build/run_bindgen.rs +++ b/openssl-sys/build/run_bindgen.rs @@ -111,6 +111,12 @@ pub fn run(include_dirs: &[PathBuf]) { #[cfg(feature = "bindgen")] pub fn run_boringssl(include_dirs: &[PathBuf]) { let out_dir = PathBuf::from(env::var_os("OUT_DIR").unwrap()); + + fs::File::create(out_dir.join("boring_static_wrapper.h")) + .expect("Failed to create boring_static_wrapper.h") + .write_all(INCLUDES.as_bytes()) + .expect("Failed to write contents to boring_static_wrapper.h"); + let mut builder = bindgen::builder() .rust_target(RustTarget::Stable_1_47) .ctypes_prefix("::libc") @@ -119,14 +125,19 @@ pub fn run_boringssl(include_dirs: &[PathBuf]) { .enable_function_attribute_detection() .default_macro_constant_type(MacroTypeVariation::Signed) .rustified_enum("point_conversion_form_t") - .allowlist_file(".*/openssl/[^/]+\\.h") + .allowlist_file(".*[/\\\\]openssl/[^/]+\\.h") .allowlist_recursively(false) .blocklist_function("BIO_vsnprintf") .blocklist_function("OPENSSL_vasprintf") .wrap_static_fns(true) .wrap_static_fns_path(out_dir.join("boring_static_wrapper").display().to_string()) .layout_tests(false) - .header_contents("includes.h", INCLUDES); + .header( + out_dir + .join("boring_static_wrapper.h") + .display() + .to_string(), + ); for include_dir in include_dirs { builder = builder @@ -140,21 +151,9 @@ pub fn run_boringssl(include_dirs: &[PathBuf]) { .write_to_file(out_dir.join("bindgen.rs")) .unwrap(); - fs::File::create(out_dir.join("boring_static_wrapper.h")) - .expect("Failed to create boring_static_wrapper.h") - .write_all(INCLUDES.as_bytes()) - .expect("Failed to write contents to boring_static_wrapper.h"); - cc::Build::new() .file(out_dir.join("boring_static_wrapper.c")) .includes(include_dirs) - .flag("-include") - .flag( - &out_dir - .join("boring_static_wrapper.h") - .display() - .to_string(), - ) .compile("boring_static_wrapper"); } @@ -180,7 +179,7 @@ pub fn run_boringssl(include_dirs: &[PathBuf]) { .arg("--enable-function-attribute-detection") .arg("--default-macro-constant-type=signed") .arg("--rustified-enum=point_conversion_form_t") - .arg("--allowlist-file=.*/openssl/[^/]+\\.h") + .arg("--allowlist-file=.*[/\\\\]openssl/[^/]+\\.h") .arg("--no-recursive-allowlist") .arg("--blocklist-function=BIO_vsnprintf") .arg("--blocklist-function=OPENSSL_vasprintf") @@ -203,13 +202,6 @@ pub fn run_boringssl(include_dirs: &[PathBuf]) { cc::Build::new() .file(out_dir.join("boring_static_wrapper.c")) .includes(include_dirs) - .flag("-include") - .flag( - &out_dir - .join("boring_static_wrapper.h") - .display() - .to_string(), - ) .compile("boring_static_wrapper"); }