зеркало из https://github.com/microsoft/git.git
gitk: Speed up resolution of short SHA1 ids
On large repositories such as the Linux kernel, it can take quite a noticeable time (several seconds) for gitk to resolve short SHA1 IDs to their long form. This speeds up the process by maintaining lists of IDs indexed by the first 4 characters of the SHA1 ID, speeding up the search by a factor of 65536 on large repositories. Signed-off-by: Paul Mackerras <paulus@samba.org>
This commit is contained in:
Родитель
5c9096f747
Коммит
22387f2395
32
gitk
32
gitk
|
@ -641,12 +641,16 @@ proc varcinit {view} {
|
|||
|
||||
proc resetvarcs {view} {
|
||||
global varcid varccommits parents children vseedcount ordertok
|
||||
global vshortids
|
||||
|
||||
foreach vid [array names varcid $view,*] {
|
||||
unset varcid($vid)
|
||||
unset children($vid)
|
||||
unset parents($vid)
|
||||
}
|
||||
foreach vid [array names vshortids $view,*] {
|
||||
unset vshortids($vid)
|
||||
}
|
||||
# some commits might have children but haven't been seen yet
|
||||
foreach vid [array names children $view,*] {
|
||||
unset children($vid)
|
||||
|
@ -933,7 +937,7 @@ proc fix_reversal {p a v} {
|
|||
proc insertrow {id p v} {
|
||||
global cmitlisted children parents varcid varctok vtokmod
|
||||
global varccommits ordertok commitidx numcommits curview
|
||||
global targetid targetrow
|
||||
global targetid targetrow vshortids
|
||||
|
||||
readcommit $id
|
||||
set vid $v,$id
|
||||
|
@ -942,6 +946,7 @@ proc insertrow {id p v} {
|
|||
set parents($vid) [list $p]
|
||||
set a [newvarc $v $id]
|
||||
set varcid($vid) $a
|
||||
lappend vshortids($v,[string range $id 0 3]) $id
|
||||
if {[string compare [lindex $varctok($v) $a] $vtokmod($v)] < 0} {
|
||||
modify_arc $v $a
|
||||
}
|
||||
|
@ -1397,7 +1402,7 @@ proc getcommitlines {fd inst view updating} {
|
|||
global commitidx commitdata vdatemode
|
||||
global parents children curview hlview
|
||||
global idpending ordertok
|
||||
global varccommits varcid varctok vtokmod vfilelimit
|
||||
global varccommits varcid varctok vtokmod vfilelimit vshortids
|
||||
|
||||
set stuff [read $fd 500000]
|
||||
# git log doesn't terminate the last commit with a null...
|
||||
|
@ -1497,6 +1502,8 @@ proc getcommitlines {fd inst view updating} {
|
|||
set id [lindex $ids 0]
|
||||
set vid $view,$id
|
||||
|
||||
lappend vshortids($view,[string range $id 0 3]) $id
|
||||
|
||||
if {!$listed && $updating && ![info exists varcid($vid)] &&
|
||||
$vfilelimit($view) ne {}} {
|
||||
# git log doesn't rewrite parents for unlisted commits
|
||||
|
@ -1719,11 +1726,26 @@ proc getcommit {id} {
|
|||
# and are present in the current view.
|
||||
# This is fairly slow...
|
||||
proc longid {prefix} {
|
||||
global varcid curview
|
||||
global varcid curview vshortids
|
||||
|
||||
set ids {}
|
||||
foreach match [array names varcid "$curview,$prefix*"] {
|
||||
lappend ids [lindex [split $match ","] 1]
|
||||
if {[string length $prefix] >= 4} {
|
||||
set vshortid $curview,[string range $prefix 0 3]
|
||||
if {[info exists vshortids($vshortid)]} {
|
||||
foreach id $vshortids($vshortid) {
|
||||
if {[string match "$prefix*" $id]} {
|
||||
if {[lsearch -exact $ids $id] < 0} {
|
||||
lappend ids $id
|
||||
if {[llength $ids] >= 2} break
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
} else {
|
||||
foreach match [array names varcid "$curview,$prefix*"] {
|
||||
lappend ids [lindex [split $match ","] 1]
|
||||
if {[llength $ids] >= 2} break
|
||||
}
|
||||
}
|
||||
return $ids
|
||||
}
|
||||
|
|
Загрузка…
Ссылка в новой задаче