summaryrefslogtreecommitdiff
path: root/hidapi-sys/build.rs
diff options
context:
space:
mode:
authorDaniel Mueller <deso@posteo.net>2018-01-15 09:36:38 -0800
committerDaniel Mueller <deso@posteo.net>2018-01-15 09:36:38 -0800
commitf3149d7f2802711791c490b71313aafc55f4809c (patch)
treecd0247b0d856be8b9e010738646965233aa60c93 /hidapi-sys/build.rs
parentd8a58488bd56ef9c09e167173124c3519bc7405d (diff)
downloadnitrocli-f3149d7f2802711791c490b71313aafc55f4809c.tar.gz
nitrocli-f3149d7f2802711791c490b71313aafc55f4809c.tar.bz2
Update hidapi-sys crate to 0.1.4
This change updates the hidapi-sys crate to version 0.1.4. In this version the cc crate (the stable and renamed version of the gcc crate) is used. Import subrepo hidapi-sys/:hidapi-sys at c01043da72c0cac898660017e4c4115278c14369 Import subrepo cc/:cc at 500c65b03775cecf55bd358e616963bc3222acca
Diffstat (limited to 'hidapi-sys/build.rs')
-rw-r--r--hidapi-sys/build.rs48
1 files changed, 30 insertions, 18 deletions
diff --git a/hidapi-sys/build.rs b/hidapi-sys/build.rs
index d910944..4a392c6 100644
--- a/hidapi-sys/build.rs
+++ b/hidapi-sys/build.rs
@@ -1,4 +1,4 @@
-extern crate gcc;
+extern crate cc;
extern crate pkg_config;
use std::env;
@@ -11,8 +11,8 @@ fn main() {
return;
}
- fetch().unwrap();
- build().unwrap();
+ fetch().expect("failed to checkout hidapi sources, internet connection and git are needed");
+ build().expect("failed to build hidapi sources");
println!("cargo:rustc-link-search=native={}", output().to_string_lossy());
}
@@ -22,10 +22,19 @@ fn output() -> PathBuf {
}
fn source() -> PathBuf {
- output().join("hidapi")
+ if let Ok(path) = env::var("HIDAPI_PATH") {
+ path.into()
+ }
+ else {
+ output().join("hidapi")
+ }
}
fn fetch() -> io::Result<()> {
+ if env::var("HIDAPI_PATH").is_ok() {
+ return Ok(());
+ }
+
Command::new("git")
.current_dir(&output())
.arg("clone")
@@ -38,44 +47,47 @@ fn fetch() -> io::Result<()> {
#[cfg(target_os = "linux")]
fn build() -> io::Result<()> {
- let mut config = gcc::Build::new();
+ let mut build = cc::Build::new();
- config.file(source().join("libusb/hid.c"));
- config.include(source().join("hidapi"));
+ build.file(source().join("libusb/hid.c"));
+ build.include(source().join("hidapi"));
+ build.static_flag(true);
for path in pkg_config::find_library("libusb-1.0").unwrap().include_paths {
- config.include(path.to_str().unwrap());
+ build.include(path.to_str().unwrap());
}
- config.compile("libhidapi-libusb.a");
+ build.compile("libhidapi-libusb.a");
Ok(())
}
#[cfg(target_os = "macos")]
fn build() -> io::Result<()> {
- let mut config = gcc::Build::new();
+ let mut build = cc::Build::new();
- config.file(source().join("libusb/hid.c"));
- config.include(source().join("hidapi"));
+ build.file(source().join("libusb/hid.c"));
+ build.include(source().join("hidapi"));
+ build.static_flag(true);
for path in pkg_config::find_library("libusb-1.0").unwrap().include_paths {
- config.include(path.to_str().unwrap());
+ build.include(path.to_str().unwrap());
}
- config.compile("libhidapi.a");
+ build.compile("libhidapi.a");
Ok(())
}
#[cfg(target_os = "windows")]
fn build() -> io::Result<()> {
- let mut config = gcc::Build::new();
+ let mut build = cc::Build::new();
- config.file(source().join("windows/hid.c"));
- config.include(source().join("hidapi"));
+ build.file(source().join("windows/hid.c"));
+ build.include(source().join("hidapi"));
+ build.static_flag(true);
- config.compile("libhidapi.a");
+ build.compile("libhidapi.a");
Ok(())
}