From 658c71ceaa3d3eddbb4187915cfb9e4c78055b52 Mon Sep 17 00:00:00 2001 From: Chinmay Dalal Date: Fri, 3 Nov 2023 08:27:55 +0530 Subject: [PATCH 1/2] CwdAwareHinter: remove cwd filter when there are no results --- src/hinter/cwd_aware.rs | 34 ++++++++++++++++++++++++---------- 1 file changed, 24 insertions(+), 10 deletions(-) diff --git a/src/hinter/cwd_aware.rs b/src/hinter/cwd_aware.rs index 9101e2c6..e27b4727 100644 --- a/src/hinter/cwd_aware.rs +++ b/src/hinter/cwd_aware.rs @@ -24,7 +24,7 @@ impl Hinter for CwdAwareHinter { use_ansi_coloring: bool, ) -> String { self.current_hint = if line.chars().count() >= self.min_chars { - history + let with_cwd = history .search(SearchQuery::last_with_prefix_and_cwd( line.to_string(), history.session(), @@ -39,15 +39,29 @@ impl Hinter for CwdAwareHinter { Err(err) } }) - .expect("todo: error handling") - .get(0) - .map_or_else(String::new, |entry| { - entry - .command_line - .get(line.len()..) - .unwrap_or_default() - .to_string() - }) + .expect("todo: error handling"); + if !with_cwd.is_empty() { + with_cwd[0] + .command_line + .get(line.len()..) + .unwrap_or_default() + .to_string() + } else { + history + .search(SearchQuery::last_with_prefix( + line.to_string(), + history.session(), + )) + .expect("todo: error handling") + .get(0) + .map_or_else(String::new, |entry| { + entry + .command_line + .get(line.len()..) + .unwrap_or_default() + .to_string() + }) + } } else { String::new() }; From 476593397ad515410e5ac366ca9cd09c090c89c4 Mon Sep 17 00:00:00 2001 From: Chinmay Dalal Date: Mon, 13 Nov 2023 18:16:33 +0530 Subject: [PATCH 2/2] remove panicking functions --- src/hinter/cwd_aware.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/hinter/cwd_aware.rs b/src/hinter/cwd_aware.rs index e27b4727..c5c43815 100644 --- a/src/hinter/cwd_aware.rs +++ b/src/hinter/cwd_aware.rs @@ -39,7 +39,7 @@ impl Hinter for CwdAwareHinter { Err(err) } }) - .expect("todo: error handling"); + .unwrap_or_default(); if !with_cwd.is_empty() { with_cwd[0] .command_line @@ -52,7 +52,7 @@ impl Hinter for CwdAwareHinter { line.to_string(), history.session(), )) - .expect("todo: error handling") + .unwrap_or_default() .get(0) .map_or_else(String::new, |entry| { entry