summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorIan Shehadeh <IanShehadeh2020@gmail.com>2018-08-24 15:26:40 -0400
committerRyan Dahl <ry@tinyclouds.org>2018-09-04 16:00:32 -0400
commit827f489c5afea68a574567ede12a0b1c60580510 (patch)
tree7e6683492df6a7c904e721070ac46320c6a93f9c /src
parentd6c310596e36cb3f64961a59be64583433b7f583 (diff)
Better flag parsing
Diffstat (limited to 'src')
-rw-r--r--src/flags.rs59
1 files changed, 48 insertions, 11 deletions
diff --git a/src/flags.rs b/src/flags.rs
index 05c7cf872..db04e42f7 100644
--- a/src/flags.rs
+++ b/src/flags.rs
@@ -4,6 +4,7 @@ use libc::c_int;
use std::ffi::CStr;
use std::ffi::CString;
use std::mem;
+use std::vec::Vec;
// Creates vector of strings, Vec<String>
#[cfg(test)]
@@ -32,7 +33,7 @@ pub fn print_usage() {
-v or --version Print the version.
-r or --reload Reload cached remote resources.
-D or --log-debug Log debug output.
---help Print this message.
+-h or --help Print this message.
--v8-options Print V8 command line options."
);
}
@@ -41,19 +42,39 @@ pub fn print_usage() {
pub fn set_flags(args: Vec<String>) -> (DenoFlags, Vec<String>) {
let mut flags = DenoFlags::default();
let mut rest = Vec::new();
- for a in &args {
- match a.as_str() {
- "-h" | "--help" => flags.help = true,
- "-D" | "--log-debug" => flags.log_debug = true,
- "-v" | "--version" => flags.version = true,
- "-r" | "--reload" => flags.reload = true,
- "--allow-env" => flags.allow_env = true,
- "--allow-write" => flags.allow_write = true,
- "--allow-net" => flags.allow_net = true,
- _ => rest.push(a.clone()),
+ let mut arg_iter = args.iter();
+
+ while let Some(a) = arg_iter.next() {
+ if a.len() > 1 && &a[0..2] == "--" {
+ match a.as_str() {
+ "--help" => flags.help = true,
+ "--log-debug" => flags.log_debug = true,
+ "--version" => flags.version = true,
+ "--reload" => flags.reload = true,
+ "--allow-write" => flags.allow_write = true,
+ "--allow-net" => flags.allow_net = true,
+ "--allow-env" => flags.allow_env = true,
+ "--" => break,
+ _ => unimplemented!(),
+ }
+ } else if a.len() > 1 && &a[0..1] == "-" {
+ let mut iter = a.chars().skip(1); // skip the "-"
+ while let Some(f) = iter.next() {
+ match f {
+ 'h' => flags.help = true,
+ 'D' => flags.log_debug = true,
+ 'v' => flags.version = true,
+ 'r' => flags.reload = true,
+ _ => unimplemented!(),
+ }
+ }
+ } else {
+ rest.push(a.clone());
}
}
+ // add any remaining arguments to `rest`
+ rest.extend(arg_iter.map(|s| s.clone()));
return (flags, rest);
}
@@ -99,6 +120,22 @@ fn test_set_flags_3() {
);
}
+#[test]
+fn test_set_flags_4() {
+ let (flags, rest) =
+ set_flags(svec!["deno", "-Dr", "script.ts", "--allow-write"]);
+ assert_eq!(rest, svec!["deno", "script.ts"]);
+ assert_eq!(
+ flags,
+ DenoFlags {
+ log_debug: true,
+ reload: true,
+ allow_write: true,
+ ..DenoFlags::default()
+ }
+ );
+}
+
// Returns args passed to V8, followed by args passed to JS
// TODO Rename to v8_set_flags_preprocess
fn parse_core_args(args: Vec<String>) -> (Vec<String>, Vec<String>) {