Skip to main content

Keymap

Struct Keymap 

Source
pub struct Keymap { /* private fields */ }

Implementations§

Source§

impl Keymap

Source

pub fn new() -> Self

Source

pub fn leader(&self) -> Option<char>

Configured leader char. None means <leader> references fail to bind.

Source

pub fn set_leader(&mut self, leader: char)

Source

pub fn bind( &mut self, mode: PageMode, keys: &str, action: PageAction, ) -> Result<(), BindError>

Bind a chord sequence to an action in the given mode. Parses keys via parse_keys and resolves <leader> to the configured leader.

Source

pub fn bind_chords( &mut self, mode: PageMode, chords: &[KeyChord], action: PageAction, )

Bind already-parsed chords. Used by the engine when feeding programmatic bindings.

Source

pub fn lookup(&self, mode: PageMode, chords: &[KeyChord]) -> Lookup<'_>

Look up the chord sequence under mode.

Source

pub fn resolve_timeout( &self, mode: PageMode, chords: &[KeyChord], ) -> Option<&PageAction>

Resolve the longest-prefix action along chords — the engine uses this when the ambiguity timeout fires.

Source

pub fn entries(&self, mode: PageMode) -> Vec<(Vec<KeyChord>, PageAction)>

Flatten every binding under mode to (chord_sequence, action) pairs. Order is unspecified — callers that want deterministic output should sort the result. Used by the new-tab page renderer to list the live keymap, including any hot-reloaded user overrides.

Source

pub fn audit_default_bindings( _leader: char, ) -> Vec<(&'static str, &'static str, PageAction)>

Phase 6 a11y audit: enumerate every static default binding as (mode_label, keys, action) rows. Sorted by (mode, keys) so the output is stable; used by --audit-keymap to verify keyboard-only reachability of every PageAction.

leader mirrors Self::default_bindings; the resolved <leader> chord is rendered as the literal character so users can see what they’d type.

Source

pub fn missing_default_bindings() -> Vec<&'static str>

Phase 6 a11y guarantee: every PageAction reachable by a reasonable user is bound to at least one default chord in some mode. Returns the list of unbound action names (debug-format of the unit/parameterised variant) — empty Vec means full coverage.

“Reasonable” here excludes a small allow-list:

Source

pub fn default_bindings(leader: char) -> Self

Default vim-flavoured bindings. leader is the configured leader char (vim default is \). See docs/keymap.md for the full table.

Trait Implementations§

Source§

impl Clone for Keymap

Source§

fn clone(&self) -> Keymap

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 Keymap

Source§

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

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

impl Default for Keymap

Source§

fn default() -> Keymap

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

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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
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.