diff options
| author | Junio C Hamano <gitster@pobox.com> | 2009-09-20 23:47:52 -0700 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2009-09-20 23:47:52 -0700 | 
| commit | 0984e3a77246c536f938f53ecded99533fb31667 (patch) | |
| tree | ccc9a03bba20d2452050be826dd54a4588bd01cc /gitk-git/gitk | |
| parent | 6e4ece61ff9c4c0a0c7eac43fca74ca1b5548e98 (diff) | |
| parent | 9bedb0e185332f9f8fb5e1c18bb5aff9964145a6 (diff) | |
| download | git-0984e3a77246c536f938f53ecded99533fb31667.tar.gz | |
Merge git://git.kernel.org/pub/scm/gitk/gitk
* git://git.kernel.org/pub/scm/gitk/gitk:
  gitk: Work around leftover temporary save file
  gitk: Show diff of commits at end of compare-commits output
  gitk: Update Swedish translation (280t0f0u)
Diffstat (limited to 'gitk-git/gitk')
| -rw-r--r-- | gitk-git/gitk | 82 | 
1 files changed, 59 insertions, 23 deletions
| diff --git a/gitk-git/gitk b/gitk-git/gitk index 8c08310e6d..a0214b7004 100644 --- a/gitk-git/gitk +++ b/gitk-git/gitk @@ -2526,6 +2526,7 @@ proc savestuff {w} {      if {$stuffsaved} return      if {![winfo viewable .]} return      catch { +	if {[file exists ~/.gitk-new]} {file delete -force ~/.gitk-new}  	set f [open "~/.gitk-new" w]  	if {$::tcl_platform(platform) eq {windows}} {  	    file attributes "~/.gitk-new" -hidden true @@ -3167,6 +3168,28 @@ proc flist_hl {only} {      set gdttype [mc "touching paths:"]  } +proc gitknewtmpdir {} { +    global diffnum gitktmpdir gitdir + +    if {![info exists gitktmpdir]} { +	set gitktmpdir [file join [file dirname $gitdir] \ +			    [format ".gitk-tmp.%s" [pid]]] +	if {[catch {file mkdir $gitktmpdir} err]} { +	    error_popup "[mc "Error creating temporary directory %s:" $gitktmpdir] $err" +	    unset gitktmpdir +	    return {} +	} +	set diffnum 0 +    } +    incr diffnum +    set diffdir [file join $gitktmpdir $diffnum] +    if {[catch {file mkdir $diffdir} err]} { +	error_popup "[mc "Error creating temporary directory %s:" $diffdir] $err" +	return {} +    } +    return $diffdir +} +  proc save_file_from_commit {filename output what} {      global nullfile @@ -3201,11 +3224,10 @@ proc external_diff_get_one_file {diffid filename diffdir} {  }  proc external_diff {} { -    global gitktmpdir nullid nullid2 +    global nullid nullid2      global flist_menu_file      global diffids -    global diffnum -    global gitdir extdifftool +    global extdifftool      if {[llength $diffids] == 1} {          # no reference commit given @@ -3227,22 +3249,8 @@ proc external_diff {} {      }      # make sure that several diffs wont collide -    if {![info exists gitktmpdir]} { -	set gitktmpdir [file join [file dirname $gitdir] \ -			    [format ".gitk-tmp.%s" [pid]]] -	if {[catch {file mkdir $gitktmpdir} err]} { -	    error_popup "[mc "Error creating temporary directory %s:" $gitktmpdir] $err" -	    unset gitktmpdir -	    return -	} -	set diffnum 0 -    } -    incr diffnum -    set diffdir [file join $gitktmpdir $diffnum] -    if {[catch {file mkdir $diffdir} err]} { -	error_popup "[mc "Error creating temporary directory %s:" $diffdir] $err" -	return -    } +    set diffdir [gitknewtmpdir] +    if {$diffdir eq {}} return      # gather files to diff      set difffromfile [external_diff_get_one_file $diffidfrom $flist_menu_file $diffdir] @@ -7400,7 +7408,7 @@ proc getblobdiffline {bdf ids} {      $ctext conf -state normal      while {[incr nr] <= 1000 && [gets $bdf line] >= 0} {  	if {$ids != $diffids || $bdf != $blobdifffd($ids)} { -	    close $bdf +	    catch {close $bdf}  	    return 0  	}  	if {![string compare -length 5 "diff " $line]} { @@ -7552,7 +7560,7 @@ proc getblobdiffline {bdf ids} {      }      $ctext conf -state disabled      if {[eof $bdf]} { -	close $bdf +	catch {close $bdf}  	return 0      }      return [expr {$nr >= 1000? 2: 1}] @@ -8273,8 +8281,11 @@ proc do_cmp_commits {a b} {  		appendshortlink $a [mc "Commit "] "  $heada\n"  		appendshortlink $b [mc " differs from\n       "] \  		    "  $headb\n" -		$ctext insert end [mc "- stopping\n"] -		break +		$ctext insert end [mc "Diff of commits:\n\n"] +		$ctext conf -state disabled +		update +		diffcommits $a $b +		return  	    }  	}  	if {$skipa} { @@ -8300,6 +8311,31 @@ proc do_cmp_commits {a b} {      $ctext conf -state disabled  } +proc diffcommits {a b} { +    global diffcontext diffids blobdifffd diffinhdr + +    set tmpdir [gitknewtmpdir] +    set fna [file join $tmpdir "commit-[string range $a 0 7]"] +    set fnb [file join $tmpdir "commit-[string range $b 0 7]"] +    if {[catch { +	exec git diff-tree -p --pretty $a >$fna +	exec git diff-tree -p --pretty $b >$fnb +    } err]} { +	error_popup [mc "Error writing commit to file: %s" $err] +	return +    } +    if {[catch { +	set fd [open "| diff -U$diffcontext $fna $fnb" r] +    } err]} { +	error_popup [mc "Error diffing commits: %s" $err] +	return +    } +    set diffids [list commits $a $b] +    set blobdifffd($diffids) $fd +    set diffinhdr 0 +    filerun $fd [list getblobdiffline $fd $diffids] +} +  proc diffvssel {dirn} {      global rowmenuid selectedline | 
