// Bitcoin secp256k1 bindings // Written in 2015 by // Andrew Poelstra // // To the extent possible under law, the author(s) have dedicated all // copyright and related and neighboring rights to this software to // the public domain worldwide. This software is distributed without // any warranty. // // You should have received a copy of the CC0 Public Domain Dedication // along with this software. // If not, see . // //! # Build script // Coding conventions #![deny(non_upper_case_globals)] #![deny(non_camel_case_types)] #![deny(non_snake_case)] #![deny(unused_mut)] #![warn(missing_docs)] #[macro_use] extern crate cfg_if; extern crate cc; use std::env; use std::ffi::OsString; use std::path::PathBuf; cfg_if! { if #[cfg(target_os = "macos")] { const OS: &'static str = "darwin"; } else if #[cfg(target_os = "linux")] { const OS: &'static str = "linux"; } else if #[cfg(target_os = "windows")] { const OS: &'static str = "windows"; } else { // all other OS without android support const OS: &'static str = "unknown"; } } const ANDROID_INCLUDE: &'static str = "platforms/android-21/arch-arm64/usr/include"; fn android_aarch_compiler() -> String { "toolchains/aarch64-linux-android-4.9/prebuilt/".to_owned() + OS + "-x86_64/bin" } fn android_arm_compiler() -> String { "toolchains/arm-linux-androideabi-4.9/prebuilt/".to_owned() + OS + "-x86_64/bin" } fn android_i686_compiler() -> String { "toolchains/x86-4.9/prebuilt/".to_owned() + OS + "-x86_64/bin" } fn concat_paths(first: &str, second: &str) -> PathBuf { let mut path = PathBuf::from(first); path.push(second); path } fn setup_android(config: &mut cc::Build) { assert_ne!(OS, "unknown", "unsupported android toolchain"); let path = env::var_os("PATH").unwrap_or_else(OsString::new); let ndk_home = env::var("NDK_HOME").expect("NDK_HOME is not set"); let mut paths = env::split_paths(&path).collect::>(); paths.push(concat_paths(&ndk_home, &android_aarch_compiler())); paths.push(concat_paths(&ndk_home, &android_arm_compiler())); paths.push(concat_paths(&ndk_home, &android_i686_compiler())); let new_path = env::join_paths(paths).expect("all paths were created using PathBuf's; qed"); env::set_var("PATH", new_path); config.include(&concat_paths(&ndk_home, ANDROID_INCLUDE)); } fn main() { let mut base_config = cc::Build::new(); base_config.include("depend/secp256k1/") .include("depend/secp256k1/include") .include("depend/secp256k1/src"); let target = env::var("TARGET").expect("TARGET env variable is set by cargo; qed"); if target.contains("android") { setup_android(&mut base_config); } base_config.flag("-g") // TODO these three should be changed to use libgmp, at least until secp PR 290 is merged .define("USE_NUM_NONE", Some("1")) .define("USE_FIELD_INV_BUILTIN", Some("1")) .define("USE_SCALAR_INV_BUILTIN", Some("1")) // TODO these should use 64-bit variants on 64-bit systems .define("USE_FIELD_10X26", Some("1")) .define("USE_SCALAR_8X32", Some("1")) .define("USE_ENDOMORPHISM", Some("1")) // These all are OK. .define("ENABLE_MODULE_ECDH", Some("1")) .define("ENABLE_MODULE_SCHNORR", Some("1")) .define("ENABLE_MODULE_RECOVERY", Some("1")); // secp256k1 base_config.file("depend/secp256k1/contrib/lax_der_parsing.c") .file("depend/secp256k1/src/ext.c") .compile("libsecp256k1.a"); }