Browse Source

Set default gcc/ar based on target when compiling android target.

add-rc-path
Glenn Watson 10 years ago
parent
commit
6cc06ee959
  1. 20
      src/lib.rs

20
src/lib.rs

@ -51,7 +51,7 @@ pub fn compile_library(output: &str, config: &Config, files: &[&str]) {
let target = getenv("TARGET").unwrap(); let target = getenv("TARGET").unwrap();
let opt_level = getenv("OPT_LEVEL").unwrap(); let opt_level = getenv("OPT_LEVEL").unwrap();
let mut cmd = Command::new(gcc()); let mut cmd = Command::new(gcc(target.as_slice()));
cmd.arg(format!("-O{}", opt_level)); cmd.arg(format!("-O{}", opt_level));
cmd.arg("-c"); cmd.arg("-c");
cmd.arg("-ffunction-sections").arg("-fdata-sections"); cmd.arg("-ffunction-sections").arg("-fdata-sections");
@ -94,7 +94,7 @@ pub fn compile_library(output: &str, config: &Config, files: &[&str]) {
} }
run(Command::new(ar()).arg("crus") run(Command::new(ar(target.as_slice())).arg("crus")
.arg(dst.join(output)) .arg(dst.join(output))
.args(objects.as_slice()) .args(objects.as_slice())
.args(config.objects.as_slice())); .args(config.objects.as_slice()));
@ -135,16 +135,26 @@ fn get_var(var_base: &str) -> Result<String, String> {
} }
} }
fn gcc() -> String { fn gcc(target: &str) -> String {
let is_android = target.find_str("android").is_some();
get_var("CC").unwrap_or(if cfg!(windows) { get_var("CC").unwrap_or(if cfg!(windows) {
"gcc".to_string() "gcc".to_string()
} else if is_android {
format!("{}-gcc", target)
} else { } else {
"cc".to_string() "cc".to_string()
}) })
} }
fn ar() -> String { fn ar(target: &str) -> String {
get_var("AR").unwrap_or("ar".to_string()) let is_android = target.find_str("android").is_some();
get_var("AR").unwrap_or(if is_android {
format!("{}-ar", target)
} else {
"ar".to_string()
})
} }
fn cflags() -> Vec<String> { fn cflags() -> Vec<String> {

Loading…
Cancel
Save