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

#345 in Testing

Download history 2142/week @ 2024-08-30 1795/week @ 2024-09-06 1051/week @ 2024-09-13 844/week @ 2024-09-20 987/week @ 2024-09-27 566/week @ 2024-10-04 780/week @ 2024-10-11 1184/week @ 2024-10-18 894/week @ 2024-10-25 955/week @ 2024-11-01 916/week @ 2024-11-08 1411/week @ 2024-11-15 994/week @ 2024-11-22 1540/week @ 2024-11-29 1509/week @ 2024-12-06 1214/week @ 2024-12-13

5,465 downloads per month
Used in 29 crates (24 directly)

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

~520–730KB
~11K SLoC