2021-03-10 12:50:46 +04:00
|
|
|
use crate::RopeSlice;
|
|
|
|
|
2021-03-11 11:14:52 +04:00
|
|
|
pub fn find_nth_next(
|
|
|
|
text: RopeSlice,
|
|
|
|
ch: char,
|
|
|
|
mut pos: usize,
|
|
|
|
n: usize,
|
|
|
|
inclusive: bool,
|
|
|
|
) -> Option<usize> {
|
2021-06-02 08:14:55 +04:00
|
|
|
if pos >= text.len_chars() {
|
|
|
|
return None;
|
|
|
|
}
|
|
|
|
|
2021-03-10 12:50:46 +04:00
|
|
|
// start searching right after pos
|
2021-03-11 05:44:38 +04:00
|
|
|
let mut chars = text.chars_at(pos + 1);
|
2021-03-10 12:50:46 +04:00
|
|
|
|
|
|
|
for _ in 0..n {
|
|
|
|
loop {
|
2021-03-11 05:44:38 +04:00
|
|
|
let c = chars.next()?;
|
|
|
|
|
|
|
|
pos += 1;
|
|
|
|
|
|
|
|
if c == ch {
|
|
|
|
break;
|
2021-03-10 12:50:46 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-03-11 05:44:38 +04:00
|
|
|
|
2021-03-11 11:14:52 +04:00
|
|
|
if !inclusive {
|
|
|
|
pos -= 1;
|
|
|
|
}
|
|
|
|
|
2021-03-11 05:44:38 +04:00
|
|
|
Some(pos)
|
2021-03-10 12:50:46 +04:00
|
|
|
}
|
|
|
|
|
2021-03-11 11:14:52 +04:00
|
|
|
pub fn find_nth_prev(
|
|
|
|
text: RopeSlice,
|
|
|
|
ch: char,
|
|
|
|
mut pos: usize,
|
|
|
|
n: usize,
|
|
|
|
inclusive: bool,
|
|
|
|
) -> Option<usize> {
|
2021-03-10 12:50:46 +04:00
|
|
|
// start searching right before pos
|
2021-03-11 05:44:38 +04:00
|
|
|
let mut chars = text.chars_at(pos.saturating_sub(1));
|
2021-03-10 12:50:46 +04:00
|
|
|
|
|
|
|
for _ in 0..n {
|
|
|
|
loop {
|
2021-03-11 05:44:38 +04:00
|
|
|
let c = chars.prev()?;
|
|
|
|
|
|
|
|
pos = pos.saturating_sub(1);
|
|
|
|
|
|
|
|
if c == ch {
|
|
|
|
break;
|
2021-03-10 12:50:46 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-03-11 05:44:38 +04:00
|
|
|
|
2021-03-11 11:14:52 +04:00
|
|
|
if !inclusive {
|
|
|
|
pos -= 1;
|
|
|
|
}
|
|
|
|
|
2021-03-11 05:44:38 +04:00
|
|
|
Some(pos)
|
2021-03-10 12:50:46 +04:00
|
|
|
}
|