aboutsummaryrefslogtreecommitdiff
path: root/src/args.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/args.rs')
-rw-r--r--src/args.rs13
1 files changed, 8 insertions, 5 deletions
diff --git a/src/args.rs b/src/args.rs
index 57ac84c..8489c2d 100644
--- a/src/args.rs
+++ b/src/args.rs
@@ -173,7 +173,10 @@ impl Args {
} else {
env_makeflags
};
- let env_makeflags = env_makeflags.split_whitespace().map(OsString::from);
+ let env_makeflags = shlex::split(&env_makeflags)
+ .expect("Bad args?")
+ .into_iter()
+ .map(OsString::from);
// per the structopt docs, the first argument will be used as the binary name,
// so we need to make sure it goes in before MAKEFLAGS
let arg_0 = args.next().unwrap_or_else(|| env!("CARGO_PKG_NAME").into());
@@ -246,9 +249,9 @@ impl Args {
let macros = self
.targets_or_macros
.iter()
- .map(|x| x.as_ref())
- .filter(|x: &&str| x.contains('='))
- .collect::<Vec<&str>>()
+ .map(|x| shlex::try_quote(x).expect("Bad quoting?"))
+ .filter(|x| x.contains('='))
+ .collect::<Vec<_>>()
.join(" ");
let mut result = String::new();
@@ -557,6 +560,6 @@ mod test {
no_print_directory: true,
targets_or_macros: vec!["V=1".into()],
};
- assert_eq!(args.makeflags(), "--no-print-directory V=1");
+ assert_eq!(args.makeflags(), "--no-print-directory 'V=1'");
}
}