7 releases

Uses old Rust 2015

0.2.3 Oct 20, 2021
0.2.2 May 17, 2019
0.2.1 Sep 24, 2018
0.2.0 Jun 5, 2018
0.1.2 Jun 3, 2018

#135 in Testing

Download history 8619/week @ 2023-11-27 8531/week @ 2023-12-04 6667/week @ 2023-12-11 6699/week @ 2023-12-18 3327/week @ 2023-12-25 7162/week @ 2024-01-01 10695/week @ 2024-01-08 11289/week @ 2024-01-15 12119/week @ 2024-01-22 11827/week @ 2024-01-29 10935/week @ 2024-02-05 11931/week @ 2024-02-12 9766/week @ 2024-02-19 10092/week @ 2024-02-26 6494/week @ 2024-03-04 4801/week @ 2024-03-11

31,949 downloads per month
Used in 20 crates

MIT OR Unlicense

9KB
170 lines

colored-diff

Show colored differences between source strings!

Inspired by / extracted from pretty-assertions and difference's github-style example

Powershell:
Powershell Example

Command Prompt:
Command Prompt Example

(Now accepting PRs for a macOS Terminal and/or Ubuntu (whatever console window) examples!)

Poem Example:

let expected = "\
    Roses are red, violets are blue,\n\
    I wrote this library here,\n\
    just for you.\n\
    (It's true).\n\
";
let actual = "\
    Roses are red, violets are blue,\n\
    I wrote this documentation here,\n\
    just for you.\n\
    (It's quite true).\n\
";

println!("{}", colored_diff::PrettyDifference { expected, actual })

Pretty-Assertions Example:

#[derive(Debug, PartialEq)]
struct Foo {
    lorem: &'static str,
    ipsum: u32,
    dolor: Result<String, String>,
}

let x = Some(Foo { lorem: "Hello World!", ipsum: 42, dolor: Ok("hey".to_string())});
let y = Some(Foo { lorem: "Hello Wrold!", ipsum: 42, dolor: Ok("hey ho!".to_string())});

let x = format!("{:#?}", x);
let y = format!("{:#?}", y);

println!("{}", colored_diff::PrettyDifference { expected: &x, actual: &y })

Dependencies

~490–710KB
~10K SLoC