1
0
mirror of https://github.com/bspeice/aeron-rs synced 2024-12-22 05:48:10 -05:00

Merge pull request #1 from bspeice/travis_windows

Windows support
This commit is contained in:
bspeice 2019-09-21 14:45:43 -04:00 committed by GitHub
commit 4bfc895869
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 27 additions and 3 deletions

View File

@ -18,7 +18,7 @@ script:
- cd aeron_driver-sys - cd aeron_driver-sys
- cargo test - cargo test
- cargo test --release - cargo test --release
- cargo test --features "static" #- cargo test --features "static"
- cd .. - cd ..
- cargo test - cargo test

View File

@ -46,12 +46,36 @@ pub fn main() {
link_type.link_lib(), link_type.link_lib(),
link_type.target_name() link_type.target_name()
); );
let lib_dir = Config::new(&aeron_path) let cmake_output = Config::new(&aeron_path)
.build_target(link_type.target_name()) .build_target(link_type.target_name())
.build(); .build();
// Trying to figure out the final path is a bit weird;
// For Linux/OSX, it's just build/lib
// For Windows, the .lib file is in build/lib/{profile}, but the DLL
// is shipped in build/binaries/{profile}
let base_lib_dir = cmake_output.join("build");
println!( println!(
"cargo:rustc-link-search=native={}", "cargo:rustc-link-search=native={}",
lib_dir.join("build/lib").display() base_lib_dir.join("lib").display()
);
// Because the `cmake_output` path is different for debug/release, we're not worried
// about accidentally linking in the wrong library
println!(
"cargo:rustc-link-search=native={}",
base_lib_dir.join("lib/Debug").display()
);
println!(
"cargo:rustc-link-search=native={}",
base_lib_dir.join("binaries/Debug").display()
);
println!(
"cargo:rustc-link-search=native={}",
base_lib_dir.join("lib/Release").display()
);
println!(
"cargo:rustc-link-search=native={}",
base_lib_dir.join("binaries/Release").display()
); );
println!("cargo:include={}", header_path.display()); println!("cargo:include={}", header_path.display());