SelectionAction

Enum SelectionAction 

Source
#[non_exhaustive]
pub enum SelectionAction { Duplicate(MoveDir1D, Count), CursorSet(SelectionCursorChange), Expand(SelectionBoundary, TargetShapeFilter), Filter(MatchAction), Join, Resize(SelectionResizeStyle, EditTarget), Split(SelectionSplitStyle, TargetShapeFilter), Trim(SelectionBoundary, TargetShapeFilter), }
Expand description

Actions for manipulating text selections.

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

Duplicate(MoveDir1D, Count)

Duplicate selections n times to adjacent lines in MoveDir1D direction.

If the column positions are too large to fit on the adjacent lines, then the next line large enough to hold the selection is used instead.

§Example: Using action!
use editor_types::prelude::*;
use editor_types::{action, Action, SelectionAction};

let count = Count::Contextual;
let act: Action = SelectionAction::Duplicate(MoveDir1D::Next, count.clone()).into();

// All of these are equivalent:
assert_eq!(action!("selection duplicate -d next"), act);
assert_eq!(action!("selection duplicate -d next -c ctx"), act);
assert_eq!(action!("selection duplicate -d next -c {count}"), act);
§

CursorSet(SelectionCursorChange)

Change the placement of the cursor and anchor of a visual selection.

§Example: Using action!
use editor_types::prelude::*;
use editor_types::{action, Action, SelectionAction};

let change = SelectionCursorChange::End;
let act: Action = action!("selection cursor-set -f end");
assert_eq!(act, SelectionAction::CursorSet(change).into());
§

Expand(SelectionBoundary, TargetShapeFilter)

Expand a selection by repositioning its cursor and anchor such that they are placed on the specified boundary.

Be aware that since this repositions the start and end of the selection, this may not do what you want with TargetShape::BlockWise selections.

§Example: Using action!
use editor_types::prelude::*;
use editor_types::{action, Action, SelectionAction};

let style = SelectionBoundary::Line;
let split: Action = action!("selection expand -b line -t all");
assert_eq!(split, SelectionAction::Expand(style, TargetShapeFilter::ALL).into());
§

Filter(MatchAction)

Filter selections using the last regular expression entered for CommandType::Search.

§Example: Using action!
use editor_types::prelude::*;
use editor_types::{action, Action, SelectionAction};

let act = SelectionAction::Filter(MatchAction::Keep);
let split: Action = action!("selection filter -F keep");
assert_eq!(split, act.into());
§

Join

Join adjacent selections together.

§Example: Using action!
use editor_types::prelude::*;
use editor_types::{action, Action, SelectionAction};

let act: Action = SelectionAction::Join.into();
assert_eq!(act, action!("selection join"));
§

Resize(SelectionResizeStyle, EditTarget)

Change the bounds of the current selection as described by the style and target.

If the context doesn’t specify a selection shape, then the selection will determine its shape from the EditTarget.

See the documentation for the SelectionResizeStyle variants for how to construct all of the possible values using action.

§

Split(SelectionSplitStyle, TargetShapeFilter)

Split matching selections into multiple selections line.

All of the new selections are of the same shape as the one they were split from.

§Example: Using action!
use editor_types::prelude::*;
use editor_types::{action, Action, SelectionAction};

let style = SelectionSplitStyle::Lines;
let split: Action = action!("selection split -s lines -F all");
assert_eq!(split, SelectionAction::Split(style, TargetShapeFilter::ALL).into());
§

Trim(SelectionBoundary, TargetShapeFilter)

Shrink a selection by repositioning its cursor and anchor such that they are placed on the specified boundary.

Be aware that since this repositions the start and end of the selection, this may not do what you want with TargetShape::BlockWise selections.

§Example: Using action!
use editor_types::prelude::*;
use editor_types::{action, Action, SelectionAction};

let style = SelectionBoundary::Line;
let split: Action = action!("selection trim -b line -t all");
assert_eq!(split, SelectionAction::Trim(style, TargetShapeFilter::ALL).into());

Trait Implementations§

Source§

impl Clone for SelectionAction

Source§

fn clone(&self) -> SelectionAction

Returns a duplicate 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 SelectionAction

Source§

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

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

impl<I: ApplicationInfo> From<SelectionAction> for Action<I>

Source§

fn from(act: SelectionAction) -> Self

Converts to this type from the input type.
Source§

impl From<SelectionAction> for EditorAction

Source§

fn from(act: SelectionAction) -> Self

Converts to this type from the input type.
Source§

impl PartialEq for SelectionAction

Source§

fn eq(&self, other: &SelectionAction) -> 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 SelectionAction

Source§

impl StructuralPartialEq for SelectionAction

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> 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.