From cc87fa8e4a2693a0015290c62cd0ccdecec0815a Mon Sep 17 00:00:00 2001 From: ClementTsang Date: Sat, 5 Sep 2020 16:25:35 -0400 Subject: [PATCH 1/2] fix: Fix mouse detection not working on proc after closing search --- src/app.rs | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/app.rs b/src/app.rs index 9ceb9d560..8db5f7778 100644 --- a/src/app.rs +++ b/src/app.rs @@ -200,6 +200,7 @@ impl App { .search_state .is_enabled = false; self.move_widget_selection(&WidgetDirection::Up); + self.is_force_redraw = true; return; } } @@ -214,6 +215,7 @@ impl App { current_proc_state.columns.backup_prev_scroll_position; current_proc_state.is_sort_open = false; self.move_widget_selection(&WidgetDirection::Right); + self.is_force_redraw = true; return; } } From 0d8572c6923c687c19a7cdbcc7128ba703e4e06d Mon Sep 17 00:00:00 2001 From: Clement Tsang <34804052+ClementTsang@users.noreply.github.com> Date: Sun, 6 Sep 2020 02:16:50 -0400 Subject: [PATCH 2/2] fix: Fixes count being sortable, but nothing occuring (#224) Fixes sorting by count being available, but doing nothing. This fix makes it sortable. --- CHANGELOG.md | 2 ++ src/app.rs | 13 +++++++++++++ src/lib.rs | 20 +++++++++----------- 3 files changed, 24 insertions(+), 11 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 5762280bb..9b3357bd3 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -27,6 +27,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - [#215](https://github.com/ClementTsang/bottom/pull/215): Add labels to Linux temperature values. +- [#224](https://github.com/ClementTsang/bottom/pull/224): Implements sorting by count. It previously did absolutely nothing. + ## [0.4.7] - 2020-08-26 ### Bug Fixes diff --git a/src/app.rs b/src/app.rs index 8db5f7778..1aa390f7d 100644 --- a/src/app.rs +++ b/src/app.rs @@ -268,6 +268,19 @@ impl App { // Toggles process widget grouping state proc_widget_state.is_grouped = !(proc_widget_state.is_grouped); + // Forcefully switch off column if we were on it... + if (proc_widget_state.is_grouped + && proc_widget_state.process_sorting_type + == data_harvester::processes::ProcessSorting::Pid) + || (!proc_widget_state.is_grouped + && proc_widget_state.process_sorting_type + == data_harvester::processes::ProcessSorting::Count) + { + proc_widget_state.process_sorting_type = + data_harvester::processes::ProcessSorting::CpuPercent; // Go back to default, negate PID for group + proc_widget_state.process_sorting_reverse = true; + } + proc_widget_state .columns .column_mapping diff --git a/src/lib.rs b/src/lib.rs index 1b1c3e7bf..2c15c73dc 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -510,16 +510,6 @@ pub fn update_final_process_list(app: &mut App, widget_id: u64) { // Quick fix for tab updating the table headers if let Some(proc_widget_state) = app.proc_state.get_mut_widget_state(widget_id) { - if let data_harvester::processes::ProcessSorting::Pid = - proc_widget_state.process_sorting_type - { - if proc_widget_state.is_grouped { - proc_widget_state.process_sorting_type = - data_harvester::processes::ProcessSorting::CpuPercent; // Go back to default, negate PID for group - proc_widget_state.process_sorting_reverse = true; - } - } - let mut resulting_processes = filtered_process_data; sort_process_data(&mut resulting_processes, proc_widget_state); @@ -645,7 +635,15 @@ pub fn sort_process_data( ) }), ProcessSorting::Count => { - // Nothing should happen here. + if proc_widget_state.is_grouped { + to_sort_vec.sort_by(|a, b| { + utils::gen_util::get_ordering( + a.group_pids.len(), + b.group_pids.len(), + proc_widget_state.process_sorting_reverse, + ) + }); + } } } }