From 51832b02c9ff3735175dd36b4d87478289402da2 Mon Sep 17 00:00:00 2001 From: Michael Davis Date: Sun, 26 Jan 2025 19:16:02 -0500 Subject: [PATCH] core: Remove unused byte index grapheme functions --- helix-core/src/graphemes.rs | 72 ++----------------------------------- 1 file changed, 3 insertions(+), 69 deletions(-) diff --git a/helix-core/src/graphemes.rs b/helix-core/src/graphemes.rs index 4ca85d315..98dfa365f 100644 --- a/helix-core/src/graphemes.rs +++ b/helix-core/src/graphemes.rs @@ -119,6 +119,9 @@ pub fn grapheme_width(g: &str) -> usize { } } +// NOTE: for byte indexing versions of these functions see `RopeSliceExt`'s +// `floor_grapheme_boundary` and `ceil_grapheme_boundary` and the rope grapheme iterators. + #[must_use] pub fn nth_prev_grapheme_boundary(slice: RopeSlice, char_idx: usize, n: usize) -> usize { // Bounds check @@ -208,43 +211,6 @@ pub fn nth_next_grapheme_boundary(slice: RopeSlice, char_idx: usize, n: usize) - chunk_char_idx + tmp } -#[must_use] -pub fn nth_next_grapheme_boundary_byte(slice: RopeSlice, mut byte_idx: usize, n: usize) -> usize { - // Bounds check - debug_assert!(byte_idx <= slice.len_bytes()); - - // Get the chunk with our byte index in it. - let (mut chunk, mut chunk_byte_idx, mut _chunk_char_idx, _) = slice.chunk_at_byte(byte_idx); - - // Set up the grapheme cursor. - let mut gc = GraphemeCursor::new(byte_idx, slice.len_bytes(), true); - - // Find the nth next grapheme cluster boundary. - for _ in 0..n { - loop { - match gc.next_boundary(chunk, chunk_byte_idx) { - Ok(None) => return slice.len_bytes(), - Ok(Some(n)) => { - byte_idx = n; - break; - } - Err(GraphemeIncomplete::NextChunk) => { - chunk_byte_idx += chunk.len(); - let (a, _, _c, _) = slice.chunk_at_byte(chunk_byte_idx); - chunk = a; - // chunk_char_idx = c; - } - Err(GraphemeIncomplete::PreContext(n)) => { - let ctx_chunk = slice.chunk_at_byte(n - 1).0; - gc.provide_context(ctx_chunk, n - ctx_chunk.len()); - } - _ => unreachable!(), - } - } - } - byte_idx -} - /// Finds the next grapheme boundary after the given char position. #[must_use] #[inline(always)] @@ -252,13 +218,6 @@ pub fn next_grapheme_boundary(slice: RopeSlice, char_idx: usize) -> usize { nth_next_grapheme_boundary(slice, char_idx, 1) } -/// Finds the next grapheme boundary after the given byte position. -#[must_use] -#[inline(always)] -pub fn next_grapheme_boundary_byte(slice: RopeSlice, byte_idx: usize) -> usize { - nth_next_grapheme_boundary_byte(slice, byte_idx, 1) -} - /// Returns the passed char index if it's already a grapheme boundary, /// or the next grapheme boundary char index if not. #[must_use] @@ -311,31 +270,6 @@ pub fn is_grapheme_boundary(slice: RopeSlice, char_idx: usize) -> bool { } } -/// Returns whether the given byte position is a grapheme boundary. -#[must_use] -pub fn is_grapheme_boundary_byte(slice: RopeSlice, byte_idx: usize) -> bool { - // Bounds check - debug_assert!(byte_idx <= slice.len_bytes()); - - // Get the chunk with our byte index in it. - let (chunk, chunk_byte_idx, _, _) = slice.chunk_at_byte(byte_idx); - - // Set up the grapheme cursor. - let mut gc = GraphemeCursor::new(byte_idx, slice.len_bytes(), true); - - // Determine if the given position is a grapheme cluster boundary. - loop { - match gc.is_boundary(chunk, chunk_byte_idx) { - Ok(n) => return n, - Err(GraphemeIncomplete::PreContext(n)) => { - let (ctx_chunk, ctx_byte_start, _, _) = slice.chunk_at_byte(n - 1); - gc.provide_context(ctx_chunk, ctx_byte_start); - } - Err(_) => unreachable!(), - } - } -} - /// An iterator over the graphemes of a `RopeSlice`. #[derive(Clone)] pub struct RopeGraphemes<'a> {