no functional change, just simplifying ratatui styling and adding guidance in AGENTS.md for future.
40 lines
1.3 KiB
Rust
40 lines
1.3 KiB
Rust
use ansi_to_tui::Error;
|
|
use ansi_to_tui::IntoText;
|
|
use ratatui::text::Line;
|
|
use ratatui::text::Text;
|
|
|
|
/// This function should be used when the contents of `s` are expected to match
|
|
/// a single line. If multiple lines are found, a warning is logged and only the
|
|
/// first line is returned.
|
|
pub fn ansi_escape_line(s: &str) -> Line<'static> {
|
|
let text = ansi_escape(s);
|
|
match text.lines.as_slice() {
|
|
[] => "".into(),
|
|
[only] => only.clone(),
|
|
[first, rest @ ..] => {
|
|
tracing::warn!("ansi_escape_line: expected a single line, got {first:?} and {rest:?}");
|
|
first.clone()
|
|
}
|
|
}
|
|
}
|
|
|
|
pub fn ansi_escape(s: &str) -> Text<'static> {
|
|
// to_text() claims to be faster, but introduces complex lifetime issues
|
|
// such that it's not worth it.
|
|
match s.into_text() {
|
|
Ok(text) => text,
|
|
Err(err) => match err {
|
|
Error::NomError(message) => {
|
|
tracing::error!(
|
|
"ansi_to_tui NomError docs claim should never happen when parsing `{s}`: {message}"
|
|
);
|
|
panic!();
|
|
}
|
|
Error::Utf8Error(utf8error) => {
|
|
tracing::error!("Utf8Error: {utf8error}");
|
|
panic!();
|
|
}
|
|
},
|
|
}
|
|
}
|