diff options
author | rabite <rabite@posteo.de> | 2019-02-07 00:57:51 +0100 |
---|---|---|
committer | rabite <rabite@posteo.de> | 2019-02-07 00:57:51 +0100 |
commit | 2496d4b6e0809b9072c2a8e29416fd5e771ae7b2 (patch) | |
tree | 79c0e0709bd64223689d83d51ffb8d458195d08f /src | |
parent | 4e9b0842f3a9166ac81da0fad1b884f09a0451a2 (diff) |
select by mtime and reverse sorting
Diffstat (limited to 'src')
-rw-r--r-- | src/files.rs | 20 | ||||
-rw-r--r-- | src/listview.rs | 73 |
2 files changed, 89 insertions, 4 deletions
diff --git a/src/files.rs b/src/files.rs index c9f3754..e38af15 100644 --- a/src/files.rs +++ b/src/files.rs @@ -14,12 +14,13 @@ lazy_static! { static ref COLORS: LsColors = LsColors::from_env().unwrap(); } -#[derive(PartialEq)] +#[derive(PartialEq, Clone)] pub struct Files { pub directory: File, pub files: Vec<File>, pub sort: SortBy, pub dirs_first: bool, + pub reverse: bool, } impl Index<usize> for Files { @@ -79,6 +80,7 @@ impl Files { files: files, sort: SortBy::Name, dirs_first: true, + reverse: false, }; files.sort(); @@ -115,12 +117,23 @@ impl Files { if self.dirs_first { self.files.sort_by(|a, b| { - if a.is_dir() && !b.is_dir() && a.name.starts_with(".") { + if a.is_dir() && !b.is_dir() { Ordering::Less } else { Ordering::Equal } }); + self.files.sort_by(|a, b| { + if a.name.starts_with(".") && !b.name.starts_with(".") { + Ordering::Less + } else { + Ordering::Equal + } + }); + } + + if self.reverse { + self.files.reverse(); } } @@ -132,6 +145,9 @@ impl Files { }; } + pub fn reverse_sort(&mut self) { + self.reverse = !self.reverse + } pub fn len(&self) -> usize { self.files.len() } diff --git a/src/listview.rs b/src/listview.rs index f3e0c79..a430d59 100644 --- a/src/listview.rs +++ b/src/listview.rs @@ -23,6 +23,7 @@ where // dimensions: (u16, u16), // position: (u16, u16), coordinates: Coordinates, + seeking: bool, } impl<T> ListView<T> @@ -39,8 +40,8 @@ where coordinates: Coordinates { size: Size((1, 1)), position: Position((1, 1)), - }, // dimensions: (1,1), - // position: (1,1) + }, + seeking: false }; view } @@ -55,6 +56,7 @@ where } self.selection -= 1; + self.seeking = false; } fn move_down(&mut self) { let lines = self.buffer.len(); @@ -69,6 +71,7 @@ where } self.selection += 1; + self.seeking = false; } fn set_selection(&mut self, position: usize) { @@ -185,6 +188,69 @@ where self.show_status(&format!("Sorting by: {}", self.content.sort)); } + fn reverse_sort(&mut self) { + let file = self.clone_selected_file(); + self.content.reverse_sort(); + self.content.sort(); + self.select_file(&file); + self.refresh(); + self.show_status(&format!("Reversed sorting by: {}", self.content.sort)); + } + + fn select_next_mtime(&mut self) { + let file = self.clone_selected_file(); + let dir_settings = self.content.dirs_first; + let sort_settings = self.content.sort; + + self.content.dirs_first = false; + self.content.sort = crate::files::SortBy::MTime; + self.content.sort(); + + self.select_file(&file); + + if self.seeking == false || self.selection + 1 == self.content.len() { + self.selection = 0; + self.offset = 0; + } else { + self.move_down(); + } + + let file = self.clone_selected_file(); + self.content.dirs_first = dir_settings; + self.content.sort = sort_settings; + self.content.sort(); + self.select_file(&file); + self.seeking = true; + + self.refresh(); + } + + fn select_prev_mtime(&mut self) { + let file = self.clone_selected_file(); + let dir_settings = self.content.dirs_first; + let sort_settings = self.content.sort; + + self.content.dirs_first = false; + self.content.sort = crate::files::SortBy::MTime; + self.content.sort(); + + self.select_file(&file); + + if self.seeking == false || self.selection == 0 { + self.set_selection(self.content.len() - 1); + } else { + self.move_up(); + } + + let file = self.clone_selected_file(); + self.content.dirs_first = dir_settings; + self.content.sort = sort_settings; + self.content.sort(); + self.select_file(&file); + + self.refresh(); + } + fn toggle_dirs_first(&mut self) { let file = self.clone_selected_file(); self.content.dirs_first = !self.content.dirs_first; @@ -301,7 +367,10 @@ impl Widget for ListView<Files> { } Key::Left => self.goto_grand_parent(), Key::Right => self.goto_selected(), + Key::Char('r') => self.reverse_sort(), Key::Char('s') => self.cycle_sort(), + Key::Char('k') => self.select_next_mtime(), + Key::Char('K') => self.select_prev_mtime(), Key::Char('d') => self.toggle_dirs_first(), Key::Char('!') => self.exec_cmd(), _ => { |