[go: up one dir, main page]

Struct Context

Source
pub struct Context {
    pub history: History,
    pub completer: Option<Box<dyn Completer>>,
    pub word_divider_fn: Box<dyn Fn(&Buffer) -> Vec<(usize, usize)>>,
    pub key_bindings: KeyBindings,
}

Fields§

§history: History§completer: Option<Box<dyn Completer>>§word_divider_fn: Box<dyn Fn(&Buffer) -> Vec<(usize, usize)>>§key_bindings: KeyBindings

Implementations§

Source§

impl Context

Source

pub fn new() -> Self

Source

pub fn read_line<P: Into<String>>( &mut self, prompt: P, handler: &mut EventHandler<'_, RawTerminal<Stdout>>, ) -> Result<String>

Creates an Editor and feeds it keypresses from stdin until the line is entered. The output is stdout. The returned line has the newline removed. Before returning, will revert all changes to the history buffers.

Source

pub fn read_line_with_init_buffer<P: Into<String>, B: Into<Buffer>>( &mut self, prompt: P, handler: &mut EventHandler<'_, RawTerminal<Stdout>>, buffer: B, ) -> Result<String>

Same as Context.read_line(), but passes the provided initial buffer to the editor.

use liner::Context;
let mut context = Context::new();
let line =
    context.read_line_with_init_buffer("[prompt]$ ",
                                       &mut |_| {},
                                       "some initial buffer");
Source

pub fn revert_all_history(&mut self)

Auto Trait Implementations§

§

impl Freeze for Context

§

impl !RefUnwindSafe for Context

§

impl !Send for Context

§

impl !Sync for Context

§

impl Unpin for Context

§

impl !UnwindSafe for Context

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