Struct yansi::Style [] [src]

#[repr(packed)]
pub struct Style { /* fields omitted */ }

Represents a set of styling options.

See the crate level documentation for usage information.

Method Glossary

The Style structure exposes many methods for convenience. The majority of these methods are shared with Paint.

Unstyled Constructors

Return a new Style structure with no styling applied.

Foreground Color Constructors

Return a new Style structure with a foreground color applied.

Getters

Return information about a Style structure.

Setters

Set a style property on a given Style structure.

These methods can be chained:

use yansi::Style;

Style::red().underline().invert().italic().dimmed().bold();

Converters

Convert a Style into another structure.

Raw Formatters

Write the raw ANSI codes for a given Style to a fmt::Formatter.

Methods

impl Style
[src]

[src]

Default, unstylized Style. This is identical to Style::default().

use yansi::Style;

let plain = Style::new();
assert_eq!(plain, Style::default());

[src]

Default, unstylized but masked Style. Aside from masking, this is identical to Style::default().

An item with masked styling is not written out when painting is disabled during Display or Debug invocations. When painting is enabled, masking has no effect.

use yansi::Style;

let plain = Style::masked();
assert_eq!(plain, Style::default());

[src]

Constructs a new Stylestructure with the foreground color set to black.

use yansi::Style; 

let black = Style::black();
println!("This is going to be black: {}", black.paint("yay!"));

[src]

Constructs a new Stylestructure with the foreground color set to red.

use yansi::Style; 

let red = Style::red();
println!("This is going to be red: {}", red.paint("yay!"));

[src]

Constructs a new Stylestructure with the foreground color set to green.

use yansi::Style; 

let green = Style::green();
println!("This is going to be green: {}", green.paint("yay!"));

[src]

Constructs a new Stylestructure with the foreground color set to yellow.

use yansi::Style; 

let yellow = Style::yellow();
println!("This is going to be yellow: {}", yellow.paint("yay!"));

[src]

Constructs a new Stylestructure with the foreground color set to blue.

use yansi::Style; 

let blue = Style::blue();
println!("This is going to be blue: {}", blue.paint("yay!"));

[src]

Constructs a new Stylestructure with the foreground color set to purple.

use yansi::Style; 

let purple = Style::purple();
println!("This is going to be purple: {}", purple.paint("yay!"));

[src]

Constructs a new Stylestructure with the foreground color set to cyan.

use yansi::Style; 

let cyan = Style::cyan();
println!("This is going to be cyan: {}", cyan.paint("yay!"));

[src]

Constructs a new Stylestructure with the foreground color set to white.

use yansi::Style; 

let white = Style::white();
println!("This is going to be white: {}", white.paint("yay!"));

[src]

Returns the foreground color of self.

use yansi::{Style, Color};

let plain = Style::new();
assert_eq!(plain.fg_color(), Color::Unset);

let red = plain.fg(Color::Red);
assert_eq!(red.fg_color(), Color::Red);

[src]

Returns the foreground color of self.

use yansi::{Style, Color};

let plain = Style::new();
assert_eq!(plain.bg_color(), Color::Unset);

let white = plain.bg(Color::White);
assert_eq!(white.bg_color(), Color::White);

[src]

Returns true if self is masked.

use yansi::Style;

let plain = Style::new();
assert!(!plain.is_masked());

let masked = plain.mask();
assert!(masked.is_masked());

[src]

Returns trueif the bold property is set on self.

use yansi::Style; 

let plain = Style::new();
assert!(!plain.is_bold());

let styled = plain.bold(); 
assert!(styled.is_bold());

[src]

Returns trueif the dimmed property is set on self.

use yansi::Style; 

let plain = Style::new();
assert!(!plain.is_dimmed());

let styled = plain.dimmed(); 
assert!(styled.is_dimmed());

[src]

Returns trueif the italic property is set on self.

use yansi::Style; 

let plain = Style::new();
assert!(!plain.is_italic());

let styled = plain.italic(); 
assert!(styled.is_italic());

[src]

Returns trueif the underline property is set on self.

use yansi::Style; 

let plain = Style::new();
assert!(!plain.is_underline());

let styled = plain.underline(); 
assert!(styled.is_underline());

Returns trueif the blink property is set on self.

use yansi::Style; 

let plain = Style::new();
assert!(!plain.is_blink());

let styled = plain.blink(); 
assert!(styled.is_blink());

[src]

Returns trueif the invert property is set on self.

use yansi::Style; 

let plain = Style::new();
assert!(!plain.is_invert());

let styled = plain.invert(); 
assert!(styled.is_invert());

[src]

Returns trueif the hidden property is set on self.

use yansi::Style; 

let plain = Style::new();
assert!(!plain.is_hidden());

