feat(ui): treat slashes as word separators in prompt (#2315)

When fiddling with paths in a :o prompt, one usually would want Ctrl-W to erase a path segment
rather than the whole path. This is how Ctrl-W works in e.g. (neo)vim out of the box.
pull/2352/head
unrelentingtech 3 years ago committed by GitHub
parent 0106173375
commit 2687b8fb3b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -56,6 +56,10 @@ pub enum Movement {
None, None,
} }
fn is_word_sep(c: char) -> bool {
c == std::path::MAIN_SEPARATOR || c.is_whitespace()
}
impl Prompt { impl Prompt {
pub fn new( pub fn new(
prompt: Cow<'static, str>, prompt: Cow<'static, str>,
@ -118,7 +122,7 @@ impl Prompt {
let mut found = None; let mut found = None;
for prev in (0..char_position - 1).rev() { for prev in (0..char_position - 1).rev() {
if char_indices[prev].1.is_whitespace() { if is_word_sep(char_indices[prev].1) {
found = Some(prev + 1); found = Some(prev + 1);
break; break;
} }
@ -141,14 +145,14 @@ impl Prompt {
for _ in 0..rep { for _ in 0..rep {
// Skip any non-whitespace characters // Skip any non-whitespace characters
while char_position < char_indices.len() while char_position < char_indices.len()
&& !char_indices[char_position].1.is_whitespace() && !is_word_sep(char_indices[char_position].1)
{ {
char_position += 1; char_position += 1;
} }
// Skip any whitespace characters // Skip any whitespace characters
while char_position < char_indices.len() while char_position < char_indices.len()
&& char_indices[char_position].1.is_whitespace() && is_word_sep(char_indices[char_position].1)
{ {
char_position += 1; char_position += 1;
} }

Loading…
Cancel
Save