From: Paul Mackerras Date: Tue, 1 Jan 2013 05:51:03 +0000 (+1100) Subject: gitk: Fix display of branch names on some commits X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=d809fb17b00f912112090294ff0257c8a87af56e;p=git.git gitk: Fix display of branch names on some commits Sometimes the code that divides commits up into arcs creates two successive arcs, but the commit between them (the commit at the end of the first arc and the beginning of the second arc) has only one parent and one child. If that commit is also the head of one or more branches, those branches get omitted from the "Branches" field in the commit display. The omission occurs because the commit gets erroneously identified as a commit which is part-way along an arc in [descheads]. This fixes it by changing the test to look at the arcouts array, which only contains elements for the commits at the start or end of an arc. Reported-by: Stephen Rothwell Signed-off-by: Paul Mackerras --- diff --git a/gitk b/gitk index bc73eea51..eead5a48d 100755 --- a/gitk +++ b/gitk @@ -10582,13 +10582,13 @@ proc anctags {id} { # including id itself if it has a head. proc descheads {id} { global arcnos arcstart arcids archeads idheads cached_dheads - global allparents + global allparents arcout if {![info exists allparents($id)]} { return {} } set aret {} - if {[llength $arcnos($id)] == 1 && [llength $allparents($id)] == 1} { + if {![info exists arcout($id)]} { # part-way along an arc; check it first set a [lindex $arcnos($id) 0] if {$archeads($a) ne {}} {