pub struct BashExecution { /* private fields */ }Expand description
Bash execution component - renders a bash command with borders, spinner, and output.
Matches pi’s BashExecutionComponent design:
- Spacer (1 blank line) above top border
- Top/bottom borders in
bashModecolor (ordimfor !! commands) - Command header with
$prefix - Spinner while running (uses Loader component)
- Streaming output in muted color (no ANSI)
- Collapse/expand support showing FIRST N lines (preview truncation)
- Status line with exit code, duration, cancellation, truncation warnings
- Width-aware visual truncation for collapsed preview
Implementations§
Source§impl BashExecution
impl BashExecution
pub fn new(command: impl Into<String>) -> Self
pub fn append_output(&mut self, line: impl Into<String>)
Sourcepub fn append_chunk(&mut self, chunk: &str)
pub fn append_chunk(&mut self, chunk: &str)
Append a chunk of output that may contain newlines. Handles splitting into lines similar to pi’s appendOutput (preserving incomplete last line).
pub fn set_complete(&mut self, exit_code: i32)
pub fn set_cancelled(&mut self)
pub fn set_error(&mut self, msg: impl Into<String>)
pub fn set_expanded(&mut self, expanded: bool)
pub fn set_exclude_from_context(&mut self, exclude: bool)
pub fn set_full_output_path(&mut self, path: impl Into<String>)
pub fn set_truncated(&mut self, truncated: bool)
Sourcepub fn set_duration_secs(&mut self, secs: f64)
pub fn set_duration_secs(&mut self, secs: f64)
Set the execution duration in seconds.
Sourcepub fn set_duration_from_content(&mut self, content: &str)
pub fn set_duration_from_content(&mut self, content: &str)
Parse and set duration from result content (format: [Xs] at end of string).
pub fn is_expanded(&self) -> bool
Sourcepub fn get_output(&self) -> String
pub fn get_output(&self) -> String
Get the raw output (for building messages sent to the LLM).
Sourcepub fn get_command(&self) -> String
pub fn get_command(&self) -> String
Get the command that was executed.
Trait Implementations§
Source§impl Component for BashExecution
impl Component for BashExecution
Source§fn set_expanded(&mut self, expanded: bool)
fn set_expanded(&mut self, expanded: bool)
Toggle expanded/collapsed state. No-op by default.
Override for components that support expand/collapse (tool results, messages, etc.).
Source§fn render(&self, width: usize) -> Vec<String>
fn render(&self, width: usize) -> Vec<String>
Render to lines for the given viewport width.
Each returned string MUST NOT exceed
width in visible width.Source§fn invalidate(&mut self)
fn invalidate(&mut self)
Mark this component as needing re-render.
Called when internal state changes (output received, expanded toggled, etc.).
Source§fn handle_input(&mut self, _key: &KeyEvent) -> bool
fn handle_input(&mut self, _key: &KeyEvent) -> bool
Handle keyboard input. Return
true if consumed.Source§fn handle_paste(&mut self, _text: &str)
fn handle_paste(&mut self, _text: &str)
Handle a paste event (text from bracketed paste mode).
Default no-op; override to process pasted content.
Source§fn is_dirty(&self) -> bool
fn is_dirty(&self) -> bool
Check if this component needs re-render.
Default: always re-render (conservative).
Source§fn clear_dirty(&mut self)
fn clear_dirty(&mut self)
Clear dirty flag after successful render.
Source§fn cache_key(&self, _width: usize) -> Option<RenderCacheKey>
fn cache_key(&self, _width: usize) -> Option<RenderCacheKey>
Get the cache key for this component’s current state.
Return None to disable caching (always re-render).
Source§fn get_cached_render(&self) -> Option<&RenderCache>
fn get_cached_render(&self) -> Option<&RenderCache>
Get cached render output, if available and valid.
Source§fn set_cached_render(&mut self, _cache: RenderCache)
fn set_cached_render(&mut self, _cache: RenderCache)
Store render output in cache.
Source§fn is_focusable(&self) -> bool
fn is_focusable(&self) -> bool
Whether this component wants focus (for IME cursor positioning).
Source§fn set_hide_thinking(&mut self, _hide: bool)
fn set_hide_thinking(&mut self, _hide: bool)
Toggle thinking block visibility. No-op by default.
Override for components that display thinking content (AssistantMessageComponent).
Auto Trait Implementations§
impl !Freeze for BashExecution
impl !RefUnwindSafe for BashExecution
impl !Send for BashExecution
impl !Sync for BashExecution
impl !UnwindSafe for BashExecution
impl Unpin for BashExecution
impl UnsafeUnpin for BashExecution
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more