Skip to content

Commit

Permalink
git-gui: Makes chooser set 'gitdir' to the resolved path
Browse files Browse the repository at this point in the history
If _is_git follows a "gitdir: ..." file link to get to the actual
repository, we want _gitdir to be set to that final path.

Signed-off-by: Chris Packham <judge.packham@gmail.com>
Signed-off-by: Remi Rampin <remirampin@gmail.com>
Signed-off-by: Pat Thoyts <patthoyts@users.sourceforge.net>
  • Loading branch information
Remi Rampin authored and Pat Thoyts committed Mar 7, 2015
1 parent cc6825e commit 83da013
Showing 1 changed file with 8 additions and 3 deletions.
11 changes: 8 additions & 3 deletions lib/choose_repository.tcl
Original file line number Diff line number Diff line change
Expand Up @@ -338,7 +338,10 @@ method _git_init {} {
return 1
}

proc _is_git {path} {
proc _is_git {path {outdir_var ""}} {
if {$outdir_var ne ""} {
upvar 1 $outdir_var outdir
}
if {[file isfile $path]} {
set fp [open $path r]
gets $fp line
Expand All @@ -352,12 +355,14 @@ proc _is_git {path} {
if {[file exists [file join $path HEAD]]
&& [file exists [file join $path objects]]
&& [file exists [file join $path config]]} {
set outdir $path
return 1
}
if {[is_Cygwin]} {
if {[file exists [file join $path HEAD]]
&& [file exists [file join $path objects.lnk]]
&& [file exists [file join $path config.lnk]]} {
set outdir $path
return 1
}
}
Expand Down Expand Up @@ -1103,7 +1108,7 @@ method _open_local_path {} {
}

method _do_open2 {} {
if {![_is_git [file join $local_path .git]]} {
if {![_is_git [file join $local_path .git] actualgit]} {
error_popup [mc "Not a Git repository: %s" [file tail $local_path]]
return
}
Expand All @@ -1116,7 +1121,7 @@ method _do_open2 {} {
}

_append_recentrepos [pwd]
set ::_gitdir .git
set ::_gitdir $actualgit
set ::_prefix {}
set done 1
}
Expand Down

0 comments on commit 83da013

Please sign in to comment.