hi_doc_jumprope

Struct JumpRopeBuf

Source
pub struct JumpRopeBuf(/* private fields */);
Expand description

This struct provides an optimized wrapper around JumpRope which buffers adjacent incoming writes before forwarding them to the underlying JumpRope.

Most of the overhead of writing to a rope comes from finding the edit location in the rope and bookkeeping. Because text editing operations are usually sequential, by aggregating adjacent editing operations together we can amortize the cost of updating the underlying data structure itself. This improves performance by about 10x compared to inserting and deleting individual characters.

There is nothing jumprope-specific in this library. It could easily be adapted to wrap other rope libraries (like Ropey) too.

This API is still experimental. This library is only enabled by enabling the “buffered’ feature.

Implementations§

Source§

impl JumpRopeBuf

Source

pub fn with_rope(rope: JumpRope) -> Self

Source

pub fn new() -> Self

Source

pub fn new_from_str(s: &str) -> Self

Source

pub fn insert(&mut self, pos: usize, content: &str)

Insert new content into the rope at the specified position. This method is semantically equivalent to JumpRope::insert. The only difference is that here we buffer the incoming edit.

Source

pub fn remove(&mut self, range: Range<usize>)

Remove content from the rope at the specified position. This method is semantically equivalent to JumpRope::remove. The only difference is that here we buffer the incoming remove operation.

Source

pub fn len_chars(&self) -> usize

Return the length of the rope in unicode characters. Note this is not the same as either the number of bytes the characters take, or the number of grapheme clusters in the string.

This method returns the length in constant-time (O(1)).

Source

pub fn len_bytes(&self) -> usize

Get the number of bytes used for the UTF8 representation of the rope. This will always match the .len() property of the equivalent String.

Source

pub fn is_empty(&self) -> bool

Source

pub fn into_inner(self) -> JumpRope

Consume the JumpRopeBuf, flush any buffered operations and return the contained JumpRope.

Source

pub fn borrow(&self) -> Ref<'_, JumpRope>

Flush changes into the rope and return a borrowed reference to the rope itself. This makes it easy to call any methods on the underlying rope which aren’t already exposed through the buffered API.

§Panics

borrow panics if the value is currently borrowed already.

Trait Implementations§

Source§

impl AsMut<JumpRope> for JumpRopeBuf

Source§

fn as_mut(&mut self) -> &mut JumpRope

Flush changes into the rope and mutably borrow the rope.

Source§

impl Clone for JumpRopeBuf

Source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for JumpRopeBuf

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for JumpRopeBuf

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl Display for JumpRopeBuf

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl From<JumpRope> for JumpRopeBuf

Source§

fn from(rope: JumpRope) -> Self

Converts to this type from the input type.
Source§

impl<S: AsRef<str>> From<S> for JumpRopeBuf

Source§

fn from(str: S) -> Self

Converts to this type from the input type.
Source§

impl PartialEq<JumpRope> for JumpRopeBuf

Source§

fn eq(&self, other: &JumpRope) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialEq<String> for &JumpRopeBuf

Source§

fn eq(&self, other: &String) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<T: AsRef<str>> PartialEq<T> for JumpRopeBuf

Source§

fn eq(&self, other: &T) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialEq<str> for JumpRopeBuf

Source§

fn eq(&self, other: &str) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialEq for JumpRopeBuf

Source§

fn eq(&self, other: &JumpRopeBuf) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Eq for JumpRopeBuf

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V