pub struct RopeSlice<'a>(/* private fields */);
Expand description
An immutable view into part of a Rope
.
Just like standard &str
slices, RopeSlice
s behave as if the text in
their range is the only text that exists. All indexing is relative to
the start of their range, and all iterators and methods that return text
truncate that text to the range of the slice.
In other words, the behavior of a RopeSlice
is always identical to that
of a full Rope
created from the same text range. Nothing should be
surprising here.
Implementations§
Source§impl<'a> RopeSlice<'a>
impl<'a> RopeSlice<'a>
Sourcepub fn len_utf16_cu(&self) -> usize
pub fn len_utf16_cu(&self) -> usize
Total number of utf16 code units that would be in the RopeSlice
if
it were encoded as utf16.
Ropey stores text internally as utf8, but sometimes it is necessary to interact with external APIs that still use utf16. This function is primarily intended for such situations, and is otherwise not very useful.
Runs in O(1) time.
Sourcepub fn byte_to_char(&self, byte_idx: usize) -> usize
pub fn byte_to_char(&self, byte_idx: usize) -> usize
Returns the char index of the given byte.
Notes:
- If the byte is in the middle of a multi-byte char, returns the index of the char that the byte belongs to.
byte_idx
can be one-past-the-end, which will return one-past-the-end char index.
Runs in O(log N) time.
§Panics
Panics if byte_idx
is out of bounds (i.e. byte_idx > len_bytes()
).
Sourcepub fn byte_to_line(&self, byte_idx: usize) -> usize
pub fn byte_to_line(&self, byte_idx: usize) -> usize
Returns the line index of the given byte.
Notes:
- Lines are zero-indexed. This is functionally equivalent to counting the line endings before the specified byte.
byte_idx
can be one-past-the-end, which will return the last line index.
Runs in O(log N) time.
§Panics
Panics if byte_idx
is out of bounds (i.e. byte_idx > len_bytes()
).
Sourcepub fn char_to_byte(&self, char_idx: usize) -> usize
pub fn char_to_byte(&self, char_idx: usize) -> usize
Returns the byte index of the given char.
Notes:
char_idx
can be one-past-the-end, which will return one-past-the-end byte index.
Runs in O(log N) time.
§Panics
Panics if char_idx
is out of bounds (i.e. char_idx > len_chars()
).
Sourcepub fn char_to_line(&self, char_idx: usize) -> usize
pub fn char_to_line(&self, char_idx: usize) -> usize
Returns the line index of the given char.
Notes:
- Lines are zero-indexed. This is functionally equivalent to counting the line endings before the specified char.
char_idx
can be one-past-the-end, which will return the last line index.
Runs in O(log N) time.
§Panics
Panics if char_idx
is out of bounds (i.e. char_idx > len_chars()
).
Sourcepub fn char_to_utf16_cu(&self, char_idx: usize) -> usize
pub fn char_to_utf16_cu(&self, char_idx: usize) -> usize
Returns the utf16 code unit index of the given char.
Ropey stores text internally as utf8, but sometimes it is necessary to interact with external APIs that still use utf16. This function is primarily intended for such situations, and is otherwise not very useful.
Runs in O(log N) time.
§Panics
Panics if char_idx
is out of bounds (i.e. char_idx > len_chars()
).
Sourcepub fn utf16_cu_to_char(&self, utf16_cu_idx: usize) -> usize
pub fn utf16_cu_to_char(&self, utf16_cu_idx: usize) -> usize
Returns the char index of the given utf16 code unit.
Ropey stores text internally as utf8, but sometimes it is necessary to interact with external APIs that still use utf16. This function is primarily intended for such situations, and is otherwise not very useful.
Note: if the utf16 code unit is in the middle of a char, returns the index of the char that it belongs to.
Runs in O(log N) time.
§Panics
Panics if utf16_cu_idx
is out of bounds
(i.e. utf16_cu_idx > len_utf16_cu()
).
Sourcepub fn line_to_byte(&self, line_idx: usize) -> usize
pub fn line_to_byte(&self, line_idx: usize) -> usize
Returns the byte index of the start of the given line.
Notes:
- Lines are zero-indexed.
line_idx
can be one-past-the-end, which will return one-past-the-end byte index.
Runs in O(log N) time.
§Panics
Panics if line_idx
is out of bounds (i.e. line_idx > len_lines()
).
Sourcepub fn line_to_char(&self, line_idx: usize) -> usize
pub fn line_to_char(&self, line_idx: usize) -> usize
Returns the char index of the start of the given line.
Notes:
- Lines are zero-indexed.
line_idx
can be one-past-the-end, which will return one-past-the-end char index.
Runs in O(log N) time.
§Panics
Panics if line_idx
is out of bounds (i.e. line_idx > len_lines()
).
Sourcepub fn byte(&self, byte_idx: usize) -> u8
pub fn byte(&self, byte_idx: usize) -> u8
Returns the byte at byte_idx
.
Runs in O(log N) time.
§Panics
Panics if byte_idx
is out of bounds (i.e. byte_idx >= len_bytes()
).
Sourcepub fn char(&self, char_idx: usize) -> char
pub fn char(&self, char_idx: usize) -> char
Returns the char at char_idx
.
Runs in O(log N) time.
§Panics
Panics if char_idx
is out of bounds (i.e. char_idx >= len_chars()
).
Sourcepub fn line(&self, line_idx: usize) -> RopeSlice<'a>
pub fn line(&self, line_idx: usize) -> RopeSlice<'a>
Returns the line at line_idx
.
Note: lines are zero-indexed.
Runs in O(log N) time.
§Panics
Panics if line_idx
is out of bounds (i.e. line_idx >= len_lines()
).
Sourcepub fn chunk_at_byte(&self, byte_idx: usize) -> (&'a str, usize, usize, usize)
pub fn chunk_at_byte(&self, byte_idx: usize) -> (&'a str, usize, usize, usize)
Returns the chunk containing the given byte index.
Also returns the byte and char indices of the beginning of the chunk and the index of the line that the chunk starts on.
Note: for convenience, a one-past-the-end byte_idx
returns the last
chunk of the RopeSlice
.
The return value is organized as
(chunk, chunk_byte_idx, chunk_char_idx, chunk_line_idx)
.
Runs in O(log N) time.
§Panics
Panics if byte_idx
is out of bounds (i.e. byte_idx > len_bytes()
).
Sourcepub fn chunk_at_char(&self, char_idx: usize) -> (&'a str, usize, usize, usize)
pub fn chunk_at_char(&self, char_idx: usize) -> (&'a str, usize, usize, usize)
Returns the chunk containing the given char index.
Also returns the byte and char indices of the beginning of the chunk and the index of the line that the chunk starts on.
Note: for convenience, a one-past-the-end char_idx
returns the last
chunk of the RopeSlice
.
The return value is organized as
(chunk, chunk_byte_idx, chunk_char_idx, chunk_line_idx)
.
Runs in O(log N) time.
§Panics
Panics if char_idx
is out of bounds (i.e. char_idx > len_chars()
).
Sourcepub fn chunk_at_line_break(
&self,
line_break_idx: usize,
) -> (&'a str, usize, usize, usize)
pub fn chunk_at_line_break( &self, line_break_idx: usize, ) -> (&'a str, usize, usize, usize)
Returns the chunk containing the given line break.
Also returns the byte and char indices of the beginning of the chunk and the index of the line that the chunk starts on.
Note: for convenience, both the beginning and end of the slice are
considered line breaks for the purposes of indexing. For example, in
the string "Hello \n world!"
0 would give the first chunk, 1 would
give the chunk containing the newline character, and 2 would give the
last chunk.
The return value is organized as
(chunk, chunk_byte_idx, chunk_char_idx, chunk_line_idx)
.
Runs in O(log N) time.
§Panics
Panics if line_break_idx
is out of bounds (i.e. line_break_idx > len_lines()
).
Sourcepub fn as_str(&self) -> Option<&'a str>
pub fn as_str(&self) -> Option<&'a str>
Returns the entire contents of the RopeSlice
as a &str
if
possible.
This is useful for optimizing cases where the slice is only a few characters or words, and therefore has a high chance of being contiguous in memory.
For large slices this method will typically fail and return None
because large slices usually cross chunk boundaries in the rope.
(Also see the From
impl for converting to a Cow<str>
.)
Runs in O(1) time.
Sourcepub fn slice<R>(&self, char_range: R) -> RopeSlice<'a>where
R: RangeBounds<usize>,
pub fn slice<R>(&self, char_range: R) -> RopeSlice<'a>where
R: RangeBounds<usize>,
Returns a sub-slice of the RopeSlice
in the given char index range.
Uses range syntax, e.g. 2..7
, 2..
, etc.
Runs in O(log N) time.
§Panics
Panics if the start of the range is greater than the end, or the end
is out of bounds (i.e. end > len_chars()
).
Sourcepub fn byte_slice<R>(&self, byte_range: R) -> RopeSlice<'a>where
R: RangeBounds<usize>,
pub fn byte_slice<R>(&self, byte_range: R) -> RopeSlice<'a>where
R: RangeBounds<usize>,
Returns a sub-slice of the RopeSlice
in the given byte index range.
Uses range syntax, e.g. 2..7
, 2..
, etc.
Runs in O(log N) time.
§Panics
Panics if:
- The start of the range is greater than the end.
- The end is out of bounds (i.e.
end > len_bytes()
). - The range doesn’t align with char boundaries.
Sourcepub fn bytes(&self) -> Bytes<'a> ⓘ
pub fn bytes(&self) -> Bytes<'a> ⓘ
Creates an iterator over the bytes of the RopeSlice
.
Runs in O(log N) time.
Sourcepub fn bytes_at(&self, byte_idx: usize) -> Bytes<'a> ⓘ
pub fn bytes_at(&self, byte_idx: usize) -> Bytes<'a> ⓘ
Creates an iterator over the bytes of the RopeSlice
, starting at
byte byte_idx
.
If byte_idx == len_bytes()
then an iterator at the end of the
RopeSlice
is created (i.e. next()
will return None
).
Runs in O(log N) time.
§Panics
Panics if byte_idx
is out of bounds (i.e. byte_idx > len_bytes()
).
Sourcepub fn chars(&self) -> Chars<'a> ⓘ
pub fn chars(&self) -> Chars<'a> ⓘ
Creates an iterator over the chars of the RopeSlice
.
Runs in O(log N) time.
Sourcepub fn chars_at(&self, char_idx: usize) -> Chars<'a> ⓘ
pub fn chars_at(&self, char_idx: usize) -> Chars<'a> ⓘ
Creates an iterator over the chars of the RopeSlice
, starting at
char char_idx
.
If char_idx == len_chars()
then an iterator at the end of the
RopeSlice
is created (i.e. next()
will return None
).
Runs in O(log N) time.
§Panics
Panics if char_idx
is out of bounds (i.e. char_idx > len_chars()
).
Sourcepub fn lines(&self) -> Lines<'a> ⓘ
pub fn lines(&self) -> Lines<'a> ⓘ
Creates an iterator over the lines of the RopeSlice
.
Runs in O(log N) time.
Sourcepub fn lines_at(&self, line_idx: usize) -> Lines<'a> ⓘ
pub fn lines_at(&self, line_idx: usize) -> Lines<'a> ⓘ
Creates an iterator over the lines of the RopeSlice
, starting at
line line_idx
.
If line_idx == len_lines()
then an iterator at the end of the
RopeSlice
is created (i.e. next()
will return None
).
Runs in O(log N) time.
§Panics
Panics if line_idx
is out of bounds (i.e. line_idx > len_lines()
).
Sourcepub fn chunks(&self) -> Chunks<'a> ⓘ
pub fn chunks(&self) -> Chunks<'a> ⓘ
Creates an iterator over the chunks of the RopeSlice
.
Runs in O(log N) time.
Sourcepub fn chunks_at_byte(
&self,
byte_idx: usize,
) -> (Chunks<'a>, usize, usize, usize)
pub fn chunks_at_byte( &self, byte_idx: usize, ) -> (Chunks<'a>, usize, usize, usize)
Creates an iterator over the chunks of the RopeSlice
, with the
iterator starting at the byte containing byte_idx
.
Also returns the byte and char indices of the beginning of the first chunk to be yielded, and the index of the line that chunk starts on.
If byte_idx == len_bytes()
an iterator at the end of the RopeSlice
(yielding None
on a call to next()
) is created.
The return value is organized as
(iterator, chunk_byte_idx, chunk_char_idx, chunk_line_idx)
.
Runs in O(log N) time.
§Panics
Panics if byte_idx
is out of bounds (i.e. byte_idx > len_bytes()
).
Sourcepub fn chunks_at_char(
&self,
char_idx: usize,
) -> (Chunks<'a>, usize, usize, usize)
pub fn chunks_at_char( &self, char_idx: usize, ) -> (Chunks<'a>, usize, usize, usize)
Creates an iterator over the chunks of the RopeSlice
, with the
iterator starting on the chunk containing char_idx
.
Also returns the byte and char indices of the beginning of the first chunk to be yielded, and the index of the line that chunk starts on.
If char_idx == len_chars()
an iterator at the end of the RopeSlice
(yielding None
on a call to next()
) is created.
The return value is organized as
(iterator, chunk_byte_idx, chunk_char_idx, chunk_line_idx)
.
Runs in O(log N) time.
§Panics
Panics if char_idx
is out of bounds (i.e. char_idx > len_chars()
).
Sourcepub fn chunks_at_line_break(
&self,
line_break_idx: usize,
) -> (Chunks<'a>, usize, usize, usize)
pub fn chunks_at_line_break( &self, line_break_idx: usize, ) -> (Chunks<'a>, usize, usize, usize)
Creates an iterator over the chunks of the RopeSlice
, with the
iterator starting at the chunk containing line_break_idx
.
Also returns the byte and char indices of the beginning of the first chunk to be yielded, and the index of the line that chunk starts on.
Note: for convenience, both the beginning and end of the RopeSlice
are
considered line breaks for the purposes of indexing. For example, in
the string "Hello \n world!"
0 would create an iterator starting on
the first chunk, 1 would create an iterator starting on the chunk
containing the newline character, and 2 would create an iterator at
the end of the RopeSlice
(yielding None
on a call to next()
).
The return value is organized as
(iterator, chunk_byte_idx, chunk_char_idx, chunk_line_idx)
.
Runs in O(log N) time.
§Panics
Panics if line_break_idx
is out of bounds (i.e. line_break_idx > len_lines()
).
Source§impl<'a> RopeSlice<'a>
impl<'a> RopeSlice<'a>
§Non-Panicking
The methods in this impl block provide non-panicking versions of
RopeSlice
’s panicking methods. They return either Option::None
or
Result::Err()
when their panicking counterparts would have panicked.
Sourcepub fn try_byte_to_char(&self, byte_idx: usize) -> Result<usize>
pub fn try_byte_to_char(&self, byte_idx: usize) -> Result<usize>
Non-panicking version of byte_to_char()
.
Sourcepub fn try_byte_to_line(&self, byte_idx: usize) -> Result<usize>
pub fn try_byte_to_line(&self, byte_idx: usize) -> Result<usize>
Non-panicking version of byte_to_line()
.
Sourcepub fn try_char_to_byte(&self, char_idx: usize) -> Result<usize>
pub fn try_char_to_byte(&self, char_idx: usize) -> Result<usize>
Non-panicking version of char_to_byte()
.
Sourcepub fn try_char_to_line(&self, char_idx: usize) -> Result<usize>
pub fn try_char_to_line(&self, char_idx: usize) -> Result<usize>
Non-panicking version of char_to_line()
.
Sourcepub fn try_char_to_utf16_cu(&self, char_idx: usize) -> Result<usize>
pub fn try_char_to_utf16_cu(&self, char_idx: usize) -> Result<usize>
Non-panicking version of char_to_utf16_cu()
.
Sourcepub fn try_utf16_cu_to_char(&self, utf16_cu_idx: usize) -> Result<usize>
pub fn try_utf16_cu_to_char(&self, utf16_cu_idx: usize) -> Result<usize>
Non-panicking version of utf16_cu_to_char()
.
Sourcepub fn try_line_to_byte(&self, line_idx: usize) -> Result<usize>
pub fn try_line_to_byte(&self, line_idx: usize) -> Result<usize>
Non-panicking version of line_to_byte()
.
Sourcepub fn try_line_to_char(&self, line_idx: usize) -> Result<usize>
pub fn try_line_to_char(&self, line_idx: usize) -> Result<usize>
Non-panicking version of line_to_char()
.
Sourcepub fn get_line(&self, line_idx: usize) -> Option<RopeSlice<'a>>
pub fn get_line(&self, line_idx: usize) -> Option<RopeSlice<'a>>
Non-panicking version of line()
.
Sourcepub fn try_chunk_at_byte(
&self,
byte_idx: usize,
) -> Result<(&'a str, usize, usize, usize)>
pub fn try_chunk_at_byte( &self, byte_idx: usize, ) -> Result<(&'a str, usize, usize, usize)>
Non-panicking version of chunk_at_byte()
.
Sourcepub fn get_chunk_at_char(
&self,
char_idx: usize,
) -> Option<(&'a str, usize, usize, usize)>
pub fn get_chunk_at_char( &self, char_idx: usize, ) -> Option<(&'a str, usize, usize, usize)>
Non-panicking version of chunk_at_char()
.
Sourcepub fn get_chunk_at_line_break(
&self,
line_break_idx: usize,
) -> Option<(&'a str, usize, usize, usize)>
pub fn get_chunk_at_line_break( &self, line_break_idx: usize, ) -> Option<(&'a str, usize, usize, usize)>
Non-panicking version of chunk_at_line_break()
.
Sourcepub fn get_slice<R>(&self, char_range: R) -> Option<RopeSlice<'a>>where
R: RangeBounds<usize>,
pub fn get_slice<R>(&self, char_range: R) -> Option<RopeSlice<'a>>where
R: RangeBounds<usize>,
Non-panicking version of slice()
.
Sourcepub fn get_byte_slice<R>(&self, byte_range: R) -> Option<RopeSlice<'a>>where
R: RangeBounds<usize>,
pub fn get_byte_slice<R>(&self, byte_range: R) -> Option<RopeSlice<'a>>where
R: RangeBounds<usize>,
Non-panicking version of byte_slice()
.
Sourcepub fn get_bytes_at(&self, byte_idx: usize) -> Option<Bytes<'a>>
pub fn get_bytes_at(&self, byte_idx: usize) -> Option<Bytes<'a>>
Non-panicking version of bytes_at()
.
Sourcepub fn get_chars_at(&self, char_idx: usize) -> Option<Chars<'a>>
pub fn get_chars_at(&self, char_idx: usize) -> Option<Chars<'a>>
Non-panicking version of chars_at()
.
Sourcepub fn get_lines_at(&self, line_idx: usize) -> Option<Lines<'a>>
pub fn get_lines_at(&self, line_idx: usize) -> Option<Lines<'a>>
Non-panicking version of lines_at()
.
Sourcepub fn get_chunks_at_byte(
&self,
byte_idx: usize,
) -> Option<(Chunks<'a>, usize, usize, usize)>
pub fn get_chunks_at_byte( &self, byte_idx: usize, ) -> Option<(Chunks<'a>, usize, usize, usize)>
Non-panicking version of chunks_at_byte()
.
Sourcepub fn get_chunks_at_char(
&self,
char_idx: usize,
) -> Option<(Chunks<'a>, usize, usize, usize)>
pub fn get_chunks_at_char( &self, char_idx: usize, ) -> Option<(Chunks<'a>, usize, usize, usize)>
Non-panicking version of chunks_at_char()
.
Sourcepub fn get_chunks_at_line_break(
&self,
line_break_idx: usize,
) -> Option<(Chunks<'a>, usize, usize, usize)>
pub fn get_chunks_at_line_break( &self, line_break_idx: usize, ) -> Option<(Chunks<'a>, usize, usize, usize)>
Non-panicking version of chunks_at_line_break()
.
Trait Implementations§
Source§impl<'a> From<&'a str> for RopeSlice<'a>
impl<'a> From<&'a str> for RopeSlice<'a>
Creates a RopeSlice
directly from a string slice.
The useful applications of this are actually somewhat narrow. It is
intended primarily as an aid when implementing additional functionality
on top of Ropey, where you may already have access to a rope chunk and
want to directly create a RopeSlice
from it, avoiding the overhead of
going through the slicing APIs.
Although it is possible to use this to create RopeSlice
s from
arbitrary strings, doing so is not especially useful. For example,
Rope
s and RopeSlice
s can already be directly compared for
equality with strings and string slices.
Runs in O(N) time, where N is the length of the string slice.
Source§impl<'a> From<RopeSlice<'a>> for Cow<'a, str>
impl<'a> From<RopeSlice<'a>> for Cow<'a, str>
Attempts to borrow the contents of the slice, but will convert to an owned string if the contents is not contiguous in memory.
Runs in best case O(1), worst case O(N).