Coloring terminal so simple, you already know how to do it !
"this is blue".blue();
"this is red".red();
"this is red on blue".red().on_blue();
"this is also red on blue".on_blue().red();
"you can also make bold comments".bold();
println!("{} {} {}", "or use".cyan(), "any".italic().yellow(), "string type".cyan());
"or change advice. This is red".yellow().blue().red();
"or clear things up. This is default color and style".red().bold().clear();
"purple and magenta are the same".purple().magenta();
"and so are normal and clear".normal().clear();
String::new("this also works!").green().bold();
format!("{:30}", "format works as expected. This will be padded".blue());
format!("{:.3}", "and this will be green but truncated to 3 chars".green());
Add this in your Cargo.toml
:
[dependencies]
colored = "1.3"
and add this to your lib.rs
or main.rs
:
extern crate colored;
use colored::*;
// test the example with `cargo run --example most_simple`
fn main() {
// TADAA !
println!("{} {} !", "it".green(), "works".blue().bold());
}
- Safe rust, easy to use, minimal dependencies, complete test suite
- Respect the
CLICOLOR
/CLICOLOR_FORCE
behavior (see the specs)
- black
- red
- green
- yellow
- blue
- magenta (or purple)
- cyan
- white
Background colors: prepend the color by on_
. Simple as that.
- bold
- underline
- italic
- dimmed
- reversed
- blink
- hidden
You can clear color and style anytime by using normal()
or clear()
If you want to disable any coloring at compile time, you can simply with using
the no-color
feature.
For example, you can do this in your Cargo.toml
to disable color in tests:
[features]
# this effectively enable the feature `no-color` of colored when testing
test = ["colored/no-color"]
- Windows console support: this works only with ansi term. I plan to support the windows console also.
- More tests ?: We always wecome more tests ! Please contribute !
This library wouldn't have been the same without the marvelous ruby gem colored.
Thanks for the ansi_term crate for providing a reference implementation, which greatly helped making this crate output correct strings.
Mozilla Public Licence 2.0. See the LICENCE file at the root of the repository.
In non legal terms it means that:
- if you fix a bug, you MUST give me the code of the fix (it's only fair)
- if you change/extend the API, you MUST give me the code you changed in the files under MPL2.
- you CAN'T sue me for anything about this code
- appart from that, you can do almost whatever you want. See the LICENCE file for details.