let styled = plain.hidden(); 
assert!(styled.is_hidden());

[src]

Returns trueif the strikethrough property is set on self.

use yansi::Style; 

let plain = Style::new();
assert!(!plain.is_strikethrough());

let styled = plain.strikethrough(); 
assert!(styled.is_strikethrough());

[src]

Sets the foreground to color.

use yansi::{Color, Style};

let red_fg = Style::new().fg(Color::Red);

[src]

Sets the background to color.

use yansi::{Color, Style};

let red_bg = Style::new().bg(Color::Red);

[src]

Sets self to be masked.

An item with masked styling is not written out when painting is disabled during Display or Debug invocations. When painting is enabled, masking has no effect.

use yansi::Style;

let masked = Style::new().mask();

// "Whoops! " will only print when coloring is enabled.
println!("{}Something happened.", masked.paint("Whoops! "));

[src]

Enables the bold style on self.

use yansi::Paint; 

println!("Using bold: {}", Paint::new("hi").bold());

[src]

Enables the dimmed style on self.

use yansi::Paint; 

println!("Using dimmed: {}", Paint::new("hi").dimmed());

[src]

Enables the italic style on self.

use yansi::Paint; 

println!("Using italic: {}", Paint::new("hi").italic());

[src]

Enables the underline style on self.

use yansi::Paint; 

println!("Using underline: {}", Paint::new("hi").underline());

Enables the blink style on self.

use yansi::Paint; 

println!("Using blink: {}", Paint::new("hi").blink());

[src]

Enables the invert style on self.

use yansi::Paint; 

println!("Using invert: {}", Paint::new("hi").invert());

[src]

Enables the hidden style on self.

use yansi::Paint; 

println!("Using hidden: {}", Paint::new("hi").hidden());

[src]

Enables the strikethrough style on self.

use yansi::Paint; 

println!("Using strikethrough: {}", Paint::new("hi").strikethrough());

[src]

Constructs a new Paint structure that encapsulates item with the style set to self.

use yansi::{Style, Color};

let alert = Style::red().bold().underline();
println!("Alert: {}", alert.paint("This thing happened!"));

[src]

Writes the ANSI code prefix for the currently set styles.

This method is intended to be used inside of fmt::Display and fmt::Debug implementations for custom or specialized use-cases. Most users should use Paint for all painting needs.

This method writes the ANSI code prefix irrespective of whether painting is currently enabled or disabled. To write the prefix only if painting is enabled, condition a call to this method on Paint::is_enabled().

Example

use std::fmt;
use yansi::Style;

struct CustomItem {
    item: u32,
    style: Style
}

impl fmt::Display for CustomItem {
    fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
        self.style.fmt_prefix(f)?;
        write!(f, "number: {}", self.item)?;
        self.style.fmt_suffix(f)
    }
}

[src]

Writes the ANSI code suffix for the currently set styles.

This method is intended to be used inside of fmt::Display and fmt::Debug implementations for custom or specialized use-cases. Most users should use Paint for all painting needs.

This method writes the ANSI code suffix irrespective of whether painting is currently enabled or disabled. To write the suffix only if painting is enabled, condition a call to this method on Paint::is_enabled().

Example

use std::fmt;
use yansi::Style;

struct CustomItem {
    item: u32,
    style: Style
}

impl fmt::Display for CustomItem {
    fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
        self.style.fmt_prefix(f)?;
        write!(f, "number: {}", self.item)?;
        self.style.fmt_suffix(f)
    }
}

Trait Implementations

impl Default for Style
[src]

[src]

Returns the "default value" for a type. Read more

impl Debug for Style
[src]

[src]

Formats the value using the given formatter. Read more

impl Eq for Style
[src]

impl Ord for Style
[src]

[src]

This method returns an Ordering between self and other. Read more

1.21.0
[src]

Compares and returns the maximum of two values. Read more

1.21.0
[src]

Compares and returns the minimum of two values. Read more

impl PartialOrd for Style
[src]

[src]

This method returns an ordering between self and other values if one exists. Read more

[src]

This method tests less than (for self and other) and is used by the < operator. Read more

[src]

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more

[src]

This method tests greater than (for self and other) and is used by the > operator. Read more

[src]

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more

impl Hash for Style
[src]

[src]

Feeds this value into the given [Hasher]. Read more

1.3.0
[src]

Feeds a slice of this type into the given [Hasher]. Read more

impl Copy for Style
[src]

impl Clone for Style
[src]

[src]

Returns a copy of the value. Read more

1.0.0
[src]

Performs copy-assignment from source. Read more

impl PartialEq for Style
[src]

[src]

This method tests for self and other values to be equal, and is used by ==. Read more

1.0.0
[src]

This method tests for !=.