diff options
author | ClementTsang <cjhtsang@uwaterloo.ca> | 2020-02-29 17:05:01 -0500 |
---|---|---|
committer | ClementTsang <cjhtsang@uwaterloo.ca> | 2020-03-02 00:09:45 -0500 |
commit | eb2622467fb05014dc52bf7ca077b3f7d57c47d9 (patch) | |
tree | 8ddc61f723c1f044f8ce1a7254954df4aaf05cbb | |
parent | ff43799037e7f8e77ed371a066a0eed3768b71f3 (diff) |
Refactoring.
-rw-r--r-- | src/app.rs | 2368 | ||||
-rw-r--r-- | src/app/data_farmer.rs | 494 | ||||
-rw-r--r-- | src/app/data_harvester.rs | 298 | ||||
-rw-r--r-- | src/app/data_harvester/cpu.rs | 30 | ||||
-rw-r--r-- | src/app/data_harvester/disks.rs | 124 | ||||
-rw-r--r-- | src/app/data_harvester/mem.rs | 38 | ||||
-rw-r--r-- | src/app/data_harvester/network.rs | 84 | ||||
-rw-r--r-- | src/app/data_harvester/processes.rs | 486 | ||||
-rw-r--r-- | src/app/data_harvester/temperature.rs | 132 | ||||
-rw-r--r-- | src/app/process_killer.rs | 54 | ||||
-rw-r--r-- | src/canvas.rs | 2837 | ||||
-rw-r--r-- | src/canvas/canvas_colours.rs | 274 | ||||
-rw-r--r-- | src/canvas/canvas_colours/colour_utils.rs | 249 | ||||
-rw-r--r-- | src/canvas/drawing_utils.rs | 246 | ||||
-rw-r--r-- | src/constants.rs | 78 | ||||
-rw-r--r-- | src/data_conversion.rs | 520 | ||||
-rw-r--r-- | src/main.rs | 1390 | ||||
-rw-r--r-- | src/options.rs | 281 | ||||
-rw-r--r-- | src/utils/error.rs | 112 | ||||
-rw-r--r-- | src/utils/gen_util.rs | 130 | ||||
-rw-r--r-- | src/utils/logging.rs | 36 |
21 files changed, 5140 insertions, 5121 deletions
@@ -16,1275 +16,1273 @@ const MAX_SEARCH_LENGTH: usize = 200; #[derive(Debug, Clone, Copy)] pub enum WidgetPosition { - Cpu, - Mem, - Disk, - Temp, - Network, - Process, - ProcessSearch, + Cpu, + Mem, + Disk, + Temp, + Network, + Process, + ProcessSearch, } #[derive(Debug)] pub enum ScrollDirection { - // UP means scrolling up --- this usually DECREMENTS - UP, - // DOWN means scrolling down --- this usually INCREMENTS - DOWN, + // UP means scrolling up --- this usually DECREMENTS + UP, + // DOWN means scrolling down --- this usually INCREMENTS + DOWN, } #[derive(Debug)] pub enum CursorDirection { - LEFT, - RIGHT, + LEFT, + RIGHT, } /// AppScrollWidgetState deals with fields for a scrollable app's current state. #[derive(Default)] pub struct AppScrollWidgetState { - pub current_scroll_position: u64, - pub previous_scroll_position: u64, + pub current_scroll_position: u64, + pub previous_scroll_position: u64, } pub struct AppScrollState { - pub scroll_direction: ScrollDirection, - pub process_scroll_state: AppScrollWidgetState, - pub disk_scroll_state: AppScrollWidgetState, - pub temp_scroll_state: AppScrollWidgetState, - pub cpu_scroll_state: AppScrollWidgetState, + pub scroll_direction: ScrollDirection, + pub process_scroll_state: AppScrollWidgetState, + pub disk_scroll_state: AppScrollWidgetState, + pub temp_scroll_state: AppScrollWidgetState, + pub cpu_scroll_state: AppScrollWidgetState, } impl Default for AppScrollState { - fn default() -> Self { - AppScrollState { - scroll_direction: ScrollDirection::DOWN, - process_scroll_state: AppScrollWidgetState::default(), - disk_scroll_state: AppScrollWidgetState::default(), - temp_scroll_state: AppScrollWidgetState::default(), - cpu_scroll_state: AppScrollWidgetState::default(), - } - } + fn default() -> Self { + AppScrollState { + scroll_direction: ScrollDirection::DOWN, + process_scroll_state: AppScrollWidgetState::default(), + disk_scroll_state: AppScrollWidgetState::default(), + temp_scroll_state: AppScrollWidgetState::default(), + cpu_scroll_state: AppScrollWidgetState::default(), + } + } } /// AppSearchState deals with generic searching (I might do this in the future). pub struct AppSearchState { - pub is_enabled: bool, - current_search_query: String, - current_regex: Option<std::result::Result<regex::Regex, regex::Error>>, - pub is_blank_search: bool, - pub is_invalid_search: bool, - pub grapheme_cursor: GraphemeCursor, - pub cursor_direction: CursorDirection, - pub cursor_bar: usize, - /// This represents the position in terms of CHARACTERS, not graphemes - pub char_cursor_position: usize, + pub is_enabled: bool, + current_search_query: String, + current_regex: Option<std::result::Result<regex::Regex, regex::Error>>, + pub is_blank_search: bool, + pub is_invalid_search: bool, + pub grapheme_cursor: GraphemeCursor, + pub cursor_direction: CursorDirection, + pub cursor_bar: usize, + /// This represents the position in terms of CHARACTERS, not graphemes + pub char_cursor_position: usize, } impl Default for AppSearchState { - fn default() -> Self { - AppSearchState { - is_enabled: false, - current_search_query: String::default(), - current_regex: None, - is_invalid_search: false, - is_blank_search: true, - grapheme_cursor: GraphemeCursor::new(0, 0, true), - cursor_direction: CursorDirection::RIGHT, - cursor_bar: 0, - char_cursor_position: 0, - } - } + fn default() -> Self { + AppSearchState { + is_enabled: false, + current_search_query: String::default(), + current_regex: None, + is_invalid_search: false, + is_blank_search: true, + grapheme_cursor: GraphemeCursor::new(0, 0, true), + cursor_direction: CursorDirection::RIGHT, + cursor_bar: 0, + char_cursor_position: 0, + } + } } impl AppSearchState { - /// Returns a reset but still enabled app search state - pub fn reset() -> Self { - let mut app_search_state = AppSearchState::default(); - app_search_state.is_enabled = true; - app_search_state - } - - pub fn is_invalid_or_blank_search(&self) -> bool { - self.is_blank_search || self.is_invalid_search - } + /// Returns a reset but still enabled app search state + pub fn reset() -> Self { + let mut app_search_state = AppSearchState::default(); + app_search_state.is_enabled = true; + app_search_state + } + + pub fn is_invalid_or_blank_search(&self) -> bool { + self.is_blank_search || self.is_invalid_search + } } /// ProcessSearchState only deals with process' search's current settings and state. pub struct ProcessSearchState { - pub search_state: AppSearchState, - pub is_searching_with_pid: bool, - pub is_ignoring_case: bool, - pub is_searching_whole_word: bool, - pub is_searching_with_regex: bool, + pub search_state: AppSearchState, + pub is_searching_with_pid: bool, + pub is_ignoring_case: bool, + pub is_searching_whole_word: bool, + pub is_searching_with_regex: bool, } impl Default for ProcessSearchState { - fn default() -> Self { - ProcessSearchState { - search_state: AppSearchState::default(), - is_searching_with_pid: false, - is_ignoring_case: true, - is_searching_whole_word: false, - is_searching_with_regex: false, - } - } + fn default() -> Self { + ProcessSearchState { + search_state: AppSearchState::default(), + is_searching_with_pid: false, + is_ignoring_case: true, + is_searching_whole_word: false, + is_searching_with_regex: false, + } + } } impl ProcessSearchState { - pub fn search_toggle_ignore_case(&mut self) { - self.is_ignoring_case = !self.is_ignoring_case; - } + pub fn search_toggle_ignore_case(&mut self) { + self.is_ignoring_case = !self.is_ignoring_case; + } - pub fn search_toggle_whole_word(&mut self) { - self.is_searching_whole_word = !self.is_searching_whole_word; - } + pub fn search_toggle_whole_word(&mut self) { + self.is_searching_whole_word = !self.is_searching_whole_word; + } - pub fn search_toggle_regex(&mut self) { - self.is_searching_with_regex = !self.is_searching_with_regex; - } + pub fn search_toggle_regex(&mut self) { + self.is_searching_with_regex = !self.is_searching_with_regex; + } } #[derive(Default)] pub struct AppDeleteDialogState { - pub is_showing_dd: bool, - pub is_on_yes: bool, // Defaults to "No" + pub is_showing_dd: bool, + pub is_on_yes: bool, // Defaults to "No" } pub enum AppHelpCategory { - General, - Process, - Search, + General, + Process, + Search, } pub struct AppHelpDialogState { - pub is_showing_help: bool, - pub current_category: AppHelpCategory, + pub is_showing_help: bool, + pub current_category: AppHelpCategory, } impl Default for AppHelpDialogState { - fn default() -> Self { - AppHelpDialogState { - is_showing_help: false, - current_category: AppHelpCategory::General, - } - } + fn default() -> Self { + AppHelpDialogState { + is_showing_help: false, + current_category: AppHelpCategory::General, + } + } } /// AppConfigFields is meant to cover basic fields that would normally be set /// by config files or launch options. Don't need to be mutable (set and forget). pub struct AppConfigFields { - pub update_rate_in_milliseconds: u64, - pub temperature_type: temperature::TemperatureType, - pub use_dot: bool, - pub left_legend: bool, - pub show_average_cpu: bool, - pub use_current_cpu_total: bool, - pub show_disabled_data: bool, - pub use_basic_mode: bool, + pub update_rate_in_milliseconds: u64, + pub temperature_type: temperature::TemperatureType, + pub use_dot: bool, + pub left_legend: bool, + pub show_average_cpu: bool, + pub use_current_cpu_total: bool, + pub show_disabled_data: bool, + pub use_basic_mode: bool, } /// Network specific pub struct NetworkState { - pub is_showing_tray: bool, - pub is_showing_rx: bool, - pub is_showing_tx: bool, - pub zoom_level: f64, + pub is_showing_tray: bool, + pub is_showing_rx: bool, + pub is_showing_tx: bool, + pub zoom_level: f64, } impl Default for NetworkState { - fn default() -> Self { - NetworkState { - is_showing_tray: false, - is_showing_rx: true, - is_showing_tx: true, - zoom_level: 100.0, - } - } + fn default() -> Self { + NetworkState { + is_showing_tray: false, + is_showing_rx: true, + is_showing_tx: true, + zoom_level: 100.0, + } + } } /// CPU specific pub struct CpuState { - pub is_showing_tray: bool, - pub zoom_level: f64, - pub core_show_vec: Vec<bool>, + pub is_showing_tray: bool, + pub zoom_level: f64, + pub core_show_vec: Vec<bool>, } impl Default for CpuState { - fn default() -> Self { - CpuState { - is_showing_tray: false, - zoom_level: 100.0, - core_show_vec: Vec::new(), - } - } + fn default() -> Self { + CpuState { + is_showing_tray: false, + zoom_level: 100.0, + core_show_vec: Vec::new(), + } + } } /// Memory specific pub struct MemState { - pub is_showing_tray: bool, - pub is_showing_ram: bool, - pub is_showing_swap: bool, - pub zoom_level: f64, + pub is_showing_tray: bool, + pub is_showing_ram: bool, + pub is_showing_swap: bool, + pub zoom_level: f64, } impl Default for MemState { - fn default() -> Self { - MemState { - is_showing_tray: false, - is_showing_ram: true, - is_showing_swap: true, - zoom_level: 100.0, - } - } + fn default() -> Self { + MemState { + is_showing_tray: false, + is_showing_ram: true, + is_showing_swap: true, + zoom_level: 100.0, + } + } } pub struct App { - pub process_sorting_type: processes::ProcessSorting, - pub process_sorting_reverse: bool, - pub update_process_gui: bool, - pub app_scroll_positions: AppScrollState, - pub current_widget_selected: WidgetPosition, - pub data: data_harvester::Data, - awaiting_second_char: bool, - second_char: Option<char>, - pub dd_err: Option<String>, - to_delete_process_list: Option<(String, Vec<u32>)>, - pub is_frozen: bool, - last_key_press: Instant, - pub canvas_data: canvas::DisplayableData, - enable_grouping: bool, - pub data_collection: DataCollection, - pub process_search_state: ProcessSearchState, - pub delete_dialog_state: AppDeleteDialogState, - pub help_dialog_state: AppHelpDialogState, - pub app_config_fields: AppConfigFields, - pub is_expanded: bool, - pub is_resized: bool, - pub cpu_state: CpuState, - pub mem_state: MemState, - pub net_state: NetworkState, + pub process_sorting_type: processes::ProcessSorting, + pub process_sorting_reverse: bool, + pub update_process_gui: bool, + pub app_scroll_positions: AppScrollState, + pub current_widget_selected: WidgetPosition, + pub data: data_harvester::Data, + awaiting_second_char: bool, + second_char: Option<char>, + pub dd_err: Option<String>, + to_delete_process_list: Option<(String, Vec<u32>)>, + pub is_frozen: bool, + last_key_press: Instant, + pub canvas_data: canvas::DisplayableData, + enable_grouping: bool, + pub data_collection: DataCollection, + pub process_search_state: ProcessSearchState, + pub delete_dialog_state: AppDeleteDialogState, + pub help_dialog_state: AppHelpDialogState, + pub app_config_fields: AppConfigFields, + pub is_expanded: bool, + pub is_resized: bool, + pub cpu_state: CpuState, + pub mem_state: MemState, + pub net_state: NetworkState, } impl App { - #[allow(clippy::too_many_arguments)] - pub fn new( - show_average_cpu: bool, temperature_type: temperature::TemperatureType, - update_rate_in_milliseconds: u64, use_dot: bool, left_legend: bool, - use_current_cpu_total: bool, current_widget_selected: WidgetPosition, - show_disabled_data: bool, use_basic_mode: bool, - ) -> App { - App { - process_sorting_type: processes::ProcessSorting::CPU, - process_sorting_reverse: true, - update_process_gui: false, - current_widget_selected, - app_scroll_positions: AppScrollState::default(), - data: data_harvester::Data::default(), - awaiting_second_char: false, - second_char: None, - dd_err: None, - to_delete_process_list: None, - is_frozen: false, - last_key_press: Instant::now(), - canvas_data: canvas::DisplayableData::default(), - enable_grouping: false, - data_collection: DataCollection::default(), - process_search_state: ProcessSearchState::default(), - delete_dialog_state: AppDeleteDialogState::default(), - help_dialog_state: AppHelpDialogState::default(), - app_config_fields: AppConfigFields { - show_average_cpu, - temperature_type, - use_dot, - update_rate_in_milliseconds, - left_legend, - use_current_cpu_total, - show_disabled_data, - use_basic_mode - }, - is_expanded: false, - is_resized: false, - cpu_state: CpuState::default(), - mem_state: MemState::default(), - net_state: NetworkState::default(), - } - } - - pub fn reset(&mut self) { - self.reset_multi_tap_keys(); - self.help_dialog_state.is_showing_help = false; - self.delete_dialog_state.is_showing_dd = false; - if self.process_search_state.search_state.is_enabled { - self.current_widget_selected = WidgetPosition::Process; - self.process_search_state.search_state.is_enabled = false; - } - self.process_search_state.search_state.current_search_query = String::new(); - self.process_search_state.is_searching_with_pid = false; - self.to_delete_process_list = None; - self.dd_err = None; - } - - pub fn on_esc(&mut self) { - self.reset_multi_tap_keys(); - if self.is_in_dialog() { - self.help_dialog_state.is_showing_help = false; - self.help_dialog_state.current_category = AppHelpCategory::General; - self.delete_dialog_state.is_showing_dd = false; - self.delete_dialog_state.is_on_yes = false; - self.to_delete_process_list = None; - self.dd_err = None; - } else if self.is_filtering_or_searching() { - match self.current_widget_selected { - WidgetPosition::Process | WidgetPosition::ProcessSearch => { - if self.process_search_state.search_state.is_enabled { - self.current_widget_selected = WidgetPosition::Process; - self.process_search_state.search_state.is_enabled = false; - } - } - WidgetPosition::Cpu => { - self.cpu_state.is_showing_tray = false; - } - WidgetPosition::Mem => { - self.mem_state.is_showing_tray = false; - } - WidgetPosition::Network => { - self.net_state.is_showing_tray = false; - } - _ => {} - } - } else if self.is_expanded { - self.is_expanded = false; - self.is_resized = true; - } - } - - fn is_filtering_or_searching(&self) -> bool { - match self.current_widget_selected { - WidgetPosition::Cpu => self.cpu_state.is_showing_tray, - WidgetPosition::Mem => self.mem_state.is_showing_tray, - WidgetPosition::Network => self.net_state.is_showing_tray, - WidgetPosition::Process | WidgetPosition::ProcessSearch => { - self.process_search_state.search_state.is_enabled - } - _ => false, - } - } - - fn reset_multi_tap_keys(&mut self) { - self.awaiting_second_char = false; - self.second_char = None; - } - - fn is_in_dialog(&self) -> bool { - self.help_dialog_state.is_showing_help || self.delete_dialog_state.is_showing_dd - } - - pub fn toggle_grouping(&mut self) { - // Disallow usage whilst in a dialog and only in processes - if !self.is_in_dialog() { - if let WidgetPosition::Process = self.current_widget_selected { - self.enable_grouping = !(self.enable_grouping); - self.update_process_gui = true; - } - } - } - - pub fn on_tab(&mut self) { - match self.current_widget_selected { - WidgetPosition::Process => { - self.toggle_grouping(); - if self.is_grouped() { - self.search_with_name(); - } else { - self.update_process_gui = true; - } - } - WidgetPosition::ProcessSearch => { - if !self.is_grouped() { - if self.process_search_state.is_searching_with_pid { - self.search_with_name(); - } else { - self.search_with_pid(); - } - } - } - _ => {} - } - } - - pub fn is_grouped(&self) -> bool { - self.enable_grouping - } - - pub fn on_space(&mut self) { - match self.current_widget_selected { - WidgetPosition::Cpu => { - let curr_posn = self - .app_scroll_positions - .cpu_scroll_state - .current_scroll_position; - if self.cpu_state.is_showing_tray - && curr_posn < self.data_collection.cpu_harvest.len() as u64 - { - self.cpu_state.core_show_vec[curr_posn as usize] = - !self.cpu_state.core_show_vec[curr_posn as usize]; - } - } - WidgetPosition::Network => {} - _ => {} - } - } - - pub fn on_slash(&mut self) { - if !self.is_in_dialog() { - match self.current_widget_selected { - WidgetPosition::Process | WidgetPosition::ProcessSearch => { - // Toggle on - self.process_search_state.search_state.is_enabled = true; - self.current_widget_selected = WidgetPosition::ProcessSearch; - if self.is_grouped() { - self.search_with_name(); - } - } - WidgetPosition::Cpu => { - self.cpu_state.is_showing_tray = true; - } - // WidgetPosition::Mem => { - // self.mem_state.is_showing_tray = true; - // } - // WidgetPosition::Network => { - // self.net_state.is_showing_tray = true; - // } - _ => {} - } - } - } - - pub fn is_searching(&self) -> bool { - self.process_search_state.search_state.is_enabled - } - - pub fn is_in_search_widget(&self) -> bool { - if let WidgetPosition::ProcessSearch = self.current_widget_selected { - true - } else { - false - } - } - - pub fn search_with_pid(&mut self) { - if !self.is_in_dialog() && self.is_searching() { - self.process_search_state.is_searching_with_pid = true; - self.update_process_gui = true; - } - } - - pub fn search_with_name(&mut self) { - if !self.is_in_dialog() && self.is_searching() { - self.process_search_state.is_searching_with_pid = false; - self.update_process_gui = true; - } - } - - pub fn get_current_search_query(&self) -> &String { - &self.process_search_state.search_state.current_search_query - } - - pub fn toggle_ignore_case(&mut self) { - self.process_search_state.search_toggle_ignore_case(); - self.update_regex(); - self.update_process_gui = true; - } - - pub fn toggle_search_whole_word(&mut self) { - self.process_search_state.search_toggle_whole_word(); - self.update_regex(); - self.update_process_gui = true; - } - - pub fn toggle_search_regex(&mut self) { - self.process_search_state.search_toggle_regex(); - self.update_regex(); - self.update_process_gui = true; - } - - pub fn update_regex(&mut self) { - if self - .process_search_state - .search_state - .current_search_query - .is_empty() - { - self.process_search_state.search_state.is_invalid_search = false; - self.process_search_state.search_state.is_blank_search = true; - } else { - let regex_string = &self.process_search_state.search_state.current_search_query; - let escaped_regex: String; - let final_regex_string = &format!( - "{}{}{}{}", - if self.process_search_state.is_searching_whole_word { - "^" - } else { - "" - }, - if self.process_search_state.is_ignoring_case { - "(?i)" - } else { - "" - }, - if !self.process_search_state.is_searching_with_regex { - escaped_regex = regex::escape(regex_string); - &escaped_regex - } else { - regex_string - }, - if self.process_search_state.is_searching_whole_word { - "$" - } else { - "" - }, - ); - - let new_regex = regex::Regex::new(final_regex_string); - self.process_search_state.search_state.is_blank_search = false; - self.process_search_state.search_state.is_invalid_search = new_regex.is_err(); - - self.process_search_state.search_state.current_regex = Some(new_regex); - } - self.app_scroll_positions - .process_scroll_state - .previous_scroll_position = 0; - self.app_scroll_positions - .process_scroll_state - .current_scroll_position = 0; - } - - pub fn get_cursor_position(&self) -> usize { - self.process_search_state - .search_state - .grapheme_cursor - .cur_cursor() - } - - pub fn get_char_cursor_position(&self) -> usize { - self.process_search_state.search_state.char_cursor_position - } - - /// One of two functions allowed to run while in a dialog... - pub fn on_enter(&mut self) { - if self.delete_dialog_state.is_showing_dd { - if self.delete_dialog_state.is_on_yes { - // If within dd... - if self.dd_err.is_none() { - // Also ensure that we didn't just fail a dd... - let dd_result = self.kill_highlighted_process(); - self.delete_dialog_state.is_on_yes = false; - - // Check if there was an issue... if so, inform the user. - if let Err(dd_err) = dd_result { - self.dd_err = Some(dd_err.to_string()); - } else { - self.delete_dialog_state.is_showing_dd = false; - } - } - } else { - self.delete_dialog_state.is_showing_dd = false; - } - } else if !self.is_in_dialog() { - // Pop-out mode. We ignore if in process search. - - match self.current_widget_selected { - WidgetPosition::ProcessSearch => {} - _ => { - self.is_expanded = true; - self.is_resized = true; - } - } - } - } - - pub fn on_delete(&mut self) { - match self.current_widget_selected { - WidgetPosition::Process => self.start_dd(), - WidgetPosition::ProcessSearch => { - if self.process_search_state.search_state.is_enabled - && self.get_cursor_position() - < self - .process_search_state - .search_state - .current_search_query - .len() - { - self.process_search_state - .search_state - .current_search_query - .remove(self.get_cursor_position()); - - self.process_search_state.search_state.grapheme_cursor = GraphemeCursor::new( - self.get_cursor_position(), - self.process_search_state - .search_state - .current_search_query - .len(), - true, - ); - - self.update_regex(); - self.update_process_gui = true; - } - } - _ => {} - } - } - - /// Deletes an entire word till the next space or end - #[allow(unused_variables)] - pub fn skip_word_backspace(&mut self) { - if let WidgetPosition::ProcessSearch = self.current_widget_selected { - if self.process_search_state.search_state.is_enabled {} - } - } - - pub fn clear_search(&mut self) { - if let WidgetPosition::ProcessSearch = self.current_widget_selected { - self.update_process_gui = true; - self.process_search_state.search_state = AppSearchState::reset(); - } - } - - pub fn search_walk_forward(&mut self, start_position: usize) { - self.process_search_state - .search_state - .grapheme_cursor - .next_boundary( - &self.process_search_state.search_state.current_search_query[start_position..], - start_position, - ) - .unwrap(); // TODO: [UNWRAP] unwrap in this and walk_back seem sketch - } - - pub fn search_walk_back(&mut self, start_position: usize) { - self.process_search_state - .search_state - .grapheme_cursor - .prev_boundary( - &self.process_search_state.search_state.current_search_query[..start_position], - 0, - ) - .unwrap(); - } - - pub fn on_backspace(&mut self) { - if let WidgetPosition::ProcessSearch = self.current_widget_selected { - if self.process_search_state.search_state.is_enabled && self.get_cursor_position() > 0 { - self.search_walk_back(self.get_cursor_position()); - - let removed_char = self - .process_search_state - .search_state - .current_search_query - .remove(self.get_cursor_position()); - - self.process_search_state.search_state.grapheme_cursor = GraphemeCursor::new( - self.get_cursor_position(), - self.process_search_state - .search_state - .current_search_query - .len(), - true, - ); - - self.process_search_state.search_state.char_cursor_position -= - UnicodeWidthChar::width(removed_char).unwrap_or(0); - self.process_search_state.search_state.cursor_direction = CursorDirection::LEFT; - - self.update_regex(); - self.update_process_gui = true; - } - } - } - - pub fn get_current_regex_matcher( - &self, - ) -> &Option<std::result::Result<regex::Regex, regex::Error>> { - &self.process_search_state.search_state.current_regex - } - - pub fn on_up_key(&mut self) { - if !self.is_in_dialog() { - if let WidgetPosition::ProcessSearch = self.current_widget_selected { - } else { - self.decrement_position_count(); - } - } - } - - pub fn on_down_key(&mut self) { - if !self.is_in_dialog() { - if let WidgetPosition::ProcessSearch = self.current_widget_selected { - } else { - self.increment_position_count(); - } - } - } - - pub fn on_left_key(&mut self) { - if !self.is_in_dialog() { - if let WidgetPosition::ProcessSearch = self.current_widget_selected { - let prev_cursor = self.get_cursor_position(); - self.search_walk_back(self.get_cursor_position()); - if self.get_cursor_position() < prev_cursor { - let str_slice = &self.process_search_state.search_state.current_search_query - [self.get_cursor_position()..prev_cursor]; - self.process_search_state.search_state.char_cursor_position -= - UnicodeWidthStr::width(str_slice); - self.process_search_state.search_state.cursor_direction = CursorDirection::LEFT; - } - } - } else if self.delete_dialog_state.is_showing_dd && !self.delete_dialog_state.is_on_yes { - self.delete_dialog_state.is_on_yes = true; - } - } - - pub fn on_right_key(&mut self) { - if !self.is_in_dialog() { - if let WidgetPosition::ProcessSearch = self.current_widget_selected { - let prev_cursor = self.get_cursor_position(); - self.search_walk_forward(self.get_cursor_position()); - if self.get_cursor_position() > prev_cursor { - let str_slice = &self.process_search_state.search_state.current_search_query - [prev_cursor..self.get_cursor_position()]; - self.process_search_state.search_state.char_cursor_position += - UnicodeWidthStr::width(str_slice); - self.process_search_state.search_state.cursor_direction = - CursorDirection::RIGHT; - } - } - } else if self.delete_dialog_state.is_showing_dd && self.delete_dialog_state.is_on_yes { - self.delete_dialog_state.is_on_yes = false; - } - } - - pub fn skip_cursor_beginning(&mut self) { - if !self.is_in_dialog() { - if let WidgetPosition::ProcessSearch = self.current_widget_selected { - self.process_search_state.search_state.grapheme_cursor = GraphemeCursor::new( - 0, - self.process_search_state - .search_state - .current_search_query - .len(), - true, - ); - self.process_search_state.search_state.char_cursor_position = 0; - self.process_search_state.search_state.cursor_direction = CursorDirection::LEFT; - } - } - } - - pub fn skip_cursor_end(&mut self) { - if !self.is_in_dialog() { - if let WidgetPosition::ProcessSearch = self.current_widget_selected { - self.process_search_state.search_state.grapheme_cursor = GraphemeCursor::new( - self.process_search_state - .search_state - .current_search_query - .len(), - self.process_search_state - .search_state - .current_search_query - .len(), - true, - ); - self.process_search_state.search_state.char_cursor_position = - UnicodeWidthStr::width( - self.process_search_state - .search_state - .current_search_query - .as_str(), - ); - self.process_search_state.search_state.cursor_direction = CursorDirection::RIGHT; |