Rewrite BMModule::get_filtered_files_from_backend() with the backend speaking Result<> now instead of Option<>

This commit is contained in:
Matthias Beyer 2015-12-04 14:17:32 +01:00
parent 40ae26d0f2
commit 04df3fdf3c

View file

@ -66,34 +66,35 @@ pub fn remove_command(module: &Module, env: CommandEnv) -> CommandResult {
} else { } else {
debug!("Remove more than one file"); debug!("Remove more than one file");
let files = get_filtered_files_from_backend(module, &env); get_filtered_files_from_backend(module, &env).and_then(|files| {
let nfiles = files.len(); let nfiles = files.len();
info!("Removing {} Files", nfiles); info!("Removing {} Files", nfiles);
let errs = files.map(|file| { let errs = files.map(|file| {
debug!("Remove file: {:?}", file); debug!("Remove file: {:?}", file);
env.bk.remove_file(module, file, checked) env.bk.remove_file(module, file, checked)
}) })
.filter(|e| e.is_err()) .filter(|e| e.is_err())
.map(|e| { .map(|e| {
let err = e.err().unwrap(); let err = e.err().unwrap();
warn!("Error occured in Filesystem operation: {}", err); warn!("Error occured in Filesystem operation: {}", err);
err err
}) })
.collect::<Vec<StorageBackendError>>(); .collect::<Vec<StorageBackendError>>();
let nerrs = errs.len(); let nerrs = errs.len();
if nerrs != 0 { if nerrs != 0 {
warn!("{} Errors occured while removing {} files", nerrs, nfiles); warn!("{} Errors occured while removing {} files", nerrs, nfiles);
let moderr = ModuleError::new("File removal failed"); let moderr = ModuleError::new("File removal failed");
// TODO : Collect StorageBackendErrors // TODO : Collect StorageBackendErrors
Err(moderr) Err(moderr)
} else { } else {
Ok(()) Ok(())
} }
})
} }
} }
@ -104,28 +105,34 @@ pub fn remove_command(module: &Module, env: CommandEnv) -> CommandResult {
*/ */
fn get_filtered_files_from_backend<'a>(module: &'a Module, fn get_filtered_files_from_backend<'a>(module: &'a Module,
env: &CommandEnv) -> IntoIter<File<'a>> env: &CommandEnv)
-> Result<IntoIter<File<'a>>, ModuleError>
{ {
let parser = Parser::new(JsonHeaderParser::new(None)); let parser = Parser::new(JsonHeaderParser::new(None));
let tags = get_tags(env.rt, env.matches); let tags = get_tags(env.rt, env.matches);
debug!("Tags: {:?}", tags); debug!("Tags: {:?}", tags);
env.bk.iter_files(module, &parser).and_then(|files| { env.bk.iter_files(module, &parser)
let f = files.filter(|file| { .map(|files| {
if tags.len() != 0 { let f = files.filter(|file| {
debug!("Checking tags of: {:?}", file.id()); if tags.len() != 0 {
get_tags_from_header(&file.header()).iter() debug!("Checking tags of: {:?}", file.id());
.any(|t| tags.contains(t)) get_tags_from_header(&file.header()).iter()
} else { .any(|t| tags.contains(t))
true } else {
} true
}).filter(|file| { }
debug!("Checking matches of: {:?}", file.id()); }).filter(|file| {
get_matcher(env.rt, env.matches) debug!("Checking matches of: {:?}", file.id());
.and_then(|r| Some(file.matches_with(&r))) get_matcher(env.rt, env.matches)
.unwrap_or(true) .and_then(|r| Some(file.matches_with(&r)))
}).collect::<Vec<File>>(); .unwrap_or(true)
Some(f) }).collect::<Vec<File>>();
}).unwrap_or(Vec::<File>::new()).into_iter() f.into_iter()
}).map_err(|e| {
let mut merr = ModuleError::new("Could not filter files");
merr.caused_by = Some(Box::new(e));
merr
})
} }
fn get_tags<'a>(rt: &Runtime, sub: &ArgMatches<'a, 'a>) -> Vec<String> { fn get_tags<'a>(rt: &Runtime, sub: &ArgMatches<'a, 'a>) -> Vec<String> {