Skip to main content

CursorAffinity

Enum CursorAffinity 

Source
pub enum CursorAffinity {
    Downstream,
    Upstream,
}
Expand description

Disambiguates the two visual placements a single character position can have at a soft-wrap boundary. A long paragraph that wraps across lines K and K+1 has one character position N that sits at both the END of line K and the START of line K+1; affinity picks which one the caret renders at and which line Home/End-style navigation considers “current”.

Affinity is a display concern: it makes no sense without a layout engine and a wrap width. It is never persisted with the text model (cf. Cocoa NSSelectionAffinity on NSTextView, not on NSTextStorage; Chromium PositionWithAffinity at the editing layer, not on Position; same in Qt and CodeMirror).

At positions that are NOT wrap boundaries — the interior of a line, the start of the first wrap-line, the end of the last wrap-line of a paragraph — affinity is a no-op and the rendering is identical.

Variants§

§

Downstream

Place the caret at the END of the previous wrap line. This is the visual “trailing” placement and the default for any position not produced by an upstream-side interaction.

§

Upstream

Place the caret at the START of the next wrap line.

Trait Implementations§

Source§

impl Clone for CursorAffinity

Source§

fn clone(&self) -> CursorAffinity

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for CursorAffinity

Source§

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

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

impl Default for CursorAffinity

Source§

fn default() -> CursorAffinity

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

impl PartialEq for CursorAffinity

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · 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 Copy for CursorAffinity

Source§

impl Eq for CursorAffinity

Source§

impl StructuralPartialEq for CursorAffinity

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, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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> Same for T

Source§

type Output = T

Should always be Self
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, 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.