gitk: Fix bug where arcs could get lost
Because we weren't fixing up vlastins when moving an arc from one place to another, it was possible for us later to decide to move an arc to the wrong place, and end up with an arc disconnected from the rest of the graph. This fixes it by updating vlastins when necessary. Signed-off-by: Paul Mackerras <paulus@samba.org>
This commit is contained in:
parent
585fb5985d
commit
841ea82449
6
gitk
6
gitk
@ -415,11 +415,12 @@ proc splitvarc {p v} {
|
||||
set varcid($v,$id) $na
|
||||
}
|
||||
lappend vdownptr($v) [lindex $vdownptr($v) $oa]
|
||||
lappend vlastins($v) [lindex $vlastins($v) $oa]
|
||||
lset vdownptr($v) $oa $na
|
||||
lset vlastins($v) $oa 0
|
||||
lappend vupptr($v) $oa
|
||||
lappend vleftptr($v) 0
|
||||
lappend vbackptr($v) 0
|
||||
lappend vlastins($v) 0
|
||||
for {set b [lindex $vdownptr($v) $na]} {$b != 0} {set b [lindex $vleftptr($v) $b]} {
|
||||
lset vupptr($v) $b $na
|
||||
}
|
||||
@ -513,6 +514,9 @@ proc renumbervarc {a v} {
|
||||
if {$d != 0} {
|
||||
lset vbackptr($v) $d $c
|
||||
}
|
||||
if {[lindex $vlastins($v) $b] == $a} {
|
||||
lset vlastins($v) $b $c
|
||||
}
|
||||
lset vupptr($v) $a $ka
|
||||
set c [lindex $vlastins($v) $ka]
|
||||
if {$c == 0 || \
|
||||
|
Loading…
Reference in New Issue
Block a user