Add a widget to show the SHA1 ID of the current commit

Add a find facility to search within the commits
Cope with multiple starting points.
This commit is contained in:
Paul Mackerras 2005-05-15 05:56:51 +00:00
parent 9a40c50c1e
commit 98f350e501

227
gitk
View File

@ -7,7 +7,7 @@ exec wish "$0" -- "${1+$@}"
# and distributed under the terms of the GNU General Public Licence, # and distributed under the terms of the GNU General Public Licence,
# either version 2, or (at your option) any later version. # either version 2, or (at your option) any later version.
# CVS $Revision: 1.7 $ # CVS $Revision: 1.8 $
set datemode 0 set datemode 0
set boldnames 0 set boldnames 0
@ -135,6 +135,7 @@ proc readcommit {id} {
proc makewindow {} { proc makewindow {} {
global canv canv2 canv3 linespc charspc ctext cflist textfont global canv canv2 canv3 linespc charspc ctext cflist textfont
global sha1entry findtype findloc findstring
menu .bar menu .bar
.bar add cascade -label "File" -menu .bar.file .bar add cascade -label "File" -menu .bar.file
@ -146,27 +147,48 @@ proc makewindow {} {
. configure -menu .bar . configure -menu .bar
panedwindow .ctop -orient vertical panedwindow .ctop -orient vertical
panedwindow .ctop.clist -orient horizontal -sashpad 0 -handlesize 4 frame .ctop.top
.ctop add .ctop.clist frame .ctop.top.bar
set canv .ctop.clist.canv pack .ctop.top.bar -side bottom -fill x
set cscroll .ctop.clist.dates.csb set cscroll .ctop.top.csb
scrollbar $cscroll -command {allcanvs yview} -highlightthickness 0
pack $cscroll -side right -fill y
panedwindow .ctop.top.clist -orient horizontal -sashpad 0 -handlesize 4
pack .ctop.top.clist -side top -fill both -expand 1
.ctop add .ctop.top
set canv .ctop.top.clist.canv
set height [expr 25 * $linespc + 4] set height [expr 25 * $linespc + 4]
canvas $canv -height $height -width [expr 45 * $charspc] \ canvas $canv -height $height -width [expr 45 * $charspc] \
-bg white -bd 0 \ -bg white -bd 0 \
-yscrollincr $linespc -yscrollcommand "$cscroll set" -yscrollincr $linespc -yscrollcommand "$cscroll set"
.ctop.clist add $canv .ctop.top.clist add $canv
set canv2 .ctop.clist.canv2 set canv2 .ctop.top.clist.canv2
canvas $canv2 -height $height -width [expr 30 * $charspc] \ canvas $canv2 -height $height -width [expr 30 * $charspc] \
-bg white -bd 0 -yscrollincr $linespc -bg white -bd 0 -yscrollincr $linespc
.ctop.clist add $canv2 .ctop.top.clist add $canv2
frame .ctop.clist.dates set canv3 .ctop.top.clist.canv3
.ctop.clist add .ctop.clist.dates
set canv3 .ctop.clist.dates.canv3
canvas $canv3 -height $height -width [expr 15 * $charspc] \ canvas $canv3 -height $height -width [expr 15 * $charspc] \
-bg white -bd 0 -yscrollincr $linespc -bg white -bd 0 -yscrollincr $linespc
scrollbar $cscroll -command {allcanvs yview} -highlightthickness 0 .ctop.top.clist add $canv3
pack .ctop.clist.dates.csb -side right -fill y
pack $canv3 -side left -fill both -expand 1 set sha1entry .ctop.top.bar.sha1
label .ctop.top.bar.sha1label -text "SHA1 ID: "
pack .ctop.top.bar.sha1label -side left
entry $sha1entry -width 40 -font $textfont -state readonly
pack $sha1entry -side left -pady 2
button .ctop.top.bar.findbut -text "Find" -command dofind
pack .ctop.top.bar.findbut -side left
set findstring {}
entry .ctop.top.bar.findstring -width 30 -font $textfont \
-textvariable findstring
pack .ctop.top.bar.findstring -side left -expand 1 -fill x
set findtype Exact
tk_optionMenu .ctop.top.bar.findtype findtype Exact IgnCase Regexp
set findloc "All fields"
tk_optionMenu .ctop.top.bar.findloc findloc "All fields" Headline \
Comments Author Committer
pack .ctop.top.bar.findloc -side right
pack .ctop.top.bar.findtype -side right
panedwindow .ctop.cdet -orient horizontal panedwindow .ctop.cdet -orient horizontal
.ctop add .ctop.cdet .ctop add .ctop.cdet
@ -215,6 +237,9 @@ proc makewindow {} {
bind . u "$ctext yview scroll -18 u" bind . u "$ctext yview scroll -18 u"
bind . Q "set stopped 1; destroy ." bind . Q "set stopped 1; destroy ."
bind . <Control-q> "set stopped 1; destroy ." bind . <Control-q> "set stopped 1; destroy ."
bind . <Control-f> dofind
bind . <Control-g> findnext
bind . <Control-r> findprev
bind $cflist <<ListboxSelect>> listboxsel bind $cflist <<ListboxSelect>> listboxsel
} }
@ -247,7 +272,7 @@ Copyright
Use and redistribute under the terms of the GNU General Public License Use and redistribute under the terms of the GNU General Public License
(CVS $Revision: 1.7 $)} \ (CVS $Revision: 1.8 $)} \
-justify center -aspect 400 -justify center -aspect 400
pack $w.m -side top -fill x -padx 20 -pady 20 pack $w.m -side top -fill x -padx 20 -pady 20
button $w.ok -text Close -command "destroy $w" button $w.ok -text Close -command "destroy $w"
@ -329,30 +354,33 @@ proc assigncolor {id} {
} }
} }
proc drawgraph {start} { proc drawgraph {startlist} {
global parents children nparents nchildren commits global parents children nparents nchildren commits
global canv canv2 canv3 mainfont namefont canvx0 canvy0 canvy linespc global canv canv2 canv3 mainfont namefont canvx0 canvy0 canvy linespc
global datemode cdate global datemode cdate
global lineid linehtag linentag linedtag commitinfo global lineid linehtag linentag linedtag commitinfo
global nextcolor colormap global nextcolor colormap numcommits
global stopped global stopped
set nextcolor 0 set nextcolor 0
assigncolor $start
foreach id $commits { foreach id $commits {
set ncleft($id) $nchildren($id) set ncleft($id) $nchildren($id)
} }
set todo [list $start] foreach id $startlist {
set level 0 assigncolor $id
}
set todo $startlist
set level [expr [llength $todo] - 1]
set y2 $canvy0 set y2 $canvy0
set linestarty(0) $canvy0
set nullentry -1 set nullentry -1
set lineno -1 set lineno -1
set numcommits 0
while 1 { while 1 {
set canvy $y2 set canvy $y2
allcanvs conf -scrollregion [list 0 0 0 $canvy] allcanvs conf -scrollregion [list 0 0 0 $canvy]
update update
if {$stopped} return if {$stopped} return
incr numcommits
incr lineno incr lineno
set nlines [llength $todo] set nlines [llength $todo]
set id [lindex $todo $level] set id [lindex $todo $level]
@ -369,12 +397,12 @@ proc drawgraph {start} {
} }
set x [expr $canvx0 + $level * $linespc] set x [expr $canvx0 + $level * $linespc]
set y2 [expr $canvy + $linespc] set y2 [expr $canvy + $linespc]
if {$linestarty($level) < $canvy} { if {[info exists linestarty($level)] && $linestarty($level) < $canvy} {
set t [$canv create line $x $linestarty($level) $x $canvy \ set t [$canv create line $x $linestarty($level) $x $canvy \
-width 2 -fill $colormap($id)] -width 2 -fill $colormap($id)]
$canv lower $t $canv lower $t
set linestarty($level) $canvy
} }
set linestarty($level) $canvy
set t [$canv create oval [expr $x - 4] [expr $canvy - 4] \ set t [$canv create oval [expr $x - 4] [expr $canvy - 4] \
[expr $x + 3] [expr $canvy + 3] \ [expr $x + 3] [expr $canvy + 3] \
-fill blue -outline black -width 1] -fill blue -outline black -width 1]
@ -403,12 +431,14 @@ proc drawgraph {start} {
set lines {} set lines {}
for {set i 0} {$i < $nlines} {incr i} { for {set i 0} {$i < $nlines} {incr i} {
if {[lindex $todo $i] == {}} continue if {[lindex $todo $i] == {}} continue
set oldstarty($i) $linestarty($i) if {[info exists linestarty($i)]} {
set oldstarty($i) $linestarty($i)
unset linestarty($i)
}
if {$i != $level} { if {$i != $level} {
lappend lines [list $i [lindex $todo $i]] lappend lines [list $i [lindex $todo $i]]
} }
} }
unset linestarty
if {$nullentry >= 0} { if {$nullentry >= 0} {
set todo [lreplace $todo $nullentry $nullentry] set todo [lreplace $todo $nullentry $nullentry]
if {$nullentry < $level} { if {$nullentry < $level} {
@ -494,13 +524,15 @@ proc drawgraph {start} {
set dst [lindex $l 1] set dst [lindex $l 1]
set j [lsearch -exact $todo $dst] set j [lsearch -exact $todo $dst]
if {$i == $j} { if {$i == $j} {
set linestarty($i) $oldstarty($i) if {[info exists oldstarty($i)]} {
set linestarty($i) $oldstarty($i)
}
continue continue
} }
set xi [expr {$canvx0 + $i * $linespc}] set xi [expr {$canvx0 + $i * $linespc}]
set xj [expr {$canvx0 + $j * $linespc}] set xj [expr {$canvx0 + $j * $linespc}]
set coords {} set coords {}
if {$oldstarty($i) < $canvy} { if {[info exists oldstarty($i)] && $oldstarty($i) < $canvy} {
lappend coords $xi $oldstarty($i) lappend coords $xi $oldstarty($i)
} }
lappend coords $xi $canvy lappend coords $xi $canvy
@ -519,6 +551,133 @@ proc drawgraph {start} {
} }
} }
proc dofind {} {
global findtype findloc findstring markedmatches commitinfo
global numcommits lineid linehtag linentag linedtag
global mainfont namefont canv canv2 canv3 selectedline
global matchinglines
unmarkmatches
set matchinglines {}
set fldtypes {Headline Author Date Committer CDate Comment}
if {$findtype == "IgnCase"} {
set fstr [string tolower $findstring]
} else {
set fstr $findstring
}
set mlen [string length $findstring]
if {$mlen == 0} return
if {![info exists selectedline]} {
set oldsel -1
} else {
set oldsel $selectedline
}
set didsel 0
for {set l 0} {$l < $numcommits} {incr l} {
set id $lineid($l)
set info $commitinfo($id)
set doesmatch 0
foreach f $info ty $fldtypes {
if {$findloc != "All fields" && $findloc != $ty} {
continue
}
if {$findtype == "Regexp"} {
set matches [regexp -indices -all -inline $fstr $f]
} else {
if {$findtype == "IgnCase"} {
set str [string tolower $f]
} else {
set str $f
}
set matches {}
set i 0
while {[set j [string first $fstr $str $i]] >= 0} {
lappend matches [list $j [expr $j+$mlen-1]]
set i [expr $j + $mlen]
}
}
if {$matches == {}} continue
set doesmatch 1
if {$ty == "Headline"} {
markmatches $canv $l $f $linehtag($l) $matches $mainfont
} elseif {$ty == "Author"} {
markmatches $canv2 $l $f $linentag($l) $matches $namefont
} elseif {$ty == "Date"} {
markmatches $canv3 $l $f $linedtag($l) $matches $mainfont
}
}
if {$doesmatch} {
lappend matchinglines $l
if {!$didsel && $l > $oldsel} {
selectline $l
set didsel 1
}
}
}
if {$matchinglines == {}} {
bell
} elseif {!$didsel} {
selectline [lindex $matchinglines 0]
}
}
proc findnext {} {
global matchinglines selectedline
if {![info exists matchinglines]} {
dofind
return
}
if {![info exists selectedline]} return
foreach l $matchinglines {
if {$l > $selectedline} {
selectline $l
return
}
}
bell
}
proc findprev {} {
global matchinglines selectedline
if {![info exists matchinglines]} {
dofind
return
}
if {![info exists selectedline]} return
set prev {}
foreach l $matchinglines {
if {$l >= $selectedline} break
set prev $l
}
if {$prev != {}} {
selectline $prev
} else {
bell
}
}
proc markmatches {canv l str tag matches font} {
set bbox [$canv bbox $tag]
set x0 [lindex $bbox 0]
set y0 [lindex $bbox 1]
set y1 [lindex $bbox 3]
foreach match $matches {
set start [lindex $match 0]
set end [lindex $match 1]
if {$start > $end} continue
set xoff [font measure $font [string range $str 0 [expr $start-1]]]
set xlen [font measure $font [string range $str 0 [expr $end]]]
set t [$canv create rect [expr $x0+$xoff] $y0 [expr $x0+$xlen+2] $y1 \
-outline {} -tags matches -fill yellow]
$canv lower $t
}
}
proc unmarkmatches {} {
global matchinglines
allcanvs delete matches
catch {unset matchinglines}
}
proc selcanvline {x y} { proc selcanvline {x y} {
global canv canvy0 ctext linespc selectedline global canv canvy0 ctext linespc selectedline
global lineid linehtag linentag linedtag global lineid linehtag linentag linedtag
@ -530,6 +689,7 @@ proc selcanvline {x y} {
set l 0 set l 0
} }
if {[info exists selectedline] && $selectedline == $l} return if {[info exists selectedline] && $selectedline == $l} return
unmarkmatches
selectline $l selectline $l
} }
@ -537,7 +697,7 @@ proc selectline {l} {
global canv canv2 canv3 ctext commitinfo selectedline global canv canv2 canv3 ctext commitinfo selectedline
global lineid linehtag linentag linedtag global lineid linehtag linentag linedtag
global canvy canvy0 linespc nparents treepending global canvy canvy0 linespc nparents treepending
global cflist treediffs currentid global cflist treediffs currentid sha1entry
if {![info exists lineid($l)] || ![info exists linehtag($l)]} return if {![info exists lineid($l)] || ![info exists linehtag($l)]} return
$canv delete secsel $canv delete secsel
set t [eval $canv create rect [$canv bbox $linehtag($l)] -outline {{}} \ set t [eval $canv create rect [$canv bbox $linehtag($l)] -outline {{}} \
@ -564,6 +724,13 @@ proc selectline {l} {
set selectedline $l set selectedline $l
set id $lineid($l) set id $lineid($l)
$sha1entry conf -state normal
$sha1entry delete 0 end
$sha1entry insert 0 $id
$sha1entry selection from 0
$sha1entry selection to end
$sha1entry conf -state readonly
$ctext conf -state normal $ctext conf -state normal
$ctext delete 0.0 end $ctext delete 0.0 end
set info $commitinfo($id) set info $commitinfo($id)
@ -592,6 +759,7 @@ proc selnextline {dir} {
global selectedline global selectedline
if {![info exists selectedline]} return if {![info exists selectedline]} return
set l [expr $selectedline + $dir] set l [expr $selectedline + $dir]
unmarkmatches
selectline $l selectline $l
} }
@ -746,8 +914,7 @@ makewindow
set start {} set start {}
foreach id $commits { foreach id $commits {
if {$nchildren($id) == 0} { if {$nchildren($id) == 0} {
set start $id lappend start $id
break
} }
} }
if {$start != {}} { if {$start != {}} {