Always sort files the same way

This fixes a bug where extra sorting options (dirs first, reverse) were not applied when listing in long mode. In other words, fixes #105.

The bug occurred because the sorting function only took Files, but the details view uses File eggs that only contain Files. This commit changes the sorting function to accept anything that AsRefs to File, and impls that on both File and Egg so the same function works for both.
This commit is contained in:
Ben S 2016-03-31 23:13:15 +01:00
parent eaa799c647
commit f6c5c89f55
3 changed files with 20 additions and 6 deletions

View File

@ -399,6 +399,12 @@ impl<'dir> File<'dir> {
} }
} }
impl<'a> AsRef<File<'a>> for File<'a> {
fn as_ref(&self) -> &File<'a> {
&self
}
}
/// Extract the filename to display from a path, converting it from UTF-8 /// Extract the filename to display from a path, converting it from UTF-8
/// lossily, into a String. /// lossily, into a String.
/// ///

View File

@ -349,8 +349,10 @@ impl FileFilter {
} }
/// Sort the files in the given vector based on the sort field option. /// Sort the files in the given vector based on the sort field option.
pub fn sort_files(&self, files: &mut Vec<File>) { pub fn sort_files<'_, F>(&self, files: &mut Vec<F>)
files.sort_by(|a, b| self.compare_files(a, b)); where F: AsRef<File<'_>> {
files.sort_by(|a, b| self.compare_files(a.as_ref(), b.as_ref()));
if self.reverse { if self.reverse {
files.reverse(); files.reverse();
@ -358,7 +360,7 @@ impl FileFilter {
if self.list_dirs_first { if self.list_dirs_first {
// This relies on the fact that `sort_by` is stable. // This relies on the fact that `sort_by` is stable.
files.sort_by(|a, b| b.is_directory().cmp(&a.is_directory())); files.sort_by(|a, b| b.as_ref().is_directory().cmp(&a.as_ref().is_directory()));
} }
} }

View File

@ -229,12 +229,18 @@ impl Details {
let mut pool = Pool::new(num_cpus::get() as u32); let mut pool = Pool::new(num_cpus::get() as u32);
let mut file_eggs = Vec::new(); let mut file_eggs = Vec::new();
struct Egg<'_> { struct Egg<'a> {
cells: Vec<TextCell>, cells: Vec<TextCell>,
xattrs: Vec<Attribute>, xattrs: Vec<Attribute>,
errors: Vec<(io::Error, Option<PathBuf>)>, errors: Vec<(io::Error, Option<PathBuf>)>,
dir: Option<Dir>, dir: Option<Dir>,
file: File<'_>, file: File<'a>,
}
impl<'a> AsRef<File<'a>> for Egg<'a> {
fn as_ref(&self) -> &File<'a> {
&self.file
}
} }
pool.scoped(|scoped| { pool.scoped(|scoped| {
@ -285,7 +291,7 @@ impl Details {
} }
}); });
file_eggs.sort_by(|a, b| self.filter.compare_files(&a.file, &b.file)); self.filter.sort_files(&mut file_eggs);
let num_eggs = file_eggs.len(); let num_eggs = file_eggs.len();
for (index, egg) in file_eggs.into_iter().enumerate() { for (index, egg) in file_eggs.into_iter().enumerate() {