owo_colors

Struct FgColorDisplay

Source
pub struct FgColorDisplay<'a, C: Color, T: ?Sized>(/* private fields */);
Expand description

Transparent wrapper around a type which implements all the formatters the wrapped type does, with the addition of changing the foreground color. Recommended to be constructed using OwoColorize.

Implementations§

Source§

impl<'a, Fg, T: ?Sized> FgColorDisplay<'a, Fg, T>
where Fg: Color,

Source

pub const fn new(thing: &'a T) -> Self

Create a new FgColorDisplay, from a reference to a type which implements Color.

This is a const function: in non-const contexts, OwoColorize::fg or one of the other methods on it may be more convenient.

§Example

Usage in const contexts:

use owo_colors::{colors::Green, FgColorDisplay};

const GREEN_TEXT: FgColorDisplay<Green, str> = FgColorDisplay::new("green");

println!("{}", GREEN_TEXT);
Source

pub const fn into_styled(self) -> Styled<&'a T>

Convert self to a generic Styled.

This method erases color-related type parameters, and can be used to unify types across branches.

§Example

Typical use:

use owo_colors::OwoColorize;

fn is_blue() -> bool {
    // ...
}

let styled_str = if is_blue() {
    "hello".blue().into_styled()
} else {
    "hello".green().into_styled()
};

println!("{}", styled_str);

Usage in const contexts:

use owo_colors::{colors::{Blue, Green}, FgColorDisplay, Styled};

const fn is_blue() -> bool {
    // ...
}

const STYLED_STR: Styled<&str> = if is_blue() {
    FgColorDisplay::<Blue, _>::new("Hello").into_styled()
} else {
    FgColorDisplay::<Green, _>::new("Hello").into_styled()
};

println!("{}", STYLED_STR);
Source

pub const fn color<NewFg: DynColor>( self, fg: NewFg, ) -> FgDynColorDisplay<'a, NewFg, T>

Set the foreground color at runtime. Only use if you do not know which color will be used at compile-time. If the color is constant, use either OwoColorize::fg or a color-specific method, such as OwoColorize::green,

use owo_colors::{OwoColorize, AnsiColors};

println!("{}", "green".color(AnsiColors::Green));
Source

pub const fn on_color<NewBg: DynColor>( self, bg: NewBg, ) -> ComboDynColorDisplay<'a, Fg::DynEquivalent, NewBg, T>

Set the background color at runtime. Only use if you do not know what color to use at compile-time. If the color is constant, use either OwoColorize::bg or a color-specific method, such as OwoColorize::on_yellow,

use owo_colors::{OwoColorize, AnsiColors};

println!("{}", "yellow background".on_color(AnsiColors::BrightYellow));
Source

pub const fn fg<C: Color>(self) -> FgColorDisplay<'a, C, T>

Set the foreground color generically

use owo_colors::{OwoColorize, colors::*};

println!("{}", "red foreground".fg::<Red>());
Source

pub const fn bg<C: Color>(self) -> ComboColorDisplay<'a, Fg, C, T>

Set the background color generically.

use owo_colors::{OwoColorize, colors::*};

println!("{}", "black background".bg::<Black>());
Source

pub const fn black(self) -> FgColorDisplay<'a, Black, T>

Change the foreground color to black

Source

pub const fn on_black(self) -> ComboColorDisplay<'a, Fg, Black, T>

Change the background color to black

Source

pub const fn red(self) -> FgColorDisplay<'a, Red, T>

Change the foreground color to red

Source

pub const fn on_red(self) -> ComboColorDisplay<'a, Fg, Red, T>

Change the background color to red

Source

pub const fn green(self) -> FgColorDisplay<'a, Green, T>

Change the foreground color to green

Source

pub const fn on_green(self) -> ComboColorDisplay<'a, Fg, Green, T>

Change the background color to green

Source

pub const fn yellow(self) -> FgColorDisplay<'a, Yellow, T>

Change the foreground color to yellow

Source

pub const fn on_yellow(self) -> ComboColorDisplay<'a, Fg, Yellow, T>

Change the background color to yellow

Source

pub const fn blue(self) -> FgColorDisplay<'a, Blue, T>

Change the foreground color to blue

Source

pub const fn on_blue(self) -> ComboColorDisplay<'a, Fg, Blue, T>

Change the background color to blue

Source

pub const fn magenta(self) -> FgColorDisplay<'a, Magenta, T>

Change the foreground color to magenta

Source

pub const fn on_magenta(self) -> ComboColorDisplay<'a, Fg, Magenta, T>

Change the background color to magenta

Source

pub const fn purple(self) -> FgColorDisplay<'a, Magenta, T>

Change the foreground color to purple

Source

pub const fn on_purple(self) -> ComboColorDisplay<'a, Fg, Magenta, T>

Change the background color to purple

Source

pub const fn cyan(self) -> FgColorDisplay<'a, Cyan, T>

Change the foreground color to cyan

Source

pub const fn on_cyan(self) -> ComboColorDisplay<'a, Fg, Cyan, T>

Change the background color to cyan

Source

pub const fn white(self) -> FgColorDisplay<'a, White, T>

Change the foreground color to white

Source

pub const fn on_white(self) -> ComboColorDisplay<'a, Fg, White, T>

Change the background color to white

Source

pub const fn bright_black(self) -> FgColorDisplay<'a, BrightBlack, T>

Change the foreground color to bright black

Source

pub const fn on_bright_black(self) -> ComboColorDisplay<'a, Fg, BrightBlack, T>

Change the background color to bright black

Source

pub const fn bright_red(self) -> FgColorDisplay<'a, BrightRed, T>

Change the foreground color to bright red

Source

pub const fn on_bright_red(self) -> ComboColorDisplay<'a, Fg, BrightRed, T>

Change the background color to bright red

Source

pub const fn bright_green(self) -> FgColorDisplay<'a, BrightGreen, T>

Change the foreground color to bright green

Source

pub const fn on_bright_green(self) -> ComboColorDisplay<'a, Fg, BrightGreen, T>

Change the background color to bright green

Source

pub const fn bright_yellow(self) -> FgColorDisplay<'a, BrightYellow, T>

Change the foreground color to bright yellow

Source

pub const fn on_bright_yellow( self, ) -> ComboColorDisplay<'a, Fg, BrightYellow, T>

Change the background color to bright yellow

Source

pub const fn bright_blue(self) -> FgColorDisplay<'a, BrightBlue, T>

Change the foreground color to bright blue

Source

pub const fn on_bright_blue(self) -> ComboColorDisplay<'a, Fg, BrightBlue, T>

Change the background color to bright blue

Source

pub const fn bright_magenta(self) -> FgColorDisplay<'a, BrightMagenta, T>

Change the foreground color to bright magenta

Source

pub const fn on_bright_magenta( self, ) -> ComboColorDisplay<'a, Fg, BrightMagenta, T>

Change the background color to bright magenta

Source

pub const fn bright_purple(self) -> FgColorDisplay<'a, BrightMagenta, T>

Change the foreground color to bright purple

Source

pub const fn on_bright_purple( self, ) -> ComboColorDisplay<'a, Fg, BrightMagenta, T>

Change the background color to bright purple

Source

pub const fn bright_cyan(self) -> FgColorDisplay<'a, BrightCyan, T>

Change the foreground color to bright cyan

Source

pub const fn on_bright_cyan(self) -> ComboColorDisplay<'a, Fg, BrightCyan, T>

Change the background color to bright cyan

Source

pub const fn bright_white(self) -> FgColorDisplay<'a, BrightWhite, T>

Change the foreground color to bright white

Source

pub const fn on_bright_white(self) -> ComboColorDisplay<'a, Fg, BrightWhite, T>

Change the background color to bright white

Trait Implementations§

Source§

impl<'a, Color: Color, T: ?Sized + Binary> Binary for FgColorDisplay<'a, Color, T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'a, Color: Color, T: ?Sized + Debug> Debug for FgColorDisplay<'a, Color, T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'a, Color: Color, T: ?Sized + Display> Display for FgColorDisplay<'a, Color, T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'a, Color: Color, T: ?Sized + LowerExp> LowerExp for FgColorDisplay<'a, Color, T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'a, Color: Color, T: ?Sized + LowerHex> LowerHex for FgColorDisplay<'a, Color, T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'a, Color: Color, T: ?Sized + Octal> Octal for FgColorDisplay<'a, Color, T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'a, Color: Color, T: ?Sized + Pointer> Pointer for FgColorDisplay<'a, Color, T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'a, Color: Color, T: ?Sized + UpperExp> UpperExp for FgColorDisplay<'a, Color, T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'a, Color: Color, T: ?Sized + UpperHex> UpperHex for FgColorDisplay<'a, Color, T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<'a, C, T> Freeze for FgColorDisplay<'a, C, T>
where T: ?Sized,

§

impl<'a, C, T> RefUnwindSafe for FgColorDisplay<'a, C, T>

§

impl<'a, C, T> Send for FgColorDisplay<'a, C, T>
where T: Sync + ?Sized, C: Send,

§

impl<'a, C, T> Sync for FgColorDisplay<'a, C, T>
where T: Sync + ?Sized, C: Sync,

§

impl<'a, C, T> Unpin for FgColorDisplay<'a, C, T>
where C: Unpin, T: ?Sized,

§

impl<'a, C, T> UnwindSafe for FgColorDisplay<'a, C, T>
where T: RefUnwindSafe + ?Sized, C: UnwindSafe,

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> 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<D> OwoColorize for D

Source§

fn fg<C: Color>(&self) -> FgColorDisplay<'_, C, Self>

Set the foreground color generically Read more
Source§

fn bg<C: Color>(&self) -> BgColorDisplay<'_, C, Self>

Set the background color generically. Read more
Source§

fn black(&self) -> FgColorDisplay<'_, Black, Self>

Change the foreground color to black
Source§

fn on_black(&self) -> BgColorDisplay<'_, Black, Self>

Change the background color to black
Source§

fn red(&self) -> FgColorDisplay<'_, Red, Self>

Change the foreground color to red
Source§

fn on_red(&self) -> BgColorDisplay<'_, Red, Self>

Change the background color to red
Source§

fn green(&self) -> FgColorDisplay<'_, Green, Self>

Change the foreground color to green
Source§

fn on_green(&self) -> BgColorDisplay<'_, Green, Self>

Change the background color to green
Source§

fn yellow(&self) -> FgColorDisplay<'_, Yellow, Self>

Change the foreground color to yellow
Source§

fn on_yellow(&self) -> BgColorDisplay<'_, Yellow, Self>

Change the background color to yellow
Source§

fn blue(&self) -> FgColorDisplay<'_, Blue, Self>

Change the foreground color to blue
Source§

fn on_blue(&self) -> BgColorDisplay<'_, Blue, Self>

Change the background color to blue
Source§

fn magenta(&self) -> FgColorDisplay<'_, Magenta, Self>

Change the foreground color to magenta
Source§

fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>

Change the background color to magenta
Source§

fn purple(&self) -> FgColorDisplay<'_, Magenta, Self>

Change the foreground color to purple
Source§

fn on_purple(&self) -> BgColorDisplay<'_, Magenta, Self>

Change the background color to purple
Source§

fn cyan(&self) -> FgColorDisplay<'_, Cyan, Self>

Change the foreground color to cyan
Source§

fn on_cyan(&self) -> BgColorDisplay<'_, Cyan, Self>

Change the background color to cyan
Source§

fn white(&self) -> FgColorDisplay<'_, White, Self>

Change the foreground color to white
Source§

fn on_white(&self) -> BgColorDisplay<'_, White, Self>

Change the background color to white
Source§

fn default_color(&self) -> FgColorDisplay<'_, Default, Self>

Change the foreground color to the terminal default
Source§

fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>

Change the background color to the terminal default
Source§

fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>

Change the foreground color to bright black
Source§

fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>

Change the background color to bright black
Source§

fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>

Change the foreground color to bright red
Source§

fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>

Change the background color to bright red
Source§

fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>

Change the foreground color to bright green
Source§

fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>

Change the background color to bright green
Source§

fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>

Change the foreground color to bright yellow
Source§

fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>

Change the background color to bright yellow
Source§

fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>

Change the foreground color to bright blue
Source§

fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>

Change the background color to bright blue
Source§

fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>

Change the foreground color to bright magenta
Source§

fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>

Change the background color to bright magenta
Source§

fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>

Change the foreground color to bright purple
Source§

fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>

Change the background color to bright purple
Source§

fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>

Change the foreground color to bright cyan
Source§

fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>

Change the background color to bright cyan
Source§

fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>

Change the foreground color to bright white
Source§

fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>

Change the background color to bright white
Source§

fn bold(&self) -> BoldDisplay<'_, Self>

Make the text bold
Source§

fn dimmed(&self) -> DimDisplay<'_, Self>

Make the text dim
Source§

fn italic(&self) -> ItalicDisplay<'_, Self>

Make the text italicized
Source§

fn underline(&self) -> UnderlineDisplay<'_, Self>

Make the text underlined
Make the text blink
Make the text blink (but fast!)
Source§

fn reversed(&self) -> ReversedDisplay<'_, Self>

Swap the foreground and background colors
Source§

fn hidden(&self) -> HiddenDisplay<'_, Self>

Hide the text
Source§

fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>

Cross out the text
Source§

fn color<Color: DynColor>( &self, color: Color, ) -> FgDynColorDisplay<'_, Color, Self>

Set the foreground color at runtime. Only use if you do not know which color will be used at compile-time. If the color is constant, use either OwoColorize::fg or a color-specific method, such as OwoColorize::green, Read more
Source§

fn on_color<Color: DynColor>( &self, color: Color, ) -> BgDynColorDisplay<'_, Color, Self>

Set the background color at runtime. Only use if you do not know what color to use at compile-time. If the color is constant, use either OwoColorize::bg or a color-specific method, such as OwoColorize::on_yellow, Read more
Source§

fn fg_rgb<const R: u8, const G: u8, const B: u8>( &self, ) -> FgColorDisplay<'_, CustomColor<R, G, B>, Self>

Set the foreground color to a specific RGB value.
Source§

fn bg_rgb<const R: u8, const G: u8, const B: u8>( &self, ) -> BgColorDisplay<'_, CustomColor<R, G, B>, Self>

Set the background color to a specific RGB value.
Source§

fn truecolor(&self, r: u8, g: u8, b: u8) -> FgDynColorDisplay<'_, Rgb, Self>

Sets the foreground color to an RGB value.
Source§

fn on_truecolor(&self, r: u8, g: u8, b: u8) -> BgDynColorDisplay<'_, Rgb, Self>

Sets the background color to an RGB value.
Source§

fn style(&self, style: Style) -> Styled<&Self>

Apply a runtime-determined style
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.