diff options
| author | Alexander Gavrilov <angavrilov@gmail.com> | 2009-02-07 19:24:01 +0300 | 
|---|---|---|
| committer | Shawn O. Pearce <spearce@spearce.org> | 2009-02-08 11:50:11 -0800 | 
| commit | 584fa9ccf4b467e7633c100333cadf92e0c07894 (patch) | |
| tree | c5e62d87d95dd8c4e04026895bb88d049ab7cdda | |
| parent | 06569cd5bef7c8e3925bd36870abc083ae7b93f8 (diff) | |
| download | git-584fa9ccf4b467e7633c100333cadf92e0c07894.tar.gz | |
git-gui: Avoid an infinite rescan loop in handle_empty_diff.
If the index update machinery and git diff happen to disagree
on whether a particular file is modified, it may cause git-gui
to enter an infinite index rescan loop, where an empty diff
starts a rescan, which finds the same set of files modified,
and tries to display the diff for the first one, which happens
to be the empty one. A current example of a possible disagreement
point is the autocrlf filter.
This patch breaks the loop by using a global counter to track
the auto-rescans. The variable is reset whenever a non-empty
diff is displayed.
Another suggested approach, which is based on giving the
--exit-code argument to git diff, cannot be used, because
diff-files seems to trust the timestamps in the index, and
returns a non-zero code even if the file is actually
unchanged, which essentially defeats the purpose of the
auto-rescan logic.
Signed-off-by: Alexander Gavrilov <angavrilov@gmail.com>
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
| -rw-r--r-- | lib/diff.tcl | 9 | 
1 files changed, 9 insertions, 0 deletions
| diff --git a/lib/diff.tcl b/lib/diff.tcl index bbbf15c875..925b3f56c1 100644 --- a/lib/diff.tcl +++ b/lib/diff.tcl @@ -51,11 +51,16 @@ proc force_diff_encoding {enc} {  proc handle_empty_diff {} {  	global current_diff_path file_states file_lists +	global diff_empty_count  	set path $current_diff_path  	set s $file_states($path)  	if {[lindex $s 0] ne {_M}} return +	# Prevent infinite rescan loops +	incr diff_empty_count +	if {$diff_empty_count > 1} return +  	info_popup [mc "No differences detected.  %s has no changes. @@ -310,6 +315,7 @@ proc read_diff {fd cont_info} {  	global ui_diff diff_active  	global is_3way_diff is_conflict_diff current_diff_header  	global current_diff_queue +	global diff_empty_count  	$ui_diff conf -state normal  	while {[gets $fd line] >= 0} { @@ -415,7 +421,10 @@ proc read_diff {fd cont_info} {  		if {[$ui_diff index end] eq {2.0}} {  			handle_empty_diff +		} else { +			set diff_empty_count 0  		} +  		set callback [lindex $cont_info 1]  		if {$callback ne {}} {  			eval $callback | 
