Skip to main content

Tui

Struct Tui 

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

Main TUI handle that integrates with the event bus.

Implementations§

Source§

impl Tui

Source

pub fn new() -> Self

Creates a new TUI instance with shared state (in-process mode).

Source

pub fn connect(base_url: &str) -> Result<Self>

Creates a TUI that connects to a running ralph-api server.

The TUI will fetch initial state via HTTP and subscribe to the RPC v1 event stream over WebSocket. No in-process observer is needed.

§Arguments
  • base_url — e.g. "http://127.0.0.1:3000"
Source

pub fn spawn(args: Vec<String>) -> Result<Self>

Creates a TUI that spawns ralph run --rpc as a subprocess.

The TUI reads JSON-RPC events from the subprocess stdout and sends commands to its stdin. This mode allows the TUI to run independently of the orchestration loop process.

§Arguments
  • args - Arguments to pass to ralph run --rpc (e.g., -p "prompt", -c config.yml)
§Example
let tui = Tui::spawn(vec![
    "-p".to_string(),
    "Implement feature X".to_string(),
    "-c".to_string(),
    "ralph.yml".to_string(),
])?;
tui.run().await?;
Source

pub fn with_hat_map(self, hat_map: HashMap<String, (HatId, String)>) -> Self

Sets the hat map for dynamic topic-to-hat resolution.

This allows the TUI to display the correct hat for custom topics without hardcoding them in TuiState::update().

Source

pub fn with_termination_signal(self, terminated_rx: Receiver<bool>) -> Self

Sets the termination signal receiver for graceful shutdown.

The TUI will exit when this receiver signals true.

Source

pub fn with_interrupt_tx(self, interrupt_tx: Sender<bool>) -> Self

Sets the interrupt channel for Ctrl+C signaling.

In raw terminal mode, SIGINT is not generated by the OS when the user presses Ctrl+C. The TUI detects Ctrl+C via crossterm events and uses this channel to signal the main orchestration loop to terminate.

Source

pub fn with_events_path(self, path: PathBuf) -> Self

Sets the path to events.jsonl for direct guidance writes.

Source

pub fn with_urgent_steer_path(self, path: PathBuf) -> Self

Sets the path to the urgent-steer marker file for immediate ! gating.

Source

pub fn state(&self) -> Arc<Mutex<TuiState>>

Returns the shared state for external updates.

Source

pub fn guidance_next_queue(&self) -> Arc<Mutex<Vec<String>>>

Returns a handle to the guidance next-queue for draining in the loop runner.

Source

pub fn observer(&self) -> impl Fn(&Event) + Send + 'static

Returns an observer closure that updates TUI state from events.

Only meaningful in in-process mode. In RPC mode, state is updated by the WebSocket bridge instead.

Source

pub async fn run(self) -> Result<()>

Runs the TUI application loop.

In in-process mode, requires with_termination_signal() to have been called first.

In RPC client mode (HTTP/WS), the TUI manages its own lifecycle — the RPC bridge runs alongside the render loop and exits on Ctrl+C or q.

In subprocess RPC mode, the TUI spawns an event reader to consume JSON events from the subprocess stdout and uses an RPC writer to send commands to the subprocess stdin.

§Errors

Returns an error if the terminal cannot be initialized or if the application loop encounters an unrecoverable error.

Trait Implementations§

Source§

impl Default for Tui

Source§

fn default() -> Self

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

Auto Trait Implementations§

§

impl Freeze for Tui

§

impl !RefUnwindSafe for Tui

§

impl Send for Tui

§

impl Sync for Tui

§

impl Unpin for Tui

§

impl UnsafeUnpin for Tui

§

impl !UnwindSafe for Tui

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> DowncastSync for T
where T: Any + Send + Sync,

Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

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

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoMaybeUndefined<T> for T

Source§

impl<T> IntoOption<T> for T

Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

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

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more