Dirb - Easy Diffing With Ruby
============================
Need diffs in your ruby app? Dirb has you covered. It provides a convenient
way to generate a diff from two strings. Instead of reimplementing the LCS diff
algorithm Dirb uses battle tested Unix diff to generate diffs, and focuses on
providing a convenient interface, and getting out of your way.
It provides several built in format options. Pass `:text`, `:color`, or
`:html` to `Dirb::Diff#to_s` to force that format, or set
`Dirb::Diff.default_format`
Getting Started
---------------
sudo gem install dirb
Here's an example of using Dirb to diff two strings
$ irb
>> string1 = <<-TXT
>" Hello how are you
>" I'm fine
>" That's great
>" TXT
=> "Hello how are you\nI'm fine\nThat's great\n"
>> string2 = <<-TXT
>" Hello how are you?
>" I'm fine
>" That's swell
>" TXT
=> "Hello how are you?\nI'm fine\nThat's swell\n"
>> puts Dirb::Diff.new(string1, string2)
-Hello how are you
+Hello how are you?
I'm fine
-That's great
+That's swell
Outputing the diff as html is easy too.
>> puts Dirb::Diff.new(string1, string2).to_s(:html)
Hello how are you
- Hello how are you?
- I'm fine
That's great
- That's swell
Then try adding this css to your stylesheets:
.diff{overflow:auto;}
.diff ul{background:#fff;overflow:auto;font-size:13px;list-style:none;margin:0;padding:0;display:table;width:100%;}
.diff del, .diff ins{display:block;text-decoration:none;}
.diff li{padding:0; display:table-row;margin: 0;}
.diff li.ins{background:#9f9;}
.diff li.del{background:#ccf;}
.diff li:hover{background:#ffc}
.diff del, .diff ins, .diff span{white-space:pre;font-family:courier;}
Dirb::Diff also alows you to set a default format. Here we set the default to
use ANSI termnial color escape sequences.
>> Dirb::Diff.default_format = :color
=> :color
>> puts Dirb::Diff.new(string1, string2) # prints color in the terminal
-Hello how are you
+Hello how are you?
I'm fine
-That's great
+That's swell
Creating custom formatted output is easy too. `Dirb::Diff` provides an
enumberable interface which lets you iterate over lines in the diff.
>> Dirb::Diff.new("foo\nbar\n", "foo\nbar\nbaz\n").each do |line|
>* case line
>> when /^\+/ then puts "line #{line.chomp} added"
>> when /^-/ then puts "line #{line.chomp} removed"
>> end
>> end
line +baz added
=> [" foo\n", " bar\n", "+baz\n"]
Use `#map`, `#inject`, or any of Enumerable's methods. Go crazy.
Report bugs or request features at http://github.com/samg/Dirb/issues