ansi_rgb

Colorful terminal text using ANSI escape sequences.

crates.io badge
docs.rs badge
Downloads badge

Foreground colors

```rust use ansi_rgb::{ Colorable, red };

println!("{}", "Hello, world!".fg(red())); ```

Output:

Hello, world!

Background colors

```rust use ansi_rgb::{ Colorable, red };

println!("{}", "Hello, world!".bg(red())); ```

Output:

Hello, world!

Nesting

```rust use ansi_rgb::{ Colorable, blue, green, red };

let formatted = format!( "Hello, world! {}", format!( "{} is an interesting {}", "This".fg(blue()), "day".fg(red()) ).bg(green()) );

println!("{}", formatted);

assert_eq!(

"Hello, world! \u{1b}[48;2;0;255;0m\u{1b}[38;2;0;0;255mThis\u{1b}[39m is an interesting \u{1b}[38;2;255;0;0mday\u{1b}[39m\u{1b}[49m",

formatted

)

```

Output:

Hello, world! This is an interesting day

Anything formattable

```rust use ansi_rgb::*;

[derive(Debug)]

struct Foo(i32, i32);

let foo = Foo(1, 2); println!("{:?}", foo.fg(green())); ```

Output:

Foo(1, 2)

3-bit colors

```rust use ansi_rgb::{ Colorable, Color3 };

println!("{}", "Hello, world!".fg(Color3::RED).bg(Color3::BLACK)); ```

Output:

Hello, world!

4-bit colors

```rust use ansi_rgb::{ Colorable, Color4 };

println!("{}", "Hello, world!".fg(Color4::BRIGHT_RED).bg(Color4::BLACK)); ```

Output:

Hello, world!

8-bit colors

```rust use ansi_rgb::{ Colorable, Color8 };

println!("{}", "Hello, world!".fg(Color8::new(160)).bg(Color8::new(0))); ```

Output:

Hello, world!

24-bit colors

Built-in support for the rgb crate.

```toml

Cargo.toml

[dependencies] rgb = { version = "0.8", default-features = false } ```

```rust use ansi_rgb::{ Colorable }; use rgb::RGB8;

let fg = RGB8::new(123, 231, 111); let bg = RGB8::new(10, 100, 20); println!("{}", "Yuck".fg(fg).bg(bg)); ```

Output:

Yuck

Extending to other color types

If you have your own color type and you know how to turn it into ANSI escape sequences then just implement FormatColor:

```rust use ansi_rgb::{ Canvas, Colorable, FormatColor }; use core::fmt;

enum FavoriteColors { SkyBlue, RocketPlumeYellow, TitaniumGray }

impl FormatColor for FavoriteColors { fn prelude(&self, f: &mut fmt::Formatter, canvas: Canvas) -> fmt::Result { let (r, g, b) = match self { FavoriteColors::SkyBlue => (135, 206, 235), FavoriteColors::RocketPlumeYellow => (255, 255, 0), FavoriteColors::TitaniumGray => (86, 95, 107) }; write!( f, "\x1B[{};2;{};{};{}m", match canvas { Canvas::Foreground => 38, Canvas::Background => 48 }, r, g, b ) } }

println!( "The sky is {}", "blue".fg(FavoriteColors::SkyBlue) );

assert_eq!("The sky is \x1B[38;2;135;206;235mblue\x1B[39m", format!("The sky is {}", "blue".fg(FavoriteColors::SkyBlue)))

```

Output:

The sky is blue

Features

default includes 3-, 4-, 8-, and 24-bit colors and depends on the rgb crate, giving you the following things:

Windows users

You need to set your console mode. Otherwise you'll get garbage like this:

�[48;2;159;114;0m �[0m