|
@ -10,6 +10,8 @@ pub struct Config { |
|
|
pub definitions: Vec<(String, Option<String>)>, |
|
|
pub definitions: Vec<(String, Option<String>)>, |
|
|
/// Additional object files to link into the final archive
|
|
|
/// Additional object files to link into the final archive
|
|
|
pub objects: Vec<Path>, |
|
|
pub objects: Vec<Path>, |
|
|
|
|
|
/// Additional flags and parameter to pass to the compiler
|
|
|
|
|
|
pub flags: Vec<String>, |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
impl Default for Config { |
|
|
impl Default for Config { |
|
@ -18,6 +20,7 @@ impl Default for Config { |
|
|
include_directories: Vec::new(), |
|
|
include_directories: Vec::new(), |
|
|
definitions: Vec::new(), |
|
|
definitions: Vec::new(), |
|
|
objects: Vec::new(), |
|
|
objects: Vec::new(), |
|
|
|
|
|
flags: Vec::new(), |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
@ -75,6 +78,10 @@ pub fn compile_library(output: &str, config: &Config, files: &[&str]) { |
|
|
cmd.arg("-I").arg(directory); |
|
|
cmd.arg("-I").arg(directory); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
for flag in config.flags.iter() { |
|
|
|
|
|
cmd.arg(flag); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
for &(ref key, ref value) in config.definitions.iter() { |
|
|
for &(ref key, ref value) in config.definitions.iter() { |
|
|
if let &Some(ref value) = value { |
|
|
if let &Some(ref value) = value { |
|
|
cmd.arg(format!("-D{}={}", key, value)); |
|
|
cmd.arg(format!("-D{}={}", key, value)); |
|
|