Dont assume cluster iterator always succeeds.
This commit is contained in:
parent
057eef07bb
commit
3e08c80fb0
12
src/file.rs
12
src/file.rs
@ -50,7 +50,11 @@ impl <'a, 'b> Read for FatFile<'a, 'b> {
|
|||||||
self.offset += read_bytes as u32;
|
self.offset += read_bytes as u32;
|
||||||
buf_offset += read_bytes;
|
buf_offset += read_bytes;
|
||||||
if self.offset % cluster_size == 0 {
|
if self.offset % cluster_size == 0 {
|
||||||
self.current_cluster = self.fs.cluster_iter(current_cluster).skip(1).next();
|
match self.fs.cluster_iter(current_cluster).skip(1).next() {
|
||||||
|
Some(Err(err)) => return Err(err),
|
||||||
|
Some(Ok(n)) => self.current_cluster = Some(n),
|
||||||
|
None => self.current_cluster = None,
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Ok(buf_offset)
|
Ok(buf_offset)
|
||||||
@ -71,7 +75,11 @@ impl <'a, 'b> Seek for FatFile<'a, 'b> {
|
|||||||
let cluster_count = (new_offset / cluster_size as i64) as usize;
|
let cluster_count = (new_offset / cluster_size as i64) as usize;
|
||||||
let mut new_cluster = Some(self.first_cluster);
|
let mut new_cluster = Some(self.first_cluster);
|
||||||
if cluster_count > 0 {
|
if cluster_count > 0 {
|
||||||
new_cluster = self.fs.cluster_iter(new_cluster.unwrap()).skip(cluster_count).next();
|
match self.fs.cluster_iter(new_cluster.unwrap()).skip(cluster_count).next() {
|
||||||
|
Some(Err(err)) => return Err(err),
|
||||||
|
Some(Ok(n)) => new_cluster = Some(n),
|
||||||
|
None => new_cluster = None,
|
||||||
|
}
|
||||||
}
|
}
|
||||||
self.offset = new_offset as u32;
|
self.offset = new_offset as u32;
|
||||||
self.current_cluster = new_cluster;
|
self.current_cluster = new_cluster;
|
||||||
|
@ -214,7 +214,7 @@ impl <'a> FatFileSystem<'a> {
|
|||||||
self.offset_from_sector(self.sector_from_cluster(cluser))
|
self.offset_from_sector(self.sector_from_cluster(cluser))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn cluster_iter<'b>(&'b self, cluster: u32) -> iter::Chain<iter::Once<u32>, FatClusterIterator<'b, 'a>> {
|
pub(crate) fn cluster_iter<'b>(&'b self, cluster: u32) -> iter::Chain<iter::Once<io::Result<u32>>, FatClusterIterator<'b, 'a>> {
|
||||||
let bytes_per_sector = self.boot.bpb.bytes_per_sector as u64;
|
let bytes_per_sector = self.boot.bpb.bytes_per_sector as u64;
|
||||||
let fat_offset = self.boot.bpb.reserved_sectors as u64 * bytes_per_sector;
|
let fat_offset = self.boot.bpb.reserved_sectors as u64 * bytes_per_sector;
|
||||||
let sectors_per_fat =
|
let sectors_per_fat =
|
||||||
|
34
src/table.rs
34
src/table.rs
@ -51,27 +51,47 @@ fn get_next_cluster_32(rdr: &mut ReadSeek, cluster: u32) -> io::Result<Option<u3
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) struct FatClusterIterator<'a, 'b: 'a> {
|
pub(crate) struct FatClusterIterator<'a, 'b: 'a> {
|
||||||
part: FatSlice<'a, 'b>,
|
rdr: FatSlice<'a, 'b>,
|
||||||
fat_type: FatType,
|
fat_type: FatType,
|
||||||
cluster: Option<u32>,
|
cluster: Option<u32>,
|
||||||
|
err: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl <'a, 'b> FatClusterIterator<'a, 'b> {
|
impl <'a, 'b> FatClusterIterator<'a, 'b> {
|
||||||
pub(crate) fn new(part: FatSlice<'a, 'b>, fat_type: FatType, cluster: u32) -> iter::Chain<iter::Once<u32>, FatClusterIterator<'a, 'b>> {
|
pub(crate) fn new(rdr: FatSlice<'a, 'b>, fat_type: FatType, cluster: u32)
|
||||||
|
-> iter::Chain<iter::Once<io::Result<u32>>, FatClusterIterator<'a, 'b>> {
|
||||||
let iter = FatClusterIterator {
|
let iter = FatClusterIterator {
|
||||||
part: part,
|
rdr: rdr,
|
||||||
fat_type: fat_type,
|
fat_type: fat_type,
|
||||||
cluster: Some(cluster),
|
cluster: Some(cluster),
|
||||||
|
err: false,
|
||||||
};
|
};
|
||||||
iter::once(cluster).chain(iter)
|
iter::once(Ok(cluster)).chain(iter)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl <'a, 'b> Iterator for FatClusterIterator<'a, 'b> {
|
impl <'a, 'b> Iterator for FatClusterIterator<'a, 'b> {
|
||||||
type Item = u32;
|
type Item = io::Result<u32>;
|
||||||
|
|
||||||
fn next(&mut self) -> Option<Self::Item> {
|
fn next(&mut self) -> Option<Self::Item> {
|
||||||
self.cluster = get_next_cluster(&mut self.part, self.fat_type, self.cluster.unwrap()).unwrap(); // FIXME: unwrap!
|
if self.err {
|
||||||
self.cluster
|
return None;
|
||||||
|
}
|
||||||
|
match self.cluster {
|
||||||
|
Some(current_cluster) => {
|
||||||
|
self.cluster = match get_next_cluster(&mut self.rdr, self.fat_type, current_cluster) {
|
||||||
|
Ok(next_cluster) => next_cluster,
|
||||||
|
Err(err) => {
|
||||||
|
self.err = true;
|
||||||
|
return Some(Err(err));
|
||||||
|
},
|
||||||
|
}
|
||||||
|
},
|
||||||
|
None => {},
|
||||||
|
};
|
||||||
|
match self.cluster {
|
||||||
|
Some(n) => Some(Ok(n)),
|
||||||
|
None => None,
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user