Skip to main content

Session

Struct Session 

Source
pub struct Session { /* private fields */ }
Expand description

One running terminal application controlled in-process by its caller.

Session is the embedded equivalent of the CLI session lifecycle. It owns a PTY and the visible terminal state, so callers can send input, wait for content, take shots, and resize without spawning a new termctrl command for each action.

Implementations§

Source§

impl Session

Source

pub fn start( command: &[String], cwd: Option<&Path>, record: Option<&Path>, options: &Options, ) -> Result<Self>

Start command inside a live PTY-backed session.

Source

pub fn send(&mut self, input: &[u8]) -> Result<()>

Send one input burst to the terminal application.

Source

pub fn send_all(&mut self, input: &[Vec<u8>], pace: Duration) -> Result<()>

Send ordered input bursts, optionally pacing them for recorded interactions.

Source

pub fn wait_for_text(&mut self, text: &str, timeout: Duration) -> Result<()>

Wait until visible terminal text contains text.

Source

pub fn wait_for_idle( &mut self, settle: Duration, timeout: Duration, ) -> Result<()>

Wait until no terminal output has arrived for settle.

Source

pub fn wait_for_exit( &mut self, timeout: Duration, ) -> Result<Option<ProcessExit>>

Wait for the terminal application to exit, returning None on timeout.

Source

pub fn capture( &mut self, settle: Duration, deadline: Duration, ) -> Result<CaptureResult>

Capture visible terminal state and report whether it settled, exited, or reached a limit.

Source

pub fn status(&mut self) -> Result<SessionStatus>

Inspect session lifecycle, geometry, and whether a visible frame is available.

Source

pub fn logs(&mut self, ansi: bool) -> Result<Vec<u8>>

Return readable normal-screen scrollback, or the exact retained ANSI/VT stream.

Source

pub fn resize( &mut self, cols: u16, rows: u16, cell_width: u16, cell_height: u16, ) -> Result<()>

Resize the PTY and reflow subsequent terminal parsing at the new dimensions.

Source

pub fn mark(&mut self, name: &str) -> Result<()>

Add a named moment to the active recording timeline.

Source

pub fn stop(&mut self) -> Result<()>

Terminate the application owned by this session.

Trait Implementations§

Source§

impl Drop for Session

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

fn pin_drop(self: Pin<&mut Self>)

🔬This is a nightly-only experimental API. (pin_ergonomics)
Execute the destructor for this type, but different to Drop::drop, it requires self to be pinned. 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> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
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.