summaryrefslogtreecommitdiff
path: root/libssh2-sys/build.rs
diff options
context:
space:
mode:
Diffstat (limited to 'libssh2-sys/build.rs')
-rw-r--r--libssh2-sys/build.rs21
1 files changed, 20 insertions, 1 deletions
diff --git a/libssh2-sys/build.rs b/libssh2-sys/build.rs
index 1af465d..26938c3 100644
--- a/libssh2-sys/build.rs
+++ b/libssh2-sys/build.rs
@@ -4,9 +4,12 @@ extern crate cmake;
use std::env;
use std::fs::File;
use std::io::prelude::*;
-use std::path::PathBuf;
+use std::path::{PathBuf, Path};
fn main() {
+ register_dep("Z");
+ register_dep("OPENSSL");
+
if let Ok(lib) = pkg_config::find_library("libssh2") {
for path in &lib.include_paths {
println!("cargo:include={}", path.display());
@@ -85,3 +88,19 @@ fn main() {
println!("cargo:rustc-link-search=native={}/lib", dst.display());
println!("cargo:include={}/include", dst.display());
}
+
+fn register_dep(dep: &str) {
+ match env::var(&format!("DEP_{}_ROOT", dep)) {
+ Ok(s) => {
+ prepend("PKG_CONFIG_PATH", Path::new(&s).join("lib/pkgconfig"));
+ }
+ Err(..) => {}
+ }
+}
+
+fn prepend(var: &str, val: PathBuf) {
+ let prefix = env::var(var).unwrap_or(String::new());
+ let mut v = vec![val];
+ v.extend(env::split_paths(&prefix));
+ env::set_var(var, &env::join_paths(v).unwrap());
+}