mirror of
git://git.proxmox.com/git/proxmox-backup.git
synced 2025-01-06 13:18:00 +03:00
impl argument parameters
This commit is contained in:
parent
c78bcf07ad
commit
a19f223dea
@ -45,6 +45,7 @@ fn parse_argument(arg: &str) -> RawArgument {
|
||||
|
||||
pub fn parse_arguments(
|
||||
args: &Vec<String>,
|
||||
arg_param: &Vec<String>,
|
||||
schema: &ObjectSchema,
|
||||
) -> Result<(Value,Vec<String>), ParameterError> {
|
||||
|
||||
@ -129,8 +130,20 @@ pub fn parse_arguments(
|
||||
if pos >= args.len() { break; }
|
||||
}
|
||||
|
||||
for i in 0..arg_param.len() {
|
||||
if rest.len() > i {
|
||||
data.push((arg_param[i].clone(), rest[i].clone()));
|
||||
} else {
|
||||
errors.push(format_err!("missing argument '{}'", arg_param[i]));
|
||||
}
|
||||
}
|
||||
|
||||
if errors.len() > 0 { return Err(errors); }
|
||||
|
||||
if arg_param.len() > 0 {
|
||||
rest = rest[arg_param.len()..].to_vec();
|
||||
}
|
||||
|
||||
let options = parse_parameter_strings(&data, schema, true)?;
|
||||
|
||||
Ok((options,rest))
|
||||
@ -158,12 +171,30 @@ fn test_boolean_arg() {
|
||||
|
||||
for (args, expect) in variants {
|
||||
let string_args = args.iter().map(|s| s.to_string()).collect();
|
||||
let res = parse_arguments(&string_args, &schema);
|
||||
let res = parse_arguments(&string_args, &vec![], &schema);
|
||||
assert!(res.is_ok());
|
||||
if let Ok((options, rest)) = res {
|
||||
assert!(options["enable"] == expect);
|
||||
assert!(rest.len() == 0);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_argument_paramenter() {
|
||||
|
||||
let schema = parameter!{
|
||||
enable => Boolean!{ optional => false },
|
||||
storage => ApiString!{ optional => false }
|
||||
};
|
||||
|
||||
let args = vec!["-enable", "local"];
|
||||
let string_args = args.iter().map(|s| s.to_string()).collect();
|
||||
let res = parse_arguments(&string_args, &vec!["storage".to_string()], &schema);
|
||||
assert!(res.is_ok());
|
||||
if let Ok((options, rest)) = res {
|
||||
assert!(options["enable"] == true);
|
||||
assert!(options["storage"] == "local");
|
||||
assert!(rest.len() == 0);
|
||||
}
|
||||
}
|
||||
|
@ -25,7 +25,7 @@ fn main() {
|
||||
};
|
||||
|
||||
let args: Vec<String> = std::env::args().skip(1).collect();
|
||||
match getopts::parse_arguments(&args, &schema) {
|
||||
match getopts::parse_arguments(&args, &vec![], &schema) {
|
||||
Ok((options, rest)) => {
|
||||
println!("Got Options: {}", options);
|
||||
println!("Remaining Arguments: {:?}", rest);
|
||||
|
Loading…
Reference in New Issue
Block a user