git-gui: Correct crash when saving options in blame mode.

Martin Waitz noticed that git-gui crashed while saving the user's
options out if the application was started in blame mode.  This
was caused by the do_save_config procedure invoking reshow_diff
incase the number of context lines was modified by the user.
Because we bypassed main window UI setup to enter blame mode we
did not set many of the globals which were accessed by reshow_diff,
and reading unset variables is an error in Tcl.

Aside from moving the globals to be set earlier, I also modified
reshow_diff to not invoke clear_diff if there is no path currently
in the diff viewer.  This way reshow_diff does not crash when in
blame mode due to the $ui_diff command not being defined.

Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
This commit is contained in:
Shawn O. Pearce 2007-02-18 02:12:32 -05:00
parent b90d479255
commit 372ef954a1

View File

@ -359,6 +359,24 @@ set _reponame [lindex [file split \
[file normalize [file dirname $_gitdir]]] \ [file normalize [file dirname $_gitdir]]] \
end] end]
######################################################################
##
## global init
set current_diff_path {}
set current_diff_side {}
set diff_actions [list]
set ui_status_value {Initializing...}
set HEAD {}
set PARENT {}
set MERGE_HEAD [list]
set commit_type {}
set empty_tree {}
set current_branch {}
set current_diff_path {}
set selected_commit_type new
###################################################################### ######################################################################
## ##
## task management ## task management
@ -682,8 +700,9 @@ proc reshow_diff {} {
global current_diff_path current_diff_side global current_diff_path current_diff_side
set p $current_diff_path set p $current_diff_path
if {$p eq {} if {$p eq {}} {
|| $current_diff_side eq {} # No diff is being shown.
} elseif {$current_diff_side eq {}
|| [catch {set s $file_states($p)}] || [catch {set s $file_states($p)}]
|| [lsearch -sorted -exact $file_lists($current_diff_side) $p] == -1} { || [lsearch -sorted -exact $file_lists($current_diff_side) $p] == -1} {
clear_diff clear_diff
@ -5647,9 +5666,6 @@ bind_button3 $ui_comm "tk_popup $ctxm %X %Y"
# -- Diff Header # -- Diff Header
# #
set current_diff_path {}
set current_diff_side {}
set diff_actions [list]
proc trace_current_diff_path {varname args} { proc trace_current_diff_path {varname args} {
global current_diff_path diff_actions file_states global current_diff_path diff_actions file_states
if {$current_diff_path eq {}} { if {$current_diff_path eq {}} {
@ -5842,7 +5858,6 @@ unset ui_diff_applyhunk
# -- Status Bar # -- Status Bar
# #
set ui_status_value {Initializing...}
label .status -textvariable ui_status_value \ label .status -textvariable ui_status_value \
-anchor w \ -anchor w \
-justify left \ -justify left \
@ -5916,15 +5931,6 @@ unset i
set file_lists($ui_index) [list] set file_lists($ui_index) [list]
set file_lists($ui_workdir) [list] set file_lists($ui_workdir) [list]
set HEAD {}
set PARENT {}
set MERGE_HEAD [list]
set commit_type {}
set empty_tree {}
set current_branch {}
set current_diff_path {}
set selected_commit_type new
wm title . "[appname] ([file normalize [file dirname [gitdir]]])" wm title . "[appname] ([file normalize [file dirname [gitdir]]])"
focus -force $ui_comm focus -force $ui_comm