pub struct AutoStream<S: RawStream> { /* private fields */ }
Expand description
std::io::Write
that adapts ANSI escape codes to the underlying Write
s capabilities
This includes
- Stripping colors for non-terminals
- Respecting env variables like NO_COLOR or CLICOLOR
- (windows) Falling back to the wincon API where ENABLE_VIRTUAL_TERMINAL_PROCESSING is unsupported
You can customize auto-detection by calling into
anstyle_query
to get a ColorChoice
and then calling [AutoStream::new(stream, choice)
].
Implementations§
source§impl<S> AutoStream<S>where
S: RawStream,
impl<S> AutoStream<S>where
S: RawStream,
sourcepub fn new(raw: S, choice: ColorChoice) -> Self
pub fn new(raw: S, choice: ColorChoice) -> Self
Runtime control over styling behavior
§Example
// Like `AutoStream::choice` but without `NO_COLOR`, `CLICOLOR_FORCE`, `CI`
fn choice(raw: &dyn anstream::stream::RawStream) -> anstream::ColorChoice {
let choice = anstream::ColorChoice::global();
if choice == anstream::ColorChoice::Auto {
if raw.is_terminal() && anstyle_query::term_supports_color() {
anstream::ColorChoice::Always
} else {
anstream::ColorChoice::Never
}
} else {
choice
}
}
let stream = std::io::stdout();
let choice = choice(&stream);
let auto = anstream::AutoStream::new(stream, choice);
sourcepub fn choice(raw: &S) -> ColorChoice
pub fn choice(raw: &S) -> ColorChoice
Report the desired choice for the given stream
sourcepub fn always_ansi(raw: S) -> Self
pub fn always_ansi(raw: S) -> Self
Force ANSI escape codes to be passed through as-is, no matter what the inner Write
supports.
sourcepub fn into_inner(self) -> S
pub fn into_inner(self) -> S
Get the wrapped RawStream
sourcepub fn is_terminal(&self) -> bool
pub fn is_terminal(&self) -> bool
Returns true
if the descriptor/handle refers to a terminal/tty.
sourcepub fn current_choice(&self) -> ColorChoice
pub fn current_choice(&self) -> ColorChoice
Prefer AutoStream::choice
This doesn’t report what is requested but what is currently active.
source§impl AutoStream<Stdout>
impl AutoStream<Stdout>
sourcepub fn lock(self) -> AutoStream<StdoutLock<'static>> ⓘ
pub fn lock(self) -> AutoStream<StdoutLock<'static>> ⓘ
Get exclusive access to the AutoStream
Why?
- Faster performance when writing in a loop
- Avoid other threads interleaving output with the current thread
source§impl AutoStream<Stderr>
impl AutoStream<Stderr>
sourcepub fn lock(self) -> AutoStream<StderrLock<'static>> ⓘ
pub fn lock(self) -> AutoStream<StderrLock<'static>> ⓘ
Get exclusive access to the AutoStream
Why?
- Faster performance when writing in a loop
- Avoid other threads interleaving output with the current thread
Trait Implementations§
source§impl<S> Write for AutoStream<S>where
S: RawStream + AsLockedWrite,
impl<S> Write for AutoStream<S>where
S: RawStream + AsLockedWrite,
source§fn write(&mut self, buf: &[u8]) -> Result<usize>
fn write(&mut self, buf: &[u8]) -> Result<usize>
Writes a buffer into this writer, returning how many bytes were written. Read more
source§fn flush(&mut self) -> Result<()>
fn flush(&mut self) -> Result<()>
Flushes this output stream, ensuring that all intermediately buffered
contents reach their destination. Read more
source§fn write_all(&mut self, buf: &[u8]) -> Result<()>
fn write_all(&mut self, buf: &[u8]) -> Result<()>
Attempts to write an entire buffer into this writer. Read more
source§fn write_fmt(&mut self, args: Arguments<'_>) -> Result<()>
fn write_fmt(&mut self, args: Arguments<'_>) -> Result<()>
Writes a formatted string into this writer, returning any error
encountered. Read more
source§fn is_write_vectored(&self) -> bool
fn is_write_vectored(&self) -> bool
🔬This is a nightly-only experimental API. (
can_vector
)Auto Trait Implementations§
impl<S> Freeze for AutoStream<S>where
S: Freeze,
impl<S> RefUnwindSafe for AutoStream<S>where
S: RefUnwindSafe,
impl<S> Send for AutoStream<S>where
S: Send,
impl<S> Sync for AutoStream<S>where
S: Sync,
impl<S> Unpin for AutoStream<S>where
S: Unpin,
impl<S> UnwindSafe for AutoStream<S>where
S: UnwindSafe,
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