mirror of
https://codeberg.org/icewind/palantir.git
synced 2026-06-03 18:24:08 +02:00
fix not listing all storages
This commit is contained in:
parent
2b7368fa78
commit
effc4641ad
1 changed files with 12 additions and 9 deletions
|
|
@ -114,22 +114,25 @@ impl Iterator for DiskUsageParser<'_> {
|
||||||
type Item = Result<DiskUsage>;
|
type Item = Result<DiskUsage>;
|
||||||
|
|
||||||
fn next(&mut self) -> Option<Self::Item> {
|
fn next(&mut self) -> Option<Self::Item> {
|
||||||
let line = loop {
|
let mount_point = loop {
|
||||||
let line = self.lines.next()?;
|
let line = self.lines.next()?;
|
||||||
if line.starts_with('/') && !line.contains("/dev/loop") && !line.contains("fuse") {
|
if line.starts_with('/') && !line.contains("/dev/loop") && !line.contains("fuse") {
|
||||||
break line;
|
debug!(line, "picking mount");
|
||||||
|
|
||||||
|
let mut parts = line.split_ascii_whitespace();
|
||||||
|
let disk = parts.next()?;
|
||||||
|
if self.found_disks.insert(hash_str(disk)) {
|
||||||
|
let mount_point = parts.next()?;
|
||||||
|
|
||||||
|
break mount_point;
|
||||||
|
} else {
|
||||||
|
debug!(line, "skipping already processed disk");
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
debug!(line, "skipping mount");
|
debug!(line, "skipping mount");
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
let mut parts = line.split_ascii_whitespace();
|
|
||||||
let disk = parts.next()?;
|
|
||||||
if !self.found_disks.insert(hash_str(disk)) {
|
|
||||||
debug!(line, "skipping already processed disk");
|
|
||||||
return None;
|
|
||||||
}
|
|
||||||
let mount_point = parts.next()?;
|
|
||||||
let stat = match statvfs(mount_point) {
|
let stat = match statvfs(mount_point) {
|
||||||
Ok(stat) => stat,
|
Ok(stat) => stat,
|
||||||
Err(e) => {
|
Err(e) => {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue