diff options
Diffstat (limited to 'lib/diff.tcl')
| -rw-r--r-- | lib/diff.tcl | 18 | 
1 files changed, 11 insertions, 7 deletions
| diff --git a/lib/diff.tcl b/lib/diff.tcl index 4a7138be9c..1970b601e1 100644 --- a/lib/diff.tcl +++ b/lib/diff.tcl @@ -192,6 +192,7 @@ proc show_diff {path w {lno {}} {scroll_pos {}}} {  		return  	} +	set ::current_diff_inheader 1  	fconfigure $fd \  		-blocking 0 \  		-encoding binary \ @@ -207,18 +208,21 @@ proc read_diff {fd scroll_pos} {  	while {[gets $fd line] >= 0} {  		# -- Cleanup uninteresting diff header lines.  		# -		if {   [string match {diff --git *}      $line] -			|| [string match {diff --cc *}       $line] -			|| [string match {diff --combined *} $line] -			|| [string match {--- *}             $line] -			|| [string match {+++ *}             $line]} { -			append current_diff_header $line "\n" -			continue +		if {$::current_diff_inheader} { +			if {   [string match {diff --git *}      $line] +			    || [string match {diff --cc *}       $line] +			    || [string match {diff --combined *} $line] +			    || [string match {--- *}             $line] +			    || [string match {+++ *}             $line]} { +				append current_diff_header $line "\n" +				continue +			}  		}  		if {[string match {index *} $line]} continue  		if {$line eq {deleted file mode 120000}} {  			set line "deleted symlink"  		} +		set ::current_diff_inheader 0  		# -- Automatically detect if this is a 3 way diff.  		# | 
