diff options
| author | Junio C Hamano <gitster@pobox.com> | 2010-01-24 11:16:26 -0800 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2010-01-24 11:16:26 -0800 | 
| commit | b30ccd757354ea09b41e4359b0a5ab429d12f02e (patch) | |
| tree | 171cf9a99a9fe390a98a2d6a500e2ff37b9f19eb | |
| parent | 288123f01cb1b835edbf6e2e188159c2ff858aca (diff) | |
| parent | 87cd09f43e56de5235d09aef3ff5d840419fef49 (diff) | |
| download | git-b30ccd757354ea09b41e4359b0a5ab429d12f02e.tar.gz | |
Merge branch 'maint' of git://git.spearce.org/git-gui into maint
* 'maint' of git://git.spearce.org/git-gui:
  git-gui: work from the .git dir
  git-gui: Fix applying a line when all following lines are deletions
  git-gui: Correct file_states when unstaging partly staged entry
  git-gui: Fix gitk for branch whose name matches local file
  git-gui: Keep repo_config(gui.recentrepos) and .gitconfig in sync
  git-gui: handle really long error messages in updateindex.
  git-gui: Add hotkeys for "Unstage from commit" and "Revert changes"
  git-gui: Makefile: consolidate .FORCE-* targets
| -rw-r--r-- | git-gui/Makefile | 7 | ||||
| -rwxr-xr-x | git-gui/git-gui.sh | 25 | ||||
| -rw-r--r-- | git-gui/lib/choose_repository.tcl | 4 | ||||
| -rw-r--r-- | git-gui/lib/diff.tcl | 1 | ||||
| -rw-r--r-- | git-gui/lib/index.tcl | 34 | 
5 files changed, 48 insertions, 23 deletions
| diff --git a/git-gui/Makefile b/git-gui/Makefile index b3580e9e48..197b55edf3 100644 --- a/git-gui/Makefile +++ b/git-gui/Makefile @@ -7,7 +7,7 @@ all::  # TCL_PATH must be vaild for this to work.  # -GIT-VERSION-FILE: .FORCE-GIT-VERSION-FILE +GIT-VERSION-FILE: FORCE  	@$(SHELL_PATH) ./GIT-VERSION-GEN  -include GIT-VERSION-FILE @@ -270,7 +270,7 @@ TRACK_VARS = \  	GITGUI_MACOSXAPP=$(GITGUI_MACOSXAPP) \  #end TRACK_VARS -GIT-GUI-VARS: .FORCE-GIT-GUI-VARS +GIT-GUI-VARS: FORCE  	@VARS='$(TRACK_VARS)'; \  	if test x"$$VARS" != x"`cat $@ 2>/dev/null`" ; then \  		echo 1>&2 "    * new locations or Tcl/Tk interpreter"; \ @@ -340,5 +340,4 @@ ifdef GITGUI_WINDOWS_WRAPPER  endif  .PHONY: all install uninstall dist-version clean -.PHONY: .FORCE-GIT-VERSION-FILE -.PHONY: .FORCE-GIT-GUI-VARS +.PHONY: FORCE diff --git a/git-gui/git-gui.sh b/git-gui/git-gui.sh index 718277a651..1fb3cbfc78 100755 --- a/git-gui/git-gui.sh +++ b/git-gui/git-gui.sh @@ -1074,6 +1074,8 @@ if {[catch {  		set _prefix {}  		}]  	&& [catch { +		# beware that from the .git dir this sets _gitdir to . +		# and _prefix to the empty string  		set _gitdir [git rev-parse --git-dir]  		set _prefix [git rev-parse --show-prefix]  	} err]} { @@ -1082,6 +1084,14 @@ if {[catch {  	choose_repository::pick  	set picked 1  } + +# we expand the _gitdir when it's just a single dot (i.e. when we're being +# run from the .git dir itself) lest the routines to find the worktree +# get confused +if {$_gitdir eq "."} { +	set _gitdir [pwd] +} +  if {![file isdirectory $_gitdir] && [is_Cygwin]} {  	catch {set _gitdir [exec cygpath --windows $_gitdir]}  } @@ -1613,6 +1623,9 @@ proc merge_state {path new_state {head_info {}} {index_info {}}} {  	} elseif {$s0 ne {_} && [string index $state 0] eq {_}  		&& $head_info eq {}} {  		set head_info $index_info +	} elseif {$s0 eq {_} && [string index $state 0] ne {_}} { +		set index_info $head_info +		set head_info {}  	}  	set file_states($path) [list $s0$s1 $icon \ @@ -1941,7 +1954,7 @@ proc do_gitk {revs} {  		cd [file dirname [gitdir]]  		set env(GIT_DIR) [file tail [gitdir]] -		eval exec $cmd $revs & +		eval exec $cmd $revs "--" "--" &  		if {$old_GIT_DIR eq {}} {  			unset env(GIT_DIR) @@ -2543,12 +2556,14 @@ if {[is_enabled multicommit] || [is_enabled singlecommit]} {  		[list .mbar.commit entryconf [.mbar.commit index last] -state]  	.mbar.commit add command -label [mc "Unstage From Commit"] \ -		-command do_unstage_selection +		-command do_unstage_selection \ +		-accelerator $M1T-U  	lappend disable_on_lock \  		[list .mbar.commit entryconf [.mbar.commit index last] -state]  	.mbar.commit add command -label [mc "Revert Changes"] \ -		-command do_revert_selection +		-command do_revert_selection \ +		-accelerator $M1T-J  	lappend disable_on_lock \  		[list .mbar.commit entryconf [.mbar.commit index last] -state] @@ -3296,6 +3311,10 @@ unset gws  bind $ui_comm <$M1B-Key-Return> {do_commit;break}  bind $ui_comm <$M1B-Key-t> {do_add_selection;break}  bind $ui_comm <$M1B-Key-T> {do_add_selection;break} +bind $ui_comm <$M1B-Key-u> {do_unstage_selection;break} +bind $ui_comm <$M1B-Key-U> {do_unstage_selection;break} +bind $ui_comm <$M1B-Key-j> {do_revert_selection;break} +bind $ui_comm <$M1B-Key-J> {do_revert_selection;break}  bind $ui_comm <$M1B-Key-i> {do_add_all;break}  bind $ui_comm <$M1B-Key-I> {do_add_all;break}  bind $ui_comm <$M1B-Key-x> {tk_textCut %W;break} diff --git a/git-gui/lib/choose_repository.tcl b/git-gui/lib/choose_repository.tcl index 633cc572bb..3f8f3030fa 100644 --- a/git-gui/lib/choose_repository.tcl +++ b/git-gui/lib/choose_repository.tcl @@ -235,6 +235,8 @@ proc _get_recentrepos {} {  	foreach p [get_config gui.recentrepo] {  		if {[_is_git [file join $p .git]]} {  			lappend recent $p +		} else { +			_unset_recentrepo $p  		}  	}  	return [lsort $recent] @@ -243,6 +245,7 @@ proc _get_recentrepos {} {  proc _unset_recentrepo {p} {  	regsub -all -- {([()\[\]{}\.^$+*?\\])} $p {\\\1} p  	git config --global --unset gui.recentrepo "^$p\$" +	load_config 1  }  proc _append_recentrepos {path} { @@ -261,6 +264,7 @@ proc _append_recentrepos {path} {  	lappend recent $path  	git config --global --add gui.recentrepo $path +	load_config 1  	while {[llength $recent] > 10} {  		_unset_recentrepo [lindex $recent 0] diff --git a/git-gui/lib/diff.tcl b/git-gui/lib/diff.tcl index bd5d189ed1..066755b864 100644 --- a/git-gui/lib/diff.tcl +++ b/git-gui/lib/diff.tcl @@ -664,6 +664,7 @@ proc apply_line {x y} {  		}  		set i_l $next_l  	} +	set patch "$patch$pre_context"  	set patch "@@ -$hln,$n +$hln,[eval expr $n $sign 1] @@\n$patch"  	if {[catch { diff --git a/git-gui/lib/index.tcl b/git-gui/lib/index.tcl index d33896a0ce..0b58bd8876 100644 --- a/git-gui/lib/index.tcl +++ b/git-gui/lib/index.tcl @@ -14,29 +14,31 @@ proc _close_updateindex {fd after} {  		toplevel $w  		wm title $w [strcat "[appname] ([reponame]): " [mc "Index Error"]]  		wm geometry $w "+[winfo rootx .]+[winfo rooty .]" -		pack [label $w.msg \ -			-justify left \ -			-anchor w \ -			-text [strcat \ -				[mc "Updating the Git index failed.  A rescan will be automatically started to resynchronize git-gui."] \ -				"\n\n$err"] \ -			] -anchor w - -		frame $w.buttons -		button $w.buttons.continue \ +		set s [mc "Updating the Git index failed.  A rescan will be automatically started to resynchronize git-gui."] +		text $w.msg -yscrollcommand [list $w.vs set] \ +			-width [string length $s] -relief flat \ +			-borderwidth 0 -highlightthickness 0 \ +			-background [$w cget -background] +		$w.msg tag configure bold -font font_uibold -justify center +		scrollbar $w.vs -command [list $w.msg yview] +		$w.msg insert end $s bold \n\n$err {} +		$w.msg configure -state disabled + +		button $w.continue \  			-text [mc "Continue"] \  			-command [list destroy $w] -		pack $w.buttons.continue -side right -padx 5 -		button $w.buttons.unlock \ +		button $w.unlock \  			-text [mc "Unlock Index"] \  			-command "destroy $w; _delete_indexlock" -		pack $w.buttons.unlock -side right -		pack $w.buttons -side bottom -fill x -pady 10 -padx 10 +		grid $w.msg - $w.vs -sticky news +		grid $w.unlock $w.continue - -sticky se -padx 2 -pady 2 +		grid columnconfigure $w 0 -weight 1 +		grid rowconfigure $w 0 -weight 1  		wm protocol $w WM_DELETE_WINDOW update -		bind $w.buttons.continue <Visibility> " +		bind $w.continue <Visibility> "  			grab $w -			focus $w.buttons.continue +			focus %W  		"  		tkwait window $w | 
