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

#331 in Testing

Download history 6111/week @ 2024-07-21 5917/week @ 2024-07-28 4062/week @ 2024-08-04 5822/week @ 2024-08-11 6135/week @ 2024-08-18 2265/week @ 2024-08-25 2122/week @ 2024-09-01 1620/week @ 2024-09-08 839/week @ 2024-09-15 930/week @ 2024-09-22 927/week @ 2024-09-29 465/week @ 2024-10-06 989/week @ 2024-10-13 1061/week @ 2024-10-20 851/week @ 2024-10-27 1005/week @ 2024-11-03

3,935 downloads per month
Used in 23 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

~520–730KB
~11K SLoC