diff options
author | Paulo Gomes <pjbgf@linux.com> | 2023-07-11 08:53:03 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-07-11 08:53:03 +0100 |
commit | 56c4bf4ca9789505db7a6eefb910a7259c1fcb79 (patch) | |
tree | 3049fbf24af25a3e52bf7a391e959e837e032e3a /repository.go | |
parent | dc17aae6503560777a665c9cfb0d2fcb3a9a9274 (diff) | |
parent | 5dad9b23030e344a4fd1458df0c50e6ada55a01a (diff) | |
download | go-git-56c4bf4ca9789505db7a6eefb910a7259c1fcb79.tar.gz |
Merge pull request #809 from AriehSchneier/tilde-user-path
*: Handle paths starting with ~Username
Diffstat (limited to 'repository.go')
-rw-r--r-- | repository.go | 18 |
1 files changed, 8 insertions, 10 deletions
diff --git a/repository.go b/repository.go index 168303f..02edb66 100644 --- a/repository.go +++ b/repository.go @@ -19,6 +19,7 @@ import ( "github.com/go-git/go-billy/v5/osfs" "github.com/go-git/go-billy/v5/util" "github.com/go-git/go-git/v5/config" + "github.com/go-git/go-git/v5/internal/path_util" "github.com/go-git/go-git/v5/internal/revision" "github.com/go-git/go-git/v5/plumbing" "github.com/go-git/go-git/v5/plumbing/cache" @@ -322,16 +323,13 @@ func PlainOpenWithOptions(path string, o *PlainOpenOptions) (*Repository, error) } func dotGitToOSFilesystems(path string, detect bool) (dot, wt billy.Filesystem, err error) { - if strings.HasPrefix(path, "~/") { - home, err := os.UserHomeDir() - if err != nil { - return nil, nil, err - } - path = filepath.Join(home, path[2:]) - } else { - if path, err = filepath.Abs(path); err != nil { - return nil, nil, err - } + path, err = path_util.ReplaceTildeWithHome(path) + if err != nil { + return nil, nil, err + } + + if path, err = filepath.Abs(path); err != nil { + return nil, nil, err } var fs billy.Filesystem |