Skip to content

Instantly share code, notes, and snippets.

@derekcollison
Forked from antirez/gist:2170066
Created March 23, 2012 17:21
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save derekcollison/2172945 to your computer and use it in GitHub Desktop.
Save derekcollison/2172945 to your computer and use it in GitHub Desktop.
#!/usr/bin/tclsh8.5
#
# Usage: unmerged branch1 branch2
proc getlog branch {
lrange [split [exec git log $branch --oneline] "\n"] 0 100
}
proc diff {title c1 c2} {
puts "\n$title"
foreach commit1 $c1 {
set found 0
set sha [lindex [split $commit1] 0]
set msg [join [lrange [split $commit1] 1 end]]
foreach commit2 $c2 {
set msg2 [join [lrange [split $commit2] 1 end]]
if {$msg eq $msg2} {
set found 1
break
}
}
if {!$found} {
puts "$commit1"
}
}
}
if {[llength $::argv] != 2} {
puts stderr "Usage: unmerged branch1 branch2"
exit 1
}
set branch1 [lindex $::argv 0]
set branch2 [lindex $::argv 1]
set c1 [getlog $branch1]
set c2 [getlog $branch2]
diff "Only in $branch1" [lrange $c1 0 50] $c2
diff "Only in $branch2" [lrange $c2 0 50] $c1
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment