From e243fe38ddbbf845a46c0b9baebaac3778c80927 Mon Sep 17 00:00:00 2001 From: Kevin K Date: Tue, 14 Apr 2015 13:56:53 -0400 Subject: [PATCH] feat(macros): add ability to get a typed multiple values --- src/macros.rs | 26 ++++++++++++++++++++++++-- 1 file changed, 24 insertions(+), 2 deletions(-) diff --git a/src/macros.rs b/src/macros.rs index d031ffe42a3..520dc9fc28b 100644 --- a/src/macros.rs +++ b/src/macros.rs @@ -40,7 +40,29 @@ macro_rules! value_t { Err(_) => Err(format!("{} isn't a valid {}",v,stringify!($t))), } }, - None => Err(format!("Argument not found")) + None => Err(format!("Argument \"{}\" not found", $v)) + } + }; + ($m:ident.values_of($v:expr), $t:ty) => { + match $m.values_of($v) { + Some(ref v) => { + let mut tmp = Vec::with_capacity(v.len()); + let mut err = None; + for pv in v { + match pv.parse::<$t>() { + Ok(rv) => tmp.push(rv), + Err(_) => { + err = Some(format!("{} isn't a valid {}",pv,stringify!($t))); + break + } + } + } + match err { + Some(e) => Err(e), + None => Ok(tmp) + } + }, + None => Err(format!("Argument \"{}\" not found", $v)) } }; } @@ -60,7 +82,7 @@ macro_rules! value_t_or_exit { } }, None => { - println!("Argument not found\n{}\nPlease re-run with --help for more information", $m.usage()); + println!("Argument \"{}\" not found or is not valid\n{}\nPlease re-run with --help for more information",$v, $m.usage()); ::std::process::exit(1); } }