summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: bea39c2)
raw | patch | inline | side by side (parent: bea39c2)
author | Shawn O. Pearce <spearce@spearce.org> | |
Fri, 1 Jun 2007 04:38:31 +0000 (00:38 -0400) | ||
committer | Shawn O. Pearce <spearce@spearce.org> | |
Wed, 6 Jun 2007 05:26:43 +0000 (01:26 -0400) |
The git-gui blame viewer has always been ugly as s**t. Linus Torvalds
suggested the coloring scheme I'm using here, which is two different
shades of grey for the background colors, and black text on a pale green
background for the currently selected/focused commit.
The difference is a massive improvement. The interface no longer will
cause seizures in people who are prone to that sort of thing. It no
longer uses a very offensive hot pink. The green being current actually
makes sense. And not having the background of the other non-current
lines change when you change the current commit is really a big deal.
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
suggested the coloring scheme I'm using here, which is two different
shades of grey for the background colors, and black text on a pale green
background for the currently selected/focused commit.
The difference is a massive improvement. The interface no longer will
cause seizures in people who are prone to that sort of thing. It no
longer uses a very offensive hot pink. The green being current actually
makes sense. And not having the background of the other non-current
lines change when you change the current commit is really a big deal.
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
lib/blame.tcl | patch | blob | history |
diff --git a/lib/blame.tcl b/lib/blame.tcl
index a6f0b4ab18752fbd7efbd350cd117d40bd667500..f48624a99eba8820230c7f30e6e9f802af1890ad 100644 (file)
--- a/lib/blame.tcl
+++ b/lib/blame.tcl
field r_final_line ; # final line number
field r_line_count ; # lines in this region
+variable active_color #98e1a0
+variable group_colors {
+ #cbcbcb
+ #e1e1e1
+}
+
constructor new {i_commit i_path} {
set commit $i_commit
set path $i_path
$w_load \
$w_line \
$w_file] {
- $i tag conf in_sel \
- -background [$i cget -foreground] \
- -foreground [$i cget -background]
$i conf -yscrollcommand \
[list many2scrollbar [list \
$w_cgrp \
} ifdeleted { catch {close $fd} }
method _read_blame {fd} {
+ variable group_colors
+
$w_cgrp conf -state normal
while {[gets $fd line] >= 0} {
if {[regexp {^([a-z0-9]{40}) (\d+) (\d+) (\d+)$} $line line \
set r_line_count $line_count
if {[catch {set g $order($cmit)}]} {
- $w_cgrp tag conf g$cmit
- $w_line tag conf g$cmit
- $w_file tag conf g$cmit
+ set bg [lindex $group_colors 0]
+ set group_colors [lrange $group_colors 1 end]
+ lappend group_colors $bg
- $w_cgrp tag raise in_sel
- $w_line tag raise in_sel
- $w_file tag raise in_sel
+ $w_cgrp tag conf g$cmit -background $bg
+ $w_line tag conf g$cmit -background $bg
+ $w_file tag conf g$cmit -background $bg
- $w_file tag raise sel
set order($cmit) $commit_count
incr commit_count
lappend commit_list $cmit
$w_cgrp tag remove g$g $lno.0 $lno_e
$w_line tag remove g$g $lno.0 $lno_e
$w_file tag remove g$g $lno.0 $lno_e
+
+ $w_cgrp tag remove a$g $lno.0 $lno_e
+ $w_line tag remove a$g $lno.0 $lno_e
+ $w_file tag remove a$g $lno.0 $lno_e
}
set line_commit($lno) $cmit
$w_line tag add g$cmit $lno.0 $lno_e
$w_file tag add g$cmit $lno.0 $lno_e
+ $w_cgrp tag add a$cmit $lno.0 $lno_e
+ $w_line tag add a$cmit $lno.0 $lno_e
+ $w_file tag add a$cmit $lno.0 $lno_e
+
if {$highlight_line == -1} {
if {[lindex [$w_file yview] 0] == 0} {
$w_file see $lno.0
method _click {cur_w pos} {
set lno [lindex [split [$cur_w index $pos] .] 0]
if {$lno eq {}} return
-
- set lno_e "$lno.0 + 1 line"
-
- $w_cgrp tag remove in_sel 0.0 end
- $w_line tag remove in_sel 0.0 end
- $w_file tag remove in_sel 0.0 end
-
- $w_cgrp tag add in_sel $lno.0 $lno_e
- $w_line tag add in_sel $lno.0 $lno_e
- $w_file tag add in_sel $lno.0 $lno_e
-
_showcommit $this $lno
}
-variable blame_colors {
- #ff4040
- #ff40ff
- #4040ff
-}
-
method _showcommit {lno} {
global repo_config
- variable blame_colors
+ variable active_color
if {$highlight_commit ne {}} {
- set idx $order($highlight_commit)
- set i 0
- foreach c $blame_colors {
- set h [lindex $commit_list [expr {$idx - 1 + $i}]]
- $w_cgrp tag conf g$h -background white
- $w_line tag conf g$h -background white
- $w_file tag conf g$h -background white
- incr i
- }
+ set cmit $highlight_commit
+ $w_cgrp tag conf a$cmit -background {}
+ $w_line tag conf a$cmit -background {}
+ $w_file tag conf a$cmit -background {}
}
$w_cmit conf -state normal
set cmit {}
$w_cmit insert end "Loading annotation..."
} else {
- set idx $order($cmit)
- set i 0
- foreach c $blame_colors {
- set h [lindex $commit_list [expr {$idx - 1 + $i}]]
- $w_cgrp tag conf g$h -background $c
- $w_line tag conf g$h -background $c
- $w_file tag conf g$h -background $c
- incr i
- }
+ $w_cgrp tag conf a$cmit -background $active_color
+ $w_line tag conf a$cmit -background $active_color
+ $w_file tag conf a$cmit -background $active_color
set author_name {}
set author_email {}