From 3febc1b6a76f0f17fcdc70836c1d48051565b3e9 Mon Sep 17 00:00:00 2001 From: ko1N Date: Sun, 18 Dec 2022 23:14:56 +0100 Subject: [PATCH] Split up pre-generated header into linux and windows version and fixed bindgen feature flag --- leechcore-sys/build.rs | 16 ++++++++++------ .../src/{leechcore.rs => leechcore_linux.rs} | 0 memflow-pcileech/src/lib.rs | 2 +- 3 files changed, 11 insertions(+), 7 deletions(-) rename leechcore-sys/src/{leechcore.rs => leechcore_linux.rs} (100%) diff --git a/leechcore-sys/build.rs b/leechcore-sys/build.rs index a3cea07..83e8ce9 100644 --- a/leechcore-sys/build.rs +++ b/leechcore-sys/build.rs @@ -4,9 +4,9 @@ extern crate pkg_config; #[cfg(bindgen)] extern crate bindgen; +use std::env; use std::path::{Path, PathBuf}; use std::process::Command; -use std::{env, fs}; #[cfg(target_os = "windows")] fn os_define() -> &'static str { @@ -68,7 +68,7 @@ fn build_leechcore(target: &str) { .unwrap_or_else(|err| panic!("Failed to find libusb-1.0 via pkg-config: {:?}", err)); let libusb_flags = Command::new("pkg-config") - .args(&["libusb-1.0", "--libs", "--cflags"]) + .args(["libusb-1.0", "--libs", "--cflags"]) .output() .unwrap_or_else(|err| panic!("Failed to find libusb-1.0 via pkg-config: {:?}", err)); @@ -101,7 +101,7 @@ fn build_leechcore(target: &str) { println!("cargo:rustc-link-lib=static=leechcore"); } -#[cfg(bindgen)] +#[cfg(feature = "bindgen")] fn gen_leechcore>(target: &str, out_dir: P) { let mut builder = bindgen::builder() .clang_arg(format!("-D{} -D_GNU_SOURCE", os_define())) @@ -123,14 +123,18 @@ fn gen_leechcore>(target: &str, out_dir: P) { .unwrap_or_else(|_| panic!("Failed to write {}", bindings_path.display())); } -#[cfg(not(bindgen))] +#[cfg(not(feature = "bindgen"))] fn gen_leechcore>(_target: &str, out_dir: P) { let manifest_dir = PathBuf::from(env::var("CARGO_MANIFEST_DIR").unwrap()); - let bindings_src_path = manifest_dir.join("src").join("leechcore.rs"); + #[cfg(target_os = "windows")] + let bindings_src_path = manifest_dir.join("src").join("leechcore_windows.rs"); + #[cfg(target_os = "linux")] + let bindings_src_path = manifest_dir.join("src").join("leechcore_linux.rs"); + let bindings_dst_path = out_dir.as_ref().to_path_buf().join("leechcore.rs"); - fs::copy(bindings_src_path, bindings_dst_path) + std::fs::copy(bindings_src_path, bindings_dst_path) .expect("Failed to copy leechcore.rs bindings to OUT_DIR"); } diff --git a/leechcore-sys/src/leechcore.rs b/leechcore-sys/src/leechcore_linux.rs similarity index 100% rename from leechcore-sys/src/leechcore.rs rename to leechcore-sys/src/leechcore_linux.rs diff --git a/memflow-pcileech/src/lib.rs b/memflow-pcileech/src/lib.rs index f8d1eb6..0788fca 100644 --- a/memflow-pcileech/src/lib.rs +++ b/memflow-pcileech/src/lib.rs @@ -96,7 +96,7 @@ impl PciLeech { // TODO: handle version error // TODO: handle special case of fUserInputRequest return Err(Error(ErrorOrigin::Connector, ErrorKind::Configuration) - .log_error(&format!("unable to create leechcore context: {:?}", err))); + .log_error(format!("unable to create leechcore context: {:?}", err))); } // TODO: allow handling these errors properly