Reimplement GlobStoreIdIterator

This commit is contained in:
Matthias Beyer 2017-07-23 11:03:00 +02:00
parent e4f8d4ec08
commit cbb36875f6

View file

@ -1037,6 +1037,15 @@ mod glob_store_iter {
use libimagerror::trace::trace_error; use libimagerror::trace::trace_error;
/// An iterator which is constructed from a `glob()` and returns valid `StoreId` objects
///
/// # Warning
///
/// On error, this iterator currently traces the error and return None (thus ending the
/// iteration). This is a known issue and will be resolved at some point.
///
/// TODO: See above.
///
pub struct GlobStoreIdIterator { pub struct GlobStoreIdIterator {
store_path: PathBuf, store_path: PathBuf,
paths: Paths, paths: Paths,
@ -1075,17 +1084,31 @@ mod glob_store_iter {
type Item = StoreId; type Item = StoreId;
fn next(&mut self) -> Option<StoreId> { fn next(&mut self) -> Option<StoreId> {
self.paths while let Some(o) = self.paths.next() {
.next()
.and_then(|o| {
debug!("GlobStoreIdIterator::next() => {:?}", o); debug!("GlobStoreIdIterator::next() => {:?}", o);
o.map_err_into(SEK::StoreIdHandlingError) match o.map_err_into(SEK::StoreIdHandlingError) {
.and_then(|p| StoreId::from_full_path(&self.store_path, p)) Ok(path) => {
.map_err(|e| { if path.exists() && path.is_file() {
return match StoreId::from_full_path(&self.store_path, path) {
Ok(id) => Some(id),
Err(e) => {
trace_error(&e);
None
}
}
/* } else { */
/* continue */
}
}
Err(e) => {
debug!("GlobStoreIdIterator error: {:?}", e); debug!("GlobStoreIdIterator error: {:?}", e);
trace_error(&e); trace_error(&e);
}).ok() return None
}) }
}
}
None
} }
} }