minicrossterm/crossterm_style
2019-09-13 23:27:19 +02:00
..
examples namespace reformat and 2018 style (#208) 2019-09-13 23:27:19 +02:00
src namespace reformat and 2018 style (#208) 2019-09-13 23:27:19 +02:00
.gitignore Introduced: Crossterm Workspace and feature flags. (#84) 2019-01-27 21:16:14 +01:00
Cargo.toml Add optional derives for Serialize and Deserialize for public enums (#190) 2019-08-10 10:16:53 +02:00
CHANGELOG.md Refactor and API stabilization (#115) 2019-04-10 23:46:30 +02:00
LICENSE Bug fix reading sync, updated licenses. 2019-04-05 15:44:39 +02:00
README.md Some fixes (#183) 2019-07-25 19:57:14 +02:00

Crossterm Style | cross-platform styling.

Lines of Code Latest Version MIT docs Join us on Discord

This crate allows you to style the terminal cross-platform. It supports all UNIX and windows terminals down to windows 7 (not all terminals are tested see Tested Terminals for more info)

This crate is a sub-crate of crossterm to style the terminal, and can be use individually.

Other sub-crates are:

When you want to use other modules as well you might want to use crossterm with feature flags.

Table of contents:

Getting Started

This documentation is only for crossterm_style version 0.3 if you have an older version I suggest you check the Upgrade Manual. Also, check out the examples folders with detailed examples for all functionality of this crate.

Add the crossterm_style package to your Cargo.toml file.

[dependencies]
crossterm_style = "0.3"

And import the crossterm_style modules you want to use.

extern crate crossterm_style;

pub use crossterm_style::{color, style, Attribute, Color, ColorType, ObjectStyle, StyledObject, TerminalColor, Colorize, Styler};

Features

These are the features of this crate:

  • Cross-platform
  • Multithreaded (send, sync)
  • Detailed Documentation
  • Few Dependencies
  • Styled output
    • Foreground Color (16 base colors)
    • Background Color (16 base colors)
    • 256 (ANSI) Color Support (Windows 10 and UNIX Only)
    • RGB Color Support (Windows 10 and UNIX only)
    • Text Attributes: bold, italic, underscore and crossed word and more (Windows 10 and UNIX only)

Examples

The examples folder has more complete and verbose examples.

style text with attributes

use crossterm_style::{Colored, Color, Colorize, Styler, Attribute};

// pass any `Attribute` value to the formatting braces.
println!("{} Underlined {} No Underline", Attribute::Underlined, Attribute::NoUnderline);

// you could also call different attribute methods on a `&str` and keep on chaining if needed.
let styled_text = "Bold Underlined".bold().underlined();
println!("{}", styled_text);

// old-way but still usable
let styled_text = style("Bold Underlined").bold().underlined();

style text with colors

use crossterm_style::{Colored, Color, Colorize};

println!("{} Red foreground color", Colored::Fg(Color::Red));
println!("{} Blue background color", Colored::Bg(Color::Blue));

// you can also call different coloring methods on a `&str`.
let styled_text = "Bold Underlined".red().on_blue();
println!("{}", styled_text);

// old-way but still usable
let styled_text = style("Bold Underlined").with(Color::Red).on(Color::Blue);

style text with RGB and ANSI Value

// custom rgb value (Windows 10 and UNIX systems)
println!("{} some colored text", Colored::Fg(Color::Rgb {
    r: 10,
    g: 10,
    b: 10
}));

// custom ansi color value (Windows 10 and UNIX systems)
println!("{} some colored text", Colored::Fg(Color::AnsiValue(10)));

Tested terminals

  • Windows Powershell
    • Windows 10 (pro)
  • Windows CMD
    • Windows 10 (pro)
    • Windows 8.1 (N)
  • Ubuntu Desktop Terminal
    • Ubuntu 17.10
  • (Arch, Manjaro) KDE Konsole
  • Linux Mint

This crate supports all Unix terminals and windows terminals down to Windows 7 but not all of them have been tested. If you have used this library for a terminal other than the above list without issues feel free to add it to the above list, I really would appreciate it.

Authors

  • Timon Post - Project Owner & creator

License

This project is licensed under the MIT License - see the LICENSE.md file for details