From 894c2d34f37f213d73911f0d2bc420b2be452867 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rafa=C5=82=20Harabie=C5=84?= Date: Sun, 24 Sep 2017 02:24:42 +0200 Subject: [PATCH] Implement Iterator for FatDir. --- src/dir.rs | 41 +++++++++++++++++++++++++---------------- 1 file changed, 25 insertions(+), 16 deletions(-) diff --git a/src/dir.rs b/src/dir.rs index bed2740..24fa8be 100644 --- a/src/dir.rs +++ b/src/dir.rs @@ -115,22 +115,7 @@ impl FatDir { pub fn list(&mut self) -> io::Result> { self.rewind(); - let mut entries = Vec::new(); - loop { - let entry = self.read_dir_entry()?; - if entry.name[0] == 0 { - break; // end of dir - } - if entry.name[0] == 0xE5 { - continue; // deleted - } - if entry.attrs == FatFileAttributes::LFN { - continue; // FIXME: support LFN - } - entries.push(entry); - } - - Ok(entries) + Ok(self.map(|x| x.unwrap()).collect()) } pub fn rewind(&mut self) { @@ -194,3 +179,27 @@ impl FatDir { } } } + +impl Iterator for FatDir { + type Item = io::Result; + + fn next(&mut self) -> Option> { + loop { + let r = self.read_dir_entry(); + let e = match r { + Ok(e) => e, + Err(_) => return Some(r), + }; + if e.name[0] == 0 { + return None; // end of dir + } + if e.name[0] == 0xE5 { + continue; // deleted + } + if e.attrs == FatFileAttributes::LFN { + continue; // FIXME: support LFN + } + return Some(Ok(e)) + } + } +